Encoding:

MSA

011110

0011

df

wt

ws

wd

3RF

011010

6

4

1

5

5

5

6

Format:

FCUEQ.df 

Vector Floating-Point Quiet Compare Unordered or Equal

FCUEQ.W wd,ws,wt

MSA

Vector Floating-Point Quiet Compare Unordered or Equal

FCUEQ.D wd,ws,wt

MSA

Vector Floating-Point Quiet Compare Unordered or Equal

Purpose:

Vector Floating-Point Quiet Compare Unordered or Equal

Vector to vector floating-point quiet compare for unordered or equality; if true all destination bits are set, otherwise clear.

Description:

wd[i] = (ws[i] =?(quiet) wt[i])

Set all bits to 1 in wd elements if the corresponding ws and wt floating-point elements are unordered or equal, otherwise set all bits to 0.

The quiet compare operation is defined by the IEEE Standard for Floating-Point Arithmetic 754TM-2008.

The Inexact Exception is not signaled when subnormal input operands are flushed based on the flush-to-zero bit FS in

MSA Control and Status Register MSACSR. In case of a floating-point exception, the default result has all bits set to

1.

The operands are values in floating-point data format df. The results are values in integer data format df.

Restrictions:

Data-dependent exceptions are poss ible as s pecified by the I EEE Standard for Floating-Point Arithmetic 754TM

2008.

Operation:

FCUEQ.W
   for i in 0 .. WRLEN/32-1
      c = UnorderedFP(WR[ws]32i+31..32i, WR[wt]32i+31..32i, 32)
      d = EqualFP(WR[ws]32i+31..32i, WR[wt]32i+31..32i, 32)
      WR[wd]32i+31..32i = (c | d)32
   endfor
FCUEQ.D
   for i in 0 .. WRLEN/64-1
      c = UnorderedFP(WR[ws]64i+63..64i, WR[wt]64i+63..64i, 64)
      d = EqualFP(WR[ws]64i+63..64i, WR[wt]64i+63..64i, 64)
      WR[wd]64i+63..64i = (c | d)64
   endfor
function UnorderedFP(tt, ts, n)
   /* Implementation defined quiet unordered compare operation. */
endfunction UnorderedFP
function EqualFP(tt, ts, n)
   /* Implementation defined quiet equal compare operation. */
endfunction EqualFP

Exceptions:

Reserved Instruction Exception, MSA Disabled Exception, MSA Floating Point Exception.