准备

通过Logisim的官网下载适合你机器的Logisim的软件,启动Logisim应用程序(Logisim可能有点bug,如果程序运行诡异,可能内部已经奔溃,最好的解决方法是重新启动它)。

Logisim 高阶使用

先介绍两个有用的Logisim的功能,对后续实验会很有帮助。

Tunnel

Tunnel允许你绘制“隐形线”将两个点绑定在一起。Tunnel根据分配给线的标签来分组,这写标签是区分大小写的,他们用于连接线,如图所示:

要小心电线通过Tunnel与哪些电线相连,反过来也可以,如图:

Splitter

顾名思义,就是分离器,将n位输入,分成m组输出(组数和每组成员都是可以调节的)。其实它也能够反过来用,即将n位输入合成一个n位的输出。

下面这个,就是将一个16位数,整体循环右移两位。

Extenders 扩展器

在更改连线宽度时,为了清晰起见,应使用Bit extender 位扩展器。

例如考虑将8位扩展成16位,一种做法是利用Splitter,将原数与00000000合并,如图

下面有一种更简便的做法,更易于阅读,并且不容易出错

在考虑丢弃比特位情况下,它可以做着“相反”的工作

实验

要求:根据你对Splitter和多路复用器的知识和经验,你可以实现一个非平凡的组合逻辑块:rotr,代表“向右循环“,rotr A,B表示将输入A的位模式”向右循环“B位。

例如,A为0bc110101,B为ob0101(即十进制5),则该电路块的输出为ob110101110101,请注意,最右边的5位从值的右端循环到左端。

在RTL中,该操作类似于"R = A >> B || A << (16 - B)"。

允许使用 除Shift位移器以外 的任何组合逻辑电路,在main的子电路中使用你的rotr子电路。

提示一:在开始接线之前,你应该仔细考虑如何将此问题分解为较小的问题并将它们连接在 一起。在实现 rotr 时,可以随意使用其他子电路。如果你不这样做,等着后悔吧。

提示二:虽然我们给你了 rotr 的 RTL 表示,但这并不意味着它是看待这个问题的最佳方式。 想想 B 的输入位并考虑如何有效地使用 splitter!

提示三::如果使用一个大的 splitter 接线会很混乱,有时可以将多个 splitter 串起来,事情会 更加局部化和整洁。例如,将 1 个输入分离成 16 个输出可以用一个 splitter 分出 4 个分支, 每个分支分别到一个有四个分支的 splitter。

思路

首先分别制作循环右移1位、2位、4位、8位的子电路(记得考虑子电路复用),其中右移1位可以用Splitter分离出16位,然后错一位连接再用Splitter合并。

将B的4位分离出来,分别作4个2-to-1-MUX的使能端。

my lab这个我写的,有错误欢迎指出,谢谢!

Logisim的使用的更多相关文章

  1. logisim自动生成电路

    之前再做有关logisim有关的实验时,一直在傻乎乎地连线,而我是看了mooc有关的视频时,才知道logisim有自动连线的功能. 自动连线需要事先知道输入与输出的真值表或者全部的表达式,将其填入lo ...

  2. 【Logisim实验】构建立即数-随机存储器-寄存器的传送

    关于Logisim Logisim在仿真软件行列中算是比较直观的软件了,它能做的事情有很多,唯一不足的是硬件描述语言的支持,总体上来说适合比较底层的仿真,依赖于Hex值,通过线路逻辑设计能够较好的 关 ...

  3. 使用logisim搭建单周期CPU与添加指令

    使用logisim搭建单周期CPU与添加指令 搭建 总设计 借用高老板的图,我们只需要分别做出PC.NPC.IM.RF.EXT.ALU.DM.Controller模块即可,再按图连线,最后进行控制信号 ...

  4. logisim元件清单

  5. ubuntu16.04中可以用于教学的有趣的应用

    ubuntu16.04中可以用于教学的有趣的应用 在ubuntu自带的软件中心里,内置了非常丰富的教育应用,可以用于物理,化学等科学课教学,只选取我用过用于教学的软件,优秀的软件不止这些,可以慢慢发掘 ...

  6. 【从零开始自制CPU之学习篇00】开篇

    从今天开始决定用面包板制作一个8位的CPU,实现几个简单的指令.我给自己分两大部分计划,第一部分是学习制作CPU的理论知识,第二部分是实践.并打算实施计划的同时用博客的方式记录下来.理论知识的部分重点 ...

  7. P4-verilog实现mips单周期CPU

    最近对学习的掌控可能出现了问题,左支右绌,p2挂了,p2.p3.p4.p5每周在计组花的连续时间少了很多,学习到的东西也少了很多,流水线都还没真正开始写,和别人比落后了一大截,随笔自然就荒废了,我得尽 ...

  8. P0-Logisim简单部件与有限状态机

    #自学了6week,pre都挂了,做了做P0课下测试,觉得自己对有限状态机概念的的理解,特别是牵扯到时序还是很模糊:状态的抽象也不够熟练:logisim和Verilog的实现也存在问题.网上针对性的l ...

  9. OO第三次博客作业(第三单元总结)

    (1)梳理JML语言的理论基础.应用工具链情况 Java 建模语言(JML)将注释添加到 Java 代码中,这样我们就可以确定方法所执行的内容,而不必说明它们如何做到这一点.有了 JML,我们就可以描 ...

随机推荐

  1. bzoj 4756 Promotion Counting —— 线段树合并

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4756 合并子树的权值线段树: merge 返回 int 或者是 void 都可以. 代码如下 ...

  2. 移动web开发------公用css----自己总结

    @charset "utf-8"; html, body { background: #fff; color: #505050; font-size: 10px; -moz-use ...

  3. CSS中style用法详解

    转自:http://www.cnblogs.com/xingxingchongchong/p/6501575.html css样式表按其所在位置分三种: 1.内嵌样式表 2.内部样式表 3.外部样式表 ...

  4. pl/sql developer安装使用即时客户端

    pl/sql developer安装使用即时客户端 背景:由于Oracle的安装比较麻烦,大部分人都使用远程Oracle,而Oracle Instantclient Basic package可以解决 ...

  5. (二十六)分类信息的curd-分类信息添加

    分类信息添加: 1.应在在左边的dtree上添加连接(展示所有的分类信息) d.add(...,"/store/adminCategory?method=findAll",&quo ...

  6. ASP.NET Core MVC 2.x 全面教程_ASP.NET Core MVC 11. Views 上

    通常会使用外层模板的view,当做公共的模块 通常叫做_Layout.cshtml views下新建Shared文件夹 主要关注RenderBody,这里会具体渲染Action返回的内容View la ...

  7. 洛谷 - P1141 - 01迷宫 - dfs

    https://www.luogu.org/problemnew/show/P1141 能互相到达的格子的答案自然是一样的,第一次dfs标记联通块,第二次dfs把cnt传递到整个联通卡并顺手消除vis ...

  8. Codeforces731E Funny Game

    dp[i][0]表示从i出发,轮到先手走的最优值. dp[i][1]表示从i出发,轮到后手走的最优值. dp[i][0]=max(dp[j][1]+sum[j]) dp[i][1]=min(dp[j] ...

  9. web前端图片预加载

    是什么? 浏览器会缓存静态资源(hmtl/css/img等).图片预加载就是让浏览器提前缓存图片,提升用户体验. 浏览器什么情况下会下载图片? 1,解析到html中img的src属性的时候 2,解析到 ...

  10. 鸟哥私房菜基础篇:Linux是什么习题

    猫宁!!! 参考链接:http://cn.linux.vbird.org/linux_basic/0110whatislinux.php#ex 鸟哥是为中国信息技术发展做出巨大贡献的人. 1-你在你的 ...