Implementación del método Middle square-Weyl sequence para generar números random en Aseembly language x86 (TASM)
La implementación del algoritmo se realiza en parte en la interrupción 81 creada.
Aún así es necesario generar una primera semilla al inicio del programa y en caso de necesitar más de un numero random, se debe guardar la semilla, la sumatoria de la semilla (secuencia de Weyl) y el número random generado anteriormente.
Para la generación de la semilla hay algunas restricciones.
En todos los lugares en los que encontré información decían que la semilla no puede ser par.
Además en algunos lugares decían que el bit menos significativo de la parte alta no puede ser cero mientras que en otros decía que el bit más significativo no puede ser cero.
Por eso en mi función me aseguro que ninguno de los 3 sea cero, por las dudas.
Junto con la interrupcion que contiene el algoritmo y la librería que contiene pricipalmente la funcion que genera una semilla basada en la fecha y hora, hay dos ejemplos: rands.asm y randint.asm
Genera un numero random de 16 bits y lo imprime por pantalla en hexa
Genera 10 numeros random de 16 bits y los imprime por pantalla en hexa separados por un espacio
Primero se deben instalar las interrupciones, para eso uso el archivo intrs.bat
intrs
Luego se compila el archivo que se desea ejecutar junto con la libreria, para esto se puede ejecutar el archivo complib.bat
complib nombre_del_archivo
Con esto se debería compilar y ejecutar el archivo deseado (rands.asm o randint.asm en este caso) sin problemas