반응형
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
Tags
- 데이터 해저드
- 클럭 게이팅
- gpgpu-sim
- linux c 컴파일
- Pyverilog 설치
- CUDA
- Pyverilog 튜토리얼
- linux c++ 컴파일
- linux makefile 작성
- AMBA
- DNN Accelerator
- 대구 반도체 설계기업 특화
- 컨벌루션 연산
- Pyvrilog tutorial
- systolic array
- Makefile compile
- pyverilog 설치 오류
- CDC
- Design DNN Accelerator
- 남산업힐
- Pyverilog 실행
- 딥러닝 가속기
- Data HAzard
- CLOCK GATING
- 이진수 곱셈 알고리즘
- pytest-pythonpath 설치 오류
- gcc 컴파일
- pygraphviz 설치 오류
- DNN 가속기
- makefile
Archives
- Today
- Total
오늘은 맑음
xilinx / mutlipliers 합성 결과 본문
반응형
요즘 딥러닝 하드웨어 가속기(NPU)에서 곱셈기에 대해 공부하고 있습니다.
vivado에서 곱셈기를 합성해보면 다양한 결과가 나옵니다.
module mult(
input [IN-1:0] a,
input [IN-1:0] b,
output [OUT-1:0] c
)
assign c = a * b;
endmodule
예를 들어 위의 곱셈을 수행하는 모듈을 만들고 합성을 해보면 어떨때는 DSP를 사용하고 어떨때는 LUT-based multiplier가 생성이 됬습니다.
xilinx document를 찾아보니 input width에 따라 합성 결과가 달라진다고 설명되어있습니다.
어떠한 케이스에서는 LUT-based multiplier가 생성이 되고, input width가 매우 큰 경우에는 dedicated multiplier block을 사용하여 합성이 된다고 합니다.
여기서 input width가 작아 dedicated multiplier block을 사용하기에 좋지 않은 경우 LUT-based multiplier가 합성되는 것 같습니다.
이 때 사용되는 multiplier block은 fpga에 따라 다르기 때문에 지원하는 라이브러리로 합성이 진행됩니다.
반응형
'Digital logic' 카테고리의 다른 글
verilog 문법(2) ! 와 ~(산술 부정과 비트단위 부정) (2) | 2021.04.18 |
---|---|
verilog 문법(1) 결합연산자, 중복연산자 (0) | 2020.07.09 |
verilog 모듈 설계시 팁(2) (0) | 2020.05.04 |
Booth's algorithm (0) | 2020.04.21 |
이진수 수의 표현 / Binary Number System(2) (0) | 2020.04.19 |
Comments