硬件编程语言

硬件画板说白了就是电气的连接,相较于PCB连接在2.5D中完成(有些大佬们是直接3D设计)考虑的东西会更多,原理图的抽象使得硬件思路更加简单。

就算是这样, 增加到上千门器件后的大工程是非常难以进行的编辑和检查的, 而如今的逻辑门等芯片电路规模都快上千亿级别了,这个规模已经不是人的两只眼睛或者一个团队能够用原理图来表示出来的。

于是 硬件语言verilog 和VHDL 就出现了,是相对于传统原理图这可以完成上万门元件的电路设计了, 上亿门元件的布局一个团队能够完成,上百亿千亿的功能,一个精英团队可以触及,但是任然是非常困难跨过这个极限带来的门坎。

module counter10(//端口定义input                   rstn,   //复位端,低有效input                   clk,    //输入时钟output [3:0]    cnt,    //计数输出output                  cout);  //溢出位reg [3:0]               cnt_temp ;      //计数器寄存器always@(posedge clk or negedge rstn) beginif(! rstn)begin         //复位时,计时归0cnt_temp        <= 4'b0 ;endelse if (cnt_temp==4'd9) begin  //计时10个cycle时,计时归0cnt_temp        <=4'b000;endelse begin                                      //计时加1cnt_temp        <= cnt_temp + 1'b1 ; endendassign  cout = (cnt_temp==4'd9) ;       //输出周期位assign  cnt  = cnt_temp ;                       //输出实时计时器
endmodule

于是工程师们引进了类似Java的 Chisel 语言,引入对象,多态等思路对硬件逻辑描述更加友善, 一个团队基本可以轻松胜任上百亿门的元件的功能描述。

class SortBlock extends Component() {override val io = new Bundle() {val in1 = new IoSortBlockOut()val in2 = new IoSortBlockOut()val out = new IoSortBlockOut()}
...
}

个人人为, 既然都涉及到高级语言了, 为啥不搞到python。
我们知道c,java这些虽然脱离了底层硬件描述的重复工作,但是还是没有完全脱离内存和数据的绑定。

而python目前在内存处理这块更加友善, 所以我打算尝试以下一门新的硬件语言的设计,而不是像MyHDL这样需要语言去描述硬件,不能带来逻辑上的极致。

MyHDL 程序风格:

from myhdl import *@block
def dff(q, d, clk):@always(clk.posedge)def logic():q.next = dreturn logic

比如上边的模块 ,我可以优化到下面更加简洁描述:

# rstn 复位端,低有效
# clk 输入时钟
def counter10(rstn, clk):cnt_temp = reg(3)    #计数器寄存器with posedge(clk) or negedge(rstn): # alwaysif not rstn:        #复位时,计时归0cnt_temp <= 0elif cnt_temp==9:  #计时10个cycle时,计时归0cnt_temp <= 0else:                               #计时加1cnt_temp <= cnt_temp + 1cout = (cnt_temp == 9)        #输出周期位cnt = cnt_temp                      #输出实时计时器return cnt, cout # 计数输出 溢出位

这里说明以下, 大家都很优秀,文章中的任何说明,都是大家的成果, 我只是在大家的思路上,前人的经验上, 提出一点思路,供大家探讨。


参考:

  • 吃透Chisel语言.01.大家Verilog和VHDL用得好好的,为什么要整个Chisel语言出来?

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Mac如何安装stable diffusion

今天跟大家一起在Mac电脑上安装下stable diffusion&#xff0c;在midjourney等模型收费的情况下如何用自己的电脑算力用上免费的画图大模型呢&#xff1f;来吧一起实操起来 一、安装homebrew 官网地址&#xff1a;Homebrew — The Missing Package Manager for macOS (or Lin…

认识Trino

认识Trino 一、Trino二、结构三、集群四、coordinator五、Worker六、数据源七、连接器八、目录九、架构十、表十一、查询执行模型十二、陈述十三、查询十四、阶段十五、任务十六、分隔十七、Driver十八、Operator十九、Exchange 一、Trino Trino&#xff08;前身为PrestoSQL&a…

conda和pip配置国内镜像源

1、conda配置镜像源&#xff1a; 使用conda进行安装时&#xff0c;访问的是国外的网络&#xff0c;所以下载和安装包时会特别慢。我们需要更换到国内镜像源地址&#xff0c;这里我更换到国内的清华大学地址。&#xff08;永久添加镜像&#xff09; Windows和Linux 对于conda修…

SQL进阶理论篇(十):数据库中的锁

文章目录 简介按照锁的粒度进行划分从数据库管理的角度进行划分从程序员的角度进行划分为什么共享锁会发生死锁&#xff1f;参考文献 简介 索引和锁&#xff0c;是数据库中的两个核心知识点。 索引的相关知识点&#xff0c;在之前的几章里我们已经介绍的差不多了。接下来我们…

[pasecactf_2019]flask_ssti proc ssti config

其实这个很简单 Linux的/proc/self/学习-CSDN博客 首先ssti 直接fenjing一把锁了 这里被加密后 存储在 config中了 然后我们去config中查看即可 {{config}} 可以获取到flag的值 -M7\x10wd94\x02!-\x0eL\x0c;\x07(DKO\r\x17!2R4\x02\rO\x0bsT#-\x1cZ\x1dG然后就可以写代码解…

MNIST内置手写数字数据集的实现

torchvision库 torchivision库是PyTorch中用来处理图像和视频的一个辅助库&#xff0c;接下来我们就会使用torchvision库加载内置的数据集进行分类模型的演示 为了统一数据加载和处理代码&#xff0c;PyTorch提供了两个类用于处理数据加载&#xff0c;他们分别是torch.utils.…

leetcode:641. 设计循环双端队列

设计循环双端队列 实现 MyCircularDeque 类: MyCircularDeque(int k) &#xff1a;构造函数,双端队列最大为 k 。 boolean insertFront()&#xff1a;将一个元素添加到双端队列头部。 如果操作成功返回 true &#xff0c;否则返回 false 。 boolean insertLast() &#xff1a;…

机器视觉技术与应用实战(开运算、闭运算、细化)

开运算和闭运算的基础是膨胀和腐蚀&#xff0c;可以在看本文章前先阅读这篇文章机器视觉技术与应用实战&#xff08;Chapter Two-04&#xff09;-CSDN博客 开运算&#xff1a;先腐蚀后膨胀。开运算可以使图像的轮廓变得光滑&#xff0c;具有断开狭窄的间断和消除细小突出物的作…

饥荒Mod 开发(十五):小地图显示物品

饥荒Mod 开发(十四)&#xff1a;制作屏幕弹窗 本篇源码 饥荒中按下Tab键可以显示地图&#xff0c;刚开始进入游戏的时候地图是未探索状态&#xff0c;所以我们并不知道地图上面的物品分布情况。并且地图上只会显示很少一部分的物品&#xff0c;比如树枝&#xff0c;草&#xf…

C++二维数组(4)

蛇形遍历 题目描述&#xff1a;用数字1,2,3,4,...,n*n这n2个数蛇形填充规模为n*n的方阵。 蛇形填充方法为&#xff1a; 对于每一条左下-右上的斜线&#xff0c;从左上到右下依次编号1,2,...,2n-1&#xff1b;按编号从小到大的顺序&#xff0c;将数字从小到大填入各 条斜线&…

【Linux】操作文件和目录

简介 常见的一些对文件和目录操作的命令如下&#xff1a; cp&#xff1a;复制文件和目录。mv&#xff1a;移动/重命名文件和目录。mkdir&#xff1a;创建目录。rm&#xff1a;删除文件和目录。ln&#xff1a;创建硬链接和符号链接。 用图形文件管理器来完成一些由这些命令执…

Debezium发布历史11

原文地址&#xff1a; https://debezium.io/blog/2016/10/25/Debezium-0-3-4-Released/ Debezium 0.3.4 发布 2016 年 10 月 25 日 作者&#xff1a; Randall Hauch 发布 mysql docker 欢迎关注留言&#xff0c;我是收集整理小能手&#xff0c;工具翻译&#xff0c;仅供参考&…

链表基础知识(二、双向链表头插、尾插、头删、尾删、查找、删除、插入)

目录 一、双向链表的概念 二、 双向链表的优缺点分析​与对比 2.1双向链表特点&#xff1a; 2.2双链表的优劣&#xff1a; 2.3循环链表的优劣 2.4 顺序表和双向链表的优缺点分析​ 三、带头双向循环链表增删改查实现 3.1SList.c 3.2创建一个新节点、头节点 3.3头插 3.…

C# WPF上位机开发(知识产权ip保护)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 上位机软件如果是和硬件模块搭配开发&#xff0c;这个时候大部分上位机基本上都是白送的&#xff0c;不会收取相关的费用。但是&#xff0c;如果上…

计算机网络基础——以太网类型,常见标准和架构

一、标准以太网 标准以太网&#xff08;10Mbit/s&#xff09;通常只定位在网络的接入层&#xff0c;新一代多媒体、影像和数据库产品很容易将10Mbit/s运行的以太网的带宽吞没。10Mbit/s 的以太网可以实现100m距离的连接。 二、快速以太网 数据传输速率为100Mbps 的快速以太网…

提示工程指南

大家好,欢迎来到本课程。在接下来的时间里,我们将一起学习如何使用 OpenAI 的提示工程指南来更有效地使用大语言模型。 目录 什么是提示工程?提示工程的原则提示工程的技巧提示工程的最佳实践提示工程的常见问题什么是提示工程? 提示工程是指设计和编写提示语以获得所需输…

项目遇到Bug如何解决(思路)

找到Bug,分析Bug,解决Bug 语法错误 ESLint:代码规则约束检测的操作&#xff0c;利用ESLint可以更好的帮助我们避免一些语法的错误信息&#xff0c;例如括号是不是匹配等。Prettier:代码格式化工具进行语法的错误和纠正&#xff0c;当出现语法错误的时候&#xff0c;代码格式化…

chrome升级后,调试vue在控制台输出总是显示cjs.js

当前chrome版本120.0.6099.72 在vue中使用console.log输出时&#xff0c;总是显示cjs.js多少多少行&#xff0c;不能显示源文件名及行数 【解决方案】 打开控制台的设置 左侧找到“Ignore List”&#xff0c;取消勾选"enable Lgnore Listing"&#xff0c;并重启chr…

4-Docker命令之docker history

1.docker history介绍 docker history命令是用来打印指定docker镜像的历史版本信息 2.docker history用法 docker history [参数] IMAGE [root@centos79 ~]# docker history --helpUsage: docker history [OPTIONS] IMAGEShow the history of an imageAliases:docker imag…

【Jmeter】Jmeter基础6-Jmeter元件介绍之前置处理器

前置处理器主要用于处理请求前的准备工作&#xff0c;如&#xff1a;参数、环境变量的设置等。 2.6.1、JSR223预处理程序 作用&#xff1a;请求前的准备工作。 参数说明&#xff1a; 语言&#xff1a;开发脚本所使用的语言&#xff0c;可通过下拉列表选择。参数&#xff1a;传…