• Saltar al contenido principal
  • Skip to secondary menu
  • Saltar a la barra lateral principal
  • Saltar al pie de página
  • Inicio
  • Secciones
    • Ciencia de datos
    • Criptografía
    • Herramientas
    • Machine Learning
    • Noticias
    • Opinión
    • Productividad
    • Programación
      • JavaScript
      • Julia
      • Matlab
      • Python
      • R
  • Programación
    • JavaScript
    • Julia
    • Matlab
    • Python
    • R
  • Laboratorio
    • Estadística
      • Calculadora del Tamaño Muestral en Encuestas
      • Calculadora de estadísticos descriptivos
      • Test de normalidad
      • Calculadora de contrastes de hipotesis
      • Calculadora de tamano del efecto
      • Simulador de Regresión Lineal con Ruido
      • Visualizador de PCA
      • Visualizador de Series Temporales
      • Simulador de Regresión Logística
      • Simulador de K-Means
      • Simulador de DBSCAN
      • Detector de la Ley de Benford
    • Probabilidad
      • Calculadora de Probabilidad de Distribuciones
      • Calculadora de Probabilidades de Lotería
      • Simulador del Problema de Monty Hall
      • Simulador de la Estrategia Martingala
    • Finanzas
      • Calculadora de Préstamos e Hipotecas
      • Conversor TIN ↔ TAE
      • Calculadora DCA con ajuste por inflación
      • Calculadora XIRR con Flujos Irregulares
      • Simulador FIRE (Financial Independence, Retire Early)
    • Negocios
      • CLV
      • Scoring
    • Herramientas
      • Formateador / Minificador de JSON
      • Conversor CSV ↔ JSON
      • Comparador y Formateador de Texto y JSON
      • Formateador y Tester de Expresiones Regulares
      • Inspector de JWT
      • Generador y verificador de hashes
      • Codificador / Decodificador Base64 y URL
      • Conversor de bases numericas
      • Conversor de Timestamp Unix
      • Conversor de colores
      • Generador de UUIDs
    • Juegos
      • Tres en Raya
      • Nim con Q-Learning
    • Más
      • Método D’Hondt
      • Generador de Contraseñas Seguras
  • Noticias
  • Boletín
  • Contacto
  • Tienda
    • Libros
    • Equipamiento de oficina
    • Equipamiento en movilidad

Analytics Lane

Ciencia e ingeniería de datos aplicada

  • Ciencia de datos
  • Machine Learning
  • IA Generativa
  • Python
  • Pandas
  • NumPy
  • R
  • Excel

Generación y manipulación de números aleatorios en NumPy

noviembre 25, 2024 Por Daniel Rodríguez Deja un comentario
Tiempo de lectura: 5 minutos

NumPy

Los números aleatorios son fundamentales para muchas aplicaciones donde es necesario simular cierta impredecibilidad en los datos. Por ejemplo, a la hora de realizar un muestreo de datos o una simulación de Montecarlo. Por ello, la biblioteca NumPy de Python cuenta con diferentes funciones con las que se pueden crear número aleatorios de forma rápida y eficiente. En esta entrada, se analizará las opciones que existen para la creación de números aleatorios en NumPy. Viendo cómo usar diferentes distribuciones, cómo configurar la semilla para obtener resultados reproducibles y su aplicación en casos prácticos como el muestreo de datos.

Tabla de contenidos

  • 1 La necesidad de los números aleatorios
  • 2 Generación de números aleatorios con NumPy
    • 2.1 Generación de números aleatorios uniformes en NumPy
    • 2.2 Generación de números aleatorios enteros en NumPy
    • 2.3 Distribución Normal (Gaussiana)
    • 2.4 Fijar la semilla para la reproducibilidad
    • 2.5 Selección aleatoria con muestreo
    • 2.6 Ejemplos adicionales de números aleatorios en NumPy
  • 3 Conclusiones

La necesidad de los números aleatorios

Cuando se trabaja con datos simulados es habitual necesitar una fuente de aleatoriedad para reproducir los reales. Lo que aplica tanto para entrenar modelos de Machine Learning, realizar experimentos estadísticos o crear simulaciones complejas. Sin embargo, la generación de estos números con verdadera aleatoriedad, de manera eficiente y reproducible puede ser complicado. Además, la generación de números aleatorios implica también la necesidad de tener control sobre su distribución, lo cual es crucial en experimentos donde se desea simular un comportamiento específico.

Generación de números aleatorios con NumPy

Debido a la necesidad de funciones para obtener números aleatorios, NumPy ofrece el módulo numpy.random que permite generar este tipo de valores de manera sencilla, eficiente y personalizada. Entre otras herramientas, este módulo proporciona:

Nuevo test de normalidad interactivo en el laboratorio de Analytics Lane
En Analytics Lane
Nuevo test de normalidad interactivo en el laboratorio de Analytics Lane

  • Distribuciones básicas (uniforme, normal, binomial, entre otras).
  • Muestreos sin reemplazo.
  • Capacidad de fijar una “semilla” para obtener resultados consistentes en experimentos.

A continuación, se muestra cómo crear números aleatorios uniformes, enteros, en base a una distribución normal, fijar la semilla y realizar un muestreo aleatorio en NumPy.

Publicidad


Generación de números aleatorios uniformes en NumPy

La función básica para obtener números aleatorios en NumPy es np.random.rand(). Esta crea un array con las dimensiones especificadas y lo llena con valores aleatorios de una distribución uniforme en el intervalo [0, 1). Un ejemplo básico del uso de esta función sería el siguiente:

import numpy as np

# Generar un array de números aleatorios de distribución uniforme
numeros_uniformes = np.random.rand(5)

print(numeros_uniformes)
[0.80476929 0.44498491 0.94860924 0.28879931 0.32462542]

El array resultante contiene valores de una distribución uniforme, muy útil en simulaciones o pruebas donde todos los valores dentro de un rango tienen la misma probabilidad de ser seleccionados.

Generación de números aleatorios enteros en NumPy

En los casos donde son necesarios valores enteros aleatorios, por ejemplo, para seleccionar elementos de un conjunto, la función que ofrece NumPy es np.random.randint(). En la que se puede especificar el rango y la cantidad de valores:

# Generar 5 números enteros aleatorios entre 0 y 100
enteros_aleatorios = np.random.randint(0, 100, size=5)

print(enteros_aleatorios)
[11 18 30 54 92]

Un resultado que se puede aplicar en simulaciones de conteos o para la selección de índices en caso de muestreo.

Distribución Normal (Gaussiana)

En modelos de Machine Learning y análisis estadísticos, la distribución normal es clave. np.random.normal() es la función de NumPy con la que se pueden generar datos con media y desviación estándar personalizables. Pudiendo recibir hasta tres parámetros con la media, la desviación estándar y la cantidad de valores:

# Generar 10 números aleatorios de una distribución normal con media 0 y desviación estándar 1
normal_aleatorios = np.random.normal(0, 1, 10)

print(normal_aleatorios)
[-0.17653863  0.26893871  0.46135882  0.21125181 -0.22133657 -0.88695851
-0.20961701 -1.10755191 -0.18830484 -0.78363385]

Este tipo de distribución es útil para simular fenómenos naturales donde los datos tienden a agruparse alrededor de un promedio.

Publicidad


Fijar la semilla para la reproducibilidad

Al realizar experimentos y entrenar modelos, a menudo se necesita que los resultados sean reproducibles. Esto se puede obtener fijando la “semilla” con np.random.seed(), lo que permite que el generador de números aleatorios produzca la misma secuencia de valores en cada ejecución.

# Fijar la semilla
np.random.seed(42)

# Generar números aleatorios con semilla fijada
numeros_semilla = np.random.rand(5)

# Fijar la semilla para reproducir los valores
np.random.seed(42)

# Volver a generarl los mismos números aleatorios con semilla fijada
numeros_semilla_2 = np.random.rand(5)

print(numeros_semilla)
print(numeros_semilla_2)
[0.37454012 0.95071431 0.73199394 0.59865848 0.15601864]
[0.37454012 0.95071431 0.73199394 0.59865848 0.15601864]

Cada vez que se usa np.random.seed(42), se obtiene el mismo conjunto de números aleatorios, garantizando así que los resultados de los experimentos sean consistentes.

Es importante recordar que los números generados no son realmente aleatorios, sino pseudoaleatorios, ya que se crean a partir de un valor inicial conocido como semilla. Al cambiar la semilla, se modifica la secuencia de valores generados, pero estos siguen un patrón que simula aleatoriedad. Esto permite reproducir la misma secuencia de “números aleatorios” al usar la misma semilla.

Una curiosidad, el número 42 es una semilla como referencia a la novela de ciencia ficción “Guía del autoestopista galáctico”.

Selección aleatoria con muestreo

Para seleccionar una muestra aleatoria de un conjunto de datos se puede usar la función np.random.choice() de NunPy. Permite extraer elementos de un array, con o sin reemplazo. Esta función recibe como parámetros el array sobre el que se desea realizar el muestreo, el número de elementos que se desean muestran y una variable opción para indicar si el muestreo se hace con reemplazo o no. Como ejemplo, a continuación, se muestra como muestra tres elementos sin reemplazo:

# Array de elementos
elementos = np.array([10, 20, 30, 40, 50])

# Seleccionar 3 elementos aleatorios sin reemplazo
muestra_sin_reemplazo = np.random.choice(elementos, 3, replace=False)

print(muestra_sin_reemplazo)
[20 10 40]

Esta función es ideal para realizar simulaciones o experimentos en los que cada elemento se puede seleccionar aleatoriamente.

Ejemplos adicionales de números aleatorios en NumPy

  1. Generar una matriz aleatoria para simular datos: Por ejemplo, si se necesita simular datos de ingresos de ventas para diferentes días. Una matriz aleatoria de enteros puede ayudar a visualizar esta simulación.
ingresos = np.random.randint(100, 1000, size=(7, 5))

print(ingresos)
[[187 472 199 971 763]
[230 761 408 869 443]
[591 513 905 485 291]
[376 260 559 413 121]
[352 847 956 660 574]
[158 610 781 575 799]
[882 289 786 662 975]]

En este caso, se han simulado ingresos aleatorios diarios para cinco regiones durante una semana.

  1. Distribuciones personalizadas: Poisson y Binomial: En ciertos casos, puede ser necesario que los datos sigan una distribución específica. Por ejemplo, si se desea simular el número de clientes que llegan a una tienda por minuto, para lo que se podría usar una distribución de Poisson.
# Generar 10 muestras de una distribución de Poisson con λ=3
clientes_por_minuto = np.random.poisson(3, 10)

print(clientes_por_minuto)
[2 2 4 2 1 3 4 4 1 2]

La distribución de Poisson es útil para simular eventos que ocurren a una tasa promedio constante.

  1. Simulación de A/B Testing usando Numpy: En marketing y experimentación, el A/B testing requiere la simulación de conversiones de usuarios. Por ejemplo, se podría usar una distribución binomial para simular conversiones de una campaña publicitaria.
# Simular conversiones de 1000 usuarios con una tasa de conversión del 20%
conversiones = np.random.binomial(1000, 0.2)

print(f'Número de conversiones: {conversiones}')
Número de conversiones: 209

Publicidad


Conclusiones

La generación y manipulación de números aleatorios es un proceso fundamental en múltiples áreas, tales como simulaciones o experimentos. Por los que la generación y manipulación de números aleatorios es una parte fundamental de NumPy. El uso de funciones como np.random.rand(), np.random.randint(), y np.random.choice() facilita enormemente esta tarea. Entendiendo y dominando estas funciones se puede implementar y ejecutar proyectos de análisis y simulación de datos.

¿Te ha parecido de utilidad el contenido?

¡Puntúalo entre una y cinco estrellas!

Puntuación promedio 0 / 5. Votos emitidos: 0

Ya que has encontrado útil este contenido...

¡Síguenos en redes sociales!

¡Siento que este contenido no te haya sido útil!

¡Déjame mejorar este contenido!

Dime, ¿cómo puedo mejorar este contenido?

Publicaciones relacionadas

  • Nuevo test de normalidad interactivo en el laboratorio de Analytics Lane
  • Nuevo conversor de timestamp Unix en el laboratorio de Analytics Lane
  • Calculadora de Contrastes de Hipótesis: interpreta correctamente el p-valor y toma decisiones estadísticas con confianza
  • Calculadora de Tamaño del Efecto: la herramienta clave para entender cuánto importa realmente una diferencia
  • Simulador de DBSCAN: descubre cómo encontrar clusters reales (y ruido) sin fijar K
  • Conversor de Colores: convierte, compara y valida cualquier color en tiempo real
  • Analytics Lane lanza su Generador de UUIDs: identificadores únicos, seguros y listos para producción en segundos
  • 1200 publicaciones en Analytics Lane
  • Analytics Lane lanza su Conversor TIN ↔ TAE: la herramienta definitiva para entender el coste real de depósitos, préstamos e hipotecas

Publicado en: Python Etiquetado como: NumPy

Interacciones con los lectores

Deja una respuesta Cancelar la respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *

I accept the Terms and Conditions and the Privacy Policy

Este sitio usa Akismet para reducir el spam. Aprende cómo se procesan los datos de tus comentarios.

Barra lateral principal

Suscríbete a nuestro boletín

Suscríbete al boletín semanal para estar al día de todas las publicaciones.

Política de Privacidad

Analytics Lane en redes sociales

  • Amazon
  • Bluesky
  • Facebook
  • GitHub
  • Instagram
  • Mastodon
  • Pinterest
  • RSS
  • Telegram
  • Tumblr
  • Twitter
  • YouTube

Publicidad

Entradas recientes

Síndrome del objeto brillante en ciencia de datos: el error simétrico a los costes hundidos

mayo 21, 2026 Por Daniel Rodríguez

De la Regresión Logística al Scorecard: La Transformación Matemática

mayo 19, 2026 Por Daniel Rodríguez

Noticias

Analytics Lane lanza la versión 1.1 del laboratorio con nuevas suites de CLV y Scoring

mayo 18, 2026 Por Daniel Rodríguez

Publicidad

Es tendencia

  • Comprobar hash SHA-256 o MD5 en Windows, macOS y Linux publicado el noviembre 1, 2023 | en Criptografía, Herramientas
  • Creación de gráficos de barras y gráficos de columnas con Seaborn publicado el julio 18, 2023 | en Python
  • La distancia de Mahalanobis publicado el abril 19, 2024 | en Ciencia de datos
  • Ecuaciones multilínea en Markdown publicado el septiembre 14, 2022 | en Herramientas
  • Redimensionar una partición de disco LVM con espacio no asignado en Linux publicado el septiembre 27, 2023 | en Herramientas

Publicidad

Lo mejor valorado

4.9 (24)

Seleccionar filas y columnas en Pandas con iloc y loc

4.6 (16)

Archivos JSON con Python: lectura y escritura

4.4 (14)

Ordenación de diccionarios en Python mediante clave o valor

4.7 (13)

Operaciones de filtrado de DataFrame con Pandas en base a los valores de las columnas

4.1 (11)

Aplicar el método D’Hondt en Excel

Comentarios recientes

  • bif en JSON en bases de datos: cuándo es buena idea y cuándo no
  • bif en Cómo desinstalar Oracle Database 19c en Windows
  • M. Pilar en Cómo eliminar las noticias en Windows 11 y recuperar tu concentración
  • Daniel Rodríguez en Probabilidad básica: cómo entender el azar en nuestra vida diaria
  • Pepe en Probabilidad básica: cómo entender el azar en nuestra vida diaria

Publicidad


Footer

Analytics Lane

  • Acerca de Analytics Lane
  • Boletín de noticias
  • Contacto
  • Libros
  • Lo más popular
  • Noticias
  • Tienda
  • Tiendas afiliadas

Secciones

  • Ciencia de datos
  • Criptografía
  • Herramientas
  • Machine Learning
  • Opinión
  • Productividad
  • Programación
  • Reseñas

Sobre de Analytics Lane

En Analytics Lane tratamos de explicar los principales conceptos de la ciencia e ingeniería de datos con un enfoque práctico. Los principales temas tratados son ciencia de datos, ingeniería de datos, inteligencia artificial, machine learning, deep learning y criptografía. Además, también se habla de los principales lenguajes de programación y herramientas utilizadas por los científicos e ingenieros de datos.

Copyright © 2018-2026 Analytics Lane ·Términos y condiciones ·Política de Cookies ·Política de Privacidad ·Herramientas de privacidad ·Contacto