亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? fp2.c

?? 斯坦福大學密碼學家Boneh的基于身份的公鑰密碼系統(tǒng)
?? C
字號:
/* F_p^2 routines * Ben Lynn *//*Copyright (C) 2001 Benjamin Lynn (blynn@cs.stanford.edu)See LICENSE for license*/#include <stdlib.h>#include <string.h>#include "fp2.h"#include "mm.h"enum {    //constants for sliding window algorithms    windowsize = 5,    windowsizepower = 15	    //this is 2^(windowsize - 1) - 1};//we represent elements of F_p^2 with//a + sqrt(-1)b where a, b lie in F_p//these are inefficient?inline void zp_mul(mpz_t x, mpz_t a, mpz_t b, mpz_t p)//x = a * b mod p{    mpz_mul(x, a, b);    mpz_mod(x, x, p);}inline void zp_add(mpz_t x, mpz_t a, mpz_t b, mpz_t p)//x = a + b mod p{    mpz_add(x, a, b);    if (mpz_cmp(x, p) >= 0) mpz_sub(x, x, p);    /*    mpz_add(x, a, b);    mpz_mod(x, x, p);    */}inline void zp_neg(mpz_t x, mpz_t b, mpz_t p)//x = -b mod p{    if (mpz_sgn(b)) {	mpz_sub(x, p, b);    }    /*    mpz_sub(x, a, b);    mpz_mod(x, x, p);    */}inline void zp_sub(mpz_t x, mpz_t a, mpz_t b, mpz_t p)//x = a - b mod p{    if (mpz_cmp(a, b) >= 0) {	mpz_sub(x, a, b);    } else {	mpz_sub(x, a, b);	mpz_add(x, x, p);    }    /*    mpz_sub(x, a, b);    mpz_mod(x, x, p);    */}void fp2_init(fp2_ptr x)//call before using x//allocates space for x{    mm_tally("fp2", 1, "init");    mpz_init(x->a);    mpz_init(x->b);}void fp2_clear(fp2_ptr x)//deallocates space for x{    mm_tally("fp2", -1, "clear");    mpz_clear(x->a);    mpz_clear(x->b);}void fp2_set(fp2_ptr x, fp2_ptr y)//assignment//x = y{    mpz_set(x->a, y->a);    mpz_set(x->b, y->b);}void fp2_set_0(fp2_ptr x)//x = 0{    mpz_set_ui(x->a, 0);    mpz_set_ui(x->b, 0);}void fp2_set_1(fp2_ptr x)//x = 1{    mpz_set_ui(x->a, 1);    mpz_set_ui(x->b, 0);}void fp2_set_cbrt_unity(fp2_ptr x, mpz_t p){    //Warning: depends on representation of F_p^2    //Z_p[sqrt(-1)] version:    mpz_t p1on4;    mpz_set(x->a, p);    mpz_sub_ui(x->a, x->a, 1);    mpz_div_ui(x->a, x->a, 2);    mpz_init_set(p1on4, p);    mpz_add_ui(p1on4, p1on4, 1);    mpz_div_ui(p1on4, p1on4, 4);    mpz_set_ui(x->b, 3);    mpz_powm(x->b, x->b, p1on4, p);    //inefficient way of halving    mpz_mul(x->b, x->b, x->a);    mpz_mod(x->b, x->b, p);    mpz_clear(p1on4);    //Z_p[sqrt(-3)] version:    //mpz_set(x->a, p);    //mpz_sub_ui(x->a, x->a, 1);    //mpz_div_ui(x->a, x->a, 2);    //mpz_set(x->b, x->a);}void fp2_init_set(fp2_ptr x, fp2_ptr y)//for convenience//combines fp2_init, fp2_set{    fp2_init(x);    fp2_set(x, y);}void fp2_neg(fp2_ptr x, fp2_ptr a, mpz_t p)//x = -a{    mpz_sub(x->a, p, a->a);    mpz_sub(x->b, p, a->b);}void fp2_add(fp2_ptr x, fp2_ptr a, fp2_ptr b, mpz_t p)//x = a + b{    zp_add(x->a, a->a, b->a, p);    zp_add(x->b, a->b, b->b, p);}void fp2_sub(fp2_ptr x, fp2_ptr a, fp2_ptr b, mpz_t p)//x = a - b{    zp_sub(x->a, a->a, b->a, p);    zp_sub(x->b, a->b, b->b, p);}void fp2_sub_ui(fp2_ptr x, fp2_ptr a, unsigned long b, mpz_t p)//x = a - b{    mpz_sub_ui(x->a, a->a, b);    mpz_mod(x->a, x->a, p);}void fp2_sqr(fp2_ptr x, fp2_ptr a, mpz_t p)//x = a * a{    mpz_t t0, t1; //temp variables    mpz_init(t0); mpz_init(t1);    //sqr_mod(t0, a->a);    //sqr_mod(t1, a->b);    //zp_sub(t0, t0, t1, p);    /*    zp_sub(t0, a->a, a->b, p);    zp_add(t1, a->a, a->b, p);    zp_mul(t0, t0, t1, p);    zp_mul(t1, a->a, a->b, p);    zp_add(x->b, t1, t1, p);    mpz_set(x->a, t0);    */    mpz_sub(t0, a->a, a->b);    mpz_add(t1, a->a, a->b);    mpz_mul(t0, t0, t1);    mpz_mul(t1, a->a, a->b);    mpz_mul_2exp(x->b, t1, 1);    mpz_mod(x->b, x->b, p);    mpz_mod(x->a, t0, p);    mpz_clear(t0); mpz_clear(t1);}void fp2_mul_mpz(fp2_ptr x, fp2_ptr a, mpz_ptr b, mpz_t p)//x = a * b{    zp_mul(x->a, a->a, b, p);    zp_mul(x->b, a->b, b, p);}void fp2_mul(fp2_ptr x, fp2_ptr a, fp2_ptr b, mpz_t p)//x = a * b{    mpz_t t0, t1, t2; //temp variables    mpz_init(t0); mpz_init(t1); mpz_init(t2);    /* This is slower    zp_mul(t0, a->a, b->a);    zp_mul(t1, a->b, b->b);    zp_sub(t0, t0, t1);    zp_mul(t1, a->a, b->b);    zp_mul(t2, a->b, b->a);    zp_add(x->b, t1, t2);    mpz_set(x->a, t0);    */    mpz_mul(t0, a->a, b->a);    mpz_mul(t1, a->b, b->b);    mpz_sub(t0, t0, t1);    mpz_mul(t1, a->a, b->b);    mpz_mul(t2, a->b, b->a);    mpz_add(x->b, t1, t2);    mpz_mod(x->b, x->b, p);    mpz_mod(x->a, t0, p);    mpz_clear(t0); mpz_clear(t1); mpz_clear(t2);}void fp2_inv(fp2_ptr x, fp2_ptr b, mpz_t p)//x = 1 / b{    mpz_t t0, t1; //temp variables    mpz_t t2;    mpz_init(t2);    mpz_init(t0); mpz_init(t1);    /*    zp_mul(t0, b->a, b->a);    zp_mul(t1, b->b, b->b);    zp_add(t0, t0, t1);    inv_mod(t1, t0);    zp_mul(t0, t1, b->b);    zp_neg(x->b, t0);    zp_mul(x->a, t1, b->a);    */    mpz_mul(t0, b->a, b->a);    mpz_mul(t1, b->b, b->b);    mpz_add(t0, t0, t1);    mpz_invert(t1, t0, p);    mpz_mul(t0, t1, b->b);    mpz_neg(x->b, t0);    mpz_mod(x->b, x->b, p);    mpz_mul(x->a, t1, b->a);    mpz_mod(x->a, x->a, p);    mpz_clear(t0); mpz_clear(t1);    mpz_clear(t2);}void fp2_div(fp2_ptr x, fp2_ptr a, fp2_ptr b, mpz_t p)//x = a / b{    mpz_t t0, t1, t2, t3; //temp variables    mpz_init(t0); mpz_init(t1); mpz_init(t2); mpz_init(t3);    /*    zp_mul(t0, b->a, b->a);    zp_mul(t1, b->b, b->b);    zp_add(t0, t0, t1);    inv_mod(t1, t0);    zp_mul(t0, a->a, b->a);    zp_mul(t2, a->b, b->b);    zp_add(t0, t0, t2);    zp_mul(t2, a->b, b->a);    zp_mul(t3, a->a, b->b);    zp_sub(t2, t2, t3);    zp_mul(x->b, t1, t2);    zp_mul(x->a, t1, t0);    */    mpz_mul(t0, b->a, b->a);    mpz_mul(t1, b->b, b->b);    mpz_add(t0, t0, t1);    mpz_invert(t1, t0, p);    mpz_mul(t0, a->a, b->a);    mpz_mul(t2, a->b, b->b);    mpz_add(t0, t0, t2);    mpz_mul(t2, a->b, b->a);    mpz_mul(t3, a->a, b->b);    mpz_sub(t2, t2, t3);    mpz_mul(x->b, t1, t2);    mpz_mod(x->b, x->b, p);    mpz_mul(x->a, t1, t0);    mpz_mod(x->a, x->a, p);    mpz_clear(t0); mpz_clear(t1); mpz_clear(t2); mpz_clear(t3);}void fp2_pow(fp2_ptr res, fp2_ptr x, mpz_t n, mpz_t p)//exponentiation//res = x^n{    int i, j, k, l, m;    mpz_t t0, t1; //temp variables    //use sliding-window method    fp2_t g[2*windowsizepower+2];    fp2_init_set(g[1], x);    fp2_init(g[2]);    fp2_mul(g[2], x, x, p);    mpz_init(t0); mpz_init(t1);    for (i=1; i<=windowsizepower; i++) {	j = 2 * i + 1;	fp2_init(g[j]);	fp2_mul(g[j], g[j - 2], g[2], p);    }    m = mpz_sizeinbase(n, 2) - 1;    fp2_set_1(res);    while(m>=0) {	if (!mpz_tstbit(n, m)) {	    { //fp2_sqr(res,res);		mpz_sub(t0, res->a, res->b);		mpz_add(t1, res->a, res->b);		mpz_mul(t0, t0, t1);		mpz_mul(t1, res->a, res->b);		mpz_mul_2exp(res->b, t1, 1);		mpz_mod(res->b, res->b, p);		mpz_mod(res->a, t0, p);	    }	    m--;	} else {	    l = m - windowsize + 1;	    if (l < 0) l = 0;	    l = mpz_scan1(n, l);	    j = 1;	    { //fp2_sqr(res,res);		mpz_sub(t0, res->a, res->b);		mpz_add(t1, res->a, res->b);		mpz_mul(t0, t0, t1);		mpz_mul(t1, res->a, res->b);		mpz_mul_2exp(res->b, t1, 1);		mpz_mod(res->b, res->b, p);		mpz_mod(res->a, t0, p);	    }	    for (k = m - 1; k>=l; k--) {		j = j << 1;		if (mpz_tstbit(n, k)) j++;		{ //fp2_sqr(res,res);		    mpz_sub(t0, res->a, res->b);		    mpz_add(t1, res->a, res->b);		    mpz_mul(t0, t0, t1);		    mpz_mul(t1, res->a, res->b);		    mpz_mul_2exp(res->b, t1, 1);		    mpz_mod(res->b, res->b, p);		    mpz_mod(res->a, t0, p);		}	    }	    fp2_mul(res, res, g[j], p);	    m = l-1;	}    }    fp2_clear(g[2]);    for (i=0; i<=windowsizepower; i++) {	j = 2 * i + 1;	fp2_clear(g[j]);    }    mpz_clear(t0); mpz_clear(t1);    /* simple method:    int m = mpz_sizeinbase(n, 2) - 1;    fp2_t x1;    fp2_init_set(x1, x);    for(;;) {	if (mpz_tstbit(n, m)) {	    fp2_mul(res, res, x1);	}	if (m == 0) break;	fp2_mul(res, res, res);	m--;    }    */}int fp2_is_0(fp2_ptr x)// x == 0?{    return (!(mpz_size(x->a) || mpz_size(x->b)));}int fp2_equal(fp2_ptr x, fp2_ptr y)// x == y?{    return (!(mpz_cmp(x->a, y->a) || mpz_cmp(x->b, y->b)));}size_t fp2_out_str(FILE *stream, int base, fp2_ptr x)//output x on stream in given base{    FILE *fp;    size_t s, status;    if (!stream) fp = stdout;    else fp = stream;    status = fprintf(fp, "[");    if (status < 0) return status;    s = status;    status = mpz_out_str(fp, base, x->a);    if (status < 0) return status;    s += status;    status = fprintf(fp, " ");    if (status < 0) return status;    s += status;    status = mpz_out_str(fp, base, x->b);    if (status < 0) return status;    s += status;    status = fprintf(fp, "]");    if (status < 0) return status;    s += status;    return s;}int fp2_set_str(fp2_t x, char *s, int base)//set value of x from s, a NULL-terminated C string, in base `base'//returns -1 on error{    int len;    char *sp;    char *buf;    len = strlen(s);    fp2_set_0(x);    if (!len) return -1;    if (s[0] != '[') return -1;    if (s[len - 1] != ']') return -1;    buf = (char *) alloca(len - 1);    memcpy(buf, &s[1], len - 2);    buf[len - 2] = 0;    sp = strchr(buf, ' ');    if (!sp) return -1;    *sp = 0;    sp++;    if (mpz_set_str(x->a, buf, base)) return -1;    if (mpz_set_str(x->b, sp, base)) return -1;    return 0;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
555www色欧美视频| 亚洲欧美经典视频| 一区二区三区在线观看动漫| 天天色天天操综合| 韩国女主播一区| 欧美在线999| 国产亚洲综合在线| 奇米影视一区二区三区| 91福利视频网站| ...xxx性欧美| 国产一区91精品张津瑜| 欧美日本韩国一区二区三区视频| 国产欧美一区二区精品性| 日本中文在线一区| 91视频观看视频| 国产欧美日韩综合| 国产在线精品一区二区三区不卡 | 国产成人精品一区二区三区四区 | 亚洲综合自拍偷拍| 成人伦理片在线| 久久久亚洲精品石原莉奈| 日本不卡视频在线观看| 欧美精品一二三| 亚洲一区二区三区爽爽爽爽爽| 99精品久久只有精品| 国产亚洲一区二区三区四区| 精品综合免费视频观看| 欧美一级免费大片| 日韩av一区二区三区| 欧美肥胖老妇做爰| 免费欧美高清视频| 日韩欧美三级在线| 卡一卡二国产精品 | 欧美日韩国产高清一区| 亚洲午夜久久久久中文字幕久| 91麻豆国产福利在线观看| 国产精品成人网| 99久久综合国产精品| 亚洲男人电影天堂| 色丁香久综合在线久综合在线观看| 国产精品国产三级国产| 99久久精品国产一区| 亚洲精品亚洲人成人网| 色8久久人人97超碰香蕉987| 一区二区三区91| 日韩三级av在线播放| 日韩高清一区二区| 精品久久久三级丝袜| 国产在线精品免费| 国产精品国产三级国产普通话三级| 91亚洲国产成人精品一区二三 | 久久久久久久性| 国产sm精品调教视频网站| 亚洲四区在线观看| 欧美日韩专区在线| 久久se精品一区二区| 国产精品久久久久久久第一福利| 91免费观看视频| 日产精品久久久久久久性色| 国产亚洲欧美激情| 欧美日韩在线精品一区二区三区激情 | 91视频国产资源| 日本va欧美va精品| 亚洲欧洲性图库| 欧美日韩精品一区二区三区四区 | 久久久不卡网国产精品一区| av电影在线观看不卡| 日韩国产一区二| 亚洲欧洲在线观看av| 91精品国产黑色紧身裤美女| 国产精品88888| 无码av免费一区二区三区试看| 欧美精品一区二区三区久久久| 色噜噜久久综合| 国产麻豆精品视频| 一区二区三区国产精华| 久久久久国产精品麻豆ai换脸| 在线观看亚洲一区| 国产99久久久国产精品潘金网站| 亚洲福利视频一区二区| 国产精品免费av| 日韩精品中文字幕一区二区三区| 99re热这里只有精品视频| 久久99国产精品免费| 一区二区三区在线不卡| 国产欧美日本一区二区三区| 777午夜精品免费视频| 91在线云播放| 国产成人午夜电影网| 老司机精品视频在线| 亚洲成人免费在线| 亚洲欧美国产三级| 国产精品久久久久久久久图文区| 精品久久99ma| 7878成人国产在线观看| 欧美三级视频在线观看| 一本色道久久综合亚洲91| 国产九色精品成人porny| 免费av网站大全久久| 亚洲va欧美va人人爽午夜| 亚洲欧美日韩在线| 亚洲欧洲av色图| 国产精品日韩成人| 国产精品女同一区二区三区| 欧美mv和日韩mv的网站| 欧美一区二区在线看| 欧美日韩国产123区| 色哟哟国产精品| 91免费视频网| 91一区一区三区| 99麻豆久久久国产精品免费| 97超碰欧美中文字幕| 成人av网站在线| 97精品国产露脸对白| 99久久精品国产毛片| 99riav一区二区三区| 欧美综合天天夜夜久久| 欧美亚洲动漫制服丝袜| 欧美伊人久久大香线蕉综合69| 91久久精品国产91性色tv| 欧美在线观看你懂的| 欧美福利视频导航| 日韩亚洲欧美一区二区三区| 欧美一区二区三区四区五区| 欧美岛国在线观看| 欧美经典一区二区| 亚洲美女免费在线| 亚洲国产中文字幕| 裸体歌舞表演一区二区| 国产精品69久久久久水密桃| 岛国一区二区三区| 色婷婷av一区| 91精品国产品国语在线不卡| 久久综合九色综合97婷婷| 国产欧美日韩亚州综合| 综合欧美亚洲日本| 日韩不卡一区二区| 国产麻豆视频精品| 色av成人天堂桃色av| 91精品国产欧美一区二区成人| 欧美精品一区二区久久婷婷| 一区免费观看视频| 日韩av在线发布| 成人黄色777网| 欧美日韩一级视频| 国产精品沙发午睡系列990531| 亚洲精品乱码久久久久久黑人 | 91免费看`日韩一区二区| 欧美色网一区二区| 久久综合狠狠综合| 亚洲免费视频成人| 激情文学综合网| 在线区一区二视频| 久久婷婷成人综合色| 一卡二卡欧美日韩| 激情文学综合插| 欧美影院精品一区| 久久影院视频免费| 亚洲一区免费在线观看| 久久99精品久久久久久国产越南| 99精品国产99久久久久久白柏| 欧美一区二区在线免费播放| 欧美激情中文字幕一区二区| 丝袜国产日韩另类美女| 成人黄色一级视频| 日韩午夜av一区| 一区二区欧美视频| 成人一级黄色片| 日韩你懂的在线观看| 一片黄亚洲嫩模| av中文字幕不卡| 久久久精品2019中文字幕之3| 亚洲电影在线播放| 色综合久久久久| 国产精品久久看| 国产超碰在线一区| 精品国产sm最大网站免费看| 亚洲一区二区三区四区五区中文 | 亚洲欧美一区二区三区极速播放 | 成人91在线观看| 亚洲精品在线免费播放| 日本亚洲免费观看| 色菇凉天天综合网| 亚洲免费视频中文字幕| fc2成人免费人成在线观看播放 | 日韩一区二区三免费高清| 一区二区三区中文字幕| 成人美女在线视频| 国产欧美视频在线观看| 国产美女在线观看一区| 精品国产一区二区国模嫣然| 美女网站色91| 日韩一级片在线观看| 麻豆成人av在线| 日韩久久久精品| 精品影院一区二区久久久| 日韩一区二区在线观看视频播放| 亚州成人在线电影| 678五月天丁香亚洲综合网| 亚洲夂夂婷婷色拍ww47 |