회원가입 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
번호 분류 제목 글쓴이 조회 수 날짜
86 개발용역 HOTRF PCB 설계 및 제작 의뢰 받습니다. 아침해 12294 2011.05.24
85 개발용역 HOT프로그램 알르바이트 해 주실분... 개여울 6248 2011.05.11
84 개발용역 HOT평생파트너가 되겠습니다. 수내아트원 6319 2011.05.03
83 개발용역 HOT부품 무료 분양 powers 5813 2011.04.24
82 개발용역 HOT로드셀 이용한 전자저울 개발의뢰합니다. 이지스윈 8656 2011.04.21
81 개발용역 HOTpcb설계및 제작 의뢰 받습니다.2 artwork 6892 2011.04.01
80 개발용역 HOT타임콘트롤판의뢰3 웃는사람 6449 2011.03.16
79 개발용역 HOTLED 간판2 미늘인 6285 2011.02.18
78 개발용역 HOT개발의뢰입니다.( 매트랩을 이용한 최적화 구현) 깐돌이01 6605 2011.02.07
77 개발용역 HOT아트웍, 프로그램 의뢰 받습니다. 꼭꺼안고서 6412 2011.02.05
76 개발용역 HOTH/W & 펌웨어 개발 및 PCB 설계 경력자 모집 용가리3 10333 2011.01.22
75 개발용역 HOTAlmighty Solution [센서공급 및 ODM 개발]1 꽁이 6344 2011.01.17
74 개발용역 HOT내 컴퓨터 바이러스 내가 치료하자 !! - 백신만들기 중앙인 6321 2011.01.17
73 개발용역 HOT전동치솔 개발 빅루프다 6527 2010.12.13
72 개발용역 HOT동아전기부품을 소개합니다. 홈런볼 6842 2010.12.08
71 개발용역 HOT초음파 센서.. 아나아나나 6269 2010.11.29
70 개발용역 HOT하드웨어 개발 및 Artwork 해 드립니다.2 야웅이 5641 2010.11.15
69 개발용역 HOT라인트레이서4 조의련 5633 2010.11.07
68 개발용역 HOTIR 리모컨과 블루투스 가 포함된 회로 설계 의뢰합니다. hyun 11949 2010.11.03
67 개발용역 HOT테스팅하우스코리아(주)를 소개합니다. davidjang 6323 2010.11.03
Prev 1 ... 3 4 5 6 7 8 9 10 11 12 Next
  • 말로하는 사랑은 쉽게 외면할 수 있으나 행동으로 보여주는 사랑은 저항할 수가 없다.
    - 무니햄
  • * 납포인트 정보 *
  • 글 작성 : 3
  • 댓글 작성 : 1
  • 내 글이 추천받음 : 1
저작권법에 위배되는 콘텐츠는 등록 불가하며, 저작물에 대한 권리는 저작자에게 있습니다.
Copyright 2006-2021 © hardwareis.com, All rights reserved.