AI Engine Intrinsics User Guide  (AIE) r2p22
All Data Structures Namespaces Functions Variables Typedefs Groups Pages

Overview

32 bit real by 32 bit complex using no conjugation

Functions

v2cacc80 lmac2 (v2cacc80 acc, v32int32 xbuff, int xstart, unsigned int xoffsets, int xstep, v4cint32 zbuff, int zstart, unsigned int zoffsets, int zstep)
 Complex multiply-accumulate intrinsic function . More...
 
v2cacc80 lmac2 (v2cacc80 acc, v16int32 xbuff, int xstart, unsigned int xoffsets, int xstep, v4cint32 zbuff, int zstart, unsigned int zoffsets, int zstep)
 Complex multiply-accumulate intrinsic function using small X input buffer. More...
 
v4cacc80 lmac4 (v4cacc80 acc, v32int32 xbuff, int xstart, unsigned int xoffsets, v4cint32 zbuff, int zstart, unsigned int zoffsets)
 Complex multiply-accumulate intrinsic function . More...
 
v4cacc80 lmac4 (v4cacc80 acc, v16int32 xbuff, int xstart, unsigned int xoffsets, v4cint32 zbuff, int zstart, unsigned int zoffsets)
 Complex multiply-accumulate intrinsic function using small X input buffer. More...
 
v2cacc80 lmsc2 (v2cacc80 acc, v32int32 xbuff, int xstart, unsigned int xoffsets, int xstep, v4cint32 zbuff, int zstart, unsigned int zoffsets, int zstep)
 Complex multiply-subtract intrinsic function . More...
 
v2cacc80 lmsc2 (v2cacc80 acc, v16int32 xbuff, int xstart, unsigned int xoffsets, int xstep, v4cint32 zbuff, int zstart, unsigned int zoffsets, int zstep)
 Complex multiply-subtract intrinsic function using small X input buffer. More...
 
v4cacc80 lmsc4 (v4cacc80 acc, v32int32 xbuff, int xstart, unsigned int xoffsets, v4cint32 zbuff, int zstart, unsigned int zoffsets)
 Complex multiply-subtract intrinsic function . More...
 
v4cacc80 lmsc4 (v4cacc80 acc, v16int32 xbuff, int xstart, unsigned int xoffsets, v4cint32 zbuff, int zstart, unsigned int zoffsets)
 Complex multiply-subtract intrinsic function using small X input buffer. More...
 
v2cacc80 lmul2 (v32int32 xbuff, int xstart, unsigned int xoffsets, int xstep, v4cint32 zbuff, int zstart, unsigned int zoffsets, int zstep)
 Complex multiply intrinsic function . More...
 
v2cacc80 lmul2 (v16int32 xbuff, int xstart, unsigned int xoffsets, int xstep, v4cint32 zbuff, int zstart, unsigned int zoffsets, int zstep)
 Complex multiply intrinsic function using small X input buffer. More...
 
v4cacc80 lmul4 (v32int32 xbuff, int xstart, unsigned int xoffsets, v4cint32 zbuff, int zstart, unsigned int zoffsets)
 Complex multiply intrinsic function . More...
 
v4cacc80 lmul4 (v16int32 xbuff, int xstart, unsigned int xoffsets, v4cint32 zbuff, int zstart, unsigned int zoffsets)
 Complex multiply intrinsic function using small X input buffer. More...
 
v2cacc80 lnegmul2 (v32int32 xbuff, int xstart, unsigned int xoffsets, int xstep, v4cint32 zbuff, int zstart, unsigned int zoffsets, int zstep)
 Complex multiply-negate intrinsic function . More...
 
v2cacc80 lnegmul2 (v16int32 xbuff, int xstart, unsigned int xoffsets, int xstep, v4cint32 zbuff, int zstart, unsigned int zoffsets, int zstep)
 Complex multiply-negate intrinsic function using small X input buffer. More...
 
v4cacc80 lnegmul4 (v32int32 xbuff, int xstart, unsigned int xoffsets, v4cint32 zbuff, int zstart, unsigned int zoffsets)
 Complex multiply-negate intrinsic function . More...
 
v4cacc80 lnegmul4 (v16int32 xbuff, int xstart, unsigned int xoffsets, v4cint32 zbuff, int zstart, unsigned int zoffsets)
 Complex multiply-negate intrinsic function using small X input buffer. More...
 

Function Documentation

v2cacc80 lmac2 ( v2cacc80  acc,
v32int32  xbuff,
int  xstart,
unsigned int  xoffsets,
int  xstep,
v4cint32  zbuff,
int  zstart,
unsigned int  zoffsets,
int  zstep 
)

Complex multiply-accumulate intrinsic function .

acc0 += z00*x00 + z01*x01
acc1 += z10*x10 + z11*x11

Parameters

Input/OutputType Comments
return v2cacc80 Returned accumulation vector (2 x cint80 lanes)
acc v2cacc80 Incoming accumulation vector (2 x cint80 lanes)
xbuff v32int32Input buffer of 32 elements of type int32
xstart int Starting position offset applied to all lanes of input from X buffer.
xoffsets unsigned int 4b offset for each lane, applied to the x buffer. LSB apply to first lane
xstep unsigned int Step between each column for selection in the xbuffer.
zbuff v4cint32Input buffer of 4 elements of type cint32
zstart int Starting position offset applied to all lanes for input from Z buffer. This must be a compile time constant. Only the 4 LSB of the argument are used.
zoffsetsunsigned int 4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
zstep int Step between each column for selection in the zbuffer.
Note
  • For more information on how data selection works from the buffers go here. The data buffer and coefficient buffer in this intrinsic use the general scheme.
  • Parameter 'zstart' must be a compile time constant.
v2cacc80 lmac2 ( v2cacc80  acc,
v16int32  xbuff,
int  xstart,
unsigned int  xoffsets,
int  xstep,
v4cint32  zbuff,
int  zstart,
unsigned int  zoffsets,
int  zstep 
)

Complex multiply-accumulate intrinsic function using small X input buffer.

acc0 += z00*x00 + z01*x01
acc1 += z10*x10 + z11*x11

Parameters

Input/OutputType Comments
return v2cacc80 Returned accumulation vector (2 x cint80 lanes)
acc v2cacc80 Incoming accumulation vector (2 x cint80 lanes)
xbuff v16int32Input buffer of 16 elements of type int32
xstart int Starting position offset applied to all lanes of input from X buffer.
xoffsets unsigned int 4b offset for each lane, applied to the x buffer. LSB apply to first lane
xstep unsigned int Step between each column for selection in the xbuffer.
zbuff v4cint32Input buffer of 4 elements of type cint32
zstart int Starting position offset applied to all lanes for input from Z buffer. This must be a compile time constant. Only the 4 LSB of the argument are used.
zoffsetsunsigned int 4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
zstep int Step between each column for selection in the zbuffer.
Note
  • For more information on how data selection works from the buffers go here. The data buffer and coefficient buffer in this intrinsic use the general scheme.
  • Parameter 'zstart' must be a compile time constant.
v4cacc80 lmac4 ( v4cacc80  acc,
v32int32  xbuff,
int  xstart,
unsigned int  xoffsets,
v4cint32  zbuff,
int  zstart,
unsigned int  zoffsets 
)

Complex multiply-accumulate intrinsic function .

acc0 += z00*x00
acc1 += z10*x10
acc2 += z20*x20
acc3 += z30*x30

Parameters

Input/OutputType Comments
return v4cacc80 Returned accumulation vector (4 x cint80 lanes)
acc v4cacc80 Incoming accumulation vector (4 x cint80 lanes)
xbuff v32int32Input buffer of 32 elements of type int32
xstart int Starting position offset applied to all lanes of input from X buffer.
xoffsets unsigned int 4b offset for each lane, applied to the x buffer. LSB apply to first lane
zbuff v4cint32Input buffer of 4 elements of type cint32
zstart int Starting position offset applied to all lanes for input from Z buffer. This must be a compile time constant. Only the 4 LSB of the argument are used.
zoffsetsunsigned int 4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
Note
  • For more information on how data selection works from the buffers go here. The data buffer and coefficient buffer in this intrinsic use the general scheme.
  • Parameter 'zstart' must be a compile time constant.
v4cacc80 lmac4 ( v4cacc80  acc,
v16int32  xbuff,
int  xstart,
unsigned int  xoffsets,
v4cint32  zbuff,
int  zstart,
unsigned int  zoffsets 
)

Complex multiply-accumulate intrinsic function using small X input buffer.

acc0 += z00*x00
acc1 += z10*x10
acc2 += z20*x20
acc3 += z30*x30

Parameters

Input/OutputType Comments
return v4cacc80 Returned accumulation vector (4 x cint80 lanes)
acc v4cacc80 Incoming accumulation vector (4 x cint80 lanes)
xbuff v16int32Input buffer of 16 elements of type int32
xstart int Starting position offset applied to all lanes of input from X buffer.
xoffsets unsigned int 4b offset for each lane, applied to the x buffer. LSB apply to first lane
zbuff v4cint32Input buffer of 4 elements of type cint32
zstart int Starting position offset applied to all lanes for input from Z buffer. This must be a compile time constant. Only the 4 LSB of the argument are used.
zoffsetsunsigned int 4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
Note
  • For more information on how data selection works from the buffers go here. The data buffer and coefficient buffer in this intrinsic use the general scheme.
  • Parameter 'zstart' must be a compile time constant.
v2cacc80 lmsc2 ( v2cacc80  acc,
v32int32  xbuff,
int  xstart,
unsigned int  xoffsets,
int  xstep,
v4cint32  zbuff,
int  zstart,
unsigned int  zoffsets,
int  zstep 
)

Complex multiply-subtract intrinsic function .

acc0 -= z00*x00 + z01*x01
acc1 -= z10*x10 + z11*x11

Parameters

Input/OutputType Comments
return v2cacc80 Returned accumulation vector (2 x cint80 lanes)
acc v2cacc80 Incoming accumulation vector (2 x cint80 lanes)
xbuff v32int32Input buffer of 32 elements of type int32
xstart int Starting position offset applied to all lanes of input from X buffer.
xoffsets unsigned int 4b offset for each lane, applied to the x buffer. LSB apply to first lane
xstep unsigned int Step between each column for selection in the xbuffer.
zbuff v4cint32Input buffer of 4 elements of type cint32
zstart int Starting position offset applied to all lanes for input from Z buffer. This must be a compile time constant. Only the 4 LSB of the argument are used.
zoffsetsunsigned int 4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
zstep int Step between each column for selection in the zbuffer.
Note
  • For more information on how data selection works from the buffers go here. The data buffer and coefficient buffer in this intrinsic use the general scheme.
  • Parameter 'zstart' must be a compile time constant.
v2cacc80 lmsc2 ( v2cacc80  acc,
v16int32  xbuff,
int  xstart,
unsigned int  xoffsets,
int  xstep,
v4cint32  zbuff,
int  zstart,
unsigned int  zoffsets,
int  zstep 
)

Complex multiply-subtract intrinsic function using small X input buffer.

acc0 -= z00*x00 + z01*x01
acc1 -= z10*x10 + z11*x11

Parameters

Input/OutputType Comments
return v2cacc80 Returned accumulation vector (2 x cint80 lanes)
acc v2cacc80 Incoming accumulation vector (2 x cint80 lanes)
xbuff v16int32Input buffer of 16 elements of type int32
xstart int Starting position offset applied to all lanes of input from X buffer.
xoffsets unsigned int 4b offset for each lane, applied to the x buffer. LSB apply to first lane
xstep unsigned int Step between each column for selection in the xbuffer.
zbuff v4cint32Input buffer of 4 elements of type cint32
zstart int Starting position offset applied to all lanes for input from Z buffer. This must be a compile time constant. Only the 4 LSB of the argument are used.
zoffsetsunsigned int 4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
zstep int Step between each column for selection in the zbuffer.
Note
  • For more information on how data selection works from the buffers go here. The data buffer and coefficient buffer in this intrinsic use the general scheme.
  • Parameter 'zstart' must be a compile time constant.
v4cacc80 lmsc4 ( v4cacc80  acc,
v32int32  xbuff,
int  xstart,
unsigned int  xoffsets,
v4cint32  zbuff,
int  zstart,
unsigned int  zoffsets 
)

Complex multiply-subtract intrinsic function .

acc0 -= z00*x00
acc1 -= z10*x10
acc2 -= z20*x20
acc3 -= z30*x30

Parameters

Input/OutputType Comments
return v4cacc80 Returned accumulation vector (4 x cint80 lanes)
acc v4cacc80 Incoming accumulation vector (4 x cint80 lanes)
xbuff v32int32Input buffer of 32 elements of type int32
xstart int Starting position offset applied to all lanes of input from X buffer.
xoffsets unsigned int 4b offset for each lane, applied to the x buffer. LSB apply to first lane
zbuff v4cint32Input buffer of 4 elements of type cint32
zstart int Starting position offset applied to all lanes for input from Z buffer. This must be a compile time constant. Only the 4 LSB of the argument are used.
zoffsetsunsigned int 4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
Note
  • For more information on how data selection works from the buffers go here. The data buffer and coefficient buffer in this intrinsic use the general scheme.
  • Parameter 'zstart' must be a compile time constant.
v4cacc80 lmsc4 ( v4cacc80  acc,
v16int32  xbuff,
int  xstart,
unsigned int  xoffsets,
v4cint32  zbuff,
int  zstart,
unsigned int  zoffsets 
)

Complex multiply-subtract intrinsic function using small X input buffer.

acc0 -= z00*x00
acc1 -= z10*x10
acc2 -= z20*x20
acc3 -= z30*x30

Parameters

Input/OutputType Comments
return v4cacc80 Returned accumulation vector (4 x cint80 lanes)
acc v4cacc80 Incoming accumulation vector (4 x cint80 lanes)
xbuff v16int32Input buffer of 16 elements of type int32
xstart int Starting position offset applied to all lanes of input from X buffer.
xoffsets unsigned int 4b offset for each lane, applied to the x buffer. LSB apply to first lane
zbuff v4cint32Input buffer of 4 elements of type cint32
zstart int Starting position offset applied to all lanes for input from Z buffer. This must be a compile time constant. Only the 4 LSB of the argument are used.
zoffsetsunsigned int 4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
Note
  • For more information on how data selection works from the buffers go here. The data buffer and coefficient buffer in this intrinsic use the general scheme.
  • Parameter 'zstart' must be a compile time constant.
v2cacc80 lmul2 ( v32int32  xbuff,
int  xstart,
unsigned int  xoffsets,
int  xstep,
v4cint32  zbuff,
int  zstart,
unsigned int  zoffsets,
int  zstep 
)

Complex multiply intrinsic function .

acc0 = z00*x00 + z01*x01
acc1 = z10*x10 + z11*x11

Parameters

Input/OutputType Comments
return v2cacc80 Returned accumulation vector (2 x cint80 lanes)
xbuff v32int32Input buffer of 32 elements of type int32
xstart int Starting position offset applied to all lanes of input from X buffer.
xoffsets unsigned int 4b offset for each lane, applied to the x buffer. LSB apply to first lane
xstep unsigned int Step between each column for selection in the xbuffer.
zbuff v4cint32Input buffer of 4 elements of type cint32
zstart int Starting position offset applied to all lanes for input from Z buffer. This must be a compile time constant. Only the 4 LSB of the argument are used.
zoffsetsunsigned int 4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
zstep int Step between each column for selection in the zbuffer.
Note
  • For more information on how data selection works from the buffers go here. The data buffer and coefficient buffer in this intrinsic use the general scheme.
  • Parameter 'zstart' must be a compile time constant.
v2cacc80 lmul2 ( v16int32  xbuff,
int  xstart,
unsigned int  xoffsets,
int  xstep,
v4cint32  zbuff,
int  zstart,
unsigned int  zoffsets,
int  zstep 
)

Complex multiply intrinsic function using small X input buffer.

acc0 = z00*x00 + z01*x01
acc1 = z10*x10 + z11*x11

Parameters

Input/OutputType Comments
return v2cacc80 Returned accumulation vector (2 x cint80 lanes)
xbuff v16int32Input buffer of 16 elements of type int32
xstart int Starting position offset applied to all lanes of input from X buffer.
xoffsets unsigned int 4b offset for each lane, applied to the x buffer. LSB apply to first lane
xstep unsigned int Step between each column for selection in the xbuffer.
zbuff v4cint32Input buffer of 4 elements of type cint32
zstart int Starting position offset applied to all lanes for input from Z buffer. This must be a compile time constant. Only the 4 LSB of the argument are used.
zoffsetsunsigned int 4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
zstep int Step between each column for selection in the zbuffer.
Note
  • For more information on how data selection works from the buffers go here. The data buffer and coefficient buffer in this intrinsic use the general scheme.
  • Parameter 'zstart' must be a compile time constant.
v4cacc80 lmul4 ( v32int32  xbuff,
int  xstart,
unsigned int  xoffsets,
v4cint32  zbuff,
int  zstart,
unsigned int  zoffsets 
)

Complex multiply intrinsic function .

acc0 = z00*x00
acc1 = z10*x10
acc2 = z20*x20
acc3 = z30*x30

Parameters

Input/OutputType Comments
return v4cacc80 Returned accumulation vector (4 x cint80 lanes)
xbuff v32int32Input buffer of 32 elements of type int32
xstart int Starting position offset applied to all lanes of input from X buffer.
xoffsets unsigned int 4b offset for each lane, applied to the x buffer. LSB apply to first lane
zbuff v4cint32Input buffer of 4 elements of type cint32
zstart int Starting position offset applied to all lanes for input from Z buffer. This must be a compile time constant. Only the 4 LSB of the argument are used.
zoffsetsunsigned int 4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
Note
  • For more information on how data selection works from the buffers go here. The data buffer and coefficient buffer in this intrinsic use the general scheme.
  • Parameter 'zstart' must be a compile time constant.
v4cacc80 lmul4 ( v16int32  xbuff,
int  xstart,
unsigned int  xoffsets,
v4cint32  zbuff,
int  zstart,
unsigned int  zoffsets 
)

Complex multiply intrinsic function using small X input buffer.

acc0 = z00*x00
acc1 = z10*x10
acc2 = z20*x20
acc3 = z30*x30

Parameters

Input/OutputType Comments
return v4cacc80 Returned accumulation vector (4 x cint80 lanes)
xbuff v16int32Input buffer of 16 elements of type int32
xstart int Starting position offset applied to all lanes of input from X buffer.
xoffsets unsigned int 4b offset for each lane, applied to the x buffer. LSB apply to first lane
zbuff v4cint32Input buffer of 4 elements of type cint32
zstart int Starting position offset applied to all lanes for input from Z buffer. This must be a compile time constant. Only the 4 LSB of the argument are used.
zoffsetsunsigned int 4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
Note
  • For more information on how data selection works from the buffers go here. The data buffer and coefficient buffer in this intrinsic use the general scheme.
  • Parameter 'zstart' must be a compile time constant.
v2cacc80 lnegmul2 ( v32int32  xbuff,
int  xstart,
unsigned int  xoffsets,
int  xstep,
v4cint32  zbuff,
int  zstart,
unsigned int  zoffsets,
int  zstep 
)

Complex multiply-negate intrinsic function .

acc0 = -( z00*x00 + z01*x01 )
acc1 = -( z10*x10 + z11*x11 )

Parameters

Input/OutputType Comments
return v2cacc80 Returned accumulation vector (2 x cint80 lanes)
xbuff v32int32Input buffer of 32 elements of type int32
xstart int Starting position offset applied to all lanes of input from X buffer.
xoffsets unsigned int 4b offset for each lane, applied to the x buffer. LSB apply to first lane
xstep unsigned int Step between each column for selection in the xbuffer.
zbuff v4cint32Input buffer of 4 elements of type cint32
zstart int Starting position offset applied to all lanes for input from Z buffer. This must be a compile time constant. Only the 4 LSB of the argument are used.
zoffsetsunsigned int 4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
zstep int Step between each column for selection in the zbuffer.
Note
  • For more information on how data selection works from the buffers go here. The data buffer and coefficient buffer in this intrinsic use the general scheme.
  • Parameter 'zstart' must be a compile time constant.
v2cacc80 lnegmul2 ( v16int32  xbuff,
int  xstart,
unsigned int  xoffsets,
int  xstep,
v4cint32  zbuff,
int  zstart,
unsigned int  zoffsets,
int  zstep 
)

Complex multiply-negate intrinsic function using small X input buffer.

acc0 = -( z00*x00 + z01*x01 )
acc1 = -( z10*x10 + z11*x11 )

Parameters

Input/OutputType Comments
return v2cacc80 Returned accumulation vector (2 x cint80 lanes)
xbuff v16int32Input buffer of 16 elements of type int32
xstart int Starting position offset applied to all lanes of input from X buffer.
xoffsets unsigned int 4b offset for each lane, applied to the x buffer. LSB apply to first lane
xstep unsigned int Step between each column for selection in the xbuffer.
zbuff v4cint32Input buffer of 4 elements of type cint32
zstart int Starting position offset applied to all lanes for input from Z buffer. This must be a compile time constant. Only the 4 LSB of the argument are used.
zoffsetsunsigned int 4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
zstep int Step between each column for selection in the zbuffer.
Note
  • For more information on how data selection works from the buffers go here. The data buffer and coefficient buffer in this intrinsic use the general scheme.
  • Parameter 'zstart' must be a compile time constant.
v4cacc80 lnegmul4 ( v32int32  xbuff,
int  xstart,
unsigned int  xoffsets,
v4cint32  zbuff,
int  zstart,
unsigned int  zoffsets 
)

Complex multiply-negate intrinsic function .

acc0 = -( z00*x00 )
acc1 = -( z10*x10 )
acc2 = -( z20*x20 )
acc3 = -( z30*x30 )

Parameters

Input/OutputType Comments
return v4cacc80 Returned accumulation vector (4 x cint80 lanes)
xbuff v32int32Input buffer of 32 elements of type int32
xstart int Starting position offset applied to all lanes of input from X buffer.
xoffsets unsigned int 4b offset for each lane, applied to the x buffer. LSB apply to first lane
zbuff v4cint32Input buffer of 4 elements of type cint32
zstart int Starting position offset applied to all lanes for input from Z buffer. This must be a compile time constant. Only the 4 LSB of the argument are used.
zoffsetsunsigned int 4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
Note
  • For more information on how data selection works from the buffers go here. The data buffer and coefficient buffer in this intrinsic use the general scheme.
  • Parameter 'zstart' must be a compile time constant.
v4cacc80 lnegmul4 ( v16int32  xbuff,
int  xstart,
unsigned int  xoffsets,
v4cint32  zbuff,
int  zstart,
unsigned int  zoffsets 
)

Complex multiply-negate intrinsic function using small X input buffer.

acc0 = -( z00*x00 )
acc1 = -( z10*x10 )
acc2 = -( z20*x20 )
acc3 = -( z30*x30 )

Parameters

Input/OutputType Comments
return v4cacc80 Returned accumulation vector (4 x cint80 lanes)
xbuff v16int32Input buffer of 16 elements of type int32
xstart int Starting position offset applied to all lanes of input from X buffer.
xoffsets unsigned int 4b offset for each lane, applied to the x buffer. LSB apply to first lane
zbuff v4cint32Input buffer of 4 elements of type cint32
zstart int Starting position offset applied to all lanes for input from Z buffer. This must be a compile time constant. Only the 4 LSB of the argument are used.
zoffsetsunsigned int 4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
Note
  • For more information on how data selection works from the buffers go here. The data buffer and coefficient buffer in this intrinsic use the general scheme.
  • Parameter 'zstart' must be a compile time constant.