dongniaocheng3773 2019-01-05 19:04
浏览 333
已采纳

如何使用Golang big.Int计算`x ^ 3 + ax + b mod p`

I'm trying to find the Y coordinate for an elliptic point. I understand the formula is y^2≡x^3+ax+b mod p.

However I'm unsure of how I would actually program this in Go.

xCubed.Exp(X, 3, nil)
AX.Mul(A,X)

N.Add(XPow3, AX) // x^3 + ax
N.Mod(N, P) // mod p
N.Add(N, B) // (x^3 + ax) + b
N.Mod(N, P) // mod p

return N

Where xCubed,X,N,P,B are *big.Int and N represents y^2

I'm a noob to modular arithmetic, so my assumption mod P is applied to each operation; Is this the correct way to to calculate x^3 + ax + b mod p?

edit: should I have added AX.Mod(p) ?

  • 写回答

1条回答 默认 最新

  • dongzhijing8202 2019-01-05 19:47
    关注

    I figured it out, by scouting some code in the elliptic lib

    func GetY(x *big.Int, curve *elliptic.CurveParams) *big.Int {
    
    
        x3 := new(big.Int).Mul(x, x)
        x3.Mul(x3, x)
    
        threeX := new(big.Int).Lsh(x, 1)
        threeX.Add(threeX, x)
    
        x3.Sub(x3, threeX)
        x3.Add(x3, curve.B)
        x3.Mod(x3, curve.P)
    
        return x3.ModSqrt(x3, curve.P)
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥20 求快手直播间榜单匿名采集ID用户名简单能学会的
  • ¥15 DS18B20内部ADC模数转换器
  • ¥15 做个有关计算的小程序
  • ¥15 MPI读取tif文件无法正常给各进程分配路径
  • ¥15 如何用MATLAB实现以下三个公式(有相互嵌套)
  • ¥30 关于#算法#的问题:运用EViews第九版本进行一系列计量经济学的时间数列数据回归分析预测问题 求各位帮我解答一下
  • ¥15 setInterval 页面闪烁,怎么解决
  • ¥15 如何让企业微信机器人实现消息汇总整合
  • ¥50 关于#ui#的问题:做yolov8的ui界面出现的问题
  • ¥15 如何用Python爬取各高校教师公开的教育和工作经历