documentation-Estuary

Tutoriales Tutoriales en MiniTidal (TidalCycles), Hydra, y CineCer0

Hydra: Intro

Hydra es una plataforma de live coding para síntesis visual basado en los desarrollos visuales que los sintetizadores análogos generan. Hydra es un proyecto open-source desarrollado por Olivia Jack.

Hydra en Estuary es una versión reducida del stand-alone de Hydra.

Primeros pasos

Ve a https://estuary.mcmaster.ca/
Selecciona SOLO MODE (Modo Solo).

Encontraras un espacio de trabajo con 6 editores de código. Cada editor tiene un menu vacío en la parte superior izquierda. Estuary permite trabajar con diferentes lenguajes para live coding. Puedes elegir el lenguaje de programación que quieras operar en este menú.

Selecciona Hydra en el menú de uno de los editores.

Escribe lo siguiente y presiona el botón de play (o también puedes presionar shift+return/enter).

IMPORTANTE: cuidado con las comillas que usas. Éstas tienen que ser del tipo "", no “” (estas últimas generarán un error de sintaxis). Si haces copias y pegas las líneas de código de este tutorial code from this tutorial, revisa que tengan las comillas correctas ya que algunas veces se pueden cambiar.

Cambia osc().out() por otras fuentes disponibles:



Fuentes - Sources

Una de las estructuras más simples de hydra es la siguiente:

Las fuentes son elementos o objetos iniciales que puedes generar en Hydra:

out() es la sintaxis para la salida.

Ejemplo:

Fuente: solid(r,g,b)

solid().out generará un sólido con parámetros por defecto: (0,0,0,1) = negro.

En el entorno digital, la composición de color se puede realizar a través de diferentes modelos.

Los parámetros para crear sólidos en Hydra son a partir del modelo RGB que toma los colores primarios modificando la intensidad a través de los tres canales, añadiendo un cuarto canal: RGBA = “alpha”, que modifica la opacidad o transparencia.

Ejemplos:

Los parámetros pueden ser enteros (int), decimales (double), y listas []. Este último resultará en un tipo de modulación discreta (con saltos ya que no pasa por números intermedios).

Fuente: gradient(velocidad)

gradient().out() generarán una gradiente con parámetros por defecto: (0).

El valor (velocidad) modifica la rapidez de cambio de la posición de colores dentro del círculo cromático = varia los tonos del gradiente.

Ejemplos:

Fuente: osc(frecuencia, sincronización, impresionDeColor)

osc().out() generará un oscilador con parámetros por defecto: (60,0.1,0).

Los osciladores generan señales (en este caso de color) periódicas. La modulación de frecuencia produce variaciones en las oscilaciones visibles (un tipo de efecto de línea en gradiente): entre más alta, más oscilaciones.

El segundo parámetro (sincronización) corresponde a la velocidad de las oscilaciones.

Ejemplos:

Fuente: noise(escala, velocidad)

noise().out() genera una textura similar al Ruido Perlin (o la estática visible generada en los televisores). Parámetros por defecto (10,0.1)

El primer parámetro (escala) modifica el tamaño de los gradientes (formas) generados. En parámetros chicos, la escala es mayor; parámetros grandes, la escala es menor.

Ejemplos:

Fuente: voronoi(escala, velocidad, combinación)

voronoi().out() genera una textura a partir de la partición del espacio con contrucciones geométricas, esto se llama Polígonos de Thiessen (Voronoi diagram). Parámetros por defecto: (5,0.3,0.3).

El tercer parámetro corresponde a la forma en que las construcciones geométricas se combinan. Valores grandes generan un tipo de espacios negativos (en negro) que deforma los polígonos. Valores negativos crean un espacio positivo (en blanco) entre ellos.

Ejemplos:

Fuente: shape(lados, radio, difuminado)

shape().out()se utiliza para generar un polígono, modificando los tres parámetros para generar formas más complejas. Parámetros por defecto: (3,0.3,0.01)

Ejemplos: