快速入门数字芯片设计,UCSD ECE111(七)enum枚举类型&优化SHA256哈希算法(一)

简介: 快速入门数字芯片设计,UCSD ECE111(七)enum枚举类型&优化SHA256哈希算法

这篇文章带来ECE111第七节课的Slides以及自己的一些补充。

该课程的网站如下:

https://link.zhihu.com/?target=http%3A//cwcserv.ucsd.edu/~billlin/classes/ECE111/index.php

书接上回,继续讨论之前的Project3:

在讨论之前首先比较了enumparameter两个关键字

enum有两种方式:

  • 第一种为特定编码,如图中指定了IDLE,STEP1,STEP2,STEP3 各自的取值
  • 还有一种方式为默认编码,在没有指定的情况下,则默认内部的值是逐一增加的。同时这些值的比特宽度和外部的state信号是一致的

对于parameter关键字,则是以常数的方式进行对待的,并且不会等到编译阶段才进行处理,在预处理阶段就会进行相应的替换。enum各自的label是唯一的(value唯一),同时对于相应的比特不能够进行逻辑操作。这里我们只需要掌握enum运用在状态机各状态声明。我们为什么要用enum呢?主要有以下几点:

  • enum相比于parameter更加安全,因为我们在对state赋值的时候,只能对其分配我们定义的标签值,不会导致赋意料之外的状态值。
  • 标签值和信号名一定是同样的大小,如果不一样,在编译阶段就会报错,而paremter并不会报错,大概率只会报warning!(甚至warning都没有)
  • 只允许由label或者其他相同类型的enum变量赋值,其他类型的赋值都是非法的。

具体的大家可以看下面这两张图,enum用在状态变量中好处多多,大家要熟练掌握。

接下来回归正题,讨论SHA256算法的优化。忘掉了SHA256是什么的请回顾上节课的内容。

我们的运算实际上是针对A~H这8个32位寄存器,持续的做运算,运算到最后一轮,这8个寄存器代表的就是256bit的哈希值。 假定�� 以及 �� 在进行轮运算之前已经都有了,则我们可以重点关注轮运算的步骤,如上图所示。

基于这个想法,我们可以写出相关的代码如图所示,通过多轮的运算(对于一个Block而言,我们需要在COMPUTE状态下持续计算A~H寄存器的值,一共64轮)。上面这段代码可以用吗?大家思考一下。

从逻辑的角度来说(或者是软件的角度来说),当然是可以的。大家做仿真也没有任何问题,结果肯定是对的。但是这样时钟频率一定是很低的。时刻要牢记我们设计的是硬件电路,写代码只是去描述硬件的行为,上面这样的一次运算我们要求它在一个时钟周期以内要算完,以满足建立时间。(因为下一个时钟周期要用到上一个时钟周期的结果做新一轮的运算),但是这段运算显然要算很久,因此时钟周期也需要很长才可以满足建立时间,这样频率一定很低。所以要针对这段代码进行优化。

目录
相关文章
|
1月前
|
机器学习/深度学习 算法 数据可视化
基于MVO多元宇宙优化的DBSCAN聚类算法matlab仿真
本程序基于MATLAB实现MVO优化的DBSCAN聚类算法,通过多元宇宙优化自动搜索最优参数Eps与MinPts,提升聚类精度。对比传统DBSCAN,MVO-DBSCAN有效克服参数依赖问题,适应复杂数据分布,增强鲁棒性,适用于非均匀密度数据集的高效聚类分析。
|
1月前
|
机器学习/深度学习 算法
采用蚁群算法对BP神经网络进行优化
使用蚁群算法来优化BP神经网络的权重和偏置,克服传统BP算法容易陷入局部极小值、收敛速度慢、对初始权重敏感等问题。
251 5
|
2月前
|
机器学习/深度学习 传感器 算法
【高创新】基于优化的自适应差分导纳算法的改进最大功率点跟踪研究(Matlab代码实现)
【高创新】基于优化的自适应差分导纳算法的改进最大功率点跟踪研究(Matlab代码实现)
217 14
|
1月前
|
机器学习/深度学习 人工智能 算法
【基于TTNRBO优化DBN回归预测】基于瞬态三角牛顿-拉夫逊优化算法(TTNRBO)优化深度信念网络(DBN)数据回归预测研究(Matlab代码实现)
【基于TTNRBO优化DBN回归预测】基于瞬态三角牛顿-拉夫逊优化算法(TTNRBO)优化深度信念网络(DBN)数据回归预测研究(Matlab代码实现)
112 0
|
2月前
|
canal 算法 vr&ar
【图像处理】基于电磁学优化算法的多阈值分割算法研究(Matlab代码实现)
【图像处理】基于电磁学优化算法的多阈值分割算法研究(Matlab代码实现)
121 1
|
2月前
|
机器学习/深度学习 运维 算法
【微电网多目标优化调度】多目标学习者行为优化算法MOLPB求解微电网多目标优化调度研究(Matlab代码实现)
【微电网多目标优化调度】多目标学习者行为优化算法MOLPB求解微电网多目标优化调度研究(Matlab代码实现)
197 1
|
2月前
|
机器学习/深度学习 算法 数据安全/隐私保护
基于WOA鲸鱼优化的XGBoost序列预测算法matlab仿真
基于WOA优化XGBoost的序列预测算法,利用鲸鱼优化算法自动寻优超参数,提升预测精度。结合MATLAB实现,适用于金融、气象等领域,具有较强非线性拟合能力,实验结果表明该方法显著优于传统模型。(238字)
|
2月前
|
机器学习/深度学习 算法 Java
基于灰狼优化算法(GWO)解决柔性作业车间调度问题(Matlab代码实现)
基于灰狼优化算法(GWO)解决柔性作业车间调度问题(Matlab代码实现)
213 1
|
2月前
|
算法 机器人 Serverless
【机器人路径规划】基于6种算法(黑翅鸢优化算法BKA、SSA、MSA、RTH、TROA、COA)求解机器人路径规划研究(Matlab代码实现)
【机器人路径规划】基于6种算法(黑翅鸢优化算法BKA、SSA、MSA、RTH、TROA、COA)求解机器人路径规划研究(Matlab代码实现)
395 2

热门文章

最新文章

下一篇
oss云网关配置