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

📄 ecn2.cpp

📁 miracl-大数运算库,大家使用有什么问题请多多提意见
💻 CPP
字号:
/*
 *    MIRACL  C++ Implementation file ecn2cpp
 *
 *    AUTHOR  : M. Scott
 *  
 *    PURPOSE : Implementation of class ECn2  (Elliptic curves over n^2)
 *
 * WARNING: This class has been cobbled together for a specific use with
 * the MIRACL library. It is not complete, and may not work in other 
 * applications
 *
 *    Copyright (c) 2001 Shamus Software Ltd.
 */


#include "ecn2.h"

using namespace std;

void ECn2::get(ZZn2& a,ZZn2& b)
{a=x;b=y;}

void ECn2::get(ZZn2& a)
{a=x;}

//
// Fp4 number is a+ib = (a,b), where a=u+i^2.v and b=s+i^2.t
//
// Point (x,0),(0,y) on the curve E(Fp4) maps to point (i^2*x,0),(i^4*y,0) on 
// the twist y^2=x^3+i^4.Ax +i^6.B, where i is 4-th root of qnr
//
// 
// Note that the mapped point is actually on E(Fp2) !
//


BOOL ECn2::set(const ZZn2& xx,const ZZn2& yy)
{ 
  BOOL result=TRUE,twist=get_mip()->TWIST;
  int qnr=get_mip()->qnr;

  if (twist)
  {
   if (yy*yy != xx*xx*xx+txx(txx(getA()*xx))+txx(txx(txx((ZZn2)getB())))) result=FALSE;
  }
  else
  {
   if (yy*yy != xx*xx*xx+getA()*xx+getB()) result=FALSE;
  }

  x=xx;
  y=yy;
  marker=MR_EPOINT_GENERAL;
  return result;
}

BOOL ECn2::set(const ZZn2& xx)
{ 
  ZZn2 w;
  BOOL twist=get_mip()->TWIST;
  int qnr=get_mip()->qnr;

  if (twist)
  {
       w=xx*xx*xx+txx(txx(getA()*xx))+txx(txx(txx((ZZn2)getB())));
  }
  else
  {
     w=xx*xx*xx+getA()*xx+getB();
  }

  if (!w.iszero())
  {
   w=sqrt(w); 
   if (w.iszero()) return FALSE;
  }
  x=xx;
  y=w;
  marker=MR_EPOINT_GENERAL;
  return TRUE;
}

ECn2 operator-(const ECn2& a) 
{ECn2 w; 
 if (a.marker!=MR_EPOINT_INFINITY) 
   {w.x=a.x; w.y=-a.y; w.marker=a.marker;} 
 return w; 
}  

ECn2& ECn2::operator*=(const Big& k)
{
    int i,j,n,nb,nbs,nzs;
    ECn2 p2,pt,t[11];
    Big h,kk;

    if (k==0)
    {
        clear();
        return *this;
    }
    if (k==1)
    {
        return (*this);
    }

    pt=*this;
    kk=k;
    if (kk<0)
    {
        pt=-pt;
        kk=-k;
    }
    h=3*kk;

    p2=pt+pt; 
    t[0]=pt;
    for (i=1;i<=10;i++)
        t[i]=t[i-1]+p2;

// Left to Right method

    nb=bits(h);
    for (i=nb-2;i>=1;)
    {
        n=naf_window(kk,h,i,&nbs,&nzs);
        for (j=0;j<nbs;j++) pt+=pt;
        if (n>0) pt+=t[n/2];
        if (n<0) pt-=t[(-n)/2];
        i-=nbs;
        if (nzs)
        {
            for (j=0;j<nzs;j++) pt+=pt;
            i-=nzs;
        }
    }
    *this=pt;
    return *this;
}

ECn2 operator*(const Big& r,const ECn2& P)
{
    ECn2 T=P;
    T*=r;
    return T;
}

#ifndef MR_NO_STANDARD_IO

ostream& operator<<(ostream& s,ECn2& b)
{
    ZZn2 x,y;
    if (b.iszero())
        s << "(Infinity)";
    else
    {
        b.get(x,y);
        s << "(" << x << "," << y << ")";
    }
    return s;
}

#endif

ECn2 operator+(const ECn2& a,const ECn2& b)
{ECn2 c=a; c+=b; return c;}

ECn2 operator-(const ECn2& a,const ECn2& b)
{ECn2 c=a; c-=b; return c;}

ECn2& ECn2::operator-=(const ECn2& z)
{ECn2 t=(-z); *this+=t; return *this; }

ECn2& ECn2::operator+=(const ECn2& z)
{
    ZZn2 lam;
    add(z,lam);
    return *this;
}

BOOL ECn2::add(const ECn2& z,ZZn2& lam)
{
    BOOL twist=get_mip()->TWIST;
    int qnr=get_mip()->qnr;
    if (marker==MR_EPOINT_INFINITY)
    {
        *this=z;
        return FALSE;
    }
    if (z.marker==MR_EPOINT_INFINITY)
    {
        return FALSE;
    }

    if (x!=z.x)
    {
        ZZn2 t=y;  t-=z.y;
        ZZn2 t2=x; t2-=z.x;                 // 2 ZZn sqrs, 5 muls, 1 Inverse
        lam=t; lam/=t2;

        x+=z.x; t=lam; t*=t; t-=x; x=t;     // 5 ZZn muls
        y=z.x; y-=x; y*=lam; y-=z.y;   

    }
    else
    {
        if (y!=z.y || y.iszero())
        {
            clear();
            lam=(ZZn2)1; 
            return TRUE;    // any non-zero value
        }
        ZZn2 t=x;
        ZZn2 t2=x;

     //   lam=(3*(x*x)+getA())/(y+y);

        lam=x;
        lam*=lam;
        lam*=3;
        if (twist) lam+=qnr*getA();
        else       lam+=getA();
        lam/=(y+y);                         // 2 sqrs, 7 muls and 1 inverse

        t2+=x;
        x=lam;
        x*=x;
        x-=t2;
         
        t-=x;
        t*=lam;
        t-=y;
        y=t;                                // 5 ZZn muls
    }

    marker=MR_EPOINT_GENERAL;    
    return TRUE;
}

⌨️ 快捷键说明

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