인프런 커뮤니티 질문&답변
LV1-21 Edge Detector 구현 방법 질문
작성
·
19
1
안녕하세요 ETA님 바쁘신데 고생 많으십니다.
L1-P21 Edge detector 문제를 실제 테스트 처럼 푸는 과정에서, xor 개념을 생각 하지 못하여 아래 코드처럼 카운터로 구현하여 edge를 detect하여 debouncing 현상도 문제 없이 처리 가능합니다.
모법 답안이 올바른 설계 방향이라는 것을 알고 있지만, 해당 방법에 대해서는 어떻게 생각하시는지 궁금합니다.
`timescale 1ns / 1ps
module rising_edge_detector (
input wire clk,
input wire signal,
output reg edge_detected
);
//TODO
reg [2:0] count;
always @(posedge clk) begin
if(signal) begin
count <= count + 1'b1;
end else begin
count <= 3'd0;
end
end
wire detect;
assign detect = (count == 3'd1) ? 1'b1 : 1'b0;
always @(*) begin
if(detect) begin
edge_detected = 1'b1;
end else begin
edge_detected = 1'b0;
end
end
// @ETA
//reg signal_prev;
//
//always @(posedge clk) begin
// signal_prev <= signal;
// edge_detected <= signal && !signal_prev;
//end
endmodule
감사합니다.
안녕하세요 🙂
[1. 질문 챕터] : eg) 몇 장, 몇 분 몇 초 쯤. or 수강생 분들이 봤을 때 어디구나?! 할 수 있게 표기 부탁 드려요.
[2. 질문 내용] : eg) 질문 내용을 자유롭게 작성해주시면 되겠습니다 🙂
[3. 시도했던 내용, 그렇게 생각하는 이유] : eg) 설치영상은 이렇게 시도했는데 안되더라 or 본인의 생각을 적어주세요. (실습 내용 중에 이해가 안되거나 잘못된 내용이 있는데, 이러 이러한 근거로 나는 이렇게 생각합니다.)
================ 다음 내용은 읽어보시고 지우시면 됩니다.=================
질문 내용을 작성해주실 때, 위의 3단계로 제가 이해할 수 있게 작성해주시면 정확한 답변을 드릴 수 있을 것 같아요!!
현업자인지라 업무때문에 답변이 늦을 수 있습니다. (길어도 만 3일 안에는 꼭 답변드리려고 노력중입니다 ㅠㅠ)
강의에서 다룬 내용들의 질문들을 부탁드립니다!! (설치과정, 강의내용을 듣고 이해가 안되었던 부분들, 강의의 오류 등등)
이런 질문은 부담스러워요.. (답변거부해도 양해 부탁드려요)
개인 과제, 강의에서 다루지 않은 내용들의 궁금증 해소, 영상과 다른 접근방법 후 디버깅 요청, 고민 상담 등..
글쓰기 에티튜드를 지켜주세요 (저 포함, 다른 수강생 분들이 함께보는 공간입니다.)
서로 예의를 지키며 존중하는 문화를 만들어가요.
질문글을 보고 내용을 이해할 수 있도록 남겨주시면 답변에 큰 도움이 될 것 같아요. (상세히 작성하면 더 좋아요! )
먼저 유사한 질문이 있었는지 검색해보세요.
잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.
==================
답변 1
0
안녕하세요 항상 감사하면 살기님,
열심히 역량을 쌓아가고 있으신 모습이 너무 좋습니다.
피드백을 드리도록 하겠습니다.
위 방법으로 한다면 현재 testbench에서의 test는 pass일 것입니다.
하지만 조금만 다른 테스트를 하더라도 문제가 발생할 수 있습니다.
제가 면접관이라면 코드 리뷰시에 문제를 파악하고 이런 것을 여쭤 봤을 것 같아요.
"카운터가 3비트인 이유는 무엇인가요?" 답변을 어떻게 하실건가요?
이러한 질문이 나왔다는건 관련 코드에 문제가 있지만 있다는 걸 이러한 힌트를 주었을 때 잘 파악할 수 있는지 볼 수 있습니다.
한번 답변에 대해서 잘 고민해보시기바랍니다.
조금만 다른 테스트라는것은 1을 길게 주었을때입니다.
아래를 보면 제가 말씀드린 부분을 이해하셨을겁니다. 135ns 에는 상승엣지를 정확히 디텍했지만,
210ns에서 엣지가 아닌데 엣지가 디텍팅 되었죠? 카운트 값이 1이기 때문입니다.

앞으로도 모범 답안이 아닌 다른 방법으로 푸신다면 본인의 경험이 더 많이 쌓이니 계속 이렇게 좋은 시도 쭉 이어가시길 바랍니다!
혹시 질문 있으시면 답변 남겨주셔요! 화이팅!




