회원가입 ID/PW 찾기
AA

전가산기를 아래와 같이 설계해봤습니다. 더 간단하게도 되지만 그냥 Behavioral로 이렇게 해봤어요

 

마치 C프로그램 짜듯이

 

그런데 원하는 출력값이 나오질 않습니다.

 

코드 설명을 잠깐 드리자면

 

a,b,ci 순서로 하나씩 확인해가면서 하나라도 1이 있으면 그 개수를 temp에 저장합니다.

 

temp가 2개 이상이면 carry가 발생하니 c=1 주고요(반대는 생략)

 

temp가 짝수이면 s=0 줍니다. (반대는 생략)

 

사용한 signal은 a,b:input ci:carry input c:carry s:sum 입니다.

 

k는 그냥 a,b,ci를 저장하고 for문으로 다루기위한 bit벡터입니다.

 

 

이렇게 해놓고

 

첨부한 파일을 보시면 a=0 b=0 ci=1일 때, s=1이어야 하는데

  

안맞는걸 확인하실 수 있을겁니다.

 

혹시나 해서 temp signal을 그냥 2만 대입해봤더니 이상하게

 

c, s에서 변화가 생깁니다. 아래 코드만 보면 c, s는 temp 값에의해 결정되니깐

 

변화가 없어야 정상인 것 같은데요.

 

원인이 무엇인지 도통 감이 잡히질 않습니다.

 

rem 연산 때문일까요??

 

 

 

 

library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;
use IEEE.NUMERIC_STD.ALL;


entity Fulladder is
    Port ( a : in  bit;
           b : in  bit;
           ci : in  bit;
           s : out  bit;               ---- sum
           c : out  bit;              ----- carry
    
end Fulladder;

architecture Behavioral of Fulladder is

signal k : bit_vector (1 to 3);

begin
 
 process(a,b,ci)
 variable temp : integer;
 begin
  temp := 0;  --- temp 변수 초기화 및 for문 조작을 위해 벡터에 a,b,ci 입력
  k(1) <= a;
  k(2) <= b;
  k(3) <= ci;

 

  for i in 1 to 3 loop                                        --- bit a, b, ci 중에 논리값이 1인 개수를 샌다.
   if (k(i)='1') then
    temp := temp + 1;    --- 개수를 temp에 저장
   end if;
  end loop;
  
  if ((temp rem 2)=0) then                                --- 짝수개이면 s=0 홀수면 s=1 : sum 결정
   s <= '0';
  else
   s <= '1';
  end if;
  
  if (temp < 2) then                                      --- 2개이상이면 c=1 1개이하이면 c=0 : carry 결정
   c <= '0';
                 else
   c <= '1';
                 end if;
 end process;

end Behavioral;

 

 

댓글 0

하드웨어 설계 및 개발에 대하여 개발자들이 자유롭게 토론하는 공간입니다.
- Q&A, 자유주재 토론, 관련 정보 공유
- 분야 : 마이크로프로세서 응용, 전기/전자(아날로그/디지털) 회로 설계, C/C++ 프로그래밍, 펌웨어,
         PCB Artwork, 트러블슈팅 등 하드웨어 설계에 관한 전반인 내용
※ 게시글에 맞는 분류를 선택하여 글을 작성해 주시면 쾌적한 사이트 운영에 많은 도움이 됩니다.
※ 하드웨어 인사이트는 회원들간의 거래정보를 게재할 뿐이지, 그 어떤 책임과 의무도 가지지 않습니다.

search
번호 분류 제목 글쓴이 조회 수 날짜
125 Allegro & OrCAD HOTOrcad 16.3 설치 파일 구할수 있나요?3 cjhwa11 2819 2011.08.09
124 Allegro & OrCAD HOT고수님들의 도움좀 바랍니다.1 하늘사랑73 1693 2011.07.25
123 Allegro & OrCAD HOTORCAD 16.3 설치 ex1 nicdday 5172 2011.07.20
122 Allegro & OrCAD HOTOrCAD 16.3 설치시 오류 메세지..... 좀 도와 주세요. Smileholic 3282 2011.07.18
121 Allegro & OrCAD HOTCadence orcad 16.3 PCD Designer에서 BNC 커넥터와 SMA커넥터의 풋프린트 값을 알고 싶습니다.1 김용민 3093 2011.07.07
120 Allegro & OrCAD HOTOrcad Layout에서 풋프린트 끼리 그룹화나 합치는 기능이 가능한가요? Isolesti 1801 2011.07.06
119 Allegro & OrCAD HOTorcad 16.3 win7(64)에서 인스톨이 안되요 도와주세요!!!!!!3 초보자1 2734 2011.07.02
118 Allegro & OrCAD HOTnever0682..orcad sst가 안보여여....4 개여울 1693 2011.05.24
117 Allegro & OrCAD HOTorcad 10.5에 대해 궁금한 점이 있습니다.4 궁금한학생 2270 2011.05.20
116 Allegro & OrCAD HOTOrcad 16.2 PCB edit componet 교체방법 가르쳐주세요 빼빼로 1967 2011.05.18
115 Allegro & OrCAD HOTORCAD Portable 버전 특징2 안전제일 4835 2011.05.11
114 Allegro & OrCAD HOTnetlist 작서 후 경고 메세지 해석1 비행중 2567 2011.04.26
113 Allegro & OrCAD HOTOrCAD 16.3 create netlist 만드는 방법좀 알려주세요 ㅠㅠ2 컴맹 3775 2011.04.26
112 Allegro & OrCAD HOTorcad 16.0 shooters 설치하고 나서 parametric sweep이 활성화가 안됩니다1 빵돼지 3634 2011.04.19
111 Allegro & OrCAD HOT이 회로도의 footprint값을 알 수 있을까요?2 amaikaze 2886 2011.04.08
110 Allegro & OrCAD HOTtext 폰트를 바꿀수 있는지요?2 만내 1890 2011.04.06
109 Allegro & OrCAD HOT거버파일은 있습니다. 질문좀 ㅠㅠ2 마모루 2068 2011.03.29
108 Allegro & OrCAD HOT부품번호 자동수정에 관한 질문입니다.1 쨍용 1869 2011.03.24
107 Allegro & OrCAD HOTvia 크기 바꾸는 방법??5 한방부르스 2722 2011.03.23
106 Allegro & OrCAD HOTPCB Editor의 설정 변경방법 문의 (Window7-64bit)1 외날 2317 2011.03.08
Prev 1 2 3 4 5 6 7 8 9 10 ... 12 Next
  • 일을 몰고 가라. 그렇지 않으면 일이 너를 몰고 갈 것이다.
    - 프랭클린
  • * 납포인트 정보 *
  • 글 작성 : 3
  • 댓글 작성 : 1
  • 내 글이 추천받음 : 1
저작권법에 위배되는 콘텐츠는 등록 불가하며, 저작물에 대한 권리는 저작자에게 있습니다.
Copyright 2006-2021 © hardwareis.com, All rights reserved.