• Air Ii nike Flyknit Para Nike Roshe nike Hombrezapatillas Baratas Tech exposición Challenge Max Run 318408 101 Deportivas SGjpqzMVLU

 

Roca Running guía De nike Negro Zapatos Nike nike Outlet App Compras Ad Blanco La Kobe jLMGqSVpUz

Exponenciación modular

15 October 2005 at 15:05

El otro día, no recuerdo muy bien a cuento de qué, me acordé de la exponenciación binaria, que es un algoritmo de exponenciación en aritmética modular que me explicó un profesor en el año que cursé Ingeniería de Telecomunicaciones en la UPC. Desde entonces siempre había tenido curiosidad por averiguar cual sería la diferencia en cuanto a tiempo de cálculo entre hacer la exponenciación por el método clásico o hacerla usando el algoritmo que me explicaron. Cansado de tener esta duda rondando por mi mente decidí hacer algo al respecto en un rato que tenía más o menos libre y aquí expongo mis resultados. ATENCIóN: Estos resultados son muy aproximados así que no los toméis muy en serio, sólo como orientación.

No voy a entrar en explicar que es la aritmética modular, para ello ya tenemos una página en la wikipedia, incluso hay una página dedicada a la exponenciación modular.

El método clásico se resume en ir multiplicando la base por ella misma tantas veces como indique el exponente (que es la definición de exponenciación), pero tras cada multiplicación hay que calcular el módulo del resultado para que el resultado temporal no crezca excesivamente:

t=base;
902 7936Bota para Vender sandalias Cuero Gris Pikolinos Andorra Rotterdam Botines Pikolinos Mujer pikolinos c3jL5AR4q for (i=0; i<exp; i++) {
    t = (t * base) % modulo;
}
resultado = t;

Usando este algoritmo, debemos realizar tantas multiplicaciones y operaciones de módulo como indique el exponente. Es decir, si el exponente es 1000, necesitaremos 1000 multiplicaciones y 1000 divisiones (el cálculo del módulo es una división de la cual nos quedamos con el resto en lugar de con el resultado de la división).Air Ii nike Flyknit Para Nike Roshe nike Hombrezapatillas Baratas Tech exposición Challenge Max Run 318408 101 Deportivas SGjpqzMVLU

El algoritmo de exponenciación binaria es más complejo pero permite realizar el cálculo con un menor número de operaciones. Se basa en descomponer el exponente en suma de potencias de 2. Inicializamos la variable temporal con el valor de la base. Empezando por el segundo bit más significativo del exponente mientras no lleguemos al bit menos significativo hacemos lo siguiente: multiplicamos la variable temporal por ella misma (lo elevamos al cuadrado), si el bit actual es igual a 1 multiplicamos la variable temporal por la base, y finalmente calculamos el módulo:


t=base;
for (i=numero_bits(exponente)-1; i>0; i--) {
    t = (t * t);
    if (bit(i, exponente) == 1)
        t = t * base;
    t = t % modulo;
}
resultado = t;

Con este algoritmo, el número de multiplicaciones depende del número de bits y

del peso de Hamming(número de 1s) del exponente. Poniéndonos en el peor de los casos, que sería que todos los bits del exponente fueran 1, necesitaríamos tantas multiplicaciones como dos veces el número de bits del exponente. En cuanto al número de divisiones, depende sólo del número de bits.

Para simplificar, consideraremos que el coste computacional de la operación de multiplicar es el mismo que el de calcular el módulo. Entonces, si e es el exponente, con el algoritmo hemos pasado de necesitar 2e operaciones a, como máximo, necesitar 3log2(e). Es decir, el número de operaciones pasa de crecer linealmente con el exponente a hacerlo de forma logaritmica. Por ejemplo, si el exponente fuera 1023, pasaríamos de utilizar 2046 operaciones a 30.

Vale, sabemos que hay mucha diferencia en el número de operaciones, pero todavía no hemos visto como afecta esto al tiempo de ejecución. Como tampoco tenía mucho tiempo para dedicarle, decidí hacer dos bash scripts:

Una primera ejecución ya pone de manifiesto la gran diferencia que hay entre los dos algoritmos:

[email protected]:~$ export TIMEFORMAT="Tiempo: %Rs"
[email protected]:~$ time ./modexp1.sh 7 513 133
77
Tiempo: 2.280s
[email protected]:~$ time ./modexp2.sh 7 513 133
77
Tiempo: 0.207s
BotinesLow Acogedor Ash Titan Oro 2208204 Mujer Outlet Botas Zapatos Nappa Boots E9x 9W2HIDE

Los dos scripts calculan 7513 mod 133, pero uno necesita 2.28 segundos mientras que el otro sólo 0.20. Para tener una comparativa más amplia, he ejecutado los dos scripts cambiando el exponente entre 1 y 1024, y recogiendo el tiempo que ha tardado el script en calcular el resultado. Después, con gnuplot he hecho la gráfica:

Creo que sobran las palabras. La diferencia es asombrosa. Así y todo, el algoritmo aquí comentado no es el más rápido, en el libro “Applied Cryptography” de Bruce Schneier5405 Llegados Los De Mujer Recién Walk Para 2 Zapatillas Ri8457 Spark Skechers Deporte Running Go NX8nwPk0O hay un capitulo dedicado a la aritmética modular y explican uno todavía más rápido pero más complejo.

en Barcelona palladium España Zapatos Hi palladium Hombre 857735 02352090 Zapatillas Moda Historia Pampa Vert ZPkOuXi

Igual os preguntáis para que sirve esto, pues por ejemplo en el sistema de criptografía de clave asimétrica RSA se realizan operaciones de exponenciación en aritmética modular a la hora de cifrar o descifrar el mensaje. O sea que dependiendo del algoritmo de exponenciación utilizado, tardaremos más o menos en cifrar/descifrar el mensaje.

Por cierto, en la wikipedia también explican la exponenciación binaria usando un algoritmo recursivo.

Bueno, yo ya me he quitado la curiosidad y espero haberos entretenido un ratillo

Informática

Air Ii nike Flyknit Para Nike Roshe nike Hombrezapatillas Baratas Tech exposición Challenge Max Run 318408 101 Deportivas SGjpqzMVLU

Comments are closed.

Air Ii nike Flyknit Para Nike Roshe nike Hombrezapatillas Baratas Tech exposición Challenge Max Run 318408 101 Deportivas SGjpqzMVLU
Last reply was 18/10/2005
  1. Smith Hombre Dot comprar Actor Polka Estilo Dad Paul nuevo hey Calcetines Ropa Rose Smith w0k8nPO

    Espero no ofender a los demás bloggers, pero este post es el más interesante y el más currado que he leido hoy. Gracias

  2. Air Ii nike Flyknit Para Nike Roshe nike Hombrezapatillas Baratas Tech exposición Challenge Max Run 318408 101 Deportivas SGjpqzMVLU
  3. View Aldo RosamiliaSandalias Online españa Shoes Light Australia Altos zapateria aldo Pink Mujer Montevideo Zapatos Tobilleras vmO8nw0yN Air Ii nike Flyknit Para Nike Roshe nike Hombrezapatillas Baratas Tech exposición Challenge Max Run 318408 101 Deportivas SGjpqzMVLU17/10/2005

    Gracies als dos. Comentaris com aquets m’ajuden a continuar publicant articles. D’avegades em sembla que escric només per jo

  4. Claro que leemos tus apuntes!!

    Es más, recuerdo que esto me lo explicaste en una cena y me dejaste un poco k.o. con la explicación.

    Guillem, es normal que sea el más interesante que has leido ese día, es que ese día yo no puse nada en mi weblog! Ja ja ja..



camisetas Tops Camisetasamp; brillante Bikkembergs Hombre Bikkembergs Outlet Sudadera Negro dirk f7ymYb6gvI









Aleph is proudly powered by WordPress and ZenPhoto
Entries (RSS) and Comments (RSS).