VHDL
VHDL의 부호 있는 유형과 부호 없는 유형은 std_logic_vector 유형과 마찬가지로 비트 벡터입니다. 차이점은 std_logic_vector가 데이터 버스를 구현하는 데는 훌륭하지만 산술 연산을 수행하는 데는 쓸모가 없다는 것입니다.
std_logic_vector 유형에 숫자를 추가하려고 하면 ModelSim에서 컴파일 오류가 발생합니다. 중위 연산자 "+"에 대해 가능한 항목이 없습니다. 이는 컴파일러가 이 비트 모음을 벡터로 해석하는 방법을 모르기 때문입니다.
이 블로그 게시물은 기본 VHDL 자습서 시리즈의 일부입니다.
컴파일러가 벡터를 숫자로 처리할 수 있도록 벡터를 부호 있는 또는 부호 없는 것으로 선언해야 합니다.
부호 있는 신호와 부호 없는 신호를 선언하는 구문은 다음과 같습니다.signal <name> : signed(<N-bits> downto 0) := <initial_value>;
signal <name> : unsigned(<N-bits> downto 0) := <initial_value>;
std_logic_vector와 마찬가지로 범위는 to
일 수 있습니다. 또는 downto
모든 범위. 그러나 downto 0
이외의 다른 범위로 신호를 선언하는 경우 너무 드물기 때문에 그 주제에 대해 더 이상 시간을 할애하는 것은 우리를 혼란스럽게 할 뿐입니다. 초기 값은 선택 사항이며 기본적으로 'U'
입니다. 모든 비트에 대해.
우리는 이미 integer
을 사용하고 있습니다. 이전 자습서의 산술 연산에 대한 유형입니다. 그렇다면 서명된 유형과 서명되지 않은 유형이 필요한 이유는 무엇입니까? 대부분의 경우 디지털 설계자는 신호가 실제로 사용하는 비트 수를 더 잘 제어하기를 원합니다.
또한 integer
범위를 넘어 증가합니다. 마지막으로, 서명된 것과 서명되지 않은 것은 'U'
과 같은 다른 값을 가질 수 있습니다. 및 'X'
, 정수는 숫자 값만 가질 수 있습니다. 이러한 메타 값은 설계에서 오류를 발견하는 데 도움이 될 수 있습니다.
이 비디오에서는 부호 있는 신호와 부호 없는 신호가 어떻게 비슷하게 작동하고 어떻게 다르게 작동하는지 배웁니다.
이 튜토리얼에서 만든 최종 코드:
library ieee; use ieee.std_logic_1164.all; use ieee.numeric_std.all; entity T12_SignedUnsignedTb is end entity; architecture sim of T12_SignedUnsignedTb is signal UnsCnt : unsigned(7 downto 0) := (others => '0'); signal SigCnt : signed(7 downto 0) := (others => '0'); signal Uns4 : unsigned(3 downto 0) := "1000"; signal Sig4 : signed(3 downto 0) := "1000"; signal Uns8 : unsigned(7 downto 0) := (others => '0'); signal Sig8 : signed(7 downto 0) := (others => '0'); begin process is begin wait for 10 ns; -- Wrapping counter UnsCnt <= UnsCnt + 1; SigCnt <= SigCnt + 1; -- Adding signals Uns8 <= Uns8 + Uns4; Sig8 <= Sig8 + Sig4; end process; end architecture;
흥미로운 부분을 확대한 ModelSim의 파형 창:
파형에 있는 모든 신호의 기수는 동일하게 비교할 수 있도록 16진수로 설정됩니다.
래핑 카운터 예제에서 부호 있는 신호와 부호 없는 신호가 정확히 같은 방식으로 동작하는 것을 볼 수 있습니다. 둘 다 UnsCnt
및 SigCnt
0에서 시작하여 FF까지 하나씩 증가합니다. 16진수 FF(십진수 255)는 8비트 신호가 보유할 수 있는 가장 큰 값입니다. 따라서 다음 증분은 둘 모두를 다시 0으로 감쌉니다.
두 개의 4비트 신호 Uns4
를 만들었습니다. 및 Sig4
, 그리고 그들 모두에게 초기 값 "1000"을 주었습니다. 파형에서 둘 다 16진수 8(2진수 1000)임을 알 수 있습니다.
우리가 만든 마지막 두 개의 8비트 신호는 Uns8
입니다. 및 Sig8
. 예상대로 초기 값이 0임을 파형에서 볼 수 있습니다. 그러나 거기에서 그들은 다르게 행동합니다! 분명히, 부호 있는 유형과 부호 없는 유형은 길이가 다른 두 개의 신호를 추가할 때 차이를 만들었습니다.
이것은 기호 확장자로 알려진 것 때문입니다. . 동일한 길이의 벡터에 저장된 양수 또는 음수를 더하는 것은 디지털 논리에서 동일한 작업입니다. 이것은 2의 보수가 작동하는 방식 때문입니다. 벡터의 길이가 다른 경우 가장 짧은 벡터를 확장해야 합니다.
부호 없는 4비트 이진수 "1000"은 십진수 8이고 부호 있는 4비트 숫자 "1000"은 십진수 -8입니다. 부호 있는 숫자의 맨 왼쪽에 있는 "1"은 이것이 음수임을 나타냅니다. 따라서 두 개의 4비트 신호는 컴파일러에 의해 서로 다르게 부호 확장됩니다.
이것은 부호 확장이 Uns8
에 대해 서로 다른 값을 생성하는 방법을 시각화한 것입니다. 및 Sig8
신호:
다음 튜토리얼로 이동 »
VHDL
수많은 Arduino 프로젝트를 실행합니까? 그리고 엄청난 양의 중요한 정보와 로그 데이터를 저장해야 합니까? 해결책은 Arduino SD 카드를 사용하는 것입니다. 어떻게 작동합니까? 이 문서에서는 기기가 무엇인지, 연결하는 방법, 사용하는 방법 등 기기에 대해 알아야 할 모든 정보를 제공합니다. 계속 읽어서 알아야 할 모든 정보를 찾아보세요. Arduino에서 SD란 무엇입니까? 아두이노 SD 카드 이미지 출처:Pixlr SD 카드 또는 마이크로 SD 카드는 두 가지 주요 구성 요소가 있는 장치입니다. 그리고 이러한
전통적인 제조 기술은 균일한 단면의 기본 모양을 효과적으로 생성할 수 있지만 속이 빈 내부 또는 복잡한 형상으로 부품을 생성하는 것은 고유한 과제를 안고 있습니다. 그러나 희생적인 도구를 사용하면 설계자와 엔지니어가 모양이나 재료 무결성을 타협할 필요가 없습니다. 희생 툴링은 용해성 재료에 구조를 인쇄한 다음 복잡한 구조를 만드는 데 사용됩니다. 이 기술을 통해 설계자와 엔지니어는 다양한 재료로 부드러운 내부를 사용하여 모든 종류의 언더컷이 있는 복잡하거나 속이 빈 구조를 쉽게 만들 수 있습니다. 희생 툴링은 일반적으로 높은 정확