快要过去的一个学期里,学了编译原理,课程大作业写简易C编译器。
能实现加减乘除四则运算,取模赋值运算,逻辑表达式运算,复合语句,if,while,for语句~支持输入输出,最终生成汇编语言代码。
移位运算没写。
调试过了,如有好建议请大家赐教。
1
FXdiv仅标头库,用于通过定点乘以逆除法在现代CPU和GPU上,整数除法比乘法要慢几倍。
FXdiv实现了一种算法,用乘法和两次移位替换整数除法。
当应用程序执行相同除数的重复除法时,此算法可提高性能。
产品特点uint32_t,uint64_t和size_t整数除法仅标头的库,无需安装或构建与C99,C++,OpenCL和CUDA兼容使用特定于平台的编译器内部函数以获得最佳性能包含单元测试和微基准测试例#include/*Divisionofarraybyaconstant:referenceimplementation*/voiddivide_array_c(size_tlength,uint32_tarray[],uint32_tdivisor){for(size_ti=0;i<length;i++){array[i]/=divisor;}}/*Divisionofarraybyaconstant:implementati
1
动态演示两个序列进行圆周卷积x1(n)⊙x2(n)的过程,要求动态演示翻转、移位、乘积、求和的过程;
圆周卷积默认使用两个序列中的最大长度,但卷积前可以指定卷积长度N用以进行混叠分析;
2025/8/14 17:49:43 35KB 卷积
1
AES加密,全称为AdvancedEncryptionStandard,是目前广泛应用于数据加密的标准算法之一,特别是在软件开发领域。
C++是一种通用的编程语言,拥有强大的性能和灵活性,因此在实现AES加密时非常适用。
本文将深入探讨AES加密的基本原理以及如何在C++中实现AES加密。
AES是一种分组密码,它将明文数据分成128位的数据块进行处理。
加密过程分为多个步骤,包括字节替代(SubBytes)、行移位(ShiftRows)、列混淆(MixColumns)和轮密钥加(AddRoundKey)。
这些步骤在10轮(对于128位密钥)或14轮(对于256位密钥)中重复执行,以确保数据的安全性。
密钥扩展也是一项关键操作,它将原始密钥扩展为足够多的轮密钥,用于每一轮的加密。
在C++中实现AES加密,首先需要理解并实现上述的加密步骤。
`aes.cpp`和`aes.h`两个文件通常包含了AES加密的函数定义和类声明。
`aes.cpp`是实现文件,包含具体的函数实现,而`aes.h`是头文件,定义了相关的类和函数接口,方便其他模块调用。
在`aes.cpp`中,可能会有一个名为`AES`的类,其中包含如`encrypt`和`decrypt`这样的成员函数,分别用于加密和解密。
这些函数可能接收一个128位的明文块和一个密钥作为输入,然后返回对应的密文块。
类内部可能还会有其他辅助函数,如进行字节替代、行移位和列混淆的函数。
`aes.h`文件则会包含`AES`类的声明,以及必要的公有成员函数和常量定义。
例如:```cppclassAES{public:AES(constunsignedchar*key,intkeySize);//初始化AES对象,设置密钥voidencrypt(unsignedchar*plaintext,unsignedchar*ciphertext);//加密函数voiddecrypt(unsignedchar*ciphertext,unsignedchar*plaintext);//解密函数private://其他私有成员变量和函数,如密钥扩展、字节操作等};```在实际使用时,开发者可以通过实例化`AES`类,并调用其`encrypt`或`decrypt`方法对数据进行加密和解密操作。
例如:```cppAESaes(key,16);//假设key是16字节的密钥unsignedcharplaintext[16],ciphertext[16];//...填充plaintext...aes.encrypt(plaintext,ciphertext);//...使用ciphertext...aes.decrypt(ciphertext,plaintext);//...plaintext恢复为原文...```AES加密在C++中的实现涉及到对加密流程的精确控制和内存操作,同时还需要注意效率和安全性。
通过`aes.cpp`和`aes.h`这两个文件,我们可以构建一个完整的AES加密库,方便在各种C++项目中集成和使用。
2025/8/12 9:24:26 17KB AES,C++
1
《数字电子技术基础:系统方法》是世界著名优秀教材,结合数字电子技术的发展趋势,从数字电子技术系统性的角度,对数字技术和数字系统内容进行重新组织,系统阐述数字电子技术的基础知识。
主要内容包括:数字电子技术的基本概念、组合逻辑、锁存器、触发器、定时器、计数器、移位寄存器、数据传输、信号处理等。
本版本对旧版本进行优化处理,颜色更为清晰,完整版压缩,解压即可学习。
2025/7/15 18:54:19 109.95MB 电子技术
1
采集到加速度变化信号并进行滤波使其信号波形改善,系统持续更新3轴加速度的最大最小值,每采样50次更新一次,并取出“动态阈值”接下来的50次采样利用此阈值判断个体是否迈出步伐,由于此阈值每50次采样更新一次,因此它是动态的。
这种选择具有自适应性,且足够快,除了动态阈值外,还利用动态精度来执行进一步的滤波。
利用移位寄存器和动态阈值判断个体是否有效地迈出一步。
2025/7/13 9:07:22 103KB 计步器 算法代码 流程架构
1
CH452是数码管显示驱动和键盘扫描控制芯片。
CH452内置时钟振荡电路,可以动态驱动8位数码管或者64位LED,具有BCD译码、闪烁、移位、段位寻址、光柱译码等功能;
同时还可以进行64键的键盘扫描;
CH452通过可以级联的4线串行接口或者2线串行接口与单片机等交换数据;
并且可以对单片机提供上电复位信号。
2025/7/12 6:23:44 809KB CH452 驱动程序 说明书
1
本教材介绍了五个方面的内容:MOS器件基本原理以及主要的特性,VLSI中逻辑结构的主要设计方法,用于VLSI系统的模拟集成单元设计方法,VLSI的测试问题与相关技术,VLSI设计系统及其组成。
涉及了五个方面的基础知识:MOS器件基础知识,半导体工艺基础知识,集成电路版图基础知识,逻辑、电路设计基础知识和CAD基础知识。
《VLSI设计基础》作为VLSI设计基础教材,注重相关理论的结论和知识的应用。
可作为本科生教材和研究生参考书。
第1章VLSI设计基础概述1.1VLSI设计技术基础与主流制造技术1.2VLSI设计方法与设计技术1.3新技术对VLSI的贡献1.4ASIC和VLSI1.5SOC1.6VLSI的版图结构和设计技术1.6.1VLSI的版图总体结构1.6.2VLSI版图的内部结构第2章MOS器件与工艺基础2.1MOS晶体管基础2.1.1MOS晶体管结构及基本工作原理2.1.2MOS晶体管的阈值电压VT2.1.3MOS晶体管的电流-电压方程2.1.4MOS晶体管的平方律转移特性2.1.5MOS晶体管的跨导gm2.1.6MOS晶体管的直流导通电阻2.1.7MOS晶体管的交流电阻2.1.8MOS晶体管的最高工作频率2.1.9MOS晶体管的衬底偏置效应2.1.10CMOS结构2.2CMOS逻辑部件2.2.1CMOS倒相器设计2.2.2CMOS与非门和或非门的结构及其等效倒相器设计方法2.2.3其他CMOS逻辑门2.2.4D触发器2.2.5内部信号的分布式驱动结构2.3MOS集成电路工艺基础2.3.1基本的集成电路加工工艺2.3.2CMOS工艺的主要流程2.3.3Bi-CMOS工艺技术第3章工艺与设计接口3.1工艺对设计的制约与工艺抽象3.1.1工艺对设计的制约3.1.2工艺抽象3.2设计规则3.2.1几何设计规则3.2.2电学设计规则3.2.3设计规则在VLSI设计中的应用第4章晶体管规则阵列设计技术4.1晶体管阵列及其逻辑设计应用4.1.1全NMOS结构ROM4.1.2ROM版图4.2MOS晶体管开关逻辑4.2.1开关逻辑4.2.2棒状图4.3PLA及其拓展结构4.3.1“与非-与非”阵列结构4.3.2“或非-或非”阵列结构4.3.3多级门阵列(MGA)4.4门阵列4.4.1门阵列单元4.4.2整体结构设计准则4.4.3门阵列在VLSI设计中的应用形式4.5晶体管规则阵列设计技术应用第5章单元库设计技术5.1单元库概念5.2标准单元设计技术5.2.1标准单元描述5.2.2标准单元库设计5.2.3输入、输出单元(I/OPAD)5.3积木块设计技术5.4单元库技术的拓展第6章微处理器6.1系统结构概述6.2微处理器单元设计6.2.1控制器单元6.2.2算术逻辑单元(ALU)6.2.3乘法器6.2.4移位器6.2.5寄存器6.2.6堆栈6.3存储器组织6.3.1存储器组织结构6.3.2行译码器结构6.3.3列选择电路结构第7章测试技术和可测试性设计7.1VLSI可测试性的重要性7.2测试基础7.2.1内部节点测试方法的测试思想7.2.2故障模型7.2.3可测试性分析7.2.4测试矢量生成7.3可测试性设计7.3.1分块测试7.3.2可测试性的改善设计7.3.3内建自测试技术7.3.4扫描测试技术第8章模拟单元与变换电路8.1模拟集成电路中的基本元件8.1.1电阻8.1.2电容8.2基本偏置电路8.2.1电流偏置电路8.2.2电压偏置电路8.3放大电路8.3.1单级倒相放大器8.3.2差分放大器8.3.3源极跟随器8.3.4MOS输出放大器8.4运算放大器8.4.1两级CMOS运放8.4.2CMOS共源-共栅(cascode)运放8.4.3带有推挽输出级的运放8.4.4采用衬底晶体管输出级的运放8.5电压比较器8.5.1电压比较器的电压传输特性8.5.2差分电压比较器8.5.3两级电压比较器8.6D/A、A/D变换电路8.6.1D/A变换电路8.6.2A/D变换电路8.
2025/6/24 15:01:24 12.57MB VLSI
1
本文将一种基于平移不变小波分解的新方法引入到像素级多传感器图像融合中。
提出的融合体系结构与“shift-decompose-fuse-shift”技术有关,并且包含许多步骤。
首先,要在水平和垂直方向上移动源图像。
移位后的图像将被转换为小波域,并通过重复“移位-翻译”来获得源图像的分解。
其次,将融合图像的不同子带系数与所提出的融合规则相结合。
最后,融合图像将通过反向平移和移位获得。
实验结果表明,该方法融合了源图像中的有用信息,性能优于离散小波变换(DWT)和平稳小波变换(SWT)。
2025/6/12 20:06:10 640KB image fusion; translation-invariant wavelet;
1
利用n级线性移位寄存器产生m序列,并借助Berlekamp-Messey算法的思想对已知m序列进行破译.根据下面给定的1+x^2+x^5本原多项式,来产生一个m序列;
2025/6/7 12:44:29 1KB m加密的破译
1
共 102 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡