首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

TEA中的sum常数是如何计算的

TEA(Tiny Encryption Algorithm,小加密算法)是一种对称密钥加密算法,主要用于简单的数据加密。TEA算法中的sum常数是一个固定的值,用于在加密和解密过程中增加混淆和扩散。

TEA算法中的sum常数是通过以下公式计算的:

代码语言:javascript
复制
sum = 0xC6EF3720

这个值是一个固定的常数,用于在加密和解密过程中的循环中作为累加器。在每次循环中,sum会与密钥的一部分进行异或操作,并与明文或密文进行一系列的加法和移位操作。

TEA算法的核心部分如下:

代码语言:javascript
复制
void tea_encrypt(uint32_t *v, uint32_t *k) {
    uint32_t v0 = v[0], v1 = v[1], sum = 0, i;
    uint32_t delta = 0x9E3779B9;
    uint32_t k0 = k[0], k1 = k[1], k2 = k[2], k3 = k[3];

    for (i = 0; i < 32; i++) {
        sum += delta;
        v0 += ((v1 << 4) + k0) ^ (v1 + sum) ^ ((v1 >> 5) + k1);
        v1 += ((v0 << 4) + k2) ^ (v0 + sum) ^ ((v0 >> 5) + k3);
    }

    v[0] = v0;
    v[1] = v1;
}

void tea_decrypt(uint32_t *v, uint32_t *k) {
    uint32_t v0 = v[0], v1 = v[1], sum = 0xC6EF3720, i;
    uint32_t delta = 0x9E3779B9;
    uint32_t k0 = k[0], k1 = k[1], k2 = k[2], k3 = k[3];

    for (i = 0; i < 32; i++) {
        v1 -= ((v0 << 4) + k2) ^ (v0 + sum) ^ ((v0 >> 5) + k3);
        v0 -= ((v1 << 4) + k0) ^ (v1 + sum) ^ ((v1 >> 5) + k1);
        sum -= delta;
    }

    v[0] = v0;
    v[1] = v1;
}

在这个算法中,sum常数的初始值为0xC6EF3720,这个值是根据TEA算法的设计者选择的,以确保加密和解密过程的安全性和正确性。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

梯度是如何计算的

引言 深度学习模型的训练本质上是一个优化问题,而常采用的优化算法是梯度下降法(SGD)。对于SGD算法,最重要的就是如何计算梯度。...如果你学过微积分,我相信你一定知道如何计算梯度,或者说计算导数。对于深度网络来说,其可以看成多层非线性函数的堆积,即: ?...如果大家细致观察的话,可以看到要求出最终的导数,你需要计算出中间结果:p与q。计算中间结果的过程一般是前向(forward)过程,然后再反向(backward)计算出最终的导数。...比如你要计算dW,你知道要用dD与X两个矩阵相乘就可以得到。W的shape是[5,10],而dD的shape是[5,3],X的shape是[10,3]。...,就是如何计算梯度。

2.6K70

TEA算法的使用及逆向中的识别技巧

TEA 分组加密算法 TEA TEA是Tiny Encryption Aigorithm 的缩写,以加密解密速度快,实现简单著称。...TEA系列算法中均使用了一个DELTA常敌,但DELTA的值对算法并无什么影响,只是为了避免不良的取值,推荐DELTA的值取为黄金分割数(5V-2)/2与232的乘积,取整后的十六进制值为0x9e3779B9...Block TEA 算法可以对32位的任意整数倍长度的变量块进行加解密的操作,该算法将XTEA轮循函数依次应用干块中的每个字,井且将它附加于被应用字的邻字。...只要会处理 TEA,XTEA和XXTEA也是同理 代码案例及原理(个人小结) TEA算法是一种分组加密算法,它的实现非常简单,通常只需要很精短的几行代码。...识别该算法的关键点应该在于,第一是加密循环次数一般为32次,其次识别delta中的压缩常数,该常数由黄金分割点得到。

9210
  • 双金属中心化合物的磁交换耦合常数的计算

    由上式可知,要计算磁交换耦合常数,需要计算体系的高自旋态和对称破缺态。 本文介绍如何用ORCA来计算耦合常数。...在ORCA中,可以在一次任务中完成两个计算,并且程序会自动给出耦合常数的数值;而使用Gaussian时,则需要手动计算两个态。...(II)配合物为例,展示如何用ORCA计算磁交换耦合常数,所用版本为ORCA 5.0.3。...需要说明的是,ORCA中的这个功能只对波函数优化一次,并不保证能得到稳定的波函数,而Gaussian中的stable=opt则会反复优化波函数直至稳定。...需要注意的是,由于ORCA 5.0版本开始,在SCF计算中默认开启RIJCOSX,且B3LYP泛函在Gaussian和ORCA中的实现不完全相同,因此结果会有微小差别。

    2.1K10

    计算机是如何启动的?

    它的主要作用是,告诉计算机到硬盘的哪一个位置去找操作系统。 主引导记录由三个部分组成: ? 其中,第二部分"分区表"的作用,是将硬盘分成若干个区。 2.2 分区表 硬盘分区有很多好处。...三、第三阶段:硬盘启动 这时,计算机的控制权就要转交给硬盘的某个分区了,这里又分成三种情况。 3.1 情况A:卷引导记录 上一节提到,四个主分区里面,只有一个是激活的。...计算机会读取激活分区的第一个扇区,叫做"卷引导记录"(Volume boot record,缩写为VBR)。 "卷引导记录"的主要作用是,告诉计算机,操作系统在这个分区里的位置。...Linux环境中,目前最流行的启动管理器是Grub。 ? 四、第四阶段:操作系统 控制权转交给操作系统后,操作系统的内核首先被载入内存。 以Linux系统为例,先载入/boot目录下面的kernel。...不过对于这种不是自己文章也标原创的人我是特别、非常反感的,写过文章的都知道写一篇文章是需要花很多时间的,申请转载就已经很不错了,还把文章搞成是自己写的,而且观察了下他的公众号,好多文章都是截图别人的文章以图片的形式发的

    91620

    计算机是如何工作的

    计算机最早是运用于军事的 埃尼阿克-第一台计算机,194x ,冯诺依曼大佬参与研发,用来计算导弹轨迹 后来冯大佬带队,开发“通用计算机”。...寄存器空间太小,往往只是几 kb 是,因此 CPU 在计算的时候就需要反复地从内存加载数据,效率比较有影响(内存读的速度相对寄存器来说就是弟弟,拖后腿了)。...位机器的指令可以有 64 位) RAM 是随机存取存储器(Random Access Memory),也叫内存 CPU 寄存器很少,所以每个都有专门的名字(表中的是虚构的) 8 bit 的指令分为两部分...A 指令:把后面四位 1110(换成十进制是 14)操作数这个地址的数据,读取到寄存器 A 中 执行指令 把 14 地址的内存数据读取出来,放到寄存器 A 中 第一条语句执行完毕,程序计数器中的值自动被系统...比如:发现某几个逻辑是控制掉血的,也是就可以写另一个程序,动态修改掉游戏程序对应内存空间里的指令,变成中弹不掉血 现在写外挂的主要难度不在于分析指令,而是在于如何绕过游戏公司的“反外挂机制”(腾讯TP)

    9510

    计算机是如何启动的?

    从打开电源到开始操作,计算机的启动是一个非常复杂的过程。 我一直搞不清楚,这个过程到底是怎么回事,只看见屏幕快速滚动各种提示...... 这几天,我查了一些资料,试图搞懂它。下面就是我整理的笔记。...最早的时候,工程师们用它来比喻,计算机启动是一个很矛盾的过程:必须先运行程序,然后计算机才能启动,但是计算机不启动就无法运行程序!...如果这512个字节的最后两个字节是0x55和0xAA,表明这个设备可以用于启动;如果不是,表明设备不能用于启动,控制权于是被转交给"启动顺序"中的下一个设备。...如果想使用更大的硬盘,只有2个方法:一是提高每个扇区的字节数,二是增加扇区总数。 三、第三阶段:硬盘启动 这时,计算机的控制权就要转交给硬盘的某个分区了,这里又分成三种情况。...Linux环境中,目前最流行的启动管理器是Grub。 四、第四阶段:操作系统 控制权转交给操作系统后,操作系统的内核首先被载入内存。 以Linux系统为例,先载入/boot目录下面的kernel。

    98650

    2021-2-17:Java HashMap 的中 key 的哈希值是如何计算的,为何这么计算?

    首先,我们知道 HashMap 的底层实现是开放地址法 + 链地址法的方式来实现。 ? 即数组 + 链表的实现方式,通过计算哈希值,找到数组对应的位置,如果已存在元素,就加到这个位置的链表上。...这个数组大小一定是 2 的 n 次方,因为找到数组对应的位置需要通过取余计算,取余计算是一个很耗费性能的计算,而对 2 的 n 次方取余就是对 2 的 n 次方减一取与运算。...所以保持数组大小为 2 的 n 次方,这样就可以保证计算位置高效。 那么这个哈希值究竟是怎么计算的呢?假设就是用 Key 的哈希值直接计算。...其实 key1 和 key2 的高位是不一样的。...由于数组是从小到达扩容的,为了优化高位被忽略这个问题,HashMap 源码中对于计算哈希值做了优化,采用高位16位组成的数字与源哈希值取异或而生成的哈希值作为用来计算 HashMap 的数组位置的哈希值

    1.2K20

    计算属性是如何被Vue实现的

    写在前边 无论是面试过程还是日常业务开发,相信大多数前端开发者对于 Vue 的应用已经熟能生巧了。 今天我们就来聊聊 Vue 中的 Computed 是如何被实现的。...文章会告别枯燥的源码,从用法到原理层层拨丝与你一起来看看在 Vue 中 Computed 是如何被实现的。 前置知识 首先,文章中的源码思路是基于最新稳定的 Vue@3.2.37 版本进行解读的。...上述的属性就是一个 Computed 中我们需要关心的属性,大概了解了各个属性代表的含义接下来就让我们一起来看看 computed 是如何被 Vue 实现的。...Effect 我已经在前置文章 Vue3中的响应式是如何被JavaScript实现的 中介绍过它的实现,有兴趣深入了解的同学可以移步查阅。 同理,当我们首次访问该计算属性时。...我们围绕上述的功能来分析源代码中是如何实现的: 首先在 getter 中我们遗失的逻辑: // #3376 在 Vue 3.0.7 前在 readonly() 中包装 computed() 会破坏计算的功能

    82630

    浮点数在计算机中是如何表示的

    在计算机中,一般用IEEE浮点近似表示任意一个实数,那么它实际上又是如何表示的呢? 下面的表达式里,i的值是多少,为什么?如果你不确定答案,那么你应该好好看看本文。...它得到值为 +∞(s=0)或-∞(s=1),它在计算机中可以表示溢出的结果,例如两个非常大的数相乘。 阶码全为1,小数域不全为0。它得到值为NaN(Note a Number)。...它在计算机中可以表示非法的数,例如计算根号-1时的值。...那么浮点数的数值范围和有效位是如何得到的呢? 浮点数的数值范围计算 有了前面了基础,我们就可以来计算浮点数的数值范围了。...浮点数在内存中的存储 了解了这么多,我们来看一下一个小数究竟是如何在内存中存储的。以float f = 8.5f为例。其二进制表示为 ?

    1.9K10

    计算机是如何存储数据的?

    那么我们怎样将其转化为二进制存储到计算机中,这个过程我们称之为编码。更广义地讲,就是把信息从一种形式转化为另一种形式的过程。...扩展ASCII码 在美国,这 128 是够了,但是其他国家不答应啊,他们的字符和英文是有出入的,比如在法语中在字母上有注音符号,如 é,这个怎么表示成二进制?...但是不管怎样,所有这些编码方式中,0--127 表示的符号是一样的,不一样的只是 128--255 的这一段。不同的国家有不同的字符集,所以它并不是国际标准。...下面,还是以汉字“严”为例,演示如何实现 UTF-8 编码。...总结 搞清楚了 ASCII、Unicode 和 UTF-8 的关系,我们就可以总结一下现在计算机系统通用的字符编码工作方式: 在计算机内存中,统一使用 Unicode 编码,当需要保存到硬盘或者需要传输的时候

    2.4K41

    程序在计算机中是如何运行起来的(一)

    来讲讲程序在计算机中是如何运行起来的计算机系统概述计算机系统的组成硬件与软件的关系操作系统的基本功能程序的编写程序设计语言概述从高级语言到机器码的转化编译器与解释器的作用程序的存储与加载存储器的层次结构程序的存储方式可执行文件的格式程序加载器的作用程序的执行...Docker的使用虚拟化对程序运行的影响未来趋势与发展云计算与边缘计算人工智能与自动化程序生成新型计算架构(量子计算、生物计算)编程语言与开发工具的发展趋势计算机系统概述计算机系统是一个由硬件和软件组成的复杂体系...为了理解程序如何运行,首先需要了解计算机系统的基本组成、硬件与软件之间的关系,以及操作系统在其中扮演的关键角色。...编码规范:编码规范是关于如何编写代码的标准和指南,通常包括命名规则、注释风格、代码格式等。良好的编码规范能够提高代码的可读性,使不同开发者之间的协作更加顺畅。...在计算机系统中,程序的存储与加载是一个非常关键的环节,它不仅决定了程序如何被存储在不同层次的存储器中,还涉及到程序从存储设备被加载到内存中以供CPU执行的整个过程。

    2.4K31

    Linux系统平均负载是如何计算的?

    大家好,又见面了,我是你们的朋友全栈君。 关于负载的计算,它的结果是包含有小数的一个浮点数,内核中是不能使用float变量的,那么这里就采用了一个整型变量的低11位来表示小数部分。...,后面就开始真正的主题,对于平均负载,它是如何计算的呢?...这样计算有一个缺点,就是我们获取到的负载值实际上并不能反应当下系统中的负载情况,因为它计算了从系统启动开始以来的平均值,无法反应当下系统的运行情况,因此系统中实际并不是这样计算的,会求最近1min,5min...和15min之内的平均值,那么计算方法是怎样的呢?...,反复如此计算下去,那么很久远的采样数据就在当前的计算结果中无限趋近于0了。

    2.3K20

    计算机是如何实现加法的

    二、一位二进制的加法 先来看一下只有一位的二进制数的加法是如何实现。一位的加法结果,如下表所示: 0 1 0 00 01 1 01 11 我们把结果分为个位和十位两个部分来看一下。...所以要实现多位的加法需要先实现进位相加。 先来看一下带进位的加和输出是如何得到的,处理方式和我们平时计算是一样的:: 现在有输入A,B和进位输入C0 对输入A和B计算得到加和输出S1和近位输出C1。...和我们小学时学的计算一毛一样 再来看一下进位输出如何计算的: 我们知道,对于A、B和C0三个输入最大就是三个都为1和为11的情况,所以最多也就产生一个为1的进位。...那现在就很明了,这进位要么在计算A加B是产生(A和B都是1)要么在加进位是产生(A和B其中只有一个为1,进位输入为1),所以只要将两次加和的进位输出做一次或运算,就取得了进位输出。...但其实对于上一位的进位输出是可以根据输入自己去计算得到的,即某一位An可以利用前面几位A1、A2、...、An-1计算得到不必等待,虽然这样使计算更多了但实际的速度确是提升的。

    2.8K10

    计算ip地址的有效范围是_ip地址如何计算

    :255.255.254.0 网关:192.168.9.1 1:IP地址 = 网络地址 + 主机地址,二进制为: 11000000 10101000 00001001 00000011 2:子网掩码的二进制表示为...: 11111111 11111111 11111110 00000000 解析:前面1的就是网络地址部分,后面0就是主机地址,所以此处有9位主机地址。...3:网络地址 = 子网掩码 & IP地址,即:192.168.8.0 4:广播地址 = 3中求出的网络地址的主机地址部分置1,即:192.168.9.255 5:有效的IP段计算: 开始地址 = 网络地址...+1,即192.168.8.1 结束地址 = 广播地址-1,即192.168.9.254 那么当前示例的有效IP段为:192.168.8.1~192.168.9.254 版权声明:本文内容由互联网用户自发贡献...如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。 ..

    3.8K10

    Java中的注解是如何工作的?

    这篇文章中,我将向大家讲述到底什么是注解,为什么要引入注解,注解是如何工作的,如何编写自定义的注解(通过例子),什么情况下可以使用注解以及最新注解和ADF(应用开发框架)。...事实上,@Override告诉编译器这个方法是一个重写方法(描述方法的元数据),如果父类中不存在该方法,编译器便会报错,提示该方法没有重写父类中的方法。...我们来看两个例子:一个是标准的注解@Override,另一个是用户自定义注解@Todo。 ? 对于@Override注释你可能有些疑问,它什么都没做,那它是如何检查在父类中有一个同名的函数呢。...因此,我们讲解一下如何编写自定义的Annotations。 我们来逐个讲述编写自定义Annotations的要点。上面的例子中,你看到一些注解应用在注解上。...信息 @Inherited – 定义该注释和子类的关系 那么,注解的内部到底是如何定义的呢?

    1.5K30

    Java中的Lambda是如何实现的

    在上面的字节码中,我们可以看到一个名为 lambdamain0 的方法,该方法是在编译阶段自动生成的,其对应于示例源码中的lambda方法体。...在main方法的字节码中,invokedynamic是整个lambda实现的关键,不过由于该字节码在JVM中的实现逻辑非常复杂,在这里我们就不看具体代码了,只说下大致思路。...那这个对象对应的类是哪里来的呢?对,也是动态生成的。...依据上面的示例,我们再来总结下lambda是如何实现的: 在编译阶段,javac会自动生成一个lambdamain0方法,该方法对应了lambda的方法体。...在Test$Lambda1类中的accept方法中,其直接调用了编译阶段生成的Test.lambdamain0方法,传入参数变量为arg Test.lambdamain0方法最终执行了lambda的方法体代码

    1.1K30

    Java中的注解是如何工作的?

    这篇文章中,我将向大家讲述到底什么是注解,为什么要引入注解,注解是如何工作的,如何编写自定义的注解(通过例子),什么情况下可以使用注解以及最新注解和ADF(应用开发框架)。...事实上,@Override告诉编译器这个方法是一个重写方法(描述方法的元数据),如果父类中不存在该方法,编译器便会报错,提示该方法没有重写父类中的方法。...因此,我们讲解一下如何编写自定义的Annotations。 我们来逐个讲述编写自定义Annotations的要点。上面的例子中,你看到一些注解应用在注解上。...信息 @Inherited – 定义该注释和子类的关系 那么,注解的内部到底是如何定义的呢?...在最新的servlet3.0中引入了很多新的注解,尤其是和servlet安全相关的注解。

    1.7K21

    Tomcat中的WebSocket是如何实现的?

    Tomcat中的WebSocket是如何实现的?...WebSocket是一种在客户端和服务器之间提供长期、双向、实时通信的协议全双工通信:WebSocket允许数据同时在客户端和服务器双向通信,无需像HTTP等待请求和响应的循环单个TCP连接:建立一次连接后...Session是WebSocket中的,而不是servlet规范的配置的端口为8080,context path为/caicaiserver: port: 8080 servlet: context-path...方法@Overridepublic void afterSingletonsInstantiated() { registerEndpoints();}也就是单例Bean实例化之后执行,会扫描容器中的...WebSocket处理类对应的方法进行调用(不会打到Container容器) 图片总结WebSocket是一种长期、双向、实时通信的协议,基于HTTP协议后升级为WebSocket协议Tomcat在处理

    33421
    领券