- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
最近,我一直在尝试实现 Keccak,这是 SHA-3 背后的密码学原语。然而,我遇到了一些问题,特别是在计算排列的“Iota”步骤中使用的轮常数时。
只是为了解决问题:是的。我知道它们是圆的常数。我知道我可以将它们硬编码为常量。但这有什么乐趣呢?
我特别提到了 FIPS 202 specification document关于 SHA-3 以及 Keccak 团队自己的 Keccak reference .然而,尽管我付出了努力,但我似乎无法得到正确的常量。我以前从未处理过位操作,所以如果我以完全错误的方式做某事,请随时告诉我。
rc 是 Keccak 的 FIPS 202 标准中定义的函数,它是一个线性反馈移位寄存器,其反馈多项式为 x^8 + x^6 + x^5 + x^4 + 1
.
t
的值(特定于 SHA-3)定义为包含 j + 7 * i_r
的整数集,其中 i_r = {0, 1 , ..., 22, 23} 和 j = {0, 1, ..., 4, 5}。
预期输出(循环常量)定义如下:0x0000000000000001、0x0000000000008082、0x800000000000808a、0x8000000080008000, 0x000000000000808b, 0x0000000080000001,0x8000000080008081,0x8000000000008009,0x000000000000008a,0x0000000000000088, 0x0000000080008009, 0x000000008000000a,0x000000008000808b,0x800000000000008b,0x8000000000008089,0x8000000000008003、0x8000000000008002、0x8000000000000080、0x000000000000800a,0x800000008000000a,0x8000000080008081,0x8000000000008080、0x0000000080000001 和 0x8000000080008008。
rc函数实现
uint64_t rc(int t)
{
if(t % 255 == 0)
{
return 0x1;
}
uint64_t R = 0x1;
for(int i = 1; i <= t % 255; i++)
{
R = R << 0x1;
R |= (((R >> 0x0) & 0x1) ^ ((R >> 0x8) & 0x1)) << 0x0;
R |= (((R >> 0x4) & 0x1) ^ ((R >> 0x8) & 0x1)) << 0x4;
R |= (((R >> 0x5) & 0x1) ^ ((R >> 0x8) & 0x1)) << 0x5;
R |= (((R >> 0x6) & 0x1) ^ ((R >> 0x8) & 0x1)) << 0x6;
R &= 0xFF;
}
return R & 0x1;
}
rc 函数调用
for(int i_r = 0; i_r < 24; i_r++)
{
uint64_t RC = 0x0;
// TODO: Fix so the limit is not constant
for(int j = 0; j < 6; j++)
{
RC ^= (rc(j + 7 * i_r) << ((int) pow(2, j) - 1));
}
printf("%llu\n", RC);
}
非常感谢您对此问题的任何帮助。
最佳答案
我对代码进行了一些随机更改,现在它可以运行了。以下是亮点:
j
循环需要从 0 计数到 6。那是因为 2^6-1 = 63。所以如果 j
永远不是 6,那么输出永远不能设置 MSB,即 0x8... 的输出是不可能的。
使用pow
函数对于此类应用程序通常不是一个好主意。 double
值有一个坏习惯,即略低于期望值,例如4 实际上是 3.99999999999,当您将其转换为 int
时,它会被截断为 3。怀疑这种情况是否发生在这种情况下,但为什么要冒险呢,因为在每次通过循环时将变量 shift
乘以 2 很容易。
t
的最大值是 7*23+6 = 167,所以 %255
什么都不做(至少对于 的值i
和 t
在此代码中)。此外,无需将 t == 0
视为特例。当t
为0时,循环不会运行,所以结果默认为0x1。
用 C 语言实现线性反馈移位寄存器非常简单。多项式中的每一项对应一个位。 x^8
只是 2^8 即 0x100
而 x^6 + x^5 + x^4 + 1
是 0x71
。因此,无论何时设置 0x100
位,您都可以将结果与 0x71
进行异或。
这是更新后的代码:
#include <stdio.h>
#include <stdint.h>
#include <inttypes.h>
uint64_t rc(int t)
{
uint64_t result = 0x1;
for (int i = 1; i <= t; i++)
{
result <<= 1;
if (result & 0x100)
result ^= 0x71;
}
return result & 0x1;
}
int main(void)
{
for (int i = 0; i < 24; i++)
{
uint64_t result = 0x0;
uint64_t shift = 1;
for (int j = 0; j < 7; j++)
{
uint64_t value = rc(7*i + j);
result |= value << (shift - 1);
shift *= 2;
}
printf("0x%016" PRIx64 "\n", result);
}
}
关于c - Keccak 中的舍入常量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52922526/
我试图为此搜索答案,但我发现很难找到这种“确切”的例子。我对指向指针的指针知之甚少,我觉得除了指向某物的指针之外,还有更多东西隐藏在它的表层之下。 那么你们会如何翻译呢? void free(sham
我有一个类的属性,比如const CFoo &bar() const,这是什么意思? 最佳答案 bar 方法返回对 const CFoo 的引用(即 bar 之前的 const CFoo & 部分),
例如是 int const x = 3; 有效代码? 如果是的话,意思是一样的 const int x = 3; ? 最佳答案 它们都是有效的代码并且它们都是等价的。对于指针类型,尽管它们都是有效代码
我知道 f(const T& obj) // (1) g(T const& obj) // (2) 是一样的。(我们不能改变f和g中obj的值)。 但是什么 h(T & const) // (3) 真
本节讲解的内容 include和include_once require和require_once 常量 引入文件和常量结合案列 变量操作函数 输出语句 前言 在上篇文章中,我们讨论了函数的应用,但是
我们知道我们可以保护变量的值,因此用户无法更改现有变量的值!这对对象来说没有什么问题吗?? 例如.. const x = 5; x = 10; alert(x) // will be returned
我正准备为 CUDA 设备编写直方图内核。它基于 NVIDIA's paper . 这个想法是每个线程计算某个部分(在我的例子中是体积)的部分直方图并将其写入共享内存块。然而,我遇到了一个奇怪的算法问
常量是固定值,程序执行期间不会改变。常量可以是任何基本数据类型,比如整数常量、浮点常量、字符常量或者字符串常量,还有枚举常量。 常量可以被当作常规的变量,只是它们的值在定义后不能被修改。 整数常
在这种情况下,如何识别是否有变量或字面量传递给函数 f()? 如何实现passed_as_constant()检查(见下面代码)? sub f { my $refStr=\$_[0]; ret
我目前想知道如何在 python 中列出 win32com 中的常量, 例如使用 excel win32com.client.Dispatch('Excel.Application') 有没有办法使用
这个问题在这里已经有了答案: PHP | define() vs. const (9 个回答) 关闭8年前。 在 PHP 中遇到常量问题想知道是否有人可以解释: 这行得通 const _ROOT =
我正在学习 Rust,到目前为止,似乎有 3 种声明变量的方法: const A: u8 = 42; static A: u8 = 42; let A: u8 = 42; 我知道你不能有一个可变的 c
我正在使用函数模板 void _createAttr(T)(args..., in T[]) 并使用 测试 T 的类型函数中的 static if(is(T == char)) 。当我打电话时, _c
这可能是一个天真的问题,我怀疑答案是"is",但我没有运气在这里和其他地方搜索“erlang编译器优化常量”等术语。无论如何,erlang 编译器是否可以(将)在编译时创建一个常量或文字的数据结构,并
我刚遇到这段 Java 脚本代码: const { myKey, uname, issorted, title, hClick, } = this.props; 请告诉我这是什么意
我正在努力实现以下目标: 我有一个父类,有一些逻辑。在子类中,我“重新定义”常量/属性。有没有办法让子属性可以通过父类中定义的方法访问?或者更具体地说 - 有什么方法可以强制“out”方法在下面的示例
如果这是个愚蠢的问题,请原谅。 我有一个带有内部类接口(interface)的“fragment ”外部类。该接口(interface)仅由另一个 Activity 类使用“implements Ou
我是 python 新手,尝试使用默认值并为类实例自定义它们。 因此,在这个示例中,我定义了一个 DEFAULT_STRING 和一个 DEFAULT_SETTINGS 变量,可以使用 customi
在 integer.xml 中,其形式为 0x001 0x002 是代码和 xml 文件都需要的存储常量。 C# 识别 Droid.Resource.Integer.foo,但它有一些大的
是否有跨平台(即跨 Linux、BSD 和 OS X,最好是所有 POSIX)我可以纯粹基于字符串 以编程方式访问诸如 O_RDWR 之类的常量>“O_RDWR”?我正在编写一些(非 C)代码,这些代
我是一名优秀的程序员,十分优秀!