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
-
Càng đọc càng thấy k hiểu gì... :3Nguyê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
-
Câu 1: FPGA thiết kế theo công nghệ CMOS. Nên tốc độ nhanh và năng lượng tiêu thụ ở chế độ tĩnh ít => ít nóng. còn I/O thì nó có các modul khác nữa, nhìn trên Kit là thấy ( còn chân của FPGA thì k biết - đọc datasheet xem có không, với lại nó chủ yếu là xử lý tín hiệu... nên phần công suất thì k phải là điều quan trọng của chip )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
-
thì đó, bạn phải biết xung của nó thì mới tính được số cần đếm chứ ..........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
-
Ừ, khổ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
-
hiện tại em đang định như thế này ạ :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
-
em cám ơn bác ạNguyên văn bởi jefflieu Xem bài viếtCode timer:
mà mình nhét cái timer này vào trong chỗ < timer=1 khoảng us> của em trên kia hay em vứt nó xuống cuối cùng đoạn code tổng thể của em.. cà 2 cách đều được hả bác ?
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
-
vâng để em thử sau ạ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 ...
.. 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 ạ
Last edited by neverup; 13-06-2014, 21:23.
Comment
-
bạn làm gần đúng ...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
-
dạ vâng ạ.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 Mạch mở đèn led dâybởi dataonline
-
Channel: Điện tử dành cho người mới bắt đầu
Hôm qua, 23:18 -
-
Trả lời cho Mạch mở đèn led dâybởi dataonline
-
Channel: Điện tử dành cho người mới bắt đầu
Hôm qua, 23:05 -
-
bởi dataonlineMình có mạch này nhưng khi hoàn thiện thì tụ k5 bị nổ và không sáng đèn led. Mọi người phân tích giúp mình cho phù hợp với ạ. Nguồn vào 24vac 6a. Đầu ra led dây 24vdc 100w. Mình cảm ơn
-
Channel: Điện tử dành cho người mới bắt đầu
Hôm qua, 23:05 -
-
Trả lời cho Giúp mình vẽ sơ đồ và phân tích nguyên lý làm việc của khảo sát các mạch nguồn ổn áp vớibởi davidcopyNgõ ra của IC 7806 là 6VDC, 7905 là -5VDC. Dòng điện ngõ ra của IC tối đa khoảng 1.5A, thông số này nên tra cứu datasheet từng loại sẽ chính xác hơn. Nếu gắn tải nhỏ làm dòng ngõ ra lớn hơn dòng tối đa(1.5A) thì điện áp ngõ ra sẽ giảm....
-
Channel: Hỗ trợ học tập
02-04-2026, 21:10 -
-
Trả lời cho Giúp mình vẽ sơ đồ và phân tích nguyên lý làm việc của khảo sát các mạch nguồn ổn áp vớibởi Tuyenvc345Cách tính U và I của từng nút sao anh
-
Channel: Hỗ trợ học tập
02-04-2026, 15:02 -
-
bởi chinhnguyen9
Nhìn ảnh sản phẩm đã thấy ấn tượng ngay bởi thiết kế tinh gọn, hiện đại, phần tản nhiệt rất đẹp, thông minh và bắt mắt. Mạch sạc MPPT tự chế của tôi đang hỏng, sửa mãi chưa xong vì lý do tổ trác! Vì vậy, tôi quyết định mua module này về dùng thử để xem chất lượng thực tế thế nào.
...-
Channel: Đánh giá sản phẩm DTVN
02-04-2026, 08:44 -
-
bởi ittcHic. Cảm ơn bác nha, chốt là em sẽ dùng camera IP POE và đầu ghi của hãng Hikvision, em có vào website quốc tế và vài website bán hàng uy tín ở VN thì hình như dòng camera gia đình nói chung em thấy họ để 4 chủng loại chính, em thì không dùng dòng Wifi nên gạt sang 1 bên, còn mấy dòng như:
- AcuSen
-
Channel: Tâm tình dân kỹ thuật
01-04-2026, 15:54 -
bởi nguyendinhvanCách ní nuận có vấn đề, không xát xao với quần chúng.
Nguồn điện lưới, lấy từ nhà máy phát điện có năng lượng hàng Mega, Gigawat, lớn hơn nhiều nhiều lần năng lượng của ắc quy. Nên bộ sạc ắc quy cần có một kiểu.
Nguồn...-
Channel: Đánh giá sản phẩm DTVN
31-03-2026, 22:19 -
-
Trả lời cho Giúp mình vẽ sơ đồ và phân tích nguyên lý làm việc của khảo sát các mạch nguồn ổn áp vớibởi davidcopyMạch 3 dùng để tạo ra nguồn đôi -/+( 5V, 6V, 9V, 12V, ...) nên ngõ ra biến áp cách ly thường là nguồn đối xứng.
Như trong mạch 3, ngõ ra biến áp là 9VAC đôi và 12VAC đôi. Khi đo 2 đầu 9V hoặc 12V thì điện áp sẽ là 18VAC hoặc 24VAC....-
Channel: Hỗ trợ học tập
31-03-2026, 19:20 -
-
Trả lời cho Giúp mình vẽ sơ đồ và phân tích nguyên lý làm việc của khảo sát các mạch nguồn ổn áp vớibởi Tuyenvc345Dạ mình muốn tìm hiểu nguyên lý của mạch 3 ạ đặc biệt là 2 con IC 7806 ở trên và 7905 ở dưới nhiệm vụ của nó làm ạ
-
Channel: Hỗ trợ học tập
30-03-2026, 15:34 -

Comment