Mọi người cho e xin code verilog hiển thị đồng hồ đếm giờ,phút,giây trên led 7 đoạn ứng dụng trên bộ kit altera De2 với ạ.Em mới học về FPGA nên chưa biết viết thế nào?Anh nào biết chỉ em với,em xin cảm ơn rất nhiều^^.
Thông báo
Collapse
No announcement yet.
Cho e xin code hiển thị đồng hồ đếm thời gian trên led 7 đoạn của Kit Altera De2???
Collapse
X
-
Em mới viết code bộ đếm tăng từ 1 đến 9 hiển thị trên led 7 đoạn.Các anh vào xem hộ em sai ở đâu nhé mà em giả lập không đúng?
Code viết = verilog:
module bcd_tang (clock, rst, s1, led);
input clock, s1, rst;
output [6:0] led;
reg [6:0] led;
reg [3:0] bcd;
always @(posedge clock )
begin
if (rst == 1'b1) bcd <= 4'b0;
else if (s1 == 1'b1) bcd <= bcd + 1'b1;
if (bcd == 4'b1001) bcd <= 4'b0000;
end
always @(posedge clock)
begin
case(bcd)
4'b0000: led = 7'b1111110;
4'b0001: led = 7'b0110000;
4'b0010: led = 7'b1101101;
4'b0011: led = 7'b1111001;
4'b0100: led = 7'b0110011;
4'b0101: led = 7'b1011011;
4'b0110: led = 7'b1011111;
4'b0111: led = 7'b1110000;
4'b1000: led = 7'b1111111;
4'b1001: led = 7'b1110011;
default: led = 7'b1111111;
endcase
end
endmodule
-
Bạn chạy mô phỏng thế nào mà không đúng?Nguyên văn bởi tigertiger Xem bài viếtEm mới viết code bộ đếm tăng từ 1 đến 9 hiển thị trên led 7 đoạn.Các anh vào xem hộ em sai ở đâu nhé mà em giả lập không đúng?
Code viết = verilog:
module bcd_tang (clock, rst, s1, led);
input clock, s1, rst;
output [6:0] led;
reg [6:0] led;
reg [3:0] bcd;
always @(posedge clock )
begin
if (rst == 1'b1) bcd <= 4'b0;
else if (s1 == 1'b1) bcd <= bcd + 1'b1;
if (bcd == 4'b1001) bcd <= 4'b0000;
end
always @(posedge clock)
begin
case(bcd)
4'b0000: led = 7'b1111110;
4'b0001: led = 7'b0110000;
4'b0010: led = 7'b1101101;
4'b0011: led = 7'b1111001;
4'b0100: led = 7'b0110011;
4'b0101: led = 7'b1011011;
4'b0110: led = 7'b1011111;
4'b0111: led = 7'b1110000;
4'b1000: led = 7'b1111111;
4'b1001: led = 7'b1110011;
default: led = 7'b1111111;
endcase
end
endmodule
mình nghĩ bạn mới học nên viết code theo các bước như thế này cho dễ:
Viết yêu cầu:
- Mạch của bạn cần bộ đếm với cổng :
- reset: bất chấp tất cả các cổng khác, trả bộ đếm về 0
- Run: khi run=1, đếm từ 0 tới 9, khi đến 9 thì trả về 0, khi run = 0 không làm gì.
Để viết thanh ghi có reset đồng bộ:
always@(posedge clk)
if(rst)
counter <= 0;
else begin
end
Để viết thanh ghi có reset đồng bộ và chân bật (run), và luôn đếm
always@(posedge clk)
if(rst)
counter <= 0;
else if(run) begin
counter <= counter + 1;
end
Để viết thanh ghi có reset đồng bộ, chân run và đếm tới khi == 9 thì quay lại:
Để viết thanh ghi có reset đồng bộ và chân bật (run), và luôn đếm
always@(posedge clk)
if(rst)
counter <= 0;
else if(run) begin
if(overflow) counter <= 0; else
counter <= counter + 1;
end
assign overflow = (counter==9)?1:0;
Ý mình muốn nói là khi mô tả, bạn nên theo bản mẫu (template). Nếu bạn muốn counter của bạn chạy phức tạp hơn thì bạn mô tả giữa phần begin và end của run.
Code của bạn không sai (nếu bạn biết bạn đang làm gì), dễ sai nếu bạn không hình dung được mạch của bạn sẽ được tổng hợp ra như thế nào.
Để tiện bạn nên viết một phần decode, ở phần testbench, bạn kết nối phần này vào các chân LED, phần code này sẽ in ra 1 2 3 4 ... Mình copy đoạn code cho bạn:
case(rv7Lo)
7'b0110000:rv4LoDigit = 4'h1;
7'b1101101:rv4LoDigit = 4'h2;
7'b1111001:rv4LoDigit = 4'h3;
7'b0110011:rv4LoDigit = 4'h4;
7'b1011011:rv4LoDigit = 4'h5;
7'b1011111:rv4LoDigit = 4'h6;
7'b1110000:rv4LoDigit = 4'h7;
7'b1111111:rv4LoDigit = 4'h8;
7'b1111011:rv4LoDigit = 4'h9;
7'b1110111:rv4LoDigit = 4'hA;
7'b0011111:rv4LoDigit = 4'hB;
7'b1001110:rv4LoDigit = 4'hC;
7'b0111101:rv4LoDigit = 4'hD;
7'b1001111:rv4LoDigit = 4'hE;
7'b1000111:rv4LoDigit = 4'hF;
7'b1111110:rv4LoDigit = 4'h0;
default: begin
rv4LoDigit = 4'hz;
$display("Error Decode Values = 0b%b",rv7Lo);
end
endcase
$display("Values = 0x%h%h",rv4HiDigit,rv4LoDigit);
Comment
-
$display là lệnh in ra .... dùng trong mô phỏng. Tất cả các ctrinh mô phỏng nào hỗ trợ Verilog đều hỗ trợ lệnh này.Nguyên văn bởi boyzzun Xem bài viếtbác Jefflieu cho em hỏi cái $display kia thì chỉ cho mô phỏng hay là dùng cho cả mạch thật nữa, em chỉ học theo giáo trình của thày giáo nhưng cũng chưa thấy qua lệnh này
$display không phải là "synthesizable code" nên ... các ctrinh synthesize sẽ bỏ qua lệnh này, không làm gì hết. Cũng dễ hiểu thôi, cứ tự hỏi board mạch thật sẽ "xuất" ra cái gì, bằng cách nào thì thấy là nó không làm được
Comment
Bài viết mới nhất
Collapse
-
Trả lời cho Yêu thơ mê nhạc, mời các bác vào đây!bởi vi van phamHôn nhân của tôi dường như có bàn tay sắp đặt của ông tơ, bà nguyệt. Bà xả nói tôi viết hồi ký duyên số này. Tôi đã viết vào tập 100 trang học sinh. Sau 50 năm lật tới, lật lui xem quyển hối ký có nơi rách nát. Tôi viết lại bằng AI, giọng đọc VBBe, ca sĩ hát là là Synthesizer V.
...-
Channel: Tâm tình dân kỹ thuật
hôm nay, 14:18 -
-
Trả lời cho Công thức tính định luật kirchhoffbởi nguyendinhvanCông thức này chắc là để áp dụng cho UAV để bắn máy bay F15....
-
Channel: Hỗ trợ học tập
Hôm qua, 21:17 -
-
Trả lời cho Yêu thơ mê nhạc, mời các bác vào đây!bởi dinhthuong92GIỚI THIỆU CA KHÚC VỀ CHA MẸ:
Nặng Nghĩa Mẹ Cha
Sáng tác: Hoàng Đình Thường
Giọng hát: AI
Công cha cao tựa như Thái Sơn
Nghĩa mẹ sâu nước biếc xanh trong
Mong con khôn lớn đời hạnh phúc
Mẹ cha...-
Channel: Tâm tình dân kỹ thuật
12-05-2026, 16:22 -
-
bởi afrendlyCảm ơn bạn. Mình hỏi để thợ có thể tham khảo thôi chứ không đủ kiển thức để sửa, mà cũng không có đồ nghề, mua đồ nghề quá tiền máy. Gọi nhiều lần mà thợ hẹn mãi chưa có tới ấy bạn. Mình muốn sửa được chứ bỏ thì uống, nhưng sợ là được mỗi người thợ mà lại không sửa nổi....
-
Channel: Điện tử gia dụng
11-05-2026, 00:34 -
-
bởi mèomướpDạ nó bị tắc ẩm hoặc rò thiếu gas hoặc lốc yếu hoặc van tiết lưu có vấn đề hoặc tất cả những nguyên nhân trên ạ. Chú ko chuyên về mảng này thì bán đi, giành thời gian trồng rau sạch đem ra chợ bán lấy tiền mua tủ mới ạ. Còn...
-
Channel: Điện tử gia dụng
10-05-2026, 17:01 -
-
bởi afrendlyXin chào mọi người. Mình lại có vấn đề về đồ điện cần nhờ mọi người hỗ trợ giúp. Mình có tủ lạnh Sharp dùng cũng lâu rồi. Trước có bị kém lạnh, không đông đá thì có thợ họ mang về, sục đường ga gì đó hết 900k và đã dùng...
-
Channel: Điện tử gia dụng
10-05-2026, 16:53 -
-
bởi dinhthuong92Đấy, cái tôi thắc mắc là chỗ màu hồng ấy bạn, để áp vào cao chứ không bị sụt gần bằng áp pin thì rất cần cuộc cảm để làm điều đó. Tuy nhiên, trong công thức bác thớt dẫn không thấy mặt L, và một vài mạch MPPT tôi đã kiểm...
-
Channel: Nguồn!
09-05-2026, 10:01 -
-
bởi mèomướpDạ mạch sạc là 1 cục nguồn, nó sẽ điều chỉnh công suất đầu ra để có tổng trở bằng nội trở của pin ạ. Và cái cách nó chỉnh công suất đầu ra sẽ là dạng buck, boot. Đều cần đến cuộn cảm ạ. Tất nhiên chú thích thì có thể dùng dạng tuyến tính transistor để bù trừ nhưng mà nó đốt năng lượng vô ích ạ...
-
Channel: Nguồn!
08-05-2026, 16:26 -
-
bởi dinhthuong92Tng trở R của tải (gồm pin và mạch sạc) trong công thức đó rõ ràng khống có L xuất hiện. Nếu tính các dây dẫn thì rất nhỏ, bỏ qua. Vì nội trở pin là rất nhỏ, có thể nói luôn lớn hơn nội trở solar, nên mạch MPPT sẽ hầu như luôn tính...
-
Channel: Nguồn!
08-05-2026, 11:00 -

Comment