【密码学】密码学数学基础:剩余系

        不得不啃的密码学数学基础之剩余系是个啥?数学里面有好多的定义都有前置的数学概念,要想弄懂剩余系还得先说说“同余”。

一、同余

        那么“同余”有是个什么呢?在谈论“同余”之前,我们先圈定个讨论的范围。接下来讨论的都是整数集合。好了!可以正式开始介绍了。

(1)等价关系与同余

        当我们讨论整数集合上的等价关系时,“同余”是一个核心概念,而由同余关系定义的“同余类”或“剩余类”则是研究整数除法性质和模运算的基本单元。

        首先,我们需要了解什么是等价关系。在数学中,如果集合 𝐴 上的关系 ∼ 满足以下三个性质,则称 ∼ 是 𝐴 上的等价关系

  1. 自反性:对于所有 𝑎∈𝐴,有 𝑎∼𝑎
  2. 对称性:对于所有 𝑎,𝑏∈𝐴,若 𝑎∼𝑏 则 𝑏∼𝑎
  3. 传递性:对于所有 𝑎,𝑏,𝑐∈𝐴,若 𝑎∼𝑏 且 𝑏∼𝑐,则 𝑎∼𝑐

        同余关系就是整数集 𝑍 上的一种等价关系。两个整数 𝑎 和 𝑏 被称为模 𝑛 同余,如果它们被 𝑛 除后的余数相同,记作 𝑎≡𝑏 (mod 𝑛)。换句话说就是,𝑎 和 𝑏 同余模 𝑛 当且仅当 𝑛 整除 𝑎−𝑏。

(2)同余类又叫剩余类

        既然同余关系是一种等价关系,那么它自然会将整数集 𝑍 划分成不同的等价类,这些等价类就是我们所说的同余类或剩余类。给定一个正整数 𝑛,对于 𝑍 中的任意整数 𝑎,我们可以构造模 𝑛 下的同余类,记作 [𝑎]𝑛 或者简单地写作 [𝑎],其中包含所有与 𝑎 同余模 𝑛 的整数。

形式上,同余类 [𝑎] 定义为:

[𝑎]={𝑏∈𝑍∣𝑎≡𝑏 (mod 𝑛)}

        例如,考虑模 7 同余关系见下图

【我的理解】模7的剩余类[1],意思就是有哪些数除7余1,将这些数组成一个集合,记为[1]_7。所以“模7的同余类”其实可以理解为除7有共同余数的七堆数(余0余1一直到余6共七堆数)。

(3)剩余系

        在模 𝑛 同余意义下,所有可能的同余类构成了一个剩余系。更具体地说,模 𝑛 的完全剩余系是一组整数,每个整数代表了不同的同余类。最常见的是取模 𝑛 的完全剩余系为 {0,1,2,…,𝑛−1}。这个剩余系包含了所有可能的余数,即模 𝑛 同余类的代表元素。

还是拿上图,模7来举例:

        我们从七堆数里面,每堆抽出一个,合为一组。就叫做一组完全剩余系。若在每一堆数里面抽出一个数,不是随机抽,而是选出最小非负的,构成的剩余系被叫做最小非负完全剩余系。

二、完全剩余系

        上面我们见过了完全剩余系长什么样子,现在我们给完全剩余系一个严谨的数学定义:

        在整数模m的所有剩余类中各取一个代表元

a_1,a_2,...,a_m(a_i \in[i-1],i=1,2,...,m)

        则称a_1,a_2,...,a_m为模m的完全剩余系,其中完全剩余系0,1,2,...,m-1被称为最小非负完全剩余系。

        用\mathbb{Z} _m表示由m的最小非负完全剩余系集合,\mathbb{Z} _m =\{ 0,1,2...,m-1 \},在\mathbb{Z} _m中的加法、减法、乘法都是模m意义下的运算。

三、简化剩余系

        在模m的一个剩余类当中,如果有一个数与m互素,则该剩余类中所有的数均与m互素,这是称该剩余类与m互素。

(1)欧拉函数的数学定义

        与m互素的剩余类的个数称为欧拉函数,记为\varphi(m)\varphi(m)等于\mathbb{Z}_m当中与m互素的数的个数,对于任意一个素数p,有\varphi (p)=p-1

(2)简化剩余系的数学定义

        在与m互素的\varphi(m)个模m的剩余类中各取一个代表元a_1,a_2,...,a_{\varphi (m)}它们组合成的集合称为模m的一个简化剩余系。\mathbb{Z}_m中与m互素的数构成模m的一个简化剩余系,称为最小非负简化剩余系。

        举例说明简化剩余系:

        设m=12,则 {0,1,2,3,4,5,6,7,8,9,10,11} 构成模12的完全剩余系,把其中与12互素选出来,即 {1,5,7,11} 构成模12的简化剩余系。

        再来一个例子加深理解,设m=6:

        模 6 的完整剩余系:可以是 {0,1,2,3,4,5} 或者 {−2,−1,0,1,2,3} 等。

        模 6 的简化剩余系:可以是 {1,5} 或者 {−1,5} 等,因为只有 1 和 5 与 6 互素。若指定最小非负简化剩余系,则为 {1,5}

        简化剩余系和欧拉函数是RSA算法(最广泛使用的公钥加密算法)中用于选择加解和解密指数的基础, RSA算法的公钥和私钥生成都依赖于简化剩余系的性质。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/800525.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

linux基本指令的学习

文章目录 ls指令pwd指令小知识 cd 指令小知识 touch 指令mkdir指令rm指令小知识 man指令cp指令mv指令cat,more,less指令小知识 (echo)head 和 tail指令小知识 (管道) date指令小知识 (时间戳) find指令小知…

STM32(五):STM32指南者-按键控制灯开关实验

说明:源代码和教程可从野火处下载,本博客为了记录学习过程STM32(四):STM32指南者-跑马灯实验的基础上 一、采用轮询方式1、bsp_key.h2、bsp_key.c3、main.c 二、采用中断方式1、bsp_exti.h2、bsp_exti.c3、stm32f10x_i…

ARM架构(一)—— ARMV8V9基础概念

目录 1.ARMCore的时间线2.ARM术语小结2.1 A64和arrch642.2ARM架构现在的5个系列2.3 微架构2.4 PE2.5 Banked2.6 ARM文档术语2.7 IMPLEMENTATION DEFINFD 和 DEPRECATED2.8 EL1t和EL1h 3 ARMv7的软件架构4 安全状态切换模型4.1 Secure state和Non-secure state介绍 5 Interproce…

鸿蒙模拟器(HarmonyOS Emulator)Beta申请审核流程

文 | Promise Sun 一.背景: 鸿蒙项目开发需要使用模拟器进行开发测试,但目前想在DevEco Studio开发工具中使用模拟器就必须到华为官网进行报名申请,参加“鸿蒙模拟器(HarmonyOS Emulator)Beta活动申请”。 申请审核通…

cleanshot Mac 上的截图工具

笔者闲来无事,最近在找一些mac上好用的工具其中一款就是cleanShot。为什么不用原有的mac自带的呢。因为相对来说编辑功能不算全面,不支持长截图。那有没有一款软件支持关于截图的好用工具呢。 所以笔者找了这款。安装包是直接安装就可使用的。请大家点赞…

AI算法17-贝叶斯岭回归算法Bayesian Ridge Regression | BRR

贝叶斯岭回归算法简介 贝叶斯岭回归(Bayesian Ridge Regression)是一种回归分析方法,它结合了岭回归(Ridge Regression)的正则化特性和贝叶斯统计的推断能力。这种方法在处理具有大量特征的数据集时特别有用&#xff…

STM32第九课:STM32-基于标准库的42步进电机的简单I/O控制(附电机教程,看到即赚到)

一:步进电机简介 步进电机又称为脉冲电机,简而言之,就是一步一步前进的电机。基于最基本的电磁铁原理,它是一种可以自由回转的电磁铁,其动作原理是依靠气隙磁导的变化来产生电磁转矩,步进电机的角位移量与输入的脉冲个数严格成正比…

4000厂商默认账号密码、默认登录凭证汇总.pdf

获取方式: 链接:https://pan.baidu.com/s/1F8ho42HTQhebKURWWVW1BQ?pwdy2u5 提取码:y2u5

Linux编程乐趣《简单、有趣、好玩的Linux命令》

文章目录 一、黑客帝国(cmatrix)1.1 centOS 手动安装:1.2 . 运行1.3 . 效果 二、cal命令三、htop四、sl:蒸汽火车五、cowsay:会说话的小牛六、boxes七、pv 一、黑客帝国(cmatrix) 1.1 centOS 手动安装: #…

2024.7.12单片机PWM

遇到了一个光标变成下划线的问题: Keil5光标变下划线,变回来的方法_keil5光标是下划线-CSDN博客 这里是用了输入捕获(IC:input capture),输出比较(OC:Output Compare)区别 学到这…

加速访问:优秀的Python、Java、Javascript和Linux镜像站点推荐

前言 当访问位于国外的官方网站时,常常会面临到网速缓慢或者无法访问的问题,这不仅令人沮丧,也影响了工作效率。为了解决这些问题,我开始寻找并使用一些镜像站点,特别是在Python、Java、Javascript和Linux等领域。 这…

3DMAX造山地形插件Mountain使用方法详解

3DMAX造山地形插件Mountain使用教程 3DMAX造山地形插件Mountain,用于在3dMax中轻松快速地创建逼真的山脉地形。它具有交互性、快速性和易用性,初学者只需点击一下即可,高级用户可以使用各种丰富的参数。Mountain创建简单的3dMax几何体&#x…

C++ //练习 15.17 尝试定义一个Disc_quote的对象,看看编译器给出的错误信息是什么?

C Primer(第5版) 练习 15.17 练习 15.17 尝试定义一个Disc_quote的对象,看看编译器给出的错误信息是什么? 环境:Linux Ubuntu(云服务器) 工具:vim 代码块 /********************…

Python机器学习、深度学习技术提升气象、海洋、水文领域实践技术

Python是功能强大、免费、开源,实现面向对象的编程语言,能够在不同操作系统和平台使用,简洁的语法和解释性语言使其成为理想的脚本语言。除了标准库,还有丰富的第三方库,Python在数据处理、科学计算、数学建模、数据挖…

STM32+TMC2209控制步进电机正反转。

STM32F103ZET6TMC2209控制步进电机正反转 1. 步进电机介绍2 驱动器TMC2209介绍2.1 引脚图及其功能2.2 细分介绍2.3 TMC控制驱动器接法 3 控制器介绍3.1 确定控制引脚3.2 UBEMX配置3.2.1 GPIO配置3.2.2 NVIC配置3.2.3 RCC配置3.2.4 SYS配置3.2.5 USRAT2配置(PS:没用上…

《Programming from the Ground Up》阅读笔记:p49-p74

《Programming from the Ground Up》学习第3天,p49-p74总结,总计26页。 一、技术总结 1.function (1)定义 p49, Functions are unit of code that do a defined piece of work on specified types of data。 函数是在指定类型的数据上完成所定义的某…

实验二:图像灰度修正

目录 一、实验目的 二、实验原理 三、实验内容 四、源程序和结果 源程序(python): 结果: 五、结果分析 一、实验目的 掌握常用的图像灰度级修正方法,包括图象的线性和非线性灰度点运算和直方图均衡化法,加深对灰度直方图的理解。掌握对比度增强、直方图增强的原理,…

数据库启动报ORA-600 6711故障分析处理---惜分飞

几个月以前的一个数据库故障,今天拿出来在win上重新分析,数据库启动报ORA-600 6711错 C:\Users\XFF>SQLPLUS / AS SYSDBA SQL*Plus: Release 12.1.0.2.0 Production on 星期日 7月 14 16:17:32 2024 Copyright (c) 1982, 2014, Oracle. All rights reserved. 已连接到空…

发那科机床切换程序号

此需求一般出现在要通过发那科机床做自动化单元的情况。通过发那科SDK给发那科寄存器指令,进而实现,机床自动程序号切换。 一、更改3006参数:开启工件号检索功能 二、更改G24的值(0-9999) G24为需要切换的程序号。 三、…