회원가입 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
번호 분류 제목 글쓴이 조회 수 날짜
4046 자유주제 HOTATMEGA128과 ATMEGA128A 밝은전기구슬 28468 2011.03.26
펌웨어 & 코딩언어 HOTVHDL 전가산기 설계 질문입니다. 나트륨 5372 2011.03.26
4044 자유주제 HOT짤렸습니다.11 혈청 16994 2011.03.25
4043 드론/로봇/라인트레이서 HOTMB라인트레이서 모터부 회로 질문입니다.1 문성욱 2362 2011.03.25
4042 펌웨어 & 코딩언어 HOTC 배열이용해서 엑셀 데이터 끌어오는 방법???2 꼬꼴리 2396 2011.03.24
4041 PADS HOTpads9.2 버전에 대해 질문이요~4 세디피아 2743 2011.03.24
4040 Allegro & OrCAD HOT부품번호 자동수정에 관한 질문입니다.1 쨍용 2113 2011.03.24
4039 Allegro & OrCAD HOTvia 크기 바꾸는 방법??5 한방부르스 2887 2011.03.23
4038 자유주제 HOTQuartus 10.1버젼 vecter waveform 어디로간거죠?? FLOW 18630 2011.03.23
4037 Analog & Mixed-Signal 설계 HOTIC555 질문..부탁드립니다 여러분5 딘재 2612 2011.03.23
4036 마이크로프로세서 HOTATmega128 ADC/DAC 관련 질문 도와주세요(주석 첨부해서 다시 올려요)1 보고싶겠지만 5966 2011.03.22
4035 Software & IDEs HOT어셈블리어 공부하기1 아이스으 2530 2011.03.22
4034 PADS HOT윈도7에서 pads깔기~5 세디피아 2817 2011.03.22
4033 드론/로봇/라인트레이서 HOTv2.0 mb라인마우스 받아서 구성중인데요 문성욱 1782 2011.03.21
4032 중고장터 HOT산켄 SLA7044M 및 PG001M 구합니다 밝은전기구슬 5155 2011.03.21
4031 Sensor 설계 HOT저항 질문이요4 초보탈출!! 3222 2011.03.21
4030 자유주제 HOT넋두리 겸 조언을 구해봅니다.3 혈청 15304 2011.03.21
4029 Analog & Mixed-Signal 설계 HOT급해요 제발 좀 봐주세요 ㅠㅠ2 bbororok 3435 2011.03.19
4028 자유주제 HOT안녕하세요 질문이있어서 문의드립니다. 아즈미자라 16058 2011.03.19
4027 Sensor 설계 HOTPT100옴 4선식 또는 PT1000옴 4선식 구매 가능한 곳 알려주세요~ siwall 3662 2011.03.18
Prev 1 ... 88 89 90 91 92 93 94 95 96 97 ... 295 Next
  • 종교에 있어서는 무관심만큼 치명적인 것은 없다. 무관심이란 것은 적어도 반은 불신심이다.
    - 버크
  • * 납포인트 정보 *
  • 글 작성 : 3
  • 댓글 작성 : 1
  • 내 글이 추천받음 : 1
저작권법에 위배되는 콘텐츠는 등록 불가하며, 저작물에 대한 권리는 저작자에게 있습니다.
Copyright 2006-2021 © hardwareis.com, All rights reserved.