Diferencia entre revisiones de «random()»
De ArduWiki
Línea 1: | Línea 1: | ||
== Descripción == | == Descripción == | ||
La función random devuelve un número aleatorio entero de un intervalo de valores especificado entre los valores min (inclusive) y max (hasta max-1). | La función random devuelve un número aleatorio entero de un intervalo de valores especificado entre los valores min (inclusive) y max (hasta max-1). | ||
+ | {{Nota|Si quiere realmente generar un número aleatorio entre una ejecución y otra, debe cambiar el valor de la "semilla" con [[randomSeed()]].}} | ||
− | |||
− | |||
− | |||
== Sintaxis == | == Sintaxis == | ||
<pre> | <pre> | ||
Línea 13: | Línea 11: | ||
== Parámetros == | == Parámetros == | ||
;max: numero maximo pero no lo incluye. Hasta max-1 | ;max: numero maximo pero no lo incluye. Hasta max-1 | ||
− | ;min: numero minimo incluido. | + | ;min: numero minimo incluido (cero cuando no se especifica este parámetro). |
== Retornos == | == Retornos == | ||
− | Retorna un | + | Retorna un número aleatorio entero tipo [[long]], cuyo valor oscilará entre '''min''' y '''max'''-1. |
== Advertencias == | == Advertencias == | ||
− | + | Es un generador pseudo-aleatorio, lo que quiere decir que si la semilla (valor de iniciación) permanece constante, la secuencia de valores generados también lo será. Hay dos formas de obtener la semilla en tiempo de ejecución y con relativa aleatoriedad: | |
+ | # El valor retornado por [[analogRead()]] sobre un pin analógico "flotante" (libre, sin conectar a nada), aunque la semilla estaría limitada a la resolución del ADC. | ||
+ | # Una técnica que involucra aprovechar el desfase natural entre el oscilador principal y el del temporizador "watchdog", pulsar [https://gist.github.com/endolith/2568571 aquí] para leer sobre el tema (en inglés y aplica únicamente para arquitecturas AVR). | ||
== Ejemplo == | == Ejemplo == |
Revisión del 01:32 25 jun 2018
Contenido
Descripción
La función random devuelve un número aleatorio entero de un intervalo de valores especificado entre los valores min (inclusive) y max (hasta max-1).
Nota: Si quiere realmente generar un número aleatorio entre una ejecución y otra, debe cambiar el valor de la "semilla" con randomSeed().
Sintaxis
random(max); random(min, max);
Parámetros
- max
- numero maximo pero no lo incluye. Hasta max-1
- min
- numero minimo incluido (cero cuando no se especifica este parámetro).
Retornos
Retorna un número aleatorio entero tipo long, cuyo valor oscilará entre min y max-1.
Advertencias
Es un generador pseudo-aleatorio, lo que quiere decir que si la semilla (valor de iniciación) permanece constante, la secuencia de valores generados también lo será. Hay dos formas de obtener la semilla en tiempo de ejecución y con relativa aleatoriedad:
- El valor retornado por analogRead() sobre un pin analógico "flotante" (libre, sin conectar a nada), aunque la semilla estaría limitada a la resolución del ADC.
- Una técnica que involucra aprovechar el desfase natural entre el oscilador principal y el del temporizador "watchdog", pulsar aquí para leer sobre el tema (en inglés y aplica únicamente para arquitecturas AVR).
Ejemplo
byte n = random(0,256); //Genera un numero entre 0~255 (max-1) int n = random(1024); //Genera un numero entre 0~1023