- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我试图从 this (old) implementation on github 了解 Shamir 的 secret 共享计划的实现,我在扩展字段 GF(p^n) 中与 Horner 规则作斗争:
void horner(int n, mpz_t y, const mpz_t x, const mpz_t coeff[])
{
int i;
mpz_set(y, x);
for(i = n - 1; i; i--) {
field_add(y, y, coeff[i]);
field_mult(y, y, x);
}
field_add(y, y, coeff[0]);
}
为什么add
先出现,然后才出现mult
?算法是什么?为什么不是这样的:
mpz_set(y,coeff[n-1]);
for(i = n - 2; i!=-1; i--) {
field_mult(y, y, x);
field_add(y,y,coeff[i]);
}
最佳答案
用正常的加法和乘法符号翻译这个horner
函数,我们得到:
y = x; // mpz_set(y, x);
for(i = n - 1; i; i--) {
y = y + coeff[i]; // field_add(y, y, coeff[i]);
y = y * x // field_mult(y, y, x);
}
y = y + coeff[0] // field_add(y, y, coeff[0]);
您可以看到它不计算任何多项式,但它是计算 monic polynomial 的 Horner 算法的变体。 .
现在你的建议是:
y = coeff[n-1]; // mpz_set(y,coeff[n-1]);
for(i = n - 2; i!=-1; i--) {
y = y * x; // field_mult(y, y, x);
y = y + coeff[i]; // field_add(y,y,coeff[i]);
}
如果你想把所有的操作都放在循环体内,你可以。毕竟,这只是以不同方式分解一系列交替指令的两种方法:
operation value of y loop iteration
add-mult loop mult-add loop
x initialization n-1
add x + coeff[n-1] n-1 n-1
mult (x + coeff[n-1]) * x n-1 n-2
add (x + coeff[n-1]) * x + coeff[n-2] n-2 n-2
mult ((x + coeff[n-1]) * x + coeff[n-2]) * x n-2 n-3
...etc...
但是您需要显式地将y
初始化为值1
(这是隐式的coeff[n]
),这样您就可以开始通过乘以 x
得到正确的最高阶项。
y = 1; // mpz_set(y,1);
for(i = n - 1; i!=-1; i--) { // NOTICE n - 1 NOT n - 2
y = y * x; // field_mult(y, y, x);
y = y + coeff[i]; // field_add(y,y,coeff[i]);
}
您可以算一下,您现在又执行了一次乘法,它是乘以 1 * x
。在有限域上,这通常使用对数表和反对数表来完成,因此您最好避免这种无用的乘法,特别是如果您要经常计算多项式。
TL;DR:这种编写 Horner 算法的方法将最后一次加法和第一次乘法放在循环体之外。因为最高阶系数是 1
,所以这个乘法被完全删除。
澄清一下:保留了最高阶项,但它是 x^n
而不是 1 * x^n
。您为完全相同的结果节省了一次乘法。
关于c - 我无法理解这个 Horner 规则在扩展字段 GF(p^n) 中的实现,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35753405/
在关于变体构造的 GF 教程中,它说要在 GF 上表达变体,应使用以下方法之一。lin Delicious = {s = "delicious" | "exquisit" | "tasty"} ;li
我在 GF 库中检查了“我 friend 的房子”中的“’s”,但我似乎找不到创建这种关系的正确方法。希望有人指导我解决这个问题。 欣赏🌹🌹 最佳答案 核心 RGL 中的所有格确实没有任何功能。仅
我使用 Phrase 生成句子“播放 BBC 主持的喜剧电影”。 mkPhr (mkVP( (mkV2 (mkV ("Play"))) (mkNP
已结束。此问题不符合 Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找书籍、工具、软件库、教程或其他场外资源的问题对于 Stack Overflow 来说是
每当我在 ubuntu 中执行 sudo su 时,每次使用任何东西都没有任何问题时,我都会收到这个奇怪的错误,但我只想问为什么它会出现,即使我已经删除了这个文件,为什么它会自动执行 bash 到这个
在此操作中,我在 RGL 中遇到了别名符号: mkRoot3 : Str -> Root3 = \fcl -> case fcl of { f@? + c@? + l => {f =
我正在尝试设置我的 .vimrc所以gf通过尝试打开与当前 FileType 具有相同扩展名的文件,将自动处理缺少文件扩展名的路径。 换句话说,我想要这样的东西: autocmd FileType
我尝试了 gF,它的行为似乎不像 :help gF 中提到的那样 如果光标位于条目 x.c 上并且我输入 gf 文件将被打开。 如果光标位于条目 x.c:3 上并且我输入 gF 我得到 E447: C
我正在尝试为莫尔斯电码培训师生成随机的英语练习短语。我想弄清楚如何用英语处理性别协议(protocol)。我希望能够生成诸如“他是儿子”、“她是母亲”、“这是一扇门”之类的短语,但要避免诸如“他是母亲
在下面的 ansible 代码中,当我将光标移动到 get_service_restart_count.yml 并在 vim 中输入“gf”时,它会打开该文件。 - name: Delete PVC
在下面的 ansible 代码中,当我将光标移动到 get_service_restart_count.yml 并在 vim 中输入“gf”时,它会打开该文件。 - name: Delete PVC
这 2 个函数执行扩展欧几里德算法,然后求乘法逆。订单似乎是正确的,但根据悉尼大学的工具,它并没有像我期望的那样返回 http://magma.maths.usyd.edu.au/calc/由于这是在
使用 vim 时,我在文件之间跳转: 标签: ctrl-] 和 ctrl-t, 跳转标记:ctrl-i 和 ctrl-o 以及 编辑位置:g-;和 g-,。 我需要的是有点不同...... 从我使用
当前的 gf 命令将打开 *.pdf 文件作为 ascii 文本。我希望使用外部工具(如 okular、foxitreader 等)打开 pdf 文件。我尝试使用 autocmd 来实现它,如下所示:
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
我有一个 GIF 动画,一只猫从左跑到右,然后转身从右跑到左。看来我的代码中的所有内容都是正确的。在我的代码过于复杂之前,它似乎工作得很好,但是移动时 gif 被卡住了。现在我修改了代码,但现在 gi
已结束。此问题正在寻求书籍、工具、软件库等的推荐。它不满足Stack Overflow guidelines 。目前不接受答案。 我们不允许提出寻求书籍、工具、软件库等推荐的问题。您可以编辑问题,以便
我经常在 vim 中使用 gf 打开文件。通常这些文件路径使用环境变量。我正在使用 tcl shell 来启动一些脚本。当环境变量在没有::env 的情况下使用时(tcl 的 env 所必需的选项),
在 gVim 中,如果光标位于包含空格的文件名(如 "C:\Program Files\Vim\vim71\README.txt")上,则使用 'gf' 失败。 我找到了 isfname选项,但文档说
例如,如果我有类似的东西: path = '/mnt/data/files/' 我的光标在 '/mnt/data/files/' , 我打了一个 gf -like 命令,它会打开 vim :Explo
我是一名优秀的程序员,十分优秀!