当前位置: 首页 > news >正文

HDLbits:Exams/ece241 2013 q4

本题是一个实际的应用问题,一个水库,有三个传感器S1、S2、S3提供输入,经过控制电路,四个输出给到四个流量阀。也就是说,本题想让我们根据水位去控制流量阀。

问题的关键在于把什么抽象成state,答案是:水位的高低。根据题意,我们知道水位高低有四种状态,可以用传感器检测。

在第一个always块中,把三个传感器输入的值,作为next_state。

在第二个always块中,用next_state判断,输出什么信号给四个流量阀。

在第三个always块中,把next_state赋给state。

在第四个always块中,给dfr赋值。因为dfr第四个水阀判断条件比较特殊,所以不跟另外三个水阀写在一起判断。

判断

module top_module (input clk,input reset,input [3:1] s,output fr3,output fr2,output fr1,output dfr
); reg [2:0] state, next_state;parameter A=3'b111, B=3'b011, C=3'b001, D=3'b000;//根据输入决定下一个状态always@(*)begincase(s)A: next_state = A;B: next_state = B;C: next_state = C;D: next_state = D;default: next_state = D;endcaseendalways@(posedge clk)beginif(reset){fr3,fr2,fr1} <= 3'b111;elsecase(next_state) //这里要想清楚判断条件是state还是next_stateA : {fr3,fr2,fr1} <= 3'b000;B : {fr3,fr2,fr1} <= 3'b001;C : {fr3,fr2,fr1} <= 3'b011;D : {fr3,fr2,fr1} <= 3'b111;endcaseendalways@(posedge clk)beginif(reset)state <= D;elsestate <= next_state;endalways@(posedge clk)beginif(reset)dfr <= 1;else if(next_state < state)dfr <= 1;else if(next_state > state)dfr <= 0;elsedfr <= dfr;endendmodule

http://www.lryc.cn/news/189264.html

相关文章:

  • 什么是React的虚拟DOM(Virtual DOM)?它的作用是什么?
  • Response Status Code 301、302
  • import { ref, onMounted, reactive } from ‘vue‘
  • 【TB作品】基于MSP430G2553单片机的超声波测距与报警系统,原理图,PCB
  • npm install报错
  • Flutter自定义model实体类
  • java项目实现不停服更新的4种方案(InsCode AI 创作助手)
  • 7.1 yolov5优化模型时,自动标注xml数据
  • 开发者职场“生存状态”大调研报告分析 - 第一版
  • 在MySQL中使用!=还能走索引吗?
  • 【算法题】2897. 对数组执行操作使平方和最大
  • 2023年中国划船机产量、销量及市场规模分析[图]
  • Kafka和RabbitMQ的对比
  • ffmpeg从一个视频中提取音频
  • CCF CSP题解:坐标变换(其一)(202309-1)
  • 跳表C语言
  • 【JavaEE】_tomcat的安装与简单使用
  • React 状态管理 - Context API 前世今生(上)旧版v16.3前
  • 微服务、SOA 和 API 之间的区别
  • python打印正反直角三角形
  • ubuntu安装Miniconda并举例使用
  • 如何保护您的数据免受.360勒索病毒的感染
  • 2024计算机保研--哈工大、中山、国防科大
  • Hadoop分布式集群搭建教程
  • 学习函数式编程、可变参数及 defer - GO语言从入门到实战
  • Linux 文件链接
  • 1.go web之gin框架
  • 工程物料管理信息化建设(十二)——关于工程物料管理系统最后的思考
  • 什么是API网关?——驱动数字化转型的“隐形冠军”
  • Java 序列化和反序列化为什么要实现 Serializable 接口?