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";
相关推荐
4. Nexys3开发板:详细讲解Nexys3的硬件特性、接口和开发工具,如何设置和使用。 5. Digilent驱动安装:说明如何下载和安装Digilent的驱动程序,确保开发板能与计算机正确通信。 6. EDK工具使用:深入理解Xilinx EDK...
OpenGL是一种强大的图形库,用于创建2D和3D图形,广泛应用于游戏开发、科学可视化、工程设计等领域。在这个项目中,我们看到一个基于OpenGL的机械臂运动仿真程序,它能够实现机械臂在四个方向上的旋转。这样的模拟对于理解机械臂的工作原理、机器人控制算法以及进行虚拟环境中的机械臂运动测试具有重要意义。 我们需要了解OpenGL的基础知识。OpenGL是一个跨语言、跨平台的编程接口,用于渲染2D和3D矢量图形。它提供了大量的函数来处理图形的绘制,包括几何形状的定义、颜色设置、光照处理、纹理映射等。开发者通过OpenGL库调用这些函数,构建出复杂的图形场景。 在这个机械臂仿真程序中,C#被用来作为编程语言。C#通常与Windows平台上的.NET Framework配合使用,提供了一种面向对象的、类型安全的语言,支持现代编程特性如LINQ、异步编程等。结合OpenGL,C#可以构建高性能的图形应用。 机械臂的运动仿真涉及到几个关键的计算和控制概念: 1. **关节角度**:机械臂的每个部分(或关节)都有一个或多个自由度,表示为关节角度。这些角度决定了机械臂各部分的位置和方向。 2. **正向运动学**:根据关节角度计算机械臂末端执行器(如抓手)在空间中的位置和方向。这涉及将各个关节的角度转换为欧拉角或四元数,然后转化为笛卡尔坐标系的X、Y、Z位置和旋转。 3. **反向运动学**:给定末端执行器的目标位置和方向,计算出各关节所需的理想角度。这是一个逆向问题,通常需要解决非线性方程组。 4. **运动规划**:确定从当前状态到目标状态的路径,确保机械臂在运动过程中避免碰撞和其他约束。 5. **OpenGL的使用**:在OpenGL中,我们首先创建几何模型来表示机械臂的各个部分。然后,使用矩阵变换(如旋转、平移和缩放)来更新关节角度对模型的影响。这些变换组合起来,形成机械臂的动态运动。 6. **四向旋转**:机械臂可能有四个独立的旋转轴,允许它在X、Y、Z三个轴上旋转,以及额外的绕自身轴线的旋转。每个轴的旋转都由对应的关节角度控制。 7. **交互控制**:用户可能可以通过输入设备(如鼠标或键盘)调整关节角度,实时观察机械臂的运动。这需要将用户输入转换为关节角度,并应用到运动学模型中。 8. **图形渲染**:OpenGL提供了多种渲染技术,如深度测试、光照模型、纹理映射等,可以用于提高机械臂模拟的真实感。例如,可以添加材质和纹理来模拟金属表面,或者使用光照来增强立体感。 这个项目结合了OpenGL的图形渲染能力与C#的编程灵活性,构建了一个可以直观展示机械臂运动的仿真环境。通过理解并实现这些关键概念,开发者不仅能够学习到图形编程技巧,还能深入理解机器人学的基本原理。
android11 udpate-engine 系统升级模块源码下载
内容概要:本文详细介绍了如何在MATLAB环境中实现SVM二分类算法,涵盖数据预处理、参数寻优及结果可视化的全过程。首先进行数据归一化处理,确保各特征在同一量纲下参与模型训练。接着采用网格搜索法对SVM的关键参数c(惩罚系数)和g(核参数)进行自动化寻优,利用5折交叉验证评估每组参数的表现。最后通过等高线图和3D曲面图直观展示参数与准确率之间的关系,并完成最终模型的训练与预测。 适合人群:具有一定MATLAB编程基础的研究人员和技术爱好者,尤其是从事机器学习、数据分析领域的从业者。 使用场景及目标:适用于需要快速搭建SVM二分类模型并进行参数调优的项目。主要目标是在短时间内获得较高准确度的分类结果,同时掌握SVM的工作原理及其在MATLAB中的具体应用方法。 其他说明:文中提供了完整的代码示例,便于读者直接上手实践。此外还提到了一些常见的注意事项,如数据格式要求、类别不平衡处理以及特征工程的重要性等。
ffmpeg
江科大CAN入门教程,万字长文理解
内容概要:本文详细介绍了基于新唐N79E814单片机的移动电源设计方案,涵盖硬件架构、PCB原理图、电路设计、代码实现等方面。移动电源主要由电池、充电电路和输出电路构成,文中重点讲解了5V1A和5V2.1A两路输出的设计思路,包括同步整流、PWM控制、充电管理等关键技术。同时,文章还探讨了PCB布局、烧录注意事项、效率优化等内容,并提供了具体的代码示例和调试建议。 适合人群:具有一定电子技术和单片机开发基础的工程师和技术爱好者。 使用场景及目标:适用于希望深入了解移动电源设计原理和实现方法的人群,旨在帮助读者掌握从原理图绘制到实际产品制作的全过程,提升电路设计和调试能力。 其他说明:文章不仅提供了理论知识,还包括大量实践经验分享,如常见的调试陷阱和解决方法,有助于读者在实践中少走弯路。
动漫角色分割_基于深度学习实现的高精度动漫角色分割算法_附项目源码_优质项目实战
javacv实现的支持多种音视频播放的播放器,比如MP4、avi、mkv、flv、MP3、ogg、wav、au等多种音视频格式,非常好用。
开发调试demo,简单的自动登录功能,插件开发入门参考
内容概要:本文详细介绍了通过修改Windows注册表来启用和配置被禁用的用户账户(如WDAGUtilityAccount)的过程。首先,通过计算机管理界面查看被禁用的用户账户,并进入注册表编辑器定位到HKEY_LOCAL_MACHINE\SAM\SAM\Domains\Account\Users路径下的相应用户条目。接着,通过对特定用户的二进制数据进行编辑,包括复制和修改关键字段,实现对被禁用账户的克隆与重新启用。最后,验证账户状态的变化,并通过远程桌面连接测试新配置的有效性。 适合人群:具备一定Windows系统管理基础的技术人员,尤其是负责企业内部网络和用户账户管理的IT管理员。 使用场景及目标:①当需要恢复或重新配置被禁用的用户账户时;②在进行系统故障排除或安全审计时,了解如何通过注册表直接操作用户账户;③确保特定用户能够正常登录并访问远程桌面服务。 阅读建议:本文涉及较为底层的系统操作,建议读者在实际操作前充分备份系统和注册表,避免误操作导致系统不稳定。同时,对于不熟悉注册表编辑的用户,应先在测试环境中练习,确保掌握相关技能后再应用于生产环境。此外,建议结合官方文档或其他权威资料,加深对Windows用户账户管理机制的理解。
2025免费微信小程序毕业设计成品,包括源码+数据库+往届论文资料,附带启动教程和安装包。 启动教程:https://www.bilibili.com/video/BV1BfB2YYEnS 讲解视频:https://www.bilibili.com/video/BV1BVKMeZEYr 技术栈:Uniapp+Vue.js+SpringBoot+MySQL。 开发工具:Idea+VSCode+微信开发者工具。
内容概要:本文详细介绍了基于西门子S7-1200 PLC的两部六层电梯控制系统的设计与实现。主要内容涵盖前期准备工作,如选择合适的PLC型号和配置硬件;核心逻辑部分深入讲解了梯形图编程的具体实现方法,包括楼层呼叫逻辑、电梯运行方向控制以及两部电梯之间的协同工作;此外,文章还探讨了仿真测试的方法及其重要性,提供了许多实用技巧和注意事项。通过具体实例展示了如何利用博途V15软件进行电梯系统的开发,并分享了一些实际操作中的经验和常见问题解决方案。 适合人群:从事工业自动化领域的工程师和技术人员,特别是那些对PLC编程有兴趣或者正在参与类似项目的从业者。 使用场景及目标:适用于需要理解和掌握S7-1200 PLC编程技能的人群,尤其是希望通过实际案例加深对梯形图编程理解的学习者。目标是在实践中提高编程能力,能够独立完成类似的工程项目。 其他说明:文中不仅包含了详细的理论解释,还有丰富的代码片段供读者参考。对于初学者而言,建议先从单部电梯开始练习,逐步过渡到复杂的双梯联调。同时,作者强调了仿真测试的重要性,指出这是验证程序正确性和优化性能的关键步骤。
2025免费微信小程序毕业设计成品,包括源码+数据库+往届论文资料,附带启动教程和安装包。 启动教程:https://www.bilibili.com/video/BV1BfB2YYEnS 讲解视频:https://www.bilibili.com/video/BV1BVKMeZEYr 技术栈:Uniapp+Vue.js+SpringBoot+MySQL。 开发工具:Idea+VSCode+微信开发者工具。
内容概要:该资源为大学英语四级听力练习音频 MP3,包含丰富多样的听力素材。涵盖四级考试常见的各类场景,如校园生活(课程学习、社团活动等)、日常社交(聚会、聊天等)、工作求职(面试、职场事务等)、旅行交通(出行方式、景点介绍等)、饮食健康(餐厅点餐、健康养生等)。音频内容依照四级听力考试题型和难度精心录制,有短对话、长对话、短文听力等形式,且语速、口音等符合四级考试要求,助力考生熟悉考试形式与节奏。 适合人群:正在备考大学英语四级考试,希望提升听力水平的学生;英语基础中等,需要通过针对性练习来适应四级听力难度、提升听力理解能力的学习者;对英语听力学习有需求,想通过大量练习积累场景词汇、熟悉英语表达习惯的人群。 能学到什么:①熟悉四级听力考试的各类场景词汇,增强词汇储备并提升在听力语境中的反应速度;②掌握不同场景下的英语常用表达和句式,提升英语语言运用能力;③锻炼听力理解技巧,如抓取关键词、推断隐含意思、梳理篇章逻辑等;④适应四级听力考试的语速、口音和题型设置,增强应试能力和自信心。 阅读建议:制定系统的练习计划,定期定量进行听力练习,如每天安排 30 - 60 分钟;第一遍泛听,了解大致内容和主题;第二遍精听,逐句听写或分析不懂的词汇和句子;对照听力原文,明确错误和没听懂的地方,积累生词和表达;定期进行模拟测试,利用该音频模拟考试环境,检验学习效果并调整学习策略。
2000-2017年各省天然气消费量数据 1、时间:2000-2017年 2、来源:国家统计j、能源nj 3、指标:行政区划代码、城市、年份、天然气消费量 4、范围:31省
内容概要:本文详细介绍了基于西门子PLC1200的自动化控制系统,涵盖了PLC与库卡机器人通过Profinet通讯、PTO模式控制松下伺服、36路模拟量处理(包括压力检测、位置检测及压力输出)、以及26个温控器通过485总线通讯的关键技术和实现方法。此外,还包括了昆仑通态触摸屏的人机交互界面设计,提供了详细的硬件组态、软件编程指导和设备操作说明。 适合人群:从事工业自动化领域的工程师和技术人员,尤其是那些负责多设备协同控制项目的设计和实施的专业人士。 使用场景及目标:适用于需要整合多种设备(如PLC、机器人、伺服系统、温控器等)的复杂自动化生产线。主要目标是提高生产效率、增强系统的稳定性和可靠性,同时降低维护成本。 其他说明:文中不仅提供了具体的编程实例和硬件配置指南,还分享了许多实际调试过程中积累的经验教训,有助于读者在实际应用中少走弯路。
内容概要:本文深入探讨了AUTOSAR BSW(Basic Software)层所提供的各类服务、驱动、接口和管理器模块及其功能。BSW提供的服务包括I/O、Memory、Crypto、Communication、Off-board Communication和System等,涵盖了标准化的访问方式以确保不同硬件和系统的兼容性与安全性。BSW里的驱动分为内部驱动和外部驱动,分别用于控制和访问微控制器内部和外部的设备,确保硬件功能的正常运作。BSW里的接口(xx_IF)对下层模块进行抽象和封装,提供标准API接口,使上层应用无需关注底层硬件细节。BSW里的管理器(xxxM)则为多个客户端提供特定服务,能够修改或适配调整一些数据,以满足复杂需求。此外,文中还简要介绍了AUTOSAR里的库文件,它们是无状态的函数集合,可被多个模块调用以实现特定功能。 适合人群:对汽车电子软件架构有一定了解,尤其是对AUTOSAR标准感兴趣的工程师和技术人员。 使用场景及目标:①理解BSW层提供的各类服务及其应用场景;②掌握BSW中驱动、接口和管理器模块的设计原理和功能;③了解库文件的作用及其在AUTOSAR架构中的位置。 其他说明:本文详细解释了BSW层各组件的功能和作用,帮助读者更好地理解AUTOSAR架构的设计思想和实现方法。建议读者结合实际项目经验,深入研究各模块的具体实现和应用场景。
内容概要:本文介绍了西门子1200系列PLC的伺服步进FB块程序,该程序由两个FB块组成,分别采用SCL语言和梯形图编写,支持PTO和PN模式,适用于多种伺服系统和步进电机。程序经过实际调试,稳定性高,兼容性强,能够灵活应用于单轴或多轴控制系统。文中提供了详细的代码示例和调试指南,帮助用户快速上手并解决常见问题。 适合人群:从事工业自动化控制领域的工程师和技术人员,尤其是使用西门子1200系列PLC进行项目开发的人员。 使用场景及目标:①用于单轴或多轴伺服步进系统的控制;②提高项目的开发效率和稳定性;③减少重复开发的工作量,加快项目进度。 其他说明:程序需要在TIA V14及以上版本打开,附带详细的文档说明和实际项目视频链接,方便用户理解和使用。