AI Engine Intrinsics User Guide
(AIE) r2p22
|
These are the intrinsics functions used for implementing a DPD forward path. The AI Engine utilizes LUTs to store the products base functions and coefficients. For details in the implementation please read the further application-specific documentation on Digital Pre-distortion on AI Engine.
Typically the DPD forward path comprises the following steps:
Data Structures | |
struct | pmx_cfg |
This type is deprecated and it is defined only for legacy. DPD configuration should be done in user space. The permuation configuration which was used in setting up the permuation control. More... | |
union | pmx_cnv |
This type is deprecated and it is defined only for legacy. DPD configuration should be done in user space. This type was used internally to the function set_pmx_idx. More... | |
class | pmx_idx |
This type is deprecated and it is defined only for legacy. DPD configuration should be done in user space. This macro was used to create a pmx_cfg struct from the values passed in. More... | |
Macros | |
#define | PMX_CFG(a00, a01, a02, a03, a04, a05, a06, a07, a08, a09, a10, a11, a12, a13, a14, a15) { a00,a01,a02,a03,a04,a05,(a06)&3,(a06)>>2,a07,a08,a09,a10,a11,(a12)&0xf,(a12)>>4,a13,a14,a15 } |
This MACRO is deprecated and it is defined only for legacy. DPD configuration should be done in user space. This macro was used to create a pmx_cfg struct from the values passed in. More... | |
Functions | |
v8cacc48 | dpd_ipol (v32cint16 xbuf, pmx_idx loffs, pmx_idx roffs, v16int16 zbuf, unsigned int zoffs, unsigned int zoffs_hi, int shft) |
LUT interpolation and post-add intrinsic for 8 complex valued output lanes. More... | |
pmx_idx const | set_pmx_idx (pmx_cfg const &pmx) |
Set permutation control for left and right buffer. More... | |
void | split (int a, unsigned n, unsigned const w, int &msb, unsigned &lsb) |
Intrinsic used by DPD to split the magnitude into index and fraction for LUT interpolation. More... | |
void | split2 (int a, unsigned n, unsigned const w, int &msb_lo, int &msb_hi, unsigned &lsb) |
Similar to doing two separate splits on the lower and upper half of input a. More... | |
Variables | |
unsigned | pmx_cnv::arr [3] |
unsigned | pmx_cfg::i00: 5 |
unsigned | pmx_cfg::i01: 5 |
unsigned | pmx_cfg::i02: 5 |
unsigned | pmx_cfg::i03: 5 |
unsigned | pmx_cfg::i04: 5 |
unsigned | pmx_cfg::i05: 5 |
unsigned | pmx_cfg::i06a: 2 |
unsigned | pmx_cfg::i06b: 3 |
unsigned | pmx_cfg::i07: 5 |
unsigned | pmx_cfg::i08: 5 |
unsigned | pmx_cfg::i09: 5 |
unsigned | pmx_cfg::i10: 5 |
unsigned | pmx_cfg::i11: 5 |
unsigned | pmx_cfg::i12a: 4 |
unsigned | pmx_cfg::i12b: 1 |
unsigned | pmx_cfg::i13: 5 |
unsigned | pmx_cfg::i14: 5 |
unsigned | pmx_cfg::i15: 5 |
pmx_cfg | pmx_cnv::pmx |
DPD multiplication intrinsics | |
v8cacc48 | dpd (v8cacc48 acc, int rot, v16cint16 lut, v8cint16 data, unsigned int zoffs) |
Intrinsic multiplying the LUT values with the data values and shifting the outputs through the output delay line. More... | |
v8cacc48 | dpd (v8cacc48 acc, v4cacc48 scd, int rot, v16cint16 lut, v8cint16 data, unsigned int zoffs) |
Intrinsic multiplying the LUT values with the data values and shifting the outputs through the output delay line. More... | |
v8cacc48 | dpd (v8cacc48 acc, int rot, v16cint16 lut, v16int16 data, unsigned int zoffs, unsigned int zoffs_hi) |
Intrinsic multiplying the LUT values with the data values and shifting the outputs through the output delay line. More... | |
v8cacc48 | dpd (v8cacc48 acc, v4cacc48 scd, int rot, v16cint16 lut, v16int16 data, unsigned int zoffs, unsigned int zoffs_hi) |
Intrinsic multiplying the LUT values with the data values and shifting the outputs through the output delay line. More... | |
v8cacc48 | mac4_preadd_rot (v8cacc48 acc, v4cacc48 scd, int rot, v16cint16 xbuff, int xstart, unsigned int xoffsets, int xstep, int ystart, int ystepmult, v8cint16 zbuff, unsigned int zstart, unsigned int zoffsets, int zstep) |
Multiply-accumulate with pre-adding and accumulator rotation. More... | |
v8cacc48 | mac4_preadd_rot (v8cacc48 acc, int rot, v16cint16 xbuff, int xstart, unsigned int xoffsets, int xstep, int ystart, int ystepmult, v8cint16 zbuff, unsigned int zstart, unsigned int zoffsets, int zstep) |
Multiply-accumulate with pre-adding and accumulator rotation. More... | |
v8cacc48 | mac4_preadd_rot (v8cacc48 acc, v4cacc48 scd, int rot, v32cint16 xbuff, int xstart, unsigned int xoffsets, int xstep, int ystart, int ystepmult, v8cint16 zbuff, unsigned int zstart, unsigned int zoffsets, int zstep) |
Multiply-accumulate with pre-adding and accumulator rotation. More... | |
v8cacc48 | mac4_preadd_rot (v8cacc48 acc, int rot, v32cint16 xbuff, int xstart, unsigned int xoffsets, int xstep, int ystart, int ystepmult, v8cint16 zbuff, unsigned int zstart, unsigned int zoffsets, int zstep) |
Multiply-accumulate with pre-adding and accumulator rotation. More... | |
v8cacc48 | mac4_rot (v8cacc48 acc, v4cacc48 scd, int rot, v16cint16 xbuff, int xstart, unsigned int xoffsets, int xstep, v8cint16 zbuff, unsigned int zstart, unsigned int zoffsets, int zstep) |
Multiply-accumulate with accumulator rotation. More... | |
v8cacc48 | mac4_rot (v8cacc48 acc, int rot, v16cint16 xbuff, int xstart, unsigned int xoffsets, int xstep, v8cint16 zbuff, unsigned int zstart, unsigned int zoffsets, int zstep) |
Multiply-accumulate with accumulator rotation. More... | |
v8cacc48 | mac4_rot (v8cacc48 acc, v4cacc48 scd, int rot, v32cint16 xbuff, int xstart, unsigned int xoffsets, int xstep, v8cint16 zbuff, unsigned int zstart, unsigned int zoffsets, int zstep) |
Multiply-accumulate with accumulator rotation. More... | |
v8cacc48 | mac4_rot (v8cacc48 acc, int rot, v32cint16 xbuff, int xstart, unsigned int xoffsets, int xstep, v8cint16 zbuff, unsigned int zstart, unsigned int zoffsets, int zstep) |
Multiply-accumulate with accumulator rotation. More... | |
struct pmx_cfg |
This type is deprecated and it is defined only for legacy. DPD configuration should be done in user space. The permuation configuration which was used in setting up the permuation control.
union pmx_cnv |
This type is deprecated and it is defined only for legacy. DPD configuration should be done in user space. This type was used internally to the function set_pmx_idx.
Data Fields | ||
---|---|---|
unsigned | arr[3] | |
pmx_cfg | pmx |
class pmx_idx |
This type is deprecated and it is defined only for legacy. DPD configuration should be done in user space. This macro was used to create a pmx_cfg struct from the values passed in.
#define PMX_CFG | ( | a00, | |
a01, | |||
a02, | |||
a03, | |||
a04, | |||
a05, | |||
a06, | |||
a07, | |||
a08, | |||
a09, | |||
a10, | |||
a11, | |||
a12, | |||
a13, | |||
a14, | |||
a15 | |||
) | { a00,a01,a02,a03,a04,a05,(a06)&3,(a06)>>2,a07,a08,a09,a10,a11,(a12)&0xf,(a12)>>4,a13,a14,a15 } |
This MACRO is deprecated and it is defined only for legacy. DPD configuration should be done in user space. This macro was used to create a pmx_cfg struct from the values passed in.
v8cacc48 dpd | ( | v8cacc48 | acc, |
int | rot, | ||
v16cint16 | lut, | ||
v8cint16 | data, | ||
unsigned int | zoffs | ||
) |
Intrinsic multiplying the LUT values with the data values and shifting the outputs through the output delay line.
The dpd intrinsic wraps up the DPD. First it permutes the input data vector to ensure that the correct data values are multiplied with their corresponding LUT values. Then it executes the 8 complex/complex or 16 complex/real multiplications. After this, neighbouring values are added in a post-add step and finally the results are added onto a v8cacc48 delay line which is then shifted by one value. The reason that the output delay accumulator is 8 values wide is that we want to output 4 output lanes at a time. Since the highest three entries in the delay line are intermediate values they are not ready for output.
The complete operation can be described by the following Pseudo-code:
Parameter | Type | Comments |
---|---|---|
acc | v8cacc48 | Output accumulator which holds the output delay line |
rot | int | Rotation value by which the delay line is shifted. Valid values are 1,2 and 4. This must be a compile time constant. |
lut | v16cint16 | Vector of 16 complex LUT values to be multiplied with the data values |
data | v8cint16 | Vector of 8 complex data values |
zoffs | unsigned | Permutation control for the input data values. Each index holds 4bit within this 32bit integer. |
Let us consider the eight complex input terms are ordered in lut as follows:
n | Term 1 m r | Term 2 m r | Lane # | DD m-n |
---|---|---|---|---|
0 | 0 0 | 0 2 | 0 | 0 |
0 | 0 1 | 0 3 | 1 | 0 |
1 | 1 1 | 1 2 | 2 | 0 |
1 | 1 2 | 1 4 | 3 | 0 |
2 | 2 2 | 2 2 | 4 | 0 |
2 | 2 3 | 2 5 | 5 | 0 |
3 | 3 3 | 3 2 | 6 | 0 |
3 | 3 4 | 3 6 | 7 | 0 |
Term 1 and Term 2 denote the two terms that were added into one value by the post-add step during interpolation. One can see that neighbouring pairs share the same n and can therefore be added in the post-adding step. The data delay column tells us which values have to be passed to the zoffs parameter. The function call in this case looks like this:
v8cacc48 dpd | ( | v8cacc48 | acc, |
v4cacc48 | scd, | ||
int | rot, | ||
v16cint16 | lut, | ||
v8cint16 | data, | ||
unsigned int | zoffs | ||
) |
Intrinsic multiplying the LUT values with the data values and shifting the outputs through the output delay line.
The dpd intrinsic wraps up the DPD. First it permutes the input data vector to ensure that the correct data values are multiplied with their corresponding LUT values. Then it executes the 8 complex/complex multiplications. After this, neighbouring values are added in a post-add step and finally the results are added onto a v8cacc48 delay line which is then shifted by one value. The reason that the output delay accumulator is 8 values wide is that we want to output 4 output lanes at a time. Since the highest three entries in the delay line are intermediate values they are not ready for output.
The complete operation can be described by the following Pseudo-code:
Parameter | Type | Comments |
---|---|---|
acc | v8cacc48 | Output accumulator which holds the output delay line |
scd | v4cacc48 | Input accumulator from the SCD cascade stream. Optional. |
rot | int | Rotation value by which the delay line is shifted. Valid values are 1,2 and 4. This must be a compile time constant. |
lut | v16cint16 | Vector of 16 complex LUT values to be multiplied with the data values |
data | v8cint16 | Vector of 8 complex data values |
zoffs | unsigned | Permutation control for the input data values. Each index holds 4bit within this 32bit integer. |
Let us consider the eight complex input terms are ordered in lut as follows:
n | Term 1 m r | Term 2 m r | Lane # | DD m-n |
---|---|---|---|---|
0 | 0 0 | 0 2 | 0 | 0 |
0 | 0 1 | 0 3 | 1 | 0 |
1 | 1 1 | 1 2 | 2 | 0 |
1 | 1 2 | 1 4 | 3 | 0 |
2 | 2 2 | 2 2 | 4 | 0 |
2 | 2 3 | 2 5 | 5 | 0 |
3 | 3 3 | 3 2 | 6 | 0 |
3 | 3 4 | 3 6 | 7 | 0 |
Term 1 and Term 2 denote the two terms that were added into one value by the post-add step during interpolation. One can see that neighbouring pairs share the same n and can therefore be added in the post-adding step. The data delay column tells us which values have to be passed to the zoffs parameter. The function call in this case looks like this:
v8cacc48 dpd | ( | v8cacc48 | acc, |
int | rot, | ||
v16cint16 | lut, | ||
v16int16 | data, | ||
unsigned int | zoffs, | ||
unsigned int | zoffs_hi | ||
) |
Intrinsic multiplying the LUT values with the data values and shifting the outputs through the output delay line.
The dpd intrinsic wraps up the DPD. First it permutes the input data vector to ensure that the correct data values are multiplied with their corresponding LUT values. Then it executes the 16 complex/real multiplications. After this, neighbouring values are added in a post-add step and finally the results are added onto a v8cacc48 delay line which is then shifted by one value. The reason that the output delay accumulator is 8 values wide is that we want to output 4 output lanes at a time. Since the highest three entries in the delay line are intermediate values they are not ready for output.
The complete operation can be described by the following Pseudo-code:
Parameter | Type | Comments |
---|---|---|
acc | v8cacc48 | Output accumulator which holds the output delay line |
rot | int | Rotation value by which the delay line is shifted. Valid values are 1,2 and 4. This must be a compile time constant. |
lut | v16cint16 | Vector of 16 complex LUT values to be multiplied with the data values |
data | v16int16 | Vector of 16 real data values |
zoffs | unsigned | Permutation control for the input data values. Each index holds 4bit within this 32bit integer. Applies to column 0 and 1. |
zoffs_hi | unsigned | Permutation control for the input data values. Each index holds 4bit within this 32bit integer. Applies to column 2 and 3. |
v8cacc48 dpd | ( | v8cacc48 | acc, |
v4cacc48 | scd, | ||
int | rot, | ||
v16cint16 | lut, | ||
v16int16 | data, | ||
unsigned int | zoffs, | ||
unsigned int | zoffs_hi | ||
) |
Intrinsic multiplying the LUT values with the data values and shifting the outputs through the output delay line.
The dpd intrinsic wraps up the DPD. First it permutes the input data vector to ensure that the correct data values are multiplied with their corresponding LUT values. Then it executes the 16 complex/real multiplications. After this, neighbouring values are added in a post-add step and finally the results are added onto a v8cacc48 delay line which is then shifted by one value. The reason that the output delay accumulator is 8 values wide is that we want to output 4 output lanes at a time. Since the highest three entries in the delay line are intermediate values they are not ready for output.
The complete operation can be described by the following Pseudo-code:
Parameter | Type | Comments |
---|---|---|
acc | v8cacc48 | Output accumulator which holds the output delay line |
scd | v4cacc48 | Input accumulator from the SCD cascade stream. Optional. |
rot | int | Rotation value by which the delay line is shifted. Valid values are 1,2 and 4. This must be a compile time constant. |
lut | v16cint16 | Vector of 16 complex LUT values to be multiplied with the data values |
data | v16int16 | Vector of 16 real data values |
zoffs | unsigned | Permutation control for the input data values. Each index holds 4bit within this 32bit integer. Applies to column 0 and 1. |
zoffs_hi | unsigned | Permutation control for the input data values. Each index holds 4bit within this 32bit integer. Applies to column 2 and 3. |
v8cacc48 dpd_ipol | ( | v32cint16 | xbuf, |
pmx_idx | loffs, | ||
pmx_idx | roffs, | ||
v16int16 | zbuf, | ||
unsigned int | zoffs, | ||
unsigned int | zoffs_hi, | ||
int | shft | ||
) |
LUT interpolation and post-add intrinsic for 8 complex valued output lanes.
The dpd_ipol intrinsic calculates 8 complex values, each one being the sum of two interpolated complex LUT values. In detail it performs the following operation:
The following parameters are required by the function:
Parameter | Type | Comments |
---|---|---|
xbuf | v32cint16 | Buffer of 32 complex LUT values of type cint16 |
loffs | pmx_idx | Permutation control determining which values end up in lbuf |
roffs | pmx_idx | Permutation control determining which values end up in rbuf |
zbuf | v16int16 | Buffer of 16 real fractional values of type int16 |
zoffs | unsigned | Permutation control determining which values end up in frac |
zoffs_hi | unsigned | Permutation control determining which values end up in frac |
shift | int | Value by which the non-multiplied part of the interpolation is shifted in order to compensate for the scaling the happens by multiplying with frac |
In the first loop a mapping from xbuf to lbuf/rbuf and from zbuf to frac takes place.
The user controls the mapping taking place through the four parameters loffs, roffs, zoffs and zoffs_hi. The following criteria must be fulfilled to ensure a correct functionality of the DPD:
Let us assume that we want to call the intrinsic for a DPD with the following terms:
r\m | 3 | 2 | 1 | 0 |
---|---|---|---|---|
6 | x | - | - | - |
5 | x | x | - | - |
4 | x | x | x | - |
3 | x | x | x | x |
2 | - | x | x | x |
1 | - | - | x | x |
0 | - | - | - | x |
And the LUT values have been loaded to xbuf in the following pattern:
LUT | m | r | Lane idx | Lane idx+1 |
---|---|---|---|---|
0 | 0 | 0 | 0 | 4 |
0 | 1 | 1 | 1 | 5 |
0 | 2 | 2 | 2 | 6 |
0 | 3 | 3 | 3 | 7 |
1 | 0 | 1 | 8 | 12 |
1 | 1 | 2 | 9 | 13 |
1 | 2 | 3 | 10 | 14 |
1 | 3 | 4 | 11 | 15 |
2 | 0 | 2 | 16 | 20 |
2 | 1 | 3 | 17 | 21 |
2 | 2 | 4 | 18 | 22 |
2 | 3 | 5 | 19 | 23 |
3 | 0 | 3 | 24 | 28 |
3 | 1 | 4 | 25 | 29 |
3 | 2 | 5 | 26 | 30 |
3 | 3 | 6 | 27 | 31 |
In order to meet the criteria mentioned above we have to map this to the following pattern in lbuf and rbuf. The PermXX values represent the indices into the old pattern and therefore the values that have to be in the control parameters.
n | m | r | Lane | PermIL | PermIR | PermIF |
---|---|---|---|---|---|---|
0 | 0 | 0 | 0 | 0 | 4 | 0 |
0 | 0 | 1 | 1 | 8 | 12 | 1 |
0 | 0 | 2 | 2 | 16 | 20 | 2 |
0 | 0 | 3 | 3 | 24 | 28 | 3 |
1 | 1 | 1 | 4 | 1 | 5 | 0 |
1 | 1 | 2 | 5 | 9 | 13 | 1 |
1 | 1 | 3 | 6 | 17 | 21 | 2 |
1 | 1 | 4 | 7 | 25 | 29 | 3 |
2 | 2 | 2 | 8 | 2 | 6 | 0 |
2 | 2 | 3 | 9 | 10 | 14 | 1 |
2 | 2 | 4 | 10 | 18 | 22 | 2 |
2 | 2 | 5 | 11 | 26 | 30 | 3 |
3 | 3 | 3 | 12 | 3 | 7 | 0 |
3 | 3 | 4 | 13 | 11 | 15 | 1 |
3 | 3 | 5 | 14 | 19 | 23 | 2 |
3 | 3 | 6 | 15 | 27 | 31 | 3 |
Therefore one can prepare the permutation configuration using the following structure and call the intrinsic:
v8cacc48 mac4_preadd_rot | ( | v8cacc48 | acc, |
v4cacc48 | scd, | ||
int | rot, | ||
v16cint16 | xbuff, | ||
int | xstart, | ||
unsigned int | xoffsets, | ||
int | xstep, | ||
int | ystart, | ||
int | ystepmult, | ||
v8cint16 | zbuff, | ||
unsigned int | zstart, | ||
unsigned int | zoffsets, | ||
int | zstep | ||
) |
Multiply-accumulate with pre-adding and accumulator rotation.
[in] | acc | Previous accumulator |
[in] | scd | Vector to be "shifted in". This must come from a call to get_scd() |
[in] | rot | Number of lanes to be rotated. Can be 1, 2 or 4. Must be a compile time constant |
[in] | xbuff | Data buffer for first multiplier input (LUT terms in the DPD context) |
[in] | xstart | Start index in xbuff for first pre-addition summand |
[in] | xoffsets | Row-dependent offsets in xbuff for first pre-addition summand |
[in] | xstep | Offset between columns for xbuff for first pre-addition summand |
[in] | ystart | Start index in xbuff for second pre-addition summand |
[in] | ystepmult | Column offset multiplier in xbuff for second pre-addition summand. Can be 0, 1, 2, 4, 8, -1, -2 or -4. Must be a compile time constant |
[in] | zbuff | Data buffer for second multiplier input (data values in the DPD context) |
[in] | zstart | Start index in zbuff. Must be a compile time constant |
[in] | zoffsets | Row-dependent offsets in zbuff |
[in] | zstep | Offset between columns for zbuff |
v8cacc48 mac4_preadd_rot | ( | v8cacc48 | acc, |
int | rot, | ||
v16cint16 | xbuff, | ||
int | xstart, | ||
unsigned int | xoffsets, | ||
int | xstep, | ||
int | ystart, | ||
int | ystepmult, | ||
v8cint16 | zbuff, | ||
unsigned int | zstart, | ||
unsigned int | zoffsets, | ||
int | zstep | ||
) |
Multiply-accumulate with pre-adding and accumulator rotation.
[in] | acc | Previous accumulator |
[in] | rot | Number of lanes to be rotated. Can be 1, 2 or 4. Must be a compile time constant |
[in] | xbuff | Data buffer for first multiplier input (LUT terms in the DPD context) |
[in] | xstart | Start index in xbuff for first pre-addition summand |
[in] | xoffsets | Row-dependent offsets in xbuff for first pre-addition summand |
[in] | xstep | Offset between columns for xbuff for first pre-addition summand |
[in] | ystart | Start index in xbuff for second pre-addition summand |
[in] | ystepmult | Column offset multiplier in xbuff for second pre-addition summand. Can be 0, 1, 2, 4, 8, -1, -2 or -4. Must be a compile time constant |
[in] | zbuff | Data buffer for second multiplier input (data values in the DPD context) |
[in] | zstart | Start index in zbuff. Must be a compile time constant |
[in] | zoffsets | Row-dependent offsets in zbuff |
[in] | zstep | Offset between columns for zbuff |
v8cacc48 mac4_preadd_rot | ( | v8cacc48 | acc, |
v4cacc48 | scd, | ||
int | rot, | ||
v32cint16 | xbuff, | ||
int | xstart, | ||
unsigned int | xoffsets, | ||
int | xstep, | ||
int | ystart, | ||
int | ystepmult, | ||
v8cint16 | zbuff, | ||
unsigned int | zstart, | ||
unsigned int | zoffsets, | ||
int | zstep | ||
) |
Multiply-accumulate with pre-adding and accumulator rotation.
[in] | acc | Previous accumulator |
[in] | scd | Vector to be "shifted in". This must come from a call to get_scd() |
[in] | rot | Number of lanes to be rotated. Can be 1, 2 or 4. Must be a compile time constant |
[in] | xbuff | Data buffer for first multiplier input (LUT terms in the DPD context) |
[in] | xstart | Start index in xbuff for first pre-addition summand |
[in] | xoffsets | Row-dependent offsets in xbuff for first pre-addition summand |
[in] | xstep | Offset between columns for xbuff for first pre-addition summand |
[in] | ystart | Start index in xbuff for second pre-addition summand |
[in] | ystepmult | Column offset multiplier in xbuff for second pre-addition summand. Can be 0, 1, 2, 4, 8, -1, -2 or -4. Must be a compile time constant |
[in] | zbuff | Data buffer for second multiplier input (data values in the DPD context) |
[in] | zstart | Start index in zbuff. Must be a compile time constant |
[in] | zoffsets | Row-dependent offsets in zbuff |
[in] | zstep | Offset between columns for zbuff |
v8cacc48 mac4_preadd_rot | ( | v8cacc48 | acc, |
int | rot, | ||
v32cint16 | xbuff, | ||
int | xstart, | ||
unsigned int | xoffsets, | ||
int | xstep, | ||
int | ystart, | ||
int | ystepmult, | ||
v8cint16 | zbuff, | ||
unsigned int | zstart, | ||
unsigned int | zoffsets, | ||
int | zstep | ||
) |
Multiply-accumulate with pre-adding and accumulator rotation.
[in] | acc | Previous accumulator |
[in] | rot | Number of lanes to be rotated. Can be 1, 2 or 4. Must be a compile time constant |
[in] | xbuff | Data buffer for first multiplier input (LUT terms in the DPD context) |
[in] | xstart | Start index in xbuff for first pre-addition summand |
[in] | xoffsets | Row-dependent offsets in xbuff for first pre-addition summand |
[in] | xstep | Offset between columns for xbuff for first pre-addition summand |
[in] | ystart | Start index in xbuff for second pre-addition summand |
[in] | ystepmult | Column offset multiplier in xbuff for second pre-addition summand. Can be 0, 1, 2, 4, 8, -1, -2 or -4. Must be a compile time constant |
[in] | zbuff | Data buffer for second multiplier input (data values in the DPD context) |
[in] | zstart | Start index in zbuff. Must be a compile time constant |
[in] | zoffsets | Row-dependent offsets in zbuff |
[in] | zstep | Offset between columns for zbuff |
v8cacc48 mac4_rot | ( | v8cacc48 | acc, |
v4cacc48 | scd, | ||
int | rot, | ||
v16cint16 | xbuff, | ||
int | xstart, | ||
unsigned int | xoffsets, | ||
int | xstep, | ||
v8cint16 | zbuff, | ||
unsigned int | zstart, | ||
unsigned int | zoffsets, | ||
int | zstep | ||
) |
Multiply-accumulate with accumulator rotation.
[in] | acc | Previous accumulator |
[in] | scd | Vector to be "shifted in". This must come from a call to get_scd() |
[in] | rot | Number of lanes to be rotated. Can be 1, 2 or 4. Must be a compile time constant |
[in] | xbuff | Data buffer for first multiplier input (LUT terms in the DPD context) |
[in] | xstart | Start index in xbuff |
[in] | xoffsets | Row-dependent offsets in xbuff |
[in] | xstep | Offset between columns for xbuff |
[in] | zbuff | Data buffer for second multiplier input (data values in the DPD context) |
[in] | zstart | Start index in zbuff. Must be a compile time constant |
[in] | zoffsets | Row-dependent offsets in zbuff |
[in] | zstep | Offset between columns for zbuff |
v8cacc48 mac4_rot | ( | v8cacc48 | acc, |
int | rot, | ||
v16cint16 | xbuff, | ||
int | xstart, | ||
unsigned int | xoffsets, | ||
int | xstep, | ||
v8cint16 | zbuff, | ||
unsigned int | zstart, | ||
unsigned int | zoffsets, | ||
int | zstep | ||
) |
Multiply-accumulate with accumulator rotation.
[in] | acc | Previous accumulator |
[in] | rot | Number of lanes to be rotated. Can be 1, 2 or 4. Must be a compile time constant |
[in] | xbuff | Data buffer for first multiplier input (LUT terms in the DPD context) |
[in] | xstart | Start index in xbuff for first pre-addition summand |
[in] | xoffsets | Row-dependent offsets in xbuff |
[in] | xstep | Offset between columns for xbuff |
[in] | zbuff | Data buffer for second multiplier input (data values in the DPD context) |
[in] | zstart | Start index in zbuff. Must be a compile time constant |
[in] | zoffsets | Row-dependent offsets in zbuff |
[in] | zstep | Offset between columns for zbuff |
v8cacc48 mac4_rot | ( | v8cacc48 | acc, |
v4cacc48 | scd, | ||
int | rot, | ||
v32cint16 | xbuff, | ||
int | xstart, | ||
unsigned int | xoffsets, | ||
int | xstep, | ||
v8cint16 | zbuff, | ||
unsigned int | zstart, | ||
unsigned int | zoffsets, | ||
int | zstep | ||
) |
Multiply-accumulate with accumulator rotation.
[in] | acc | Previous accumulator |
[in] | scd | Vector to be "shifted in". This must come from a call to get_scd() |
[in] | rot | Number of lanes to be rotated. Can be 1, 2 or 4. Must be a compile time constant |
[in] | xbuff | Data buffer for first multiplier input (LUT terms in the DPD context) |
[in] | xstart | Start index in xbuff for first pre-addition summand |
[in] | xoffsets | Row-dependent offsets in xbuff |
[in] | xstep | Offset between columns for xbuff |
[in] | zbuff | Data buffer for second multiplier input (data values in the DPD context) |
[in] | zstart | Start index in zbuff. Must be a compile time constant |
[in] | zoffsets | Row-dependent offsets in zbuff |
[in] | zstep | Offset between columns for zbuff |
v8cacc48 mac4_rot | ( | v8cacc48 | acc, |
int | rot, | ||
v32cint16 | xbuff, | ||
int | xstart, | ||
unsigned int | xoffsets, | ||
int | xstep, | ||
v8cint16 | zbuff, | ||
unsigned int | zstart, | ||
unsigned int | zoffsets, | ||
int | zstep | ||
) |
Multiply-accumulate with accumulator rotation.
[in] | acc | Previous accumulator |
[in] | rot | Number of lanes to be rotated. Can be 1, 2 or 4. Must be a compile time constant |
[in] | xbuff | Data buffer for first multiplier input (LUT terms in the DPD context) |
[in] | xstart | Start index in xbuff for first pre-addition summand |
[in] | xoffsets | Row-dependent offsets in xbuff |
[in] | xstep | Offset between columns for xbuff |
[in] | zbuff | Data buffer for second multiplier input (data values in the DPD context) |
[in] | zstart | Start index in zbuff. Must be a compile time constant |
[in] | zoffsets | Row-dependent offsets in zbuff |
[in] | zstep | Offset between columns for zbuff |
Set permutation control for left and right buffer.
This intrinsic is used in DPD to set the permutation control for left and right buffer. Is is composed of 16 5-bit values.
void split | ( | int | a, |
unsigned | n, | ||
unsigned const | w, | ||
int & | msb, | ||
unsigned & | lsb | ||
) |
Intrinsic used by DPD to split the magnitude into index and fraction for LUT interpolation.
The split intrinsic prepares the magnitude values for further processing in the DPD. The parameters are the following:
a | Input magnitude as a 32bit integer |
n | Number of LSBs that shall end up in the fraction. This must be a compile time constant. |
w | Width of the LUT in bytes on a binary logarithmic scale. The index will be shifted to the left by this value. This must be a compile-time constant. |
msb | Output index into the LUT by reference |
lsb | Output fraction for interpolation between msb and msb+1 in the LUT by reference |
The instrinsic performs the following operation:
To compute the index into the LUT the intrinsic first shifts the magnitude value to the right by n and then to the left by w, therefore disregarding the fractional bits and filling up as many zeroes as necessary to correctly index the LUT. For the fraction value the magnitude is masked so that only the fractional bits remain.
Let us assume we want to split a magnitude value under the following requirements:
The first requirement dictates that w must be ld(4*sizeof(cint16)) = ld(16) = 4. n obviously is 7.
Therefore in this case a call of the split function could look like this:
void split2 | ( | int | a, |
unsigned | n, | ||
unsigned const | w, | ||
int & | msb_lo, | ||
int & | msb_hi, | ||
unsigned & | lsb | ||
) |
Similar to doing two separate splits on the lower and upper half of input a.
a | Input as two lanes of 16 bits in a 32bit integer |
n | Number of LSBs that shall end up in the fraction. This must be a compile time constant. |
w | Width of the LUT in bytes on a binary logarithmic scale. The index will be shifted to the left by this value. This must be a compile time constant. |
msb_lo | Lower order bits of output index into the LUT by reference |
msb_hi | Higher order bits of output index into the LUT by reference |
lsb | Output fraction for interpolation between msb and msb+1 in the LUT by reference (Two lanes of 16 bits each) |
The instrinsic performs the following operations:
unsigned pmx_cnv::arr[3] |
unsigned pmx_cfg::i00 |
unsigned pmx_cfg::i01 |
unsigned pmx_cfg::i02 |
unsigned pmx_cfg::i03 |
unsigned pmx_cfg::i04 |
unsigned pmx_cfg::i05 |
unsigned pmx_cfg::i06a |
unsigned pmx_cfg::i06b |
unsigned pmx_cfg::i07 |
unsigned pmx_cfg::i08 |
unsigned pmx_cfg::i09 |
unsigned pmx_cfg::i10 |
unsigned pmx_cfg::i11 |
unsigned pmx_cfg::i12a |
unsigned pmx_cfg::i12b |
unsigned pmx_cfg::i13 |
unsigned pmx_cfg::i14 |
unsigned pmx_cfg::i15 |
pmx_cfg pmx_cnv::pmx |