org.jchdl.model.gsl.core.meta.Node.java
 
generated by Intellij IDEA powered by yFiles
 
Node为所有节点的父类。所有用户创建的节点,必须继承Node类。Node为用户创建了节点提供了很多支持方法,但把logic()方法留给子类自行定义。
 
一. 类结构
 
 
主要属性:
  1. netI:连接在节点Input接口上的线;
  1. netO: 链接在节点Output接口上的线;
  1. ioI:节点的Input接口,与netI中的线一一对应;
  1. ioO:接口Output接口,与netO中的线一一对应;
 
主要方法:
  1. 收集连接在接口Input接口上的线的方法:
  1. in(Net): 添加一条输入线;
  1. in(Net[]):添加一组输入线;
  1. 收集连接在接口Output接口上的线的方法:
  1. out(Net): 添加一条输出线;
  1. out(Net[]):添加一组输出线;
  1. 获取节点Input接口的方法:
  1. in(int index): 获取第index个Input接口;
  1. inputs(): 获取所有的Input接口;
  1. inputs(int from):获取从from开始的所有接口;
  1. inputs(int from, int to):[from, to),获取从from(包含)到to(不包含)的所有接口;
 
  1. 获取节点Output接口的方法:
  1. out(int index): 获取第index个Output接口;
  1. outputs(): 获取所有的Output接口;
  1. outputs(int from):获取从from开始的所有接口;
  1. outputs(int from, int to):[from, to),获取从from(包含)到to(不包含)的所有接口;
 
  1. 节点内部逻辑构建方法:logic()
该方法为抽象方法,留给子类自行定义,即用户通过重新定义该方法,来实现节点的自定义逻辑。
 
  1. 节点构建方法:construct()
辅助方法,下面单讲。
 
  1. 转换为Verilog的方法:toVerilog()
把节点转换为Verilog的(门和开关层结构建模)实现。
 
二. 构建节点
 
当前构建节点的方法如下:
  1. 收集节点构造方法中提供的输入线和输出线;
  1. 调用construct()方法:
  1. 根据收集的输入线和输出线,分别创建足够数量的Input接口和Output接口与之对应;
  1. 调用用户自定义的logic()方法构建节点内部逻辑;
  1. 将输入线和输出线与节点的Input接口和Output接口一一连接;
如此即完成节点构建。
 
三. 用户自定义逻辑:logic()
 
用户自定义逻辑的方法是在子类中覆盖logic方法。logic方法主要做以下事情:
 
  1. 创建线或一组线从Input接口牵出。(创建线时即可自动将Input接口连接到新创建的线的Input接口上,从而驱动(driven)线)
  1. 创建线或一组线连接到Output接口。(创建线时即可自动把线的Output接口连接到节点的Output接口上)
  1. 创建内部子节点;(创建内部子节点时,即可自动把Input牵出作为子节点输入线的线,连接到子节点的Input接口上;并且自动把子节点的Output接口连接到子节点的输出线上)
 
另外,可以通过pullup/pulldown来处理临时需要的线;使用toGround()处理不再需要的线。
 
注意:logic内部使用的线,属于节点的一部分,最好是定义为节点类的属性。
 
四. 总结
 
可以看出,节点的构建其实就是连线:
  1. 把输入线连到Input接口上;
  1. 从Input接口牵出线连到内部子节点上;
  1. 从内部子节点牵出线连接到Output接口上;
  1. Output接口牵出线以供后续使用;(连接到下一个节点,或者接地,或者悬空供观察使用)
 
五. 实例Mux
 
Mux为二选一。
 
  1. 构造函数
构造函数的参数为输入线和输出线,使用in()和out()分别收集:
  1. 收集输入线 in1, in2, sel;
  1. 收集输出线out;
  1. 调用construct方法构建Mux节点;
 
  1. 内部逻辑
  1. 从输入口牵出线,比如:
in1 = new Wire(in(0))
其中,in(0)方法为Node类提供的辅助方法,获取第0个Input接口;
然后创建一条线,从这第0个Input接口牵出。
  1. 创建线连接到输出口,比如:
out = new Wire(out(0))
out(0)方法为Node类提供的辅助方法,获取第0个Output接口;
然后创建一条线,连接到这个输出口上;
  1. 创建子节点Not需要的输出线selNot;
  1. 创建字节点Not:sel作为输入线,selNot作为输出线;
  1. 同理,逐个创建子节点:两个与门,一个或门;
 
  1. 节点内部的线
 
节点内部使用的线,推荐作为节点属性声明:
 
  1. 创建Mux节点
 
PS. inst静态方法可以省略new关键字,使代码更紧凑。
 
六. 原子节点(AtomicNode)
 
原子节点是节点的子类。覆盖了logic方法,但实现为空。
 
该类定义了抽象方法atomic()供子类覆盖,以实现从输入到输出的转化逻辑。最简单的比如非门:
 
atomic()方法调用not()方法,实现从输入到输出值的转换。
 

jchdl - GSL Node的更多相关文章

  1. jchdl - GSL Port

    https://mp.weixin.qq.com/s/DVmMrCFgNLuZDtssQ85w7A   org.jchdl.model.gsl.core.meta.Port.java   ​​ gen ...

  2. jchdl - GSL实例 - Add

    https://mp.weixin.qq.com/s/6xcYYdYZTBPTf25xFluzBQ   使用FullAdder级联实现加法器   参考链接: https://github.com/wj ...

  3. jchdl - GSL实例 - Mux4(使用Mux)

    https://mp.weixin.qq.com/s/GrYJ4KXEFRoLLmLnAGoMSA 原理图 ​​ 参考链接 https://github.com/wjcdx/jchdl/blob/ma ...

  4. jchdl - GSL实例 - Mux4(使用WireVec简化输入线声明)

    https://mp.weixin.qq.com/s/yJx_dV6ScUStJtPWVuD38w 原理图 ​​ 参考链接 https://github.com/wjcdx/jchdl/blob/ma ...

  5. jchdl - GSL值的传播

    https://mp.weixin.qq.com/s/jgMljoca-Cwe9x0NaTLzZg   GSL的拓扑模型是线和节点连接的模型,值的传播,即是值在线和节点之间传播和转化的过程.   值的 ...

  6. jchdl - GSL Wire

    https://mp.weixin.qq.com/s/4w_wwwCd6iBhh0QR2wK81Q   org.jchdl.model.gsl.core.datatype.net.Wire.java ...

  7. jchdl - GSL实例 - DFlipFlop(D触发器)

    https://mp.weixin.qq.com/s/7N3avTxTd2ZUnAcKg4w3Ig   D触发器对边沿敏感,只有当相应的边沿出现时,才会触发D的值传播到输出Q.   ​​ 引自:htt ...

  8. jchdl - GSL实例 - Div

    因为对除法研究不深,这里略去不表.   有兴趣可以参考链接: https://github.com/wjcdx/jchdl/blob/master/src/org/jchdl/model/gsl/op ...

  9. jchdl - GSL实例 - MulC2(有符号数的乘法)

      这里的实现,先把符号位取出来,使用两个正数相乘,然后在把符号加到乘积上.   参考链接 https://github.com/wjcdx/jchdl/blob/master/src/org/jch ...

随机推荐

  1. Java 面向对象和封装

    目录 面向对象思想的概述 类和对象的关系 什么是类 什么是对象 类和对象的关系 局部变量和成员变量的区别 this关键字 构造方法 一个标准的类 面向对象思想的概述 面向过程:当需要实现一个功能的时候 ...

  2. spring boot中使用AJAX请求,并将回调函数赋值给input输入框

    HTML: <script>/* $(document).ready(function(){} 页面加载事件,加载完页面之后执行 */ $(document).ready(function ...

  3. 对已经创建的docker container设置开机自启动

    首先显示出所有的容器 docker ps -a #显示所有容器 设置已经建立的容器的开机自启动方法 docker update --restart=always <container ID 根据 ...

  4. JS做类型检测到底有几种方法?看完本文就知道了!

    JS有很多数据类型,对于不同数据类型的识别和相互转换也是面试中的一个常考点,本文主要讲的就是类型转换和类型检测. 数据类型 JS中的数据类型主要分为两大类:原始类型(值类型)和引用类型.常见的数据类型 ...

  5. 一些常见的pro文件配置

    UI_DIR = ./ui #ui文件目录 TARGET = Test #最终生成目标名 DESTDIR = $$PWD/../test #目标生成目录,$$PWD表示当前目录下 DLLDESTDIR ...

  6. 数学建模(二)优劣解距离法Topsis模型部分

    步骤: (一)统一指标类型:指标正向化(转化为极大型)(论文) 越大越好极大型指标,效益型指标 越小越好极小型指标,成本型指标 max-x,max=max{xi} 落在某个区间[a,b]是最好的,区间 ...

  7. HDU 2011 (水)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2011 题目大意:给你 m 个数,对于每个数,求前 n 项和,数列:1 - 1/2 + 1/3 - 1/ ...

  8. 「雕爷学编程」Arduino动手做(8)——湿度传感器模块

    37款传感器和模块的提法,在网络上广泛流传,其实Arduino能够兼容的传感器模块肯定是不止37种的.鉴于本人手头积累了一些传感器与模块,依照实践出真知(动手试试)的理念,以学习和交流为目的,这里准备 ...

  9. XShell 评估到期

    刚刚打开XShell弹出”评估到期“,点击确定后自动打开中文官网,得购买后才能使用. 当初下载的时候没留意到会有这一天.. 手头拮据的朋友可以通过下面方法绕过: 删除XShell. 到英文官网下载页找 ...

  10. jenkins+gitee+ssh自动化部署

    一.准备环境 1,配置maven(MAVEN_HOME) 2,配置jdk(JAVA_HOME)我这里用的jdk1.8.0_121,之前碰到过一次别的版本的jdk在启动tomcat无法解析https情况 ...