Integer to Bit Converter
Map vector of integers to vector of bits
Libraries:
Simulink /
Logic and Bit Operations
Communications Toolbox /
Utility Blocks
HDL Coder /
Logic and Bit Operations
Description
The Integer to Bit Converter block maps each integer (or fixed-point value) in the input vector to a group of bits in the output vector.
This block is single-rate and single-channel. The block maps each integer value (or stored integer when you use a fixed point input) to a group of M bits, using the selection for the Output bit order to determine the most significant bit. The resulting output vector length is M times the input vector length.
Ports
Input
In — Input signal
integer | column vector of integers
Input signal, specified as an integer or a length N column vector of integers.
If M is specified by the Number of bits per integer(M) parameter:
When the Number of bits per integer parameter is set to
Unsigned
, input values must be integers in the range [0, (2M – 1)].When the Number of bits per integer parameter is set to
Signed
, input values must be integers in the range [(–2M-1), (2M – 1 – 1)].
During simulation, the block performs a run-time check and issues an error if any input value is outside of the appropriate range. When the block generates code, it does not perform this run-time check.
Data Types: double
Output
Out — Output signal
bit scalar | column vector of bits
Output signal, returned as a scalar or column vector of bits of length M·N.
Parameters
Number of bits per integer(M) — Number of bits per integer
3
(default) | integer in the range [1, 32]
Number of input bits mapped to each integer in the input, specified as an integer in the range [1, 32].
Programmatic Use
Block Parameter: nbits |
Type: character vector |
Values: integer in the range [1, 32] |
Default: '3' |
Treat input values as — Treat input values as
Unsigned
(default) | Signed
Indicate if the integer value input ranges should be treated as signed or unsigned.
Programmatic Use
Block Parameter:
signedInputValues |
Type: character vector |
Values: 'Unsigned' |
'Signed' |
Default: 'Unsigned' |
Output bit order — Output bit order
MSB first
(default) | LSB first
Define whether the first bit of the output signal is the most significant bit (MSB) or the least significant bit (LSB).
Programmatic Use
Block Parameter:
bitOrder |
Type: character vector |
Values: 'MSB first' |
'LSB first' |
Default: 'MSB first' |
Output data type — Output data type
Inherit via internal rule
(default) | Smallest unsigned integer
| Same as input
| double
| single
| int8
| uint8
| int16
| uint16
| int32
| uint32
| boolean
Specify the data type of the output bits. You can choose one of the following Output data type options:
Inherit via internal rule
–– The block determines the output data type based on the input data type.If the input signal is floating-point (either
single
ordouble
), the output data type is the same as the input data type.If the input data type is not floating-point, the output data type is determined as if the parameter is set to
Smallest integer
.
Smallest integer
––The block selects the output data type based on settings used in the Hardware Implementation Pane of the Configuration Parameters dialog box.If you select
ASIC/FPGA
for the device vendor, the output data type is the ideal one-bit size (ufix1).For all other device vendor selections, the output data type is an unsigned integer with the smallest available word length, as defined in the Hardware Implementation settings (for example, uint8)
Same as input
double
single
uint8
uint16
uint32
Programmatic Use
Block Parameter:
outDtype |
Type: character vector |
Values: 'Inherit via internal
rule' | 'Smallest unsigned integer' | 'Same as
input' | 'double' | 'single' |
'int8' | 'uint8' | 'int16' |
'uint16' | 'int32' | 'uint32' |
'boolean' |
Default: 'Inherit via internal
rule' |
Block Characteristics
Extended Capabilities
C/C++ Code Generation
Generate C and C++ code using Simulink® Coder™.
HDL Code Generation
Generate VHDL, Verilog and SystemVerilog code for FPGA and ASIC designs using HDL Coder™.
HDL Coder™ provides additional configuration options that affect HDL implementation and synthesized logic.
This block has one default HDL architecture.
General | |
---|---|
ConstrainedOutputPipeline | Number of registers to place at
the outputs by moving existing delays within your design. Distributed
pipelining does not redistribute these registers. The default is
|
InputPipeline | Number of input pipeline stages
to insert in the generated code. Distributed pipelining and constrained
output pipelining can move these registers. The default is
|
OutputPipeline | Number of output pipeline stages
to insert in the generated code. Distributed pipelining and constrained
output pipelining can move these registers. The default is
|
Native Floating Point | |
---|---|
LatencyStrategy | Specify whether to map the blocks in your design to |
CustomLatency | When LatencyStrategy is set to |
The block supports these data types for HDL code generation:
Input Port | Dimension | Fixed-Point | Floating-Point | Built-in Integers | Bus | Boolean | Complex Signal |
---|---|---|---|---|---|---|---|
In | Scalar Vector | Yes | Single Double | Yes | Yes | Yes | No |
This block has multi-cycle implementations that introduce additional latency in the generated code. To see the added latency, view the generated model or validation model. See Generated Model and Validation Model (HDL Coder).
Floating-Point Latency
Architecture | Floating-Point Type | Latency Strategy | Latency (in cycles) | Custom Latency Support |
---|---|---|---|---|
default | Single | Min | 6 | Yes |
Max | 6 | |||
Double | Min | 3 | ||
Max | 6 |
Matrix input is not supported.
Version History
Introduced before R2006aR2022a: Integer to Bit Converter Block Added to Simulink Logic and Bit Operations Library
The Integer to Bit Converter block has been added from the Communications Toolbox > Utility Blocks library to the Simulink > Logic and Bit Operations library. All existing models continue to work.
MATLAB Command
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
Select a Web Site
Choose a web site to get translated content where available and see local events and offers. Based on your location, we recommend that you select: .
You can also select a web site from the following list:
How to Get Best Site Performance
Select the China site (in Chinese or English) for best site performance. Other MathWorks country sites are not optimized for visits from your location.
Americas
- América Latina (Español)
- Canada (English)
- United States (English)
Europe
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)