## Last updated 1/7/25

- 2 primary types of conversions
  - Vector conversions
    - Fully synthesizable all about interpretation

<->

- Similar to a type cast in programming
- std\_logic\_vector
- std\_logic\_vector <->
- signed <->

unsigned unsigned

signed

- Integer conversions
  - Not synthesizable
    - compile time calculations
    - simulations
  - Requires a function to make the conversion

<->

- signed <-> integer
- unsigned

integer

- Vector conversions
  - SLV to signed

my\_4bit\_signed <= signed(my\_4bit\_slv);</pre>

SLV to unsigned

my\_4bit\_unsigned <= unsigned(my\_4bit\_slv);</pre>

signed to SLV

my\_6bit\_slv <= std\_logic\_vector(my\_6bit\_signed);</pre>

- unsigned to SLV
  my\_8bit\_slv <= std\_logic\_vector(my\_8bit\_unsigned);</li>
- unsigned to signed my\_12bit\_signed <= signed(my\_12bit\_unsigned);</li>
- signed to unsigned my\_16bit\_unsigned <= unsigned(my\_16bit\_signed);</li>

- Integer conversions
  - Integers can only convert to/from signed/unsigned
    - SLV has no numerical interpretation
  - Vector to integer conversions
    - signed to int my\_comparison\_int <= to\_integer(my\_12bit\_signed);</li>
    - unsigned to int my\_limit\_int <= to\_integer(my\_16bit\_unsigned);</li>
  - Integer to vector conversions require the number of bits to use in the vector
    - integer to signed my\_8bit\_signed\_sim\_input <= to\_signed(22, 8);</li>
    - integer to unsigned

my\_4bit\_unsigned\_sim\_input <= to\_unsigned(11, 4);</pre>

