회원가입 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
번호 분류 제목 글쓴이 조회 수 날짜
16 구인구직 HOT(주)소프트라인 - 응용/웹프로그래머 채용 쭈니닷 5196 2012.06.26
15 구인구직 HOT시앤지원 - 웹 프로그램 개발 및 문서암호화 솔루션 인스톨 및 이행 쭈니닷 5290 2012.06.22
14 구인구직 HOT사람인 - 월급 1000만원 프로젝트, 프로그래머 모집 쭈니닷 5355 2012.06.18
13 구인구직 HOT(주)엑스큐어넷 - 소프트웨어 개발자(프로그래머) 채용 쭈니닷 5153 2012.06.12
12 구인구직 HOT(주)시뮬라인 - 기술개발본부 소프트웨어 팀 신입/경력사원 채용공고 쭈니닷 5747 2012.06.11
11 구인구직 HOT㈜엔써즈 - 시스템엔지니어 신입사원 모집 쭈니닷 6906 2012.06.08
10 구인구직 HOT㈜고우넷 - unix 엔지니어 채용 콘마개마 4150 2012.06.05
9 구인구직 HOT전액무료 자바(java)기반 하이브리드 프레임웍개발 안드로이드 개발교육과정 cocoa13 3875 2012.05.14
8 구인구직 HOT[교육부담 0%] 이공계 전액무료 하이브리드 앱 개발자 취업확정자 교육연수과정 cocoa13 5352 2012.05.01
7 구인구직 HOT[전액무료교육] 구로디지털 단지 자바개발 업체 채용확정자 취업교육” 안드로이드 개발 및 프로젝트 과정 cocoa13 4144 2012.04.30
6 구인구직 HOT[전액무료과정] 웹디자이너 양성교육 비주얼 컨텐츠 디자인 과정 안내 cocoa13 4957 2012.04.26
5 구인구직 HOTPOWER설계 및 하드웨어 경력자 찾아요. 박우종 5191 2012.03.07
4 구인구직 HOT회로수리 및 수땜, ECO작업등 필요하시면 연락주세요. 세윤파파 9187 2012.01.27
3 구인구직 HOT실력있는 펌웨어 엔지니어를 모집합니다. JamesHan 8599 2011.12.27
2 구인구직 HOT(주)로벤 연구소에서 연구원을 모집합니다. maddog 6860 2011.11.10
1 구인구직 HOT[급구] PCB 설계 경력자 & H/W 및 펌웨어 엔지니어 모집 용가리3 13968 2010.12.23
Prev 1 ... 5 6 7 8 9 10 11 12 13 14 Next
  • 훌륭한 사람들은 실패를 통해 지혜롭게 되었기 때문에 훌륭하다. 성공으로부터는 별로 지혜를 얻지 못한다.
    - 샤로안
  • * 납포인트 정보 *
  • 글 작성 : 3
  • 댓글 작성 : 1
  • 내 글이 추천받음 : 1
저작권법에 위배되는 콘텐츠는 등록 불가하며, 저작물에 대한 권리는 저작자에게 있습니다.
Copyright 2006-2021 © hardwareis.com, All rights reserved.