ZK-ALU-在有限域上实现左移
先看在实数域上实现左移, 再看在有限域上的实现
左移-整数
计算机中的左移计算(<< 操作)通常由处理器的硬件电路直接支持,因此效率非常高。在编程语言中,左移操作可以通过位移运算符(例如 C/C++ 中的 <<)来完成,其底层实现如下:
1. 左移的基本原理
左移操作是将二进制数的每一位向左移动指定的位数,右边用 0 填充。
- 如果一个数是 xxx,左移 nnn 位后,结果为 x×2nx \times 2^nx×2n。
- 举例:
5 ( 10 ) = 10 1 ( 2 ) 5_{(10)} = 101_{(2)} 5(10)=101(2) 左移 2 位:
10 1 ( 2 ) < < 2 = 1010 0 ( 2 ) = 2 0 ( 10 ) 101_{(2)} << 2 = 10100_{(2)} = 20_{(10)} 101(2)<<2=10100(2)=20(10)
2. 硬件实现
处理器的算术逻辑单元(ALU)通常支持位移操作,通过移位寄存器(Shift Register)完成。其工作原理如下:
- 输入一个二进制数。
- 按位移动数据流,通过硬件电路将高位移出(可能被丢弃)并在低位补
0。
现代处理器中,移位操作通常是一个单周期的操作,直接在 ALU 中完成。
3. 软件层的实现
在编程语言中,左移通常是直接调用处理器指令完成的。例如:
-
C语言实现
int x = 5; int y = x << 2; // 等效于 5 * 2^2 = 20 -
底层会使用类似以下汇编指令(取决于具体的 CPU 架构):
SHL eax, 2 ; 将寄存器 eax 的值左移 2 位
4. 左移的注意事项
-
溢出问题:
左移可能导致高位的有效位丢失,从而发生溢出。需要确保目标寄存器或变量有足够的位宽。
- 例如,对于 8 位整数: 20 0 ( 10 ) = 1100100 0 ( 2 ) 200_{(10)} = 11001000_{(2)} 200(10)=11001000(2) 左移 2 位后会变成 1001000 0 ( 2 ) = 14 4 ( 10 ) 10010000_{(2)} = 144_{(10)} 10010000(2)=144(10)
-
符号位的影响:
在带符号数中(例如int),左移不改变符号位的处理规则,但右移可能需要区分算术移位和逻辑移位。
5. 与逻辑运算结合
左移操作可以与按位与、按位或等操作结合,实现特定的算法逻辑。例如:
-
清除某些位:
int x = 0b101011; int mask = ~(1 << 3); // 生成掩码 int result = x & mask; // 清除第 3 位
左移-有限域(大整数)
在有限域中,左移计算的实现需要特别考虑有限域的特性,尤其是模运算和多项式表示法的影响。以下是有限域中左移计算的具体解释和实现细节:
1. 有限域的表示方式
- 有限域通常记作 G F ( 2 m ) GF(2^m) GF(2m),其中元素可以用二进制多项式表示。例如, x 3 + x + 1 x^3 + x + 1 x3+x+1 可以表示为二进制数 101 1 2 1011_2 10112。
- 左移在有限域中的表现类似于将多项式的所有项的幂次增加,但需要结合模多项式 P ( x ) P(x) P(x) 限制结果。
2. 有限域左移的意义
有限域的左移操作本质上是多项式乘以 xx。例如:
A ( x ) = a m − 1 x m − 1 + ⋯ + a 1 x + a 0 A(x) = a_{m-1}x^{m-1} + \cdots + a_1x + a_0 A(x)=am−1xm−1+⋯+a1x+a0
左移后变为:
A ( x ) ⋅ x = a m − 1 x m + ⋯ + a 1 x 2 + a 0 x A(x) \cdot x = a_{m-1}x^m + \cdots + a_1x^2 + a_0x A(x)⋅x=am−1xm+⋯+a1x2+a0x
如果幂次超过 m − 1 m-1 m−1,需要模 P ( x ) P(x) P(x) 进行化简。
3. 有限域左移的实现
实现中需要考虑溢出项的处理,具体步骤如下:
步骤 1:左移多项式
- 将当前多项式的每一位向左移动 1 位。
- 高位溢出时,需要与模多项式 P ( x ) P(x) P(x) 进行异或运算(相当于取模)。
步骤 2:检查溢出
- 判断最高位(对应 x m x^m xm 的系数)是否为 1。
- 如果为 1,减去(或异或)模多项式 P ( x ) P(x) P(x)。
4. 具体算法
用伪代码表示:
def gf2m_left_shift(poly, m, modulus):"""在有限域 GF(2^m) 中实现左移操作。:param poly: 待左移的多项式,用整数表示(如 0b1011)。:param m: 有限域的位数。:param modulus: 模多项式,用整数表示(如 0b10011 表示 x^4 + x + 1)。:return: 左移后的结果。"""# 左移操作poly <<= 1# 检查是否需要模运算if poly & (1 << m): # 如果超过了 m 位poly ^= modulus # 异或模多项式相当于取模# 返回结果,确保结果位数不超过 m 位return poly & ((1 << m) - 1)
5. 例子
以 G F ( 2 4 ) GF(2^4) GF(24) 为例,模多项式 P ( x ) = x 4 + x + 1 P(x) = x^4 + x + 1 P(x)=x4+x+1 (即 0 b 10011 0b10011 0b10011):
- A ( x ) = x 3 + x = 101 0 2 A(x) = x^3 + x = 1010_2 A(x)=x3+x=10102
- 左移 1 位: A ( x ) ⋅ x = x 4 + x 2 A(x) \cdot x = x^4 + x^2 A(x)⋅x=x4+x2 (即 1010 0 2 10100_2 101002)
- 取模: 1010 0 2 ⊕ 1001 1 2 = 0011 1 2 10100_2 \oplus 10011_2 = 00111_2 101002⊕100112=001112
- 结果: x 2 + x + 1 x^2 + x + 1 x2+x+1(即 0 b 0111 0b0111 0b0111)。
6. 硬件实现
在硬件中,有限域左移操作可通过移位寄存器和异或逻辑门实现:
- 使用移位寄存器完成左移操作。
- 当最高位溢出时,通过异或门与模多项式进行模运算。
7. 应用场景
- 加密算法:如 AES 中的 GF(2^8) 操作。
- 误差校正:如 CRC 校验。
- 多项式运算:如 Reed-Solomon 编码。
- 往期精彩回顾:
- 区块链知识系列
- 密码学系列
- 零知识证明系列
- 共识系列
- 公链调研系列
- BTC系列
- 以太坊系列
- EOS系列
- Filecoin系列
- 联盟链系列
- Fabric系列
- 智能合约系列
- Token系列
相关文章:
ZK-ALU-在有限域上实现左移
先看在实数域上实现左移, 再看在有限域上的实现 左移-整数 计算机中的左移计算(<< 操作)通常由处理器的硬件电路直接支持,因此效率非常高。在编程语言中,左移操作可以通过位移运算符(例如 C/C 中的 <<&a…...
掌握API和控制点(从Java到JNI接口)_36 JNI开发与NDK 04
4、 *.so的入口函数:JNI_OnLoad() VM (virtual machine)的角色 Java代码在VM上执行。在执行Java代码的过程中,如果Java需要与本地代码(*.so)沟通时, VM就会把*.so視为插件<Tn>而加载到VM里。然后让Java函数呼叫到这插件<Tn>里的…...
Spring Bean 容器
技术成长,是对场景设计细节不断的雕刻! 你觉得自己的技术什么时候得到了快速的提高,是CRUD写的多了以后吗?想都不要想,绝对不可能!CRUD写的再多也只是能满足你作为一个搬砖工具人,敲击少逻辑流…...
Maven全解析:从基础到精通的实战指南
概念: Maven 是跨平台的项目管理工具。主要服务基于 Java 平台的构建,依赖管理和项目信息管理项目构建:高度自动化,跨平台,可重用的组件,标准化的流程 依赖管理: 对第三方依赖包的管理…...
【开源免费】基于SpringBoot+Vue.JS贸易行业crm系统(JAVA毕业设计)
本文项目编号 T 153 ,文末自助获取源码 \color{red}{T153,文末自助获取源码} T153,文末自助获取源码 目录 一、系统介绍二、数据库设计三、配套教程3.1 启动教程3.2 讲解视频3.3 二次开发教程 四、功能截图五、文案资料5.1 选题背景5.2 国内…...
高效接口限流:基于自定义注解与RateLimiter的实践
在高并发场景下,接口的流量控制是保证系统稳定性和提升性能的关键之一。通过实现接口限流,我们可以有效避免系统在访问高峰时发生崩溃。本文将详细介绍如何通过自定义注解和切面编程结合RateLimiter来实现接口的限流功能,以应对高并发请求。 …...
nodejs:express + js-mdict 网页查询英汉词典,能播放声音
向 DeepSeek R1 提问: 我想写一个Web 前端网页,后台用 nodejs js-mdict, 实现在线查询英语单词 1. 项目结构 首先,创建一个项目目录,结构如下: mydict-app/ ├── public/ │ ├── index.html │ ├── st…...
无人机PX4飞控 | PX4源码添加自定义uORB消息并保存到日志
PX4源码添加自定义uORB消息并保存到日志 0 前言 PX4的内部通信机制主要依赖于uORB(Micro Object Request Broker),这是一种跨进程的通信机制,一种轻量级的中间件,用于在PX4飞控系统的各个模块之间进行高效的数据交换…...
【IocDI】_存储Bean的五大类注解及getBean的使用
目录 1. Bean的存储 1.1 类注解 1.1.1 Controller:控制器存储 1.1.2 Service:服务存储 1.1.3 Repository:仓库存储 1.1.4 Component:组件存储 1.1.5 Configuration:配置存储 1.2 五大类注解之间的关系 2. get…...
VLAN 基础 | 不同 VLAN 间通信实验
注:本文为 “ Vlan 间通信” 相关文章合辑。 英文引文,机翻未校。 图片清晰度限于原文图源状态。 未整理去重。 How to Establish Communications between VLANs? 如何在 VLAN 之间建立通信? Posted on November 20, 2015 by RouterSwi…...
GRE阅读双线阅读 --青山学堂GRE全程班 包括 阅读、数学、写作、填空、背单词
新版GRE考试整体结构 section题量时间写作1篇issue30min语文S112道题(7道填空5道阅读)18min数学S112道题21min语文S215道题(7道填空8道阅读)23min数学S215道题26min Tips: 写作结束后,语文和数学的顺序不固定,2中可能: issue -> V ->…...
算法总结-二分查找
文章目录 1.搜索插入位置1.答案2.思路 2.搜索二维矩阵1.答案2.思路 3.寻找峰值1.答案2.思路 4.搜索旋转排序数组1.答案2.思路 5.在排序数组中查找元素的第一个和最后一个位置1.答案2.思路 6.寻找旋转排序数组中的最小值1.答案2.思路 1.搜索插入位置 1.答案 package com.sunxi…...
litemall,又一个小商场系统
litemall Spring Boot后端 Vue管理员前端 微信小程序用户前端 Vue用户移动端 代码地址:litemall: 又一个小商城。 litemall Spring Boot后端 Vue管理员前端 微信小程序用户前端 Vue用户移动端...
5.5.1 面向对象的基本概念
文章目录 基本概念面向对象的5个原则 基本概念 面向对象的方法,特点时其分析与设计无明显界限。虽然在软件开发过程中,用户的需求会经常变化,但客观世界对象间的关系是相对稳定的。对象是基本的运行实体,由数据、操作、对象名组成…...
Java_类加载器
小程一言类加载器的基础双亲委派模型核心思想优势 各类加载器的职责 类加载器的工作流程举例:如何在Java中使用类加载器启动类加载器、扩展类加载器与系统类加载器输出解释自定义类加载器 类加载器与类冲突总结 小程一言 本专栏是对Java知识点的总结。在学习Java的过…...
开源音乐管理软件Melody
本文软件由网友 heqiusheng 推荐。不过好像已经是一年前了 😂 简介 什么是 Melody ? Melody 是你的音乐精灵,旨在帮助你更好地管理音乐。目前的主要能力是帮助你将喜欢的歌曲或者音频上传到音乐平台的云盘。 主要功能包括: 歌曲…...
一、TensorFlow的建模流程
1. 数据准备与预处理: 加载数据:使用内置数据集或自定义数据。 预处理:归一化、调整维度、数据增强。 划分数据集:训练集、验证集、测试集。 转换为Dataset对象:利用tf.data优化数据流水线。 import tensorflow a…...
Vue.js组件开发-实现左侧浮动菜单跟随页面滚动
使用 Vue 实现左侧浮动菜单跟随页面滚动 实现步骤 创建 Vue 项目:使用 Vue CLI 创建一个新的 Vue 项目。设计 HTML 结构:包含一个左侧浮动菜单和一个主要内容区域。编写 CSS 样式:设置菜单的初始样式和滚动时的样式。使用 Vue 的生命周期钩…...
分析哲学:从 语言解剖到 思想澄清的哲学探险
分析哲学:从 语言解剖 到 思想澄清 的哲学探险 第一节:分析哲学的基本概念与公式解释 【通俗讲解,打比方来讲解!】 分析哲学,就像一位 “语言侦探”,专注于 “解剖语言”,揭示我们日常使用的语…...
MySQL 插入数据指南
MySQL 插入数据指南 引言 MySQL 是一款广泛使用的开源关系数据库管理系统,被广泛应用于各种规模的组织中。在数据库管理中,数据的插入是基础操作之一。本文将详细介绍如何在 MySQL 中插入数据,包括插入单条记录和多条记录,以及一…...
寒假刷题Day20
一、80. 删除有序数组中的重复项 II class Solution { public:int removeDuplicates(vector<int>& nums) {int n nums.size();int stackSize 2;for(int i 2; i < n; i){if(nums[i] ! nums[stackSize - 2]){nums[stackSize] nums[i];}}return min(stackSize, …...
鸿蒙物流项目之基础结构
目录: 1、项目结构2、三种包的区别和使用场景3、静态资源的导入4、颜色样式设置5、修改项目名称和图标6、静态包基础目录7、组件的抽离8、在功能模块包里面引用静态资源包的组件 1、项目结构 2、三种包的区别和使用场景 3、静态资源的导入 放在har包中,那…...
[漏洞篇]SQL注入漏洞详解
[漏洞篇]SQL注入漏洞详解 介绍 把SQL命令插入到Web表单提交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令。通过构造恶意的输入,使数据库执行恶意命令,造成数据泄露或者修改内容等,以达到攻击的目的。…...
【最后203篇系列】006 -使用ollama运行deepseek-r1前后端搭建
说明 这块已经不算新内容了,年前搭完了后端(ollama),本来想早点分享的,但是当时的openwebui有点不给力,有些地方不适配,然后配置项找不到。所以前端没搭好,也就不完整:只能通过命令…...
CSS Module 常用笔记
Date: January 30, 2025 CSS 先介绍下普通 CSS,再简明介绍下 css module 的使用 普通 CSS 内联 style 定义: 内联 style 是通过在元素的 style 属性中直接设置 CSS 样式。这种方式允许我们直接在 JSX 中为组件或元素添加样式。 写法: &…...
JDK-1.8.0_432安装(CentOS7)
目录 1、卸载系统自带JDK 2、下载安装包并解压 3、赋予可执行权限 4、设置环境变量 5、刷新环境变量 6、查看JDK版本 1、卸载系统自带JDK # 查询出自带的jdk rpm -qa | grep jdk rpm -qa | grep java # 将上述命令列出的包依次删除 rpm -e --nodeps xxxxxxx 2、下载…...
【Linux】24.进程信号(1)
文章目录 1. 信号入门1.1 进程与信号的相关知识1.2 技术应用角度的信号1.3 注意1.4 信号概念1.5 信号处理常见方式概览 2. 产生信号2.1 通过终端按键产生信号2.2 调用系统函数向进程发信号2.3 由软件条件产生信号2.4 硬件异常产生信号2.5 信号保存 3. 阻塞信号3.1 信号其他相关…...
C++ 字面量深度解析:从基础到实战进阶
在 C 开发中,字面量(Literal)不仅是基础语法的一部分,更是提升代码可读性、安全性和性能的关键工具。本文将深入探讨 C 字面量的高级特性、最新标准支持(C11/14/17/20)以及实际开发中的应用技巧,…...
股票入门知识
股票入门(更适合中国宝宝体制) 股市基础知识 本文介绍了股票的基础知识,股票的分类,各板块发行上市条件,股票代码,交易时间,交易规则,炒股术语,影响股价的因素…...
用Python实现K均值聚类算法
在数据挖掘和机器学习领域,聚类是一种常见的无监督学习方法,用于将数据点划分为不同的组或簇。K均值聚类算法是其中一种简单而有效的聚类算法。今天,我将通过一个具体的Python代码示例,向大家展示如何实现K均值聚类算法࿰…...
