Nexys3开发板Verilog Demo
这个学期开始学FPGA开发,使用的开发板是Nexys3,硬件编程语言是Verilog。苦于之前一直没有找到很好的代码学习资料,于是在这里将自己写过的一些相对简单的代码整理了一下分享开来,希望能对各位初学者有所帮助。
本文提供的Verilog代码都是属于Demo级别的,不过限于本人水平,也不免会有一些瑕疵,这里仅供参考,还请各位慎思!(“博学、审问、慎思、明辨、笃行。” 我的校训啊!)
如果各位还想学习更加复杂的Verilog project,请持续关注我以后的博客更新。(透个口风,我目前正在做的project有两个,微秒级秒表以及VGA显示。)
注意:由于本文大部分Demo都是十分简单经典的Verilog模块,所以把题意部分也省了,直接上电路图和代码,如果发现代码有看不懂,可以下载文章末尾的附件,里面有更加详细的介绍。
目录
2输入逻辑门
2位比较器
4位2选一多路选择器
7段译码器
3-8译码器
8-3优先编码器
4位二进制-BCD 码转换器
4位RCA加法器
4位CLA加法器
4位移位器
4位移位寄存器
4位移位寄存器生成伪随机数列
7段译码器扫描显示2位
Traffic controller(Moore FSM)
Traffic controller(Mealy FSM)
1、2输入逻辑门
简单的与门、与非门、或门、或非门、异或门、异或非门的实现。
2输入逻辑门电路图
// 设计文件: gate2.v `timescale 1ns / 1ps module gates2(input wire a, b, output wire [5:0] y); assign y[0] = a & b; // AND assign y[1] = ~(a & b); // NAND assign y[2] = a | b; // OR assign y[3] = ~(a | b); // NOR assign y[4] = a ^ b; // XOR assign y[5] = ~(a ^ b); // NXOR endmodule
// 测试文件: gate2_test.v `timescale 1ns / 1ps module gates2_test; // Inputs reg a, b; // Outputs wire [5:0] y; // Instantiate the Unit Under Test (UUT) gates2 uut ( .a(a), .b(b), .y(y) ); initial begin // Initialize Inputs a = 0; b = 0; // Wait 100 ns for global reset to finish #100; // Add stimulus here #200 a <= 0; b <= 0; #200 a <= 0; b <= 1; #200 a <= 1; b <= 0; #200 a <= 1; b <= 1; end endmodule
// 引脚文件:gate2_ucf.ucf NET "a" LOC = "T5"; NET "b" LOC = "V8"; NET "y[0]" LOC = "U15"; NET "y[1]" LOC = "V15"; NET "y[2]" LOC = "M11"; NET "y[3]" LOC = "N11"; NET "y[4]" LOC = "R11"; NET "y[5]" LOC = "T11";
2、2位比较器
2位比较器真值表
// 设计文件:comp2bit.v `timescale 1ns / 1ps module comp2bit( input [1:0] a, input [1:0] b, output a_eq_b, output a_gt_b, output a_lt_b ); assign a_eq_b = (a == b); assign a_gt_b = (a > b); assign a_lt_b = (a < b); endmodule
// 测试文件:comp2bit_test.v `timescale 1ns / 1ps module comp2bit_test; // Inputs reg [1:0] a; reg [1:0] b; // Outputs wire a_eq_b; wire a_gt_b; wire a_lt_b; // Instantiate the Unit Under Test (UUT) comp2bit uut ( .a(a), .b(b), .a_eq_b(a_eq_b), .a_gt_b(a_gt_b), .a_lt_b(a_lt_b) ); initial begin // Initialize Inputs a = 0; b = 0; // Wait 100 ns for global reset to finish #100; // Add stimulus here a = 1; b = 0; #100; a = 2; b = 0; #100; a = 3; b = 0; #100; a = 0; b = 1; #100; a = 1; b = 1; #100; a = 2; b = 1; #100; a = 3; b = 1; #100; a = 0; b = 2; #100; a = 1; b = 2; #100; a = 2; b = 2; #100; a = 3; b = 2; #100; a = 0; b = 3; #100; a = 1; b = 3; #100; a = 2; b = 3; #100; a = 3; b = 3; #100; end endmodule
// 引脚文件:comp2bit_ucf.ucf NET "a[1]" LOC="T5"; NET "a[0]" LOC="V8"; NET "b[1]" LOC="U8"; NET "b[0]" LOC="N8"; NET "a_eq_b" LOC="T11"; NET "a_gt_b" LOC="R11"; NET "a_lt_b" LOC="N11";
3、4位2选一多路选择器
4位2选一多路选择器原理图
// 设计文件:mux24a.v `timescale 1ns / 1ps module mux24a( output [3:0] y, input [3:0] a, input [3:0] b, input s ); assign y = (s == 0) ? a : b; endmodule
// 测试文件:mux24a_test.v `timescale 1ns / 1ps module mux24a_test; // Inputs reg [3:0] a; reg [3:0] b; reg s; // Outputs wire [3:0] y; // Instantiate the Unit Under Test (UUT) mux24a uut ( .y(y), .a(a), .b(b), .s(s) ); initial begin // Initialize Inputs a = 0; b = 0; s = 0; // Wait 100 ns for global reset to finish #100; // Add stimulus here a = 4'b0101; b = 4'b1010; #200; s = 1; #200; s = 0; #200; s = 1; #200; a = 4'b1001; b = 4'b0100; #200; s = 0; #200; s = 1; end endmodule
// 引脚文件:mux24a_ucf.ucf NET "a[3]" LOC="T5"; NET "a[2]" LOC="V8"; NET "a[1]" LOC="U8"; NET "a[0]" LOC="N8"; NET "b[3]" LOC="M8"; NET "b[2]" LOC="V9"; NET "b[1]" LOC="T9"; NET "b[0]" LOC="T10"; NET "y[3]" LOC="T11"; NET "y[2]" LOC="R11"; NET "y[1]" LOC="N11"; NET "y[0]" LOC="M11"; NET "s" LOC="C9";
4、7段译码器
7段译码器原理图
// 设计文件:hex7seg.v `timescale 1ns / 1ps module hex7seg( input [3:0] x, output [3:0] an, output [6:0] seg ); reg [6:0] seg; assign an = 4'b0000; always @ (x) case (x) 4'b0000: seg <= 7'b0000001; 4'b0001: seg <= 7'b1001111; 4'b0010: seg <= 7'b0010010; 4'b0011: seg <= 7'b0000110; 4'b0100: seg <= 7'b1001100; 4'b0101: seg <= 7'b0100100; 4'b0110: seg <= 7'b0100000; 4'b0111: seg <= 7'b0001111; 4'b1000: seg <= 7'b0000000; 4'b1001: seg <= 7'b0000100; 4'b1010: seg <= 7'b0001000; 4'b1011: seg <= 7'b1100000; 4'b1100: seg <= 7'b0110001; 4'b1101: seg <= 7'b1000010; 4'b1110: seg <= 7'b0110000; 4'b1111: seg <= 7'b0111000; endcase endmodule
// 测试文件:hex7seg_test.v `timescale 1ns / 1ps module hex7seg_test; // Inputs reg [3:0] x; // Outputs wire [3:0] an; wire [6:0] seg; // Instantiate the Unit Under Test (UUT) hex7seg uut ( .x(x), .an(an), .seg(seg) ); initial begin // Initialize Inputs x = 0; // Wait 100 ns for global reset to finish #100; // Add stimulus here x = 0; #100; x = 1; #100; x = 2; #100; x = 3; #100; x = 4; #100; x = 5; #100; x = 6; #100; x = 7; #100; x = 8; #100; x = 9; #100; x = 10; #100; x = 11; #100; x = 12; #100; x = 13; #100; x = 14; #100; x = 15; #100; end endmodule
// 引脚文件:hex7seg_ucf.ucf NET "x[3]" LOC = "T5"; NET "x[2]" LOC = "V8"; NET "x[1]" LOC = "U8"; NET "x[0]" LOC = "N8"; NET "an[3]" LOC = "P17"; NET "an[2]" LOC = "P18"; NET "an[1]" LOC = "N15"; NET "an[0]" LOC = "N16"; NET "seg[6]" LOC = "T17"; NET "seg[5]" LOC = "T18"; NET "seg[4]" LOC = "U17"; NET "seg[3]" LOC = "U18"; NET "seg[2]" LOC = "M14"; NET "seg[1]" LOC = "N14"; NET "seg[0]" LOC = "L14";
5、3-8译码器
3-8译码器真值表
// 设计文件:decode38a.v `timescale 1ns / 1ps module decode38a( input [2:0] a, output [7:0] y ); reg [7:0] y; always @ (a) case (a) 3'b000: y <= 8'b0000_0001; 3'b001: y <= 8'b0000_0010; 3'b010: y <= 8'b0000_0100; 3'b011: y <= 8'b0000_1000; 3'b100: y <= 8'b0001_0000; 3'b101: y <= 8'b0010_0000; 3'b110: y <= 8'b0100_0000; 3'b111: y <= 8'b1000_0000; endcase endmodule
// 测试文件:decode38a_test.v `timescale 1ns / 1ps module decode38a_test; // Inputs reg [2:0] a; // Outputs wire [7:0] y; // Instantiate the Unit Under Test (UUT) decode38a uut ( .a(a), .y(y) ); initial begin // Initialize Inputs a = 0; // Wait 100 ns for global reset to finish #100; // Add stimulus here a = 3'b000; #100; a = 3'b001; #100; a = 3'b010; #100; a = 3'b011; #100; a = 3'b100; #100; a = 3'b101; #100; a = 3'b110; #100; a = 3'b111; #100; end endmodule
// 引脚文件:decode38a_ucf.ucf NET "a[2]" LOC = "T5"; NET "a[1]" LOC = "V8"; NET "a[0]" LOC = "U8"; NET "y[7]" LOC = "T11"; NET "y[6]" LOC = "R11"; NET "y[5]" LOC = "N11"; NET "y[4]" LOC = "M11"; NET "y[3]" LOC = "V15"; NET "y[2]" LOC = "U15"; NET "y[1]" LOC = "V16"; NET "y[0]" LOC = "U16";
6、8-3优先编码器
8-3优先编码器真值表
// 设计文件:pencode83.v `timescale 1ns / 1ps module pencode83( input [7:0] x, output reg [2:0] y, output reg valid ); always @ (x) begin if (x[7] == 1) y <= 3'b111; else if (x[6] == 1) y <= 3'b110; else if (x[5] == 1) y <= 3'b101; else if (x[4] == 1) y <= 3'b100; else if (x[3] == 1) y <= 3'b011; else if (x[2] == 1) y <= 3'b010; else if (x[1] == 1) y <= 3'b001; else if (x[0] == 1) y <= 3'b000; if (x == 8'b0000_0000) valid <= 0; else valid <= 1; end endmodule
// 测试文件:pencode83_test.v `timescale 1ns / 1ps module pencode83_test; // Inputs reg [7:0] x; // Outputs wire [2:0] y; wire valid; // Instantiate the Unit Under Test (UUT) pencode83 uut ( .x(x), .y(y), .valid(valid) ); initial begin // Initialize Inputs x = 0; // Wait 100 ns for global reset to finish #100; // Add stimulus here x = 8'b0000_0000; #100; x = 8'b0000_0001; #100; x = 8'b0000_0011; #100; x = 8'b0000_0111; #100; x = 8'b0000_1111; #100; x = 8'b0001_1111; #100; x = 8'b0011_1111; #100; x = 8'b0111_1111; #100; x = 8'b1111_1111; #100; end endmodule
// 引脚文件:pencode83_ucf.ucf NET "x[7]" LOC = "T5"; NET "x[6]" LOC = "V8"; NET "x[5]" LOC = "U8"; NET "x[4]" LOC = "N8"; NET "x[3]" LOC = "M8"; NET "x[2]" LOC = "V9"; NET "x[1]" LOC = "T9"; NET "x[0]" LOC = "T10"; NET "y[2]" LOC = "T11"; NET "y[1]" LOC = "R11"; NET "y[0]" LOC = "N11"; NET "valid" LOC = "U16";
7、4位二进制-BCD 码转换器
4位二进制-BCD码转换器真值表
// 设计文件:binbcd4.v `timescale 1ns / 1ps module binbcd4( input [3:0] b, output reg [4:0] p ); always @ (b) begin if (b <= 9) p <= {1'b0, b[3:0]}; else p <= {1'b1, b[3:0]-4'b1010}; end endmodule
// 测试文件:binbcd4_test.v `timescale 1ns / 1ps module binbcd4_test; // Inputs reg [3:0] b; // Outputs wire [4:0] p; // Instantiate the Unit Under Test (UUT) binbcd4 uut ( .b(b), .p(p) ); initial begin // Initialize Inputs b = 0; // Wait 100 ns for global reset to finish #100; // Add stimulus here b = 4'b0000; #100; b = 4'b0001; #100; b = 4'b0010; #100; b = 4'b0011; #100; b = 4'b0100; #100; b = 4'b0101; #100; b = 4'b0110; #100; b = 4'b0111; #100; b = 4'b1000; #100; b = 4'b1001; #100; b = 4'b1010; #100; b = 4'b1011; #100; b = 4'b1100; #100; b = 4'b1101; #100; b = 4'b1110; #100; b = 4'b1111; #100; end endmodule
// 引脚文件:binbcd4_ucf.ucf NET "b[3]" LOC = "T5"; NET "b[2]" LOC = "V8"; NET "b[1]" LOC = "U8"; NET "b[0]" LOC = "N8"; NET "p[4]" LOC = "T11"; NET "p[3]" LOC = "R11"; NET "p[2]" LOC = "N11"; NET "p[1]" LOC = "M11"; NET "p[0]" LOC = "V15";
8、4位RCA加法器
4位RCA加法器
// 设计文件:adder4a.v `timescale 1ns / 1ps module FA( input a, b, cin, output cout, sum ); assign sum = a ^ b ^ cin; assign cout = a & b | a & cin | b & cin; endmodule module adder4a( input [3:0] a, input [3:0] b, output [3:0] s, output cf, output ovf ); wire c0, c1, c2; FA fa0(a[0], b[0], 1'b0, c0, s[0]); FA fa1(a[1], b[1], c0, c1, s[1]); FA fa2(a[2], b[2], c1, c2, s[2]); FA fa3(a[3], b[3], c2, cf, s[3]); assign ovf = c2 ^ cf; endmodule
// 测试文件:adder4a_test.v `timescale 1ns / 1ps module adder4a_test; // Inputs reg [3:0] a; reg [3:0] b; // Outputs wire [3:0] s; wire cf; // Instantiate the Unit Under Test (UUT) adder4a uut ( .a(a), .b(b), .s(s), .cf(cf), .ovf(ovf) ); initial begin // Initialize Inputs a = 0; b = 0; // Wait 100 ns for global reset to finish #100; // Add stimulus here a = 4'b0000; b = 4'b0001; #100; a = 4'b0000; b = 4'b0010; #100; a = 4'b0000; b = 4'b0011; #100; a = 4'b0111; b = 4'b0000; #100; a = 4'b0111; b = 4'b0001; #100; a = 4'b0111; b = 4'b0010; #100; a = 4'b0111; b = 4'b0011; #100; a = 4'b1111; b = 4'b0000; #100; a = 4'b1111; b = 4'b0001; #100; a = 4'b1111; b = 4'b0010; #100; a = 4'b1111; b = 4'b0011; #100; end endmodule
// 引脚文件:adder4a_ucf.ucf NET "a[3]" LOC = "T5"; NET "a[2]" LOC = "V8"; NET "a[1]" LOC = "U8"; NET "a[0]" LOC = "N8"; NET "b[3]" LOC = "M8"; NET "b[2]" LOC = "V9"; NET "b[1]" LOC = "T9"; NET "b[0]" LOC = "T10"; NET "s[3]" LOC = "T11"; NET "s[2]" LOC = "R11"; NET "s[1]" LOC = "N11"; NET "s[0]" LOC = "M11"; NET "cf" LOC = "V16"; NET "ovf" LOC = "U16";
9、4位CLA加法器
4位CLA加法器框图
// 设计文件:adder4a_cla.v `timescale 1ns / 1ps module adder4a_cla( input [3:0] a, input [3:0] b, output [3:0] s, output cf, output ovf ); wire G[3:0], P[3:0]; wire c0, c1, c2; assign G[0] = a[0] & b[0]; assign G[1] = a[1] & b[1]; assign G[2] = a[2] & b[2]; assign G[3] = a[3] & b[3]; assign P[0] = a[0] | b[0]; assign P[1] = a[1] | b[1]; assign P[2] = a[2] | b[2]; assign P[3] = a[3] | b[3]; assign c0 = G[0] | P[0] & 1'b0; assign c1 = G[1] | G[0] & P[1] | P[0] & P[1] & 1'b0; assign c2 = G[2] | G[1] & P[2] | G[0] & P[1] & P[2] | P[0]& P[1] & P[2] & 1'b0; assign cf = G[3] | G[2] & P[3] | G[1] & P[2] & P[3] | G[0] & P[1] & P[2] & P[3] | P[0] & P[1] & P[2] & P[3] & 1'b0; assign ovf = c2 ^ cf; assign s[0] = a[0] ^ b[0]; assign s[1] = a[1] ^ b[1] ^ c0; assign s[2] = a[2] ^ b[2] ^ c1; assign s[3] = a[3] ^ b[3] ^ c2; endmodule
// 测试文件:adder4a_cla_test.v `timescale 1ns / 1ps module adder4a_cla_test; // Inputs reg [3:0] a; reg [3:0] b; // Outputs wire [3:0] s; wire cf; wire ovf; // Instantiate the Unit Under Test (UUT) adder4a_cla uut ( .a(a), .b(b), .s(s), .cf(cf), .ovf(ovf) ); initial begin // Initialize Inputs a = 0; b = 0; // Wait 100 ns for global reset to finish #100; // Add stimulus here a = 4'b0000; b = 4'b0001; #100; a = 4'b0000; b = 4'b0010; #100; a = 4'b0000; b = 4'b0011; #100; a = 4'b0111; b = 4'b0000; #100; a = 4'b0111; b = 4'b0001; #100; a = 4'b0111; b = 4'b0010; #100; a = 4'b0111; b = 4'b0011; #100; a = 4'b1111; b = 4'b0000; #100; a = 4'b1111; b = 4'b0001; #100; a = 4'b1111; b = 4'b0010; #100; a = 4'b1111; b = 4'b0011; #100; end endmodule
// 引脚文件:adder4a_cla_ucf.ucf NET "a[3]" LOC = "T5"; NET "a[2]" LOC = "V8"; NET "a[1]" LOC = "U8"; NET "a[0]" LOC = "N8"; NET "b[3]" LOC = "M8"; NET "b[2]" LOC = "V9"; NET "b[1]" LOC = "T9"; NET "b[0]" LOC = "T10"; NET "s[3]" LOC = "T11"; NET "s[2]" LOC = "R11"; NET "s[1]" LOC = "N11"; NET "s[0]" LOC = "M11"; NET "cf" LOC = "V16"; NET "ovf" LOC = "U16";
10、4位移位器
4位移位器框图和功能表
// 设计文件:shift4.v `timescale 1ns / 1ps module shift4( input [2:0] s, input [3:0] d, output reg [3:0] y ); always @ (s or d) begin case (s) 3'b000: y <= d; 3'b001: y <= {1'b0, d[3:1]}; 3'b010: y <= {d[2:0], 1'b0}; 3'b011: y <= {d[0], d[3:1]}; 3'b100: y <= {d[2:0], d[3]}; 3'b101: y <= {d[3], d[3:1]}; 3'b110: y <= {d[1], d[0], d[3:2]}; 3'b111: y <= d; endcase end endmodule
// 测试文件:shift4_test.v `timescale 1ns / 1ps module shift4_test; // Inputs reg [2:0] s; reg [3:0] d; // Outputs wire [3:0] y; // Instantiate the Unit Under Test (UUT) shift4 uut ( .s(s), .d(d), .y(y) ); initial begin // Initialize Inputs s = 0; d = 0; // Wait 100 ns for global reset to finish #100; // Add stimulus here d = 4'b0010; #100; s = 3'b000; #100; s = 3'b001; #100; s = 3'b010; #100; s = 3'b011; #100; s = 3'b100; #100; s = 3'b101; #100; s = 3'b110; #100; s = 3'b111; #100; end endmodule
// 引脚文件:shift4_ucf.ucf NET "s[2]" LOC = "T5"; NET "s[1]" LOC = "V8"; NET "s[0]" LOC = "U8"; NET "d[3]" LOC = "M8"; NET "d[2]" LOC = "V9"; NET "d[1]" LOC = "T9"; NET "d[0]" LOC = "T10"; NET "y[3]" LOC = "T11"; NET "y[2]" LOC = "R11"; NET "y[1]" LOC = "N11"; NET "y[0]" LOC = "M11";
11、4位移位寄存器
4位移位寄存器电路图
// 设计文件:shiftreg.v `timescale 1ns / 1ps module shiftreg( input data_in, input clk, input clr, output reg [3:0] q ); always @ (posedge clr or posedge clk) begin if (clr == 1) q <= 4'b0000; else q <= {data_in, q[3:1]}; end endmodule
// 测试文件:shiftreg_test.v `timescale 1ns / 1ps module shiftreg_test; // Inputs reg data_in; reg clk; reg clr; // Outputs wire [3:0] q; // Instantiate the Unit Under Test (UUT) shiftreg uut ( .data_in(data_in), .clk(clk), .clr(clr), .q(q) ); initial begin // Initialize Inputs data_in = 0; clk = 0; clr = 0; // Wait 100 ns for global reset to finish #100; // Add stimulus here #100; clr = 1; data_in = 1; #100; clk = 1; #100; clk = 0; clr = 0; #100; clk = 1; #100; clk = 0; #100; clk = 1; #100; clk = 0; #100; clk = 1; #100; clk = 0; #100; clk = 1; #100; clk = 0; clr = 1; end endmodule
// 引脚文件:shiftreg_ucf.ucf NET "data_in" LOC = "T5"; NET "clk" LOC = "C9"; NET "clr" LOC = "B8"; NET "q[3]" LOC = "T11"; NET "q[2]" LOC = "R11"; NET "q[1]" LOC = "N11"; NET "q[0]" LOC = "M11";
12、4位移位寄存器生成伪随机数列
// 设计文件:pseurandseq.v `timescale 1ns / 1ps module pseurandseq( input clk, input clr, output reg [7:0] q ); always @ (posedge clr or posedge clk) begin if (clr == 1) q <= 4'b00001000; else q <= {q[3:0], q[0], q[3:2], q[0]^q[1]}; end endmodule
// 测试文件:pseurandseq_test.v `timescale 1ns / 1ps module pseurandseq_test; // Inputs reg clk; reg clr; // Outputs wire [7:0] q; integer i; // Instantiate the Unit Under Test (UUT) pseurandseq uut ( .clk(clk), .clr(clr), .q(q) ); initial begin // Initialize Inputs clk = 0; clr = 0; // Wait 100 ns for global reset to finish #100; // Add stimulus here clr = 1; #100; clr = 0; #100; for (i=0; i<32; i=i+1) begin clk = 1; #100; clk = 0; #100; end end endmodule
// 引脚文件:pseurandseq_ucf.ucf NET "clk" LOC = "C9"; NET "clr" LOC = "B8"; NET "q[7]" LOC = "T11"; NET "q[6]" LOC = "R11"; NET "q[5]" LOC = "N11"; NET "q[4]" LOC = "M11"; NET "q[3]" LOC = "V15"; NET "q[2]" LOC = "U15"; NET "q[1]" LOC = "V16"; NET "q[0]" LOC = "U16";
13、7段译码器扫描显示2位
// 设计文件:Hex7seg2num.v `timescale 1ns / 1ps module Hex7seg2num( input clk, input clr, input [3:0] high, input [3:0] low, output reg [3:0] an, output reg [6:0] seg ); parameter CLK_COUNT = 249999; reg [31:0] count; reg mclk; always @ (posedge clk) begin if (clr) begin count <= 0; mclk <= 0; end else if (count == CLK_COUNT) begin count <= 0; mclk <= ~mclk; end else count <= count+1; end always @ (mclk) begin if (mclk == 0) begin an <= 4'b1101; case(high) 4'b0000: seg <= 7'b0000001; 4'b0001: seg <= 7'b1001111; 4'b0010: seg <= 7'b0010010; 4'b0011: seg <= 7'b0000110; 4'b0100: seg <= 7'b1001100; 4'b0101: seg <= 7'b0100100; 4'b0110: seg <= 7'b0100000; 4'b0111: seg <= 7'b0001111; 4'b1000: seg <= 7'b0000000; 4'b1001: seg <= 7'b0000100; 4'b1010: seg <= 7'b0001000; 4'b1011: seg <= 7'b1100000; 4'b1100: seg <= 7'b0110001; 4'b1101: seg <= 7'b1000010; 4'b1110: seg <= 7'b0110000; 4'b1111: seg <= 7'b0111000; endcase end else if (mclk == 1) begin an <= 4'b1110; case(low) 4'b0000: seg <= 7'b0000001; 4'b0001: seg <= 7'b1001111; 4'b0010: seg <= 7'b0010010; 4'b0011: seg <= 7'b0000110; 4'b0100: seg <= 7'b1001100; 4'b0101: seg <= 7'b0100100; 4'b0110: seg <= 7'b0100000; 4'b0111: seg <= 7'b0001111; 4'b1000: seg <= 7'b0000000; 4'b1001: seg <= 7'b0000100; 4'b1010: seg <= 7'b0001000; 4'b1011: seg <= 7'b1100000; 4'b1100: seg <= 7'b0110001; 4'b1101: seg <= 7'b1000010; 4'b1110: seg <= 7'b0110000; 4'b1111: seg <= 7'b0111000; endcase end end endmodule
// 测试文件:Hex7seg2num_test.v `timescale 1ns / 1ps module Hex7seg2num_test; // Inputs reg clk; reg clr; reg [3:0] high; reg [3:0] low; // Outputs wire [3:0] an; wire [6:0] seg; // Instantiate the Unit Under Test (UUT) Hex7seg2num uut ( .clk(clk), .clr(clr), .high(high), .low(low), .an(an), .seg(seg) ); initial begin // Initialize Inputs clk = 0; clr = 0; high = 0; low = 0; // Wait 5 ns for global reset to finish #5; // Add stimulus here clr = 1; high = 2; low = 4; #5; clr = 0; end always #5 clk = ~clk; endmodule
// 引脚文件:Hex7seg2num_ucf.ucf NET "clk" LOC = "V10"; NET "clr" LOC = "C9"; NET "high[3]" LOC = "T5"; NET "high[2]" LOC = "V8"; NET "high[1]" LOC = "U8"; NET "high[0]" LOC = "N8"; NET "low[3]" LOC = "M8"; NET "low[2]" LOC = "V9"; NET "low[1]" LOC = "T9"; NET "low[0]" LOC = "T10"; NET "an[3]" LOC = "P17"; NET "an[2]" LOC = "P18"; NET "an[1]" LOC = "N15"; NET "an[0]" LOC = "N16"; NET "seg[6]" LOC = "T17"; NET "seg[5]" LOC = "T18"; NET "seg[4]" LOC = "U17"; NET "seg[3]" LOC = "U18"; NET "seg[2]" LOC = "M14"; NET "seg[1]" LOC = "N14"; NET "seg[0]" LOC = "L14";
14、Traffic controller(Moore FSM)
Moore FSM状态转换图
// 设计文件:trafficcontrollermoore.v `timescale 1ns / 1ps module trafficcontrollermoore( input TA, input TB, input clk, input clr, output reg [2:0] LA, output reg [2:0] LB ); reg [1:0] state, nextstate; reg [31:0] count; reg mclk; parameter S0 = 2'b00; parameter S1 = 2'b01; parameter S2 = 2'b10; parameter S3 = 2'b11; parameter GREEN = 3'b100; parameter YELLOW = 3'b010; parameter RED = 3'b001; parameter CLK_COUNT = 4; //板级验证的时候该值改为249999999; always @ (posedge clk or posedge clr) begin if (clr) begin count <= 0; mclk <= 0; end else if (count == CLK_COUNT) begin count <= 0; mclk <= ~mclk; end else count <= count+1; end always @ (posedge mclk or posedge clr) begin if (clr) state <= S0; else state <= nextstate; end always @ (*) begin case (state) S0: if (TA) nextstate = S0; else nextstate = S1; S1: nextstate = S2; S2: if (TB) nextstate = S2; else nextstate = S3; S3: nextstate = S0; default: nextstate = S0; endcase end always @ (*) begin case (state) S0: begin LA = GREEN; LB = RED; end S1: begin LA = YELLOW; LB = RED; end S2: begin LA = RED; LB = GREEN; end S3: begin LA = RED; LB = YELLOW; end default: begin LA = GREEN; LB = RED; end endcase end endmodule
// 测试文件:trafficcontrollermoore_test.v `timescale 1ns / 1ps module trafficcontrollermoore_test; // Inputs reg TA; reg TB; reg clk; reg clr; // Outputs wire [2:0] LA; wire [2:0] LB; // Instantiate the Unit Under Test (UUT) trafficcontrollermoore uut ( .TA(TA), .TB(TB), .clk(clk), .clr(clr), .LA(LA), .LB(LB) ); initial begin // Initialize Inputs TA = 0; TB = 0; clk = 0; clr = 0; // Wait 100 ns for global reset to finish #100; // Add stimulus here clr = 1; #100; clr = 0; #45; TA = 1; TB = 0; #100; TA = 0; TB = 0; #200 TA = 1; TB = 1; #100; TA = 1; TB = 0; #200; TA = 0; TB = 1; #100; clr = 1; #100; clr = 0; end always # 5 clk <= ~clk; endmodule
// 引脚文件:trafficcontrollermoore_ucf.ucf NET "clk" LOC = "V10"; NET "clr" LOC = "C9"; NET "TA" LOC = "T5"; NET "TB" LOC = "V8"; NET "LA[2]" LOC = "T11"; NET "LA[1]" LOC = "R11"; NET "LA[0]" LOC = "N11"; NET "LB[2]" LOC = "U15"; NET "LB[1]" LOC = "V16"; NET "LB[0]" LOC = "U16";
15、Traffic controller(Mealy FSM)
Mealy FSM状态转换图
// 设计文件:trafficcontrollermealy.v `timescale 1ns / 1ps module trafficcontrollermealy( input TA, input TB, input clk, input clr, output reg [2:0] LA, output reg [2:0] LB ); reg [1:0] state, nextstate; reg [31:0] count; reg mclk; parameter S0 = 2'b00; parameter S1 = 2'b01; parameter S2 = 2'b10; parameter S3 = 2'b11; parameter GREEN = 3'b100; parameter YELLOW = 3'b010; parameter RED = 3'b001; parameter CLK_COUNT = 249999999; //板级验证的时候该值改为249999999; always @ (posedge clk or posedge clr) begin if (clr) begin count <= 0; mclk <= 0; end else if (count == CLK_COUNT) begin count <= 0; mclk <= ~mclk; end else count <= count+1; end always @ (posedge mclk or posedge clr) begin if (clr) state <= S0; else state <= nextstate; end always @ (*) begin case (state) S0: if (TA) nextstate = S0; else nextstate = S1; S1: nextstate = S2; S2: if (TB) nextstate = S2; else nextstate = S3; S3: nextstate = S0; default: nextstate = S0; endcase end always @ (*) begin case (nextstate) S0: begin LA = GREEN; LB = RED; end S1: begin LA = YELLOW; LB = RED; end S2: begin LA = RED; LB = GREEN; end S3: begin LA = RED; LB = YELLOW; end default: begin LA = GREEN; LB = RED; end endcase end endmodule
// 测试文件:trafficcontrollermealy_test.v `timescale 1ns / 1ps module trafficcontrollermealy_test; // Inputs reg TA; reg TB; reg clk; reg clr; // Outputs wire [2:0] LA; wire [2:0] LB; // Instantiate the Unit Under Test (UUT) trafficcontrollermealy uut ( .TA(TA), .TB(TB), .clk(clk), .clr(clr), .LA(LA), .LB(LB) ); initial begin // Initialize Inputs TA = 0; TB = 0; clk = 0; clr = 0; // Wait 100 ns for global reset to finish #100; // Add stimulus here clr = 1; #100; clr = 0; #45; TA = 1; TB = 0; #100; TA = 0; TB = 0; #200 TA = 1; TB = 1; #100; TA = 1; TB = 0; #200; TA = 0; TB = 1; #100; clr = 1; #100; clr = 0; end always # 5 clk <= ~clk; endmodule
// 引脚文件:trafficcontrollermealy_ucf.ucf NET "clk" LOC = "V10"; NET "clr" LOC = "C9"; NET "TA" LOC = "T5"; NET "TB" LOC = "V8"; NET "LA[2]" LOC = "T11"; NET "LA[1]" LOC = "R11"; NET "LA[0]" LOC = "N11"; NET "LB[2]" LOC = "U15"; NET "LB[1]" LOC = "V16"; NET "LB[0]" LOC = "U16";
相关推荐
"HFSS软件包下的圆锥(圆形)喇叭天线模型制作与参数调整:自主创造,实验验证,全流程教程指导",HFSS圆锥(圆形)喇叭天线 天线模型,自己做的,附带结果,可改参数,HFSS软件包 (有教程,具体到每一步,可以自己做出来) ,HFSS; 圆锥(圆形)喇叭天线; 模型自制; 参数可改; HFSS软件包; 教程详尽。,HFSS圆锥喇叭天线模型:可自定义参数与结果
免费JAVA毕业设计 2024成品源码+论文+数据库+启动教程 启动教程:https://www.bilibili.com/video/BV1SzbFe7EGZ 项目讲解视频:https://www.bilibili.com/video/BV1Tb421n72S 二次开发教程:https://www.bilibili.com/video/BV18i421i7Dx
"基于S7-200 PLC与组态王技术构建的智能化新能源汽车电池检测系统上位机软件平台",基于S7-200plc与组态王组态的新能源汽车电池检测系统上位机 ,S7-200plc;组态王组态;新能源汽车电池检测系统;上位机,"基于PLC与组态王的汽车电池检测上位机系统"
免费JAVA毕业设计 2024成品源码+论文+数据库+启动教程 启动教程:https://www.bilibili.com/video/BV1SzbFe7EGZ 项目讲解视频:https://www.bilibili.com/video/BV1Tb421n72S 二次开发教程:https://www.bilibili.com/video/BV18i421i7Dx
nodejs010-nodejs-docs-0.10.5-8.el6.centos.alt.x86_64.rpm
免费JAVA毕业设计 2024成品源码+论文+录屏+启动教程 启动教程:https://www.bilibili.com/video/BV1SzbFe7EGZ 项目讲解视频:https://www.bilibili.com/video/BV1Tb421n72S 二次开发教程:https://www.bilibili.com/video/BV18i421i7Dx
“基于Cadence Orcad的全面元器件数据库管理系统——全配版与基础版对比分析”,搭建使用Cadence Orcad CIS元器件数据库(默认为Access数据库,如需MySQL数据库需提前沟通),含orcad符号库,Allegro PCB库 —————————————————— 该元器件数据库种类丰富,大分类就有28种(全配版,含有很多如海思,全志,瑞芯微,TI,Xilinx等主流复杂IC的库信息),20种(基础版)。 ———————————————————— 全配版包含1000多种元器件属性信息汇总,都是已验证使用过的,可直接用于自己的电路设计。 全配版还附有大部分与元器件PCB封装已匹配好的的3D模型。 强烈建议原理图库及封装库基于数据库的方式来管理,好处主要有以下几点: 1. 易于管理,可通过数据库文件批量添加、更改或删除器件参数; 2. 减少原理图库的种类, 同类器件只需要新建一次原理图库, 例如不同阻值、精度的电阻; 3. 器件具有唯一性, 每个器件的参数都是唯一的; 4. 方便使用, 如使用 Link Database Part 功能,可以快速完成器件批量替,
1、文件内容:ptlib-devel-2.10.10-6.el7.rpm以及相关依赖 2、文件形式:tar.gz压缩包 3、安装指令: #Step1、解压 tar -zxvf /mnt/data/output/ptlib-devel-2.10.10-6.el7.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm 4、安装指导:私信博主,全程指导安装
西门子S7-1200+5轴伺服驱动系统的走工艺对象技术解析——采用脉冲输出驱动方式的控制方法及在全博途V15.1程序中的应用研究。,S7-1200+5轴伺服 走工艺对象 脉冲输出驱动方式 适用于西门子s7-1200+第三方伺服驱动器 全套博途v15.1程序 ,S7-1200;5轴伺服;走工艺对象;脉冲输出驱动方式;第三方伺服驱动器;博途v15.1程序,西门子S7-1200 5轴伺服系统控制程序
免费JAVA毕业设计 2024成品源码+论文+数据库+启动教程 启动教程:https://www.bilibili.com/video/BV1SzbFe7EGZ 项目讲解视频:https://www.bilibili.com/video/BV1Tb421n72S 二次开发教程:https://www.bilibili.com/video/BV18i421i7Dx
《四层三列堆垛式立体库控制系统:带解释的梯形图接线原理图及IO分配与组态画面详解》,4x3堆垛式立体库4层3列四层三列书架式立体库控制系统 带解释的梯形图接线图原理图图纸,io分配,组态画面 ,立体库; 堆垛式; 控制系统; 梯形图; 接线图; 原理图; IO分配; 组态画面,"立体库控制系统原理图:四层三列堆垛式书架的IO分配与组态画面"
1、文件内容:pyOpenSSL-0.13.1-4.el7.rpm以及相关依赖 2、文件形式:tar.gz压缩包 3、安装指令: #Step1、解压 tar -zxvf /mnt/data/output/pyOpenSSL-0.13.1-4.el7.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm 4、安装指导:私信博主,全程指导安装
免费JAVA毕业设计 2024成品源码+论文+数据库+启动教程 启动教程:https://www.bilibili.com/video/BV1SzbFe7EGZ 项目讲解视频:https://www.bilibili.com/video/BV1Tb421n72S 二次开发教程:https://www.bilibili.com/video/BV18i421i7Dx
基于三菱PLC与MCGS技术的防盗门报警系统:梯形图接线图原理及IO分配、组态画面详解,基于三菱PLC和MCGS的防盗门报警器 带解释的梯形图接线图原理图图纸,io分配,组态画面 ,三菱PLC; MCGS; 防盗门报警器; 梯形图接线图; IO分配; 组态画面,基于三菱PLC与MCGS的报警器系统:梯形图接线与组态画面详解
"COMSOL金膜表面等离子共振(SPR)分析:不同入射角下的共振角度观察",comsol金膜表面等离子共振SPR,不同入射角查看共振角度 ,关键词:comsol金膜表面;等离子共振(SPR);不同入射角;共振角度;分离度;角度调节;材料表面光;生物传感;互动现象;实时分析,"COMSOL研究金膜表面等离子共振: 角度变化影响共振角度"
1. 机器学习与深度学习 机器学习是人工智能的核心领域,旨在通过数据训练模型,使计算机能够从经验中学习和改进。监督学习、无监督学习和强化学习是其主要分支,广泛应用于图像识别、语音处理和预测分析等场景。深度学习作为机器学习的重要子领域,通过神经网络模拟人脑的工作机制,尤其在图像分类、自然语言处理和自动驾驶等领域取得了突破性进展。深度学习模型如卷积神经网络(CNN)和循环神经网络(RNN)已成为许多AI应用的基础。 2. 自然语言处理与计算机视觉 自然语言处理(NLP)使计算机能够理解、生成和处理人类语言,关键技术包括机器翻译、语音识别、情感分析和问答系统。例如,智能助手(如Siri、Alexa)和聊天机器人(如ChatGPT)都依赖于NLP技术。计算机视觉则让计算机能够“看懂”图像和视频,广泛应用于人脸识别、自动驾驶、医疗影像分析等领域。目标检测、图像分割和视频分析等技术正在推动安防、零售和制造业的智能化转型。 3. 强化学习与AI伦理 强化学习通过试错和奖励机制,训练智能体在复杂环境中做出最优决策,广泛应用于游戏AI(如AlphaGo)、机器人控制和资源调度等领域。与此同时,随着AI技术的快速发展,AI伦理和社会影响也成为重要研究方向。如何确保AI的公平性、透明性和隐私保护,以及应对AI对就业和社会结构的潜在影响,已成为学术界和产业界共同关注的焦点。AI的可持续发展离不开技术与伦理的平衡。
不同放牧策略对草原土壤性质的影响研究——基于机器学习.pdf
本资源提供一种基于Proteus仿真的纯硬件NE555呼吸灯设计方案,结合NE555定时器、三极管(如2N2222或8050)、电阻、电容等元件,完整实现LED的呼吸灯效果。内容包括: Proteus仿真模型搭建:电路原理图设计、虚拟示波器波形分析; 硬件实现步骤:元件选型、焊接调试、实测波形对比; 参数调优方法:通过仿真快速调整RC参数控制呼吸频率与渐变平滑度。 目标: 掌握Proteus中NE555电路仿真技巧; 理解硬件电路与仿真模型的匹配性; 学习从虚拟仿真到实物落地的全流程设计; 培养故障排查与参数优化能力。 核心功能: 仿真验证:在Proteus中模拟NE555的PWM输出及LED亮度渐变效果; 硬件实现:通过三极管驱动电路将仿真结果转化为实物呼吸灯; 双向调试:支持仿真与硬件实测数据对比,快速定位设计问题。 关键模块: NE555无稳态多谐振荡器(控制占空比渐变); Proteus虚拟示波器(观测PWM波形变化); 三极管电流放大电路(驱动高亮度LED)。 设计亮点 虚实结合:通过Proteus仿真降低硬件试错成本,提升学习效率。
,全c源程序太阳能并网逆变器全C源程序单相3kw5kw,板图原理图清单,可以直接打板验证,超好的生产光伏逆变器的技术方案,量产方案
免费JAVA毕业设计 2024成品源码+论文+数据库+启动教程 启动教程:https://www.bilibili.com/video/BV1SzbFe7EGZ 项目讲解视频:https://www.bilibili.com/video/BV1Tb421n72S 二次开发教程:https://www.bilibili.com/video/BV18i421i7Dx