AI Engine Intrinsics User Guide (AIE) v2024.2
Loading...
Searching...
No Matches

Overview

16 bit complex by 16 bit complex using X and Z buffer conjugation

Functions

v4cacc48 mac4_sym_ct_cc (v4cacc48 acc, v16cint16 xbuff, int xstart, unsigned int xoffsets, int ystart, unsigned int mtap, v8cint16 zbuff, int zstart, unsigned int zoffsets, int zstep)
 Complex symetric multiply-accumulate intrinsic function with center-tap optimization with x and z buffer conjugation with pre-add from x input buffer using small X input buffer.
 
v4cacc48 mac4_sym_ct_cc (v4cacc48 acc, v16cint16 xbuff, int xstart, unsigned int xoffsets, v16cint16 ybuff, int ystart, unsigned int mtap, v8cint16 zbuff, int zstart, unsigned int zoffsets, int zstep)
 Complex symetric multiply-accumulate intrinsic function with center-tap optimization with x and z buffer conjugation with pre-add from x and y input buffers using small X input buffer.
 
v4cacc48 mac4_sym_ct_cc (v4cacc48 acc, v32cint16 xbuff, int xstart, unsigned int xoffsets, int ystart, unsigned int mtap, v8cint16 zbuff, int zstart, unsigned int zoffsets, int zstep)
 Complex symetric multiply-accumulate intrinsic function with center-tap optimization with x and z buffer conjugation with pre-add from x input buffer .
 
v4cacc48 msc4_sym_ct_cc (v4cacc48 acc, v16cint16 xbuff, int xstart, unsigned int xoffsets, int ystart, unsigned int mtap, v8cint16 zbuff, int zstart, unsigned int zoffsets, int zstep)
 Complex symetric multiply-subtract intrinsic function with center-tap optimization with x and z buffer conjugation with pre-add from x input buffer using small X input buffer.
 
v4cacc48 msc4_sym_ct_cc (v4cacc48 acc, v16cint16 xbuff, int xstart, unsigned int xoffsets, v16cint16 ybuff, int ystart, unsigned int mtap, v8cint16 zbuff, int zstart, unsigned int zoffsets, int zstep)
 Complex symetric multiply-subtract intrinsic function with center-tap optimization with x and z buffer conjugation with pre-add from x and y input buffers using small X input buffer.
 
v4cacc48 msc4_sym_ct_cc (v4cacc48 acc, v32cint16 xbuff, int xstart, unsigned int xoffsets, int ystart, unsigned int mtap, v8cint16 zbuff, int zstart, unsigned int zoffsets, int zstep)
 Complex symetric multiply-subtract intrinsic function with center-tap optimization with x and z buffer conjugation with pre-add from x input buffer .
 
v4cacc48 mul4_sym_ct_cc (v16cint16 xbuff, int xstart, unsigned int xoffsets, int ystart, unsigned int mtap, v8cint16 zbuff, int zstart, unsigned int zoffsets, int zstep)
 Complex symetric multiply intrinsic function with center-tap optimization with x and z buffer conjugation with pre-add from x input buffer using small X input buffer.
 
v4cacc48 mul4_sym_ct_cc (v16cint16 xbuff, int xstart, unsigned int xoffsets, v16cint16 ybuff, int ystart, unsigned int mtap, v8cint16 zbuff, int zstart, unsigned int zoffsets, int zstep)
 Complex symetric multiply intrinsic function with center-tap optimization with x and z buffer conjugation with pre-add from x and y input buffers using small X input buffer.
 
v4cacc48 mul4_sym_ct_cc (v32cint16 xbuff, int xstart, unsigned int xoffsets, int ystart, unsigned int mtap, v8cint16 zbuff, int zstart, unsigned int zoffsets, int zstep)
 Complex symetric multiply intrinsic function with center-tap optimization with x and z buffer conjugation with pre-add from x input buffer .
 
v4cacc48 negmul4_sym_ct_cc (v16cint16 xbuff, int xstart, unsigned int xoffsets, int ystart, unsigned int mtap, v8cint16 zbuff, int zstart, unsigned int zoffsets, int zstep)
 Complex symetric multiply-negate intrinsic function with center-tap optimization with x and z buffer conjugation with pre-add from x input buffer using small X input buffer.
 
v4cacc48 negmul4_sym_ct_cc (v16cint16 xbuff, int xstart, unsigned int xoffsets, v16cint16 ybuff, int ystart, unsigned int mtap, v8cint16 zbuff, int zstart, unsigned int zoffsets, int zstep)
 Complex symetric multiply-negate intrinsic function with center-tap optimization with x and z buffer conjugation with pre-add from x and y input buffers using small X input buffer.
 
v4cacc48 negmul4_sym_ct_cc (v32cint16 xbuff, int xstart, unsigned int xoffsets, int ystart, unsigned int mtap, v8cint16 zbuff, int zstart, unsigned int zoffsets, int zstep)
 Complex symetric multiply-negate intrinsic function with center-tap optimization with x and z buffer conjugation with pre-add from x input buffer .
 

Function Documentation

◆ mac4_sym_ct_cc() [1/3]

v4cacc48 mac4_sym_ct_cc ( v4cacc48  acc,
v16cint16  xbuff,
int  xstart,
unsigned int  xoffsets,
int  ystart,
unsigned int  mtap,
v8cint16  zbuff,
int  zstart,
unsigned int  zoffsets,
int  zstep 
)

Complex symetric multiply-accumulate intrinsic function with center-tap optimization with x and z buffer conjugation with pre-add from x input buffer using small X input buffer.

acc0 += cnj(z00)*(cnj(x00) + cnj(y00)) + cnj(z01)*cnj(x01)
acc1 += cnj(z10)*(cnj(x10) + cnj(y10)) + cnj(z11)*cnj(x11)
acc2 += cnj(z20)*(cnj(x20) + cnj(y20)) + cnj(z21)*cnj(x21)
acc3 += cnj(z30)*(cnj(x30) + cnj(y30)) + cnj(z31)*cnj(x31)
Returns
Returned accumulation vector (4 x cint48 lanes)
Parameters
accIncoming accumulation vector (4 x cint48 lanes)
xbuffInput buffer of 16 elements of type cint16
xstartStarting position offset applied to all lanes of input from X buffer.
xoffsets4b offset for each lane, applied to both x and y buffers. LSB apply to first lane
ystartStarting position offset applied to all lanes for input from Y buffer.
mtapSelector for partial pre-adding relative to xstart
zbuffInput buffer of 8 elements of type cint16
zstartStarting 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.
zoffsets4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
zstepStep 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.

◆ mac4_sym_ct_cc() [2/3]

v4cacc48 mac4_sym_ct_cc ( v4cacc48  acc,
v16cint16  xbuff,
int  xstart,
unsigned int  xoffsets,
v16cint16  ybuff,
int  ystart,
unsigned int  mtap,
v8cint16  zbuff,
int  zstart,
unsigned int  zoffsets,
int  zstep 
)

Complex symetric multiply-accumulate intrinsic function with center-tap optimization with x and z buffer conjugation with pre-add from x and y input buffers using small X input buffer.

acc0 += cnj(z00)*(cnj(x00) + cnj(y00)) + cnj(z01)*cnj(x01)
acc1 += cnj(z10)*(cnj(x10) + cnj(y10)) + cnj(z11)*cnj(x11)
acc2 += cnj(z20)*(cnj(x20) + cnj(y20)) + cnj(z21)*cnj(x21)
acc3 += cnj(z30)*(cnj(x30) + cnj(y30)) + cnj(z31)*cnj(x31)
Returns
Returned accumulation vector (4 x cint48 lanes)
Parameters
accIncoming accumulation vector (4 x cint48 lanes)
xbuffInput buffer of 16 elements of type cint16
xstartStarting position offset applied to all lanes of input from X buffer.
xoffsets4b offset for each lane, applied to both x and y buffers. LSB apply to first lane
ybuffRight input buffer of 16 elements of type cint16
ystartStarting position offset applied to all lanes for input from Y buffer.
mtapSelector for partial pre-adding relative to xstart
zbuffInput buffer of 8 elements of type cint16
zstartStarting 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.
zoffsets4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
zstepStep 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.

◆ mac4_sym_ct_cc() [3/3]

v4cacc48 mac4_sym_ct_cc ( v4cacc48  acc,
v32cint16  xbuff,
int  xstart,
unsigned int  xoffsets,
int  ystart,
unsigned int  mtap,
v8cint16  zbuff,
int  zstart,
unsigned int  zoffsets,
int  zstep 
)

Complex symetric multiply-accumulate intrinsic function with center-tap optimization with x and z buffer conjugation with pre-add from x input buffer .

acc0 += cnj(z00)*(cnj(x00) + cnj(y00)) + cnj(z01)*cnj(x01)
acc1 += cnj(z10)*(cnj(x10) + cnj(y10)) + cnj(z11)*cnj(x11)
acc2 += cnj(z20)*(cnj(x20) + cnj(y20)) + cnj(z21)*cnj(x21)
acc3 += cnj(z30)*(cnj(x30) + cnj(y30)) + cnj(z31)*cnj(x31)
Returns
Returned accumulation vector (4 x cint48 lanes)
Parameters
accIncoming accumulation vector (4 x cint48 lanes)
xbuffInput buffer of 32 elements of type cint16
xstartStarting position offset applied to all lanes of input from X buffer.
xoffsets4b offset for each lane, applied to both x and y buffers. LSB apply to first lane
ystartStarting position offset applied to all lanes for input from Y buffer.
mtapSelector for partial pre-adding relative to xstart
zbuffInput buffer of 8 elements of type cint16
zstartStarting 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.
zoffsets4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
zstepStep 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.

◆ msc4_sym_ct_cc() [1/3]

v4cacc48 msc4_sym_ct_cc ( v4cacc48  acc,
v16cint16  xbuff,
int  xstart,
unsigned int  xoffsets,
int  ystart,
unsigned int  mtap,
v8cint16  zbuff,
int  zstart,
unsigned int  zoffsets,
int  zstep 
)

Complex symetric multiply-subtract intrinsic function with center-tap optimization with x and z buffer conjugation with pre-add from x input buffer using small X input buffer.

acc0 -= cnj(z00)*(cnj(x00) + cnj(y00)) + cnj(z01)*cnj(x01)
acc1 -= cnj(z10)*(cnj(x10) + cnj(y10)) + cnj(z11)*cnj(x11)
acc2 -= cnj(z20)*(cnj(x20) + cnj(y20)) + cnj(z21)*cnj(x21)
acc3 -= cnj(z30)*(cnj(x30) + cnj(y30)) + cnj(z31)*cnj(x31)
Returns
Returned accumulation vector (4 x cint48 lanes)
Parameters
accIncoming accumulation vector (4 x cint48 lanes)
xbuffInput buffer of 16 elements of type cint16
xstartStarting position offset applied to all lanes of input from X buffer.
xoffsets4b offset for each lane, applied to both x and y buffers. LSB apply to first lane
ystartStarting position offset applied to all lanes for input from Y buffer.
mtapSelector for partial pre-adding relative to xstart
zbuffInput buffer of 8 elements of type cint16
zstartStarting 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.
zoffsets4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
zstepStep 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.

◆ msc4_sym_ct_cc() [2/3]

v4cacc48 msc4_sym_ct_cc ( v4cacc48  acc,
v16cint16  xbuff,
int  xstart,
unsigned int  xoffsets,
v16cint16  ybuff,
int  ystart,
unsigned int  mtap,
v8cint16  zbuff,
int  zstart,
unsigned int  zoffsets,
int  zstep 
)

Complex symetric multiply-subtract intrinsic function with center-tap optimization with x and z buffer conjugation with pre-add from x and y input buffers using small X input buffer.

acc0 -= cnj(z00)*(cnj(x00) + cnj(y00)) + cnj(z01)*cnj(x01)
acc1 -= cnj(z10)*(cnj(x10) + cnj(y10)) + cnj(z11)*cnj(x11)
acc2 -= cnj(z20)*(cnj(x20) + cnj(y20)) + cnj(z21)*cnj(x21)
acc3 -= cnj(z30)*(cnj(x30) + cnj(y30)) + cnj(z31)*cnj(x31)
Returns
Returned accumulation vector (4 x cint48 lanes)
Parameters
accIncoming accumulation vector (4 x cint48 lanes)
xbuffInput buffer of 16 elements of type cint16
xstartStarting position offset applied to all lanes of input from X buffer.
xoffsets4b offset for each lane, applied to both x and y buffers. LSB apply to first lane
ybuffRight input buffer of 16 elements of type cint16
ystartStarting position offset applied to all lanes for input from Y buffer.
mtapSelector for partial pre-adding relative to xstart
zbuffInput buffer of 8 elements of type cint16
zstartStarting 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.
zoffsets4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
zstepStep 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.

◆ msc4_sym_ct_cc() [3/3]

v4cacc48 msc4_sym_ct_cc ( v4cacc48  acc,
v32cint16  xbuff,
int  xstart,
unsigned int  xoffsets,
int  ystart,
unsigned int  mtap,
v8cint16  zbuff,
int  zstart,
unsigned int  zoffsets,
int  zstep 
)

Complex symetric multiply-subtract intrinsic function with center-tap optimization with x and z buffer conjugation with pre-add from x input buffer .

acc0 -= cnj(z00)*(cnj(x00) + cnj(y00)) + cnj(z01)*cnj(x01)
acc1 -= cnj(z10)*(cnj(x10) + cnj(y10)) + cnj(z11)*cnj(x11)
acc2 -= cnj(z20)*(cnj(x20) + cnj(y20)) + cnj(z21)*cnj(x21)
acc3 -= cnj(z30)*(cnj(x30) + cnj(y30)) + cnj(z31)*cnj(x31)
Returns
Returned accumulation vector (4 x cint48 lanes)
Parameters
accIncoming accumulation vector (4 x cint48 lanes)
xbuffInput buffer of 32 elements of type cint16
xstartStarting position offset applied to all lanes of input from X buffer.
xoffsets4b offset for each lane, applied to both x and y buffers. LSB apply to first lane
ystartStarting position offset applied to all lanes for input from Y buffer.
mtapSelector for partial pre-adding relative to xstart
zbuffInput buffer of 8 elements of type cint16
zstartStarting 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.
zoffsets4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
zstepStep 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.

◆ mul4_sym_ct_cc() [1/3]

v4cacc48 mul4_sym_ct_cc ( v16cint16  xbuff,
int  xstart,
unsigned int  xoffsets,
int  ystart,
unsigned int  mtap,
v8cint16  zbuff,
int  zstart,
unsigned int  zoffsets,
int  zstep 
)

Complex symetric multiply intrinsic function with center-tap optimization with x and z buffer conjugation with pre-add from x input buffer using small X input buffer.

acc0 = cnj(z00)*(cnj(x00) + cnj(y00)) + cnj(z01)*cnj(x01)
acc1 = cnj(z10)*(cnj(x10) + cnj(y10)) + cnj(z11)*cnj(x11)
acc2 = cnj(z20)*(cnj(x20) + cnj(y20)) + cnj(z21)*cnj(x21)
acc3 = cnj(z30)*(cnj(x30) + cnj(y30)) + cnj(z31)*cnj(x31)
Returns
Returned accumulation vector (4 x cint48 lanes)
Parameters
xbuffInput buffer of 16 elements of type cint16
xstartStarting position offset applied to all lanes of input from X buffer.
xoffsets4b offset for each lane, applied to both x and y buffers. LSB apply to first lane
ystartStarting position offset applied to all lanes for input from Y buffer.
mtapSelector for partial pre-adding relative to xstart
zbuffInput buffer of 8 elements of type cint16
zstartStarting 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.
zoffsets4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
zstepStep 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.

◆ mul4_sym_ct_cc() [2/3]

v4cacc48 mul4_sym_ct_cc ( v16cint16  xbuff,
int  xstart,
unsigned int  xoffsets,
v16cint16  ybuff,
int  ystart,
unsigned int  mtap,
v8cint16  zbuff,
int  zstart,
unsigned int  zoffsets,
int  zstep 
)

Complex symetric multiply intrinsic function with center-tap optimization with x and z buffer conjugation with pre-add from x and y input buffers using small X input buffer.

acc0 = cnj(z00)*(cnj(x00) + cnj(y00)) + cnj(z01)*cnj(x01)
acc1 = cnj(z10)*(cnj(x10) + cnj(y10)) + cnj(z11)*cnj(x11)
acc2 = cnj(z20)*(cnj(x20) + cnj(y20)) + cnj(z21)*cnj(x21)
acc3 = cnj(z30)*(cnj(x30) + cnj(y30)) + cnj(z31)*cnj(x31)
Returns
Returned accumulation vector (4 x cint48 lanes)
Parameters
xbuffInput buffer of 16 elements of type cint16
xstartStarting position offset applied to all lanes of input from X buffer.
xoffsets4b offset for each lane, applied to both x and y buffers. LSB apply to first lane
ybuffRight input buffer of 16 elements of type cint16
ystartStarting position offset applied to all lanes for input from Y buffer.
mtapSelector for partial pre-adding relative to xstart
zbuffInput buffer of 8 elements of type cint16
zstartStarting 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.
zoffsets4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
zstepStep 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.

◆ mul4_sym_ct_cc() [3/3]

v4cacc48 mul4_sym_ct_cc ( v32cint16  xbuff,
int  xstart,
unsigned int  xoffsets,
int  ystart,
unsigned int  mtap,
v8cint16  zbuff,
int  zstart,
unsigned int  zoffsets,
int  zstep 
)

Complex symetric multiply intrinsic function with center-tap optimization with x and z buffer conjugation with pre-add from x input buffer .

acc0 = cnj(z00)*(cnj(x00) + cnj(y00)) + cnj(z01)*cnj(x01)
acc1 = cnj(z10)*(cnj(x10) + cnj(y10)) + cnj(z11)*cnj(x11)
acc2 = cnj(z20)*(cnj(x20) + cnj(y20)) + cnj(z21)*cnj(x21)
acc3 = cnj(z30)*(cnj(x30) + cnj(y30)) + cnj(z31)*cnj(x31)
Returns
Returned accumulation vector (4 x cint48 lanes)
Parameters
xbuffInput buffer of 32 elements of type cint16
xstartStarting position offset applied to all lanes of input from X buffer.
xoffsets4b offset for each lane, applied to both x and y buffers. LSB apply to first lane
ystartStarting position offset applied to all lanes for input from Y buffer.
mtapSelector for partial pre-adding relative to xstart
zbuffInput buffer of 8 elements of type cint16
zstartStarting 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.
zoffsets4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
zstepStep 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.

◆ negmul4_sym_ct_cc() [1/3]

v4cacc48 negmul4_sym_ct_cc ( v16cint16  xbuff,
int  xstart,
unsigned int  xoffsets,
int  ystart,
unsigned int  mtap,
v8cint16  zbuff,
int  zstart,
unsigned int  zoffsets,
int  zstep 
)

Complex symetric multiply-negate intrinsic function with center-tap optimization with x and z buffer conjugation with pre-add from x input buffer using small X input buffer.

acc0 = -( cnj(z00)*(cnj(x00) + cnj(y00)) + cnj(z01)*cnj(x01) )
acc1 = -( cnj(z10)*(cnj(x10) + cnj(y10)) + cnj(z11)*cnj(x11) )
acc2 = -( cnj(z20)*(cnj(x20) + cnj(y20)) + cnj(z21)*cnj(x21) )
acc3 = -( cnj(z30)*(cnj(x30) + cnj(y30)) + cnj(z31)*cnj(x31) )
Returns
Returned accumulation vector (4 x cint48 lanes)
Parameters
xbuffInput buffer of 16 elements of type cint16
xstartStarting position offset applied to all lanes of input from X buffer.
xoffsets4b offset for each lane, applied to both x and y buffers. LSB apply to first lane
ystartStarting position offset applied to all lanes for input from Y buffer.
mtapSelector for partial pre-adding relative to xstart
zbuffInput buffer of 8 elements of type cint16
zstartStarting 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.
zoffsets4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
zstepStep 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.

◆ negmul4_sym_ct_cc() [2/3]

v4cacc48 negmul4_sym_ct_cc ( v16cint16  xbuff,
int  xstart,
unsigned int  xoffsets,
v16cint16  ybuff,
int  ystart,
unsigned int  mtap,
v8cint16  zbuff,
int  zstart,
unsigned int  zoffsets,
int  zstep 
)

Complex symetric multiply-negate intrinsic function with center-tap optimization with x and z buffer conjugation with pre-add from x and y input buffers using small X input buffer.

acc0 = -( cnj(z00)*(cnj(x00) + cnj(y00)) + cnj(z01)*cnj(x01) )
acc1 = -( cnj(z10)*(cnj(x10) + cnj(y10)) + cnj(z11)*cnj(x11) )
acc2 = -( cnj(z20)*(cnj(x20) + cnj(y20)) + cnj(z21)*cnj(x21) )
acc3 = -( cnj(z30)*(cnj(x30) + cnj(y30)) + cnj(z31)*cnj(x31) )
Returns
Returned accumulation vector (4 x cint48 lanes)
Parameters
xbuffInput buffer of 16 elements of type cint16
xstartStarting position offset applied to all lanes of input from X buffer.
xoffsets4b offset for each lane, applied to both x and y buffers. LSB apply to first lane
ybuffRight input buffer of 16 elements of type cint16
ystartStarting position offset applied to all lanes for input from Y buffer.
mtapSelector for partial pre-adding relative to xstart
zbuffInput buffer of 8 elements of type cint16
zstartStarting 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.
zoffsets4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
zstepStep 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.

◆ negmul4_sym_ct_cc() [3/3]

v4cacc48 negmul4_sym_ct_cc ( v32cint16  xbuff,
int  xstart,
unsigned int  xoffsets,
int  ystart,
unsigned int  mtap,
v8cint16  zbuff,
int  zstart,
unsigned int  zoffsets,
int  zstep 
)

Complex symetric multiply-negate intrinsic function with center-tap optimization with x and z buffer conjugation with pre-add from x input buffer .

acc0 = -( cnj(z00)*(cnj(x00) + cnj(y00)) + cnj(z01)*cnj(x01) )
acc1 = -( cnj(z10)*(cnj(x10) + cnj(y10)) + cnj(z11)*cnj(x11) )
acc2 = -( cnj(z20)*(cnj(x20) + cnj(y20)) + cnj(z21)*cnj(x21) )
acc3 = -( cnj(z30)*(cnj(x30) + cnj(y30)) + cnj(z31)*cnj(x31) )
Returns
Returned accumulation vector (4 x cint48 lanes)
Parameters
xbuffInput buffer of 32 elements of type cint16
xstartStarting position offset applied to all lanes of input from X buffer.
xoffsets4b offset for each lane, applied to both x and y buffers. LSB apply to first lane
ystartStarting position offset applied to all lanes for input from Y buffer.
mtapSelector for partial pre-adding relative to xstart
zbuffInput buffer of 8 elements of type cint16
zstartStarting 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.
zoffsets4b offset for each lane, applied to input from Z buffer. LSB apply to first lane
zstepStep 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.