Nguyên văn bởi jefflieu
Xem bài viết
Thông báo
Collapse
No announcement yet.
Mong một bài hướng dẫn nhỏ về Quartus II
Collapse
X
-
Nguyên văn bởi neverup Xem bài viếtem ko hiểu lắm với câu giải thích 3.. bác bảo xuất ra A='1' -> đếm chu kì đủ 1us ( A vẫn ra giá trị 1 chưa mất) -> xuất ra B='1' ( B bây giờ có giá trị 1 và A vẫn đang giữ giá trị 1) .. có phải bác định nói thế đúng ko ạ
cứ từ từ mà học......
Comment
-
Nguyên văn bởi neverup Xem bài viếtbác jefflieu , thanhnguyen, tan071 ơi, bác nào giải đáp em 1 số câu hỏi vụn vặt này nhé :
1, tín hiệu ra ở chân I/O liệu có đủ mạnh để kích chân của trans không ?
2,giả sử output của em là A với giá trị 4'b0101 thì lúc assign pin với trên broad ấy ạ thì " chiều" nó sẽ ra như thế nào ở A(0),A(1),A(2),A(3)?
3,em muốn thời gian xuất tín hiều ở output bằng 1 khoảng tg delay nào đó thì em sử dụng như thế này được ko ạ :
if(rst) q=a
#delay q=a
em xin cám ơn ạ
Câu 2: Thì bít trọng số thấp tương ứng với chân có trọng số thấp (còn cho ra bus nào là do mình - nhưng phải dựa vào thiết kế I/O của Kit nữa).
Câu 3: trong VHDL có nhiều kiểu lắm ( wait for, for, while,.... thích dùng cái nào thì dùng ) mà I/O và Signal chỉ thay đổi ở xung tiếp theo. chỉ varvarr mới thay đổi giá trị ngay.
Comment
-
Nguyên văn bởi neverup Xem bài viếtem tưởng tần số clk mình đưa vào là mặc định tùy theo mình dùng thạch anh gì chứ ạ
Comment
-
Nguyên văn bởi neverup Xem bài viếtem ko hiểu lắm với câu giải thích 3.. bác bảo xuất ra A='1' -> đếm chu kì đủ 1us ( A vẫn ra giá trị 1 chưa mất) -> xuất ra B='1' ( B bây giờ có giá trị 1 và A vẫn đang giữ giá trị 1) .. có phải bác định nói thế đúng ko ạ
Cho ra B='1' hay A='0' là tùy bạn ... ý mình nói là 2 "việc" khác nhau. Nếu bạn muốn cho xung A = 1 trong thời gian 1 us thì sau 1 us, bạn cho nó xuống 0. Ý mình khi nói xung B='1' là trương hợp bạn muốn 2 xung lệch nhau 1 us.
Comment
-
Nguyên văn bởi jefflieu Xem bài viếtỪ, khổ !
Cho ra B='1' hay A='0' là tùy bạn ... ý mình nói là 2 "việc" khác nhau. Nếu bạn muốn cho xung A = 1 trong thời gian 1 us thì sau 1 us, bạn cho nó xuống 0. Ý mình khi nói xung B='1' là trương hợp bạn muốn 2 xung lệch nhau 1 us.
input x;
output y;
if(x=1) begin
y=1
<timer= 1 khoảng us>
end
nó hơi vớ vẩn tý mong anh hiểu ạ ... Tức là thế này đầu vào x chỉ cần 1 lần " click" để lấy tín hiệu 1 còn đầu ra y sẽ ra và vẫn còn lưu tín hiệu 1 khoảng tg
nữa ạ . và anh giúp dùm em chỗ <timer=1 khoảng us> được không ạ
Comment
-
Code timer:
signal timer: std_logic_vector(11 downto 0):=(others=>'0');
signal timer_run : std_logic :='0';
signal times_up : std_logic :='0';
process(clk)
begin
if(rising_edge(clk)) then
if(timer_run='1' and times_up='0') then
timer<=timer+1;
end if;
end if;
end process;
times_up <= '1' when timer = x"1234" else '0';
Comment
-
Nguyên văn bởi jefflieu Xem bài viếtCode timer:
Comment
-
Mình nghĩ bạn làm bước này trước:
- Tạo 1 module/entity timer, có cổng clock, run, restart và output là timers_up ... có generic/parameter là C_TIME là constant dùng để đếm tới đâu thì dừng.
- Rồi bạn tạo testbench và simulate trong model
- Bạn vào Quartus, tao project và dùng signaltap để coi mạch hoạt động ...
Bạn làm cái đó trước đi ...
Comment
-
Nguyên văn bởi jefflieu Xem bài viếtMình nghĩ bạn làm bước này trước:
- Tạo 1 module/entity timer, có cổng clock, run, restart và output là timers_up ... có generic/parameter là C_TIME là constant dùng để đếm tới đâu thì dừng.
- Rồi bạn tạo testbench và simulate trong model
- Bạn vào Quartus, tao project và dùng signaltap để coi mạch hoạt động ...
Bạn làm cái đó trước đi ...
module time(clk,rst,x,y);
input clk,rst,x;
output [1:0] y;
reg [1:0] y;
reg [3:0] count;
always @(posedge clk)
begin
if (rst) y<=1'b0;
else if (x==1'b1) begin
y<=1'b1;
count<=1;
end
end
always @(posedge clk)
begin
if (rst) begin count<=0;
end
else if (count==249999) begin count<=0;
end
else begin
count<=count+1;
end
end
endmodule
" khi ra dữ liệu tại y=1 thì bắt đầu đếm, đếm đến 249999 thì y =0... anh xem em làm có đúng ko ạ
anh cho em xin cái gmail hay yahoo của anh để em hỏi anh 1 số vấn đề với ạLast edited by neverup; 13-06-2014, 21:23.
Comment
-
Nguyên văn bởi neverup Xem bài viếtvâng để em thử sau ạ .. em định làm như thế này anh kiểm tra dùm em với ạ
module time(clk,rst,x,y);
input clk,rst,x;
output [1:0] y;
reg [1:0] y;
reg [3:0] count;
always @(posedge clk)
begin
if (rst) y<=1'b0;
else if (x==1'b1) begin
y<=1'b1;
count<=1;
end
end
always @(posedge clk)
begin
if (rst) begin count<=0;
end
else if (count==249999) begin count<=0;
end
else begin
count<=count+1;
end
end
endmodule
" khi ra dữ liệu tại y=1 thì bắt đầu đếm, đếm đến 249999 thì y =0... anh xem em làm có đúng ko ạ
anh cho em xin cái gmail hay yahoo của anh để em hỏi anh 1 số vấn đề với ạ
Bạn muốn khi y=1 thì bắt đàu đếm thì phải làm thế này:
always @(posedge clk)
begin
if (rst) begin count<=0;
end
else if (count==249999) begin count<=0;
end
else if (y==1'b1) begin
count<=count+1;
end
end
Khi đếm đến hết y = 0 thì phải làm thế náy:
if (rst) y<=1'b0;
else if (x==1'b1) begin
y<=1'b1;
else if(count==249999)
y<=1'b0;
end
end
Bạn không gán cho 1 register ở 2 vòng always đươc ... Như code đấu của bạn x==1'b1, count <= 1 là không được .... Mỗi câu lênh always@ sẽ sinh ra một mạch gồm các registers nên 2 câu lệnh always@ không cùng gán cho 1 register được.
Bạn vào modelsim viêt test bench và simulate thử đi
Comment
-
Nguyên văn bởi jefflieu Xem bài viếtbạn làm gần đúng ...
Bạn muốn khi y=1 thì bắt đàu đếm thì phải làm thế này:
always @(posedge clk)
begin
if (rst) begin count<=0;
end
else if (count==249999) begin count<=0;
end
else if (y==1'b1) begin
count<=count+1;
end
end
Khi đếm đến hết y = 0 thì phải làm thế náy:
if (rst) y<=1'b0;
else if (x==1'b1) begin
y<=1'b1;
else if(count==249999)
y<=1'b0;
end
end
Bạn không gán cho 1 register ở 2 vòng always đươc ... Như code đấu của bạn x==1'b1, count <= 1 là không được .... Mỗi câu lênh always@ sẽ sinh ra một mạch gồm các registers nên 2 câu lệnh always@ không cùng gán cho 1 register được.
Bạn vào modelsim viêt test bench và simulate thử đi
tiện thể anh cho em hỏi luôn làm thế nào dùng được 2 module trong 1 code ạ em ngại tìm tài liệu tiện thể hỏi luôn
Comment
Bài viết mới nhất
Collapse
-
Trả lời cho Năm mới dientuvietnam.netbởi mèomướpDạ năm mới cháu xin kính chúc ông, bà, cô, dì, chú, bác, anh, chị, em, các bạn, các cháu... trong diễn đàn sức khỏe dồi dào, gặp nhìu may mắn và thành công...
-
Channel: Tâm tình dân kỹ thuật
Hôm qua, 05:42 -
-
Trả lời cho Năm mới dientuvietnam.netbởi nhathung1101Chúc cả nhà ăn no mặc ấm, quần lúc có lúc không.
-
Channel: Tâm tình dân kỹ thuật
Hôm qua, 00:02 -
-
Trả lời cho Năm mới dientuvietnam.netbởi vandong1111Năm mới 2025 cháu chúc các chú, các bác mạnh khỏe, vui vẻ, gặp nhiều may mắn.
-
Channel: Tâm tình dân kỹ thuật
29-01-2025, 20:59 -
-
Trả lời cho tìm mua đồng hồ vạn năngbởi bqvietNói một cách xây dựng thì kiểu đồng hồ kiêm kẹp dòng NJTY3266 mà bạn Mèo đề cập là đúng nhu cầu người hỏi rồi. Một số cửa hàng bán trên 200ng, vài sàn thương mại điện tử bán dưới - thế là đúng nhu cầu về giá. Nếu khéo săn...
-
Channel: Điện tử dành cho người mới bắt đầu
27-01-2025, 20:02 -
-
Trả lời cho tìm mua đồng hồ vạn năngbởi nhathung1101Đa năng còn chưa dùng hết, nếu không biết cách dùng.
200k thì hơi khó mua, nhưng 50k chắc là có. Cứ bảo bán cho tôi cái đồng hồ hỏng.-
Channel: Điện tử dành cho người mới bắt đầu
26-01-2025, 23:21 -
-
Trả lời cho Sửa bộ nguồn DC 60V 45Abởi nhathung1101Lão Đinh Vặn học giải phương trình hồi đi trẻ mà. Mẫu giáo học lập trình AI rồi. Lớp lão ấy gần lớp em nên em biết....
-
Channel: Điện tử công suất
26-01-2025, 23:11 -
-
Trả lời cho Giúp em về mạch MPPT và Solar Panel với!?bởi nhathung1101Vậy chú đã hỏi hãng SIEMEN chưa? Tại sao cái PLC S7-200 cổ lỗ mà họ vẫn thiết kế riêng cho thị trường TQ với chữ SMART? Thậm chí phần mềm riêng để đọc file ngu.smart?
Vấn đề không còn là công nghệ "cốt lõi" nữa, mà là giá thành quyết định. Ham rẻ là trả giá mà....-
Channel: Điện tử công suất
26-01-2025, 23:01 -
-
Trả lời cho Giúp em về mạch MPPT và Solar Panel với!?bởi vi van phamĐồng ý với Bqv.
50 năm làm nghề, tôi đã chứng kiến 3 lần máy x quang mới nhập từ nước ngoài về bị lỗi.
- Lần thứ 1 máy xq của Pháp được ks Pháp lằp đặt bị lỗi 1 con didode, đưa cho ks Pháp con didode khác cùng mã số, ông...-
Channel: Điện tử công suất
26-01-2025, 08:09 -
-
Trả lời cho Giúp em về mạch MPPT và Solar Panel với!?bởi mèomướpDạ chú dinh... muốn sửa lỗi cho hãng thì chú cứ gửi những hình ảnh, video cho họ đi ạ, chú có thể tìm thông tin của những lãnh đạo bên ấy để gửi thì sẽ hiệu quả hơn ạ. Về tổng quan thì họ sẽ ko phản hồi rõ ràng đâu ạ, vì nhận...
-
Channel: Điện tử công suất
26-01-2025, 06:19 -
-
Trả lời cho Giúp em về mạch MPPT và Solar Panel với!?bởi bqvietCuối năm bàn thêm chuyện to hơn chút, đấy là 2 vụ rơi đám 737 đời mới và trục trặc ở cả tá chiếc khác. Ngay cả những thứ tưởng như cao siêu sang xịn thật thì vẫn có thể gặp trường hợp oái oăm như thường. Từ hồi đó bqv đã thấy khó hiểu làm sao lại đẻ ra đám MCAS quái thai đến thế được. Rồi...
-
Channel: Điện tử công suất
24-01-2025, 19:40 -
Comment