

# Vector multiplier based on Vedic Multiplication Algorithm

**Author** : Abdullah Jhatial Associate Engineer at 10x Engineers

**Tech lead** : Ahmed Shahid Senior Engineer at 10x Engineers

**Subject** : The purpose of this IP doc is to understand how it works at a higher abstraction level . so v\_mult IP can be integrated into systems

**Introduction** : This Vector multiplier IP supports **MUL , MULH , MULHU,MULHSU** instructions.and supported precisions are **BYTE, HALF WORD,WORD**. It is three stages pipelined. A 2GHz frequency was observed at the synthesis stage.

**Terminology** : 2'C , tc :: Two's complement , r\_ : remaining

## Higher level abstraction



# Vector multiplier based on Vedic Multiplication Algorithm

---



**Top module interface signals: v\_mult\_su**

| Signal    | Width  | Description                                                                                                                                                         |
|-----------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| operand_a | 32 bit | Operand_a is a 32-bit vector. Its element sizes interpret on precision signal                                                                                       |
| operand_b | 32 bit | Operand_a is a 32 bit vector. Its element sizes interpret on precision signal                                                                                       |
| precision | 2 bit  | precision signal define element size in vector,<br>Supported precisions are<br>4 byte size elements (00)<br>2 half word size element (01)<br>Word size element (10) |
| opcode    | 2 bit  | opcode signal used for type of operation<br>Supported operation are<br>MUL,MULH,MULHU,MULHSU, (00,01,10,11)                                                         |
| Mul_out   | 32 bit | Mul_out is operation's result as precision and<br>opcode signal are driven                                                                                          |

**3\_Cycles** : at first pos edge clk input reg load operands and opcode and precision ,  
at 2nd pos edge mid reg in multiplier load with intermediate signals and  
at 3rd posedge output reg loads the result of multiplication

# Vector multiplier based on Vedic Multiplication Algorithm

---

[Git hub repo :](#)

**RTL:**

**Operands tow's complement**

tc\_selct\_8\_16.sv // parametrized N-WIDTH  
tc\_bit\_stream\_with\_precision.sv  
operand\_tc\_contorl.sv

**v\_mul\_u:**

two\_bit\_multiplier.sv  
multiplier\_4bit.sv  
multiplier\_8bit.sv  
multiplier\_16bit.sv  
multiplier\_32bit.sv

**adder\_RTL:**

prefix\_adder.sv // kogge\_stone parameterized up N-WIDTH  
carry\_save\_adder.sv  
carry\_select\_adder.sv // Using BEC  
half\_adder.sv  
full\_adder.sv // using majority circuit

**output\_control:**

v\_mul\_su\_output\_control.sv

**v\_mul\_su\_top\_module:**

v\_mul\_su.sv // top module

**Synthesis:**

**tcl\_scripts:**

tcl\_run.tcl  
tcl\_arg.arg

**Verif:**

**Self\_checking:**

tcl\_verif.tcl  
tcl\_arg.arg

# Vector multiplier based on Vedic Multiplication Algorithm

## Operands Tow's Complement control

**First\_8bit\_tc** : First\_8bit\_tc, is responsible for computing the two's complement of the first 8 bits of the operand. This block is parameterized in NWidth, Modified tow's complement circuit is used in parallel prefix calculation Architecture.

**r\_8bits\_tc** : r\_8bits\_tc, handles the two's complement for intermediate segments. This block has dependencies on two critical signals: the previous carry propagate signal and precision signals. The carry propagate signal is essential because the result of the first 8-bit block can influence the carry into the next 8-bit segment. The precision signals dictate how the operand is processed in terms of the operand size or precision.

**last\_8bit\_tc** : only difference between this and r\_tc circuit is carry out signal.

**control block** : This control block generates the sign signals which are used as mux select. Whether we selects tow's complement of element or used as unsigned. Sign signal dependence on the opcode ,precision and MSB's. These generated sign signals are also used in output control.



# Vector multiplier based on Vedic Multiplication Algorithm

**Vector Multiplier** : This multiplier based on vedic multiplication for understanding vedic Multipliers refer to this Research paper [Ref\[1\]](#).

For vector support we have to control the input vector bit's pattern Which is controlled by precision signal for 32 bit multiplication. Second 16 bit multiplier got first 16 bits of operand A and last 16 bit of - operand B. For 16bit multiplication Second 16bit multiplier will get upper 16 bits of operand A and B .

this control also implemented in 16bit multiplier which is used for control 16bit Multiplication or 8bit multiplication . this implement only second placed 16bit multiplier.



# Vector multiplier based on Vedic Multiplication Algorithm

**Output control :** This control is designed for signed multiplication with opcode support  
 For instruction sign\_mux select whether taking tc of mul out or not . that depends on sign signals which are generated from Operand tow's complement block . mux is used for instruction's support with precision control



# **Vector multiplier based on Vedic Multiplication Algorithm**

---

[Ref\[1\]](#): Ganjikunta, G. K., Khan, S. I., & Basha, M. M. (2019). A high-performance signed-unsigned multiplier using Vedic mathematics. *Journal of Low Power Electronics*, 15(5), 302-308.  
American Scientific Publishers.

[Ref\[2\]](#) : kogge stone adder

[System diagram](#): Vector Multiplier based on Vedic multiplication

[TCP slides](#) : TCP Slides and Results