⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 mrlucas.c

📁 miracl-大数运算库,大家使用有什么问题请多多提意见
💻 C
字号:
/*
 *   MIRACL methods for evaluating lucas V function
 *   mrlucas.c 
 *
 *   Copyright (c) 1988-1999 Shamus Software Ltd.
 */

#include <stdlib.h>
#include "miracl.h"

void nres_lucas(_MIPD_ big p,big r,big vp,big v)
{
    int i,nb;
#ifdef MR_OS_THREADS
    miracl *mr_mip=get_mip();
#endif
    if (mr_mip->ERNUM) return;

    MR_IN(107)

    if (size(r)==0) 
    {
        zero(vp);
        convert(_MIPP_ 2,v);
        nres(_MIPP_ v,v);
        MR_OUT
        return;
    }
    if (size(r)==1 || size(r)==(-1))
    { /* note - sign of r doesn't matter */
        convert(_MIPP_ 2,vp);
        nres(_MIPP_ vp,vp);
        copy(p,v);
        MR_OUT
        return;
    }

    copy(p,mr_mip->w3);
    
    convert(_MIPP_ 2,mr_mip->w4);
    nres(_MIPP_ mr_mip->w4,mr_mip->w4);     /* w4=2 */

    copy(mr_mip->w4,mr_mip->w8);
    copy(mr_mip->w3,mr_mip->w9);

    copy(r,mr_mip->w1);
    insign(PLUS,mr_mip->w1);         
    decr(_MIPP_ mr_mip->w1,1,mr_mip->w1);

#ifndef MR_ALWAYS_BINARY
    if (mr_mip->base==mr_mip->base2)
    {
#endif
        nb=logb2(_MIPP_ mr_mip->w1);
        for (i=nb-1;i>=0;i--)
        {
            if (mr_mip->user!=NULL) (*mr_mip->user)();

            if (mr_testbit(_MIPP_ mr_mip->w1,i))
            {
                nres_modmult(_MIPP_ mr_mip->w8,mr_mip->w9,mr_mip->w8);
                nres_modsub(_MIPP_ mr_mip->w8,mr_mip->w3,mr_mip->w8);
                nres_modmult(_MIPP_ mr_mip->w9,mr_mip->w9,mr_mip->w9);
                nres_modsub(_MIPP_ mr_mip->w9,mr_mip->w4,mr_mip->w9);

            }
            else
            {
                nres_modmult(_MIPP_ mr_mip->w9,mr_mip->w8,mr_mip->w9);
                nres_modsub(_MIPP_ mr_mip->w9,mr_mip->w3,mr_mip->w9);
                nres_modmult(_MIPP_ mr_mip->w8,mr_mip->w8,mr_mip->w8);
                nres_modsub(_MIPP_ mr_mip->w8,mr_mip->w4,mr_mip->w8);
            }  
        }

#ifndef MR_ALWAYS_BINARY
    }
    else
    {
        expb2(_MIPP_ logb2(_MIPP_ mr_mip->w1)-1,mr_mip->w2);                                                                                                   

        while (!mr_mip->ERNUM && size(mr_mip->w2)!=0)
        { /* use binary method */
            if (compare(mr_mip->w1,mr_mip->w2)>=0)
            { /* vp=v*vp-p, v=v*v-2 */ 
                nres_modmult(_MIPP_ mr_mip->w8,mr_mip->w9,mr_mip->w8);
                nres_modsub(_MIPP_ mr_mip->w8,mr_mip->w3,mr_mip->w8);
                nres_modmult(_MIPP_ mr_mip->w9,mr_mip->w9,mr_mip->w9);
                nres_modsub(_MIPP_ mr_mip->w9,mr_mip->w4,mr_mip->w9);
                subtract(_MIPP_ mr_mip->w1,mr_mip->w2,mr_mip->w1);
            }
            else
            { /* v=v*vp-p, vp=vp*vp-2 */
                nres_modmult(_MIPP_ mr_mip->w9,mr_mip->w8,mr_mip->w9);
                nres_modsub(_MIPP_ mr_mip->w9,mr_mip->w3,mr_mip->w9);
                nres_modmult(_MIPP_ mr_mip->w8,mr_mip->w8,mr_mip->w8);
                nres_modsub(_MIPP_ mr_mip->w8,mr_mip->w4,mr_mip->w8);
            }
            subdiv(_MIPP_ mr_mip->w2,2,mr_mip->w2);
        }
    }
#endif

    copy(mr_mip->w9,v);
    if (v!=vp) copy(mr_mip->w8,vp);
    MR_OUT

}

void lucas(_MIPD_ big p,big r,big n,big vp,big v)
{
#ifdef MR_OS_THREADS
    miracl *mr_mip=get_mip();
#endif
    if (mr_mip->ERNUM) return;

    MR_IN(108)
    prepare_monty(_MIPP_ n);
    nres(_MIPP_ p,mr_mip->w3);
    nres_lucas(_MIPP_ mr_mip->w3,r,mr_mip->w8,mr_mip->w9);
    redc(_MIPP_ mr_mip->w9,v);
    if (v!=vp) redc(_MIPP_ mr_mip->w8,vp);
    MR_OUT
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -