**SME** 

**Instructions** 

# FABS (vector)

Floating-point Absolute value (vector). This instruction calculates the absolute value of each vector element in the source SIMD&FP register. writes the result to a vector, and writes the vector to the destination SIMD&FP register.

Depending on the settings in the CPACR EL1, CPTR EL2, and CPTR EL3 registers, and the current Security state and Exception level, an attempt to execute the instruction might be trapped.

It has encodings from 2 classes: Half-precision and Single-precision and double-precision

## Half-precision (FEAT\_FP16)

```
31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
IJ
```

#### FABS <Vd>.<T>, <Vn>.<T>

```
if !IsFeatureImplemented(FEAT_FP16) then UNDEFINED;
integer d = UInt(Rd);
integer n = UInt(Rn);
constant integer esize = 16;
constant integer datasize = 64 << UInt(Q);</pre>
integer elements = datasize DIV esize;
boolean neg = (U == '1');
```

### Single-precision and double-precision

```
31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
0 Q 0 0 1 1 1 0 1 sz 1 0 0 0 0 0 1 1 1 1 1 0
                                                          Rn
```

#### FABS <Vd>.<T>, <Vn>.<T>

```
integer d = <u>UInt</u>(Rd);
integer n = UInt(Rn);
if sz:Q == '10' then UNDEFINED;
constant integer esize = 32 << UInt(sz);</pre>
constant integer datasize = 64 << UInt(Q);</pre>
integer elements = datasize DIV esize;
boolean neg = (U == '1');
```

### **Assembler Symbols**

<Vd>

Is the name of the SIMD&FP destination register, encoded in the "Rd" field.

<T>

For the half-precision variant: is an arrangement specifier, encoded in "Q":

| Q | <t></t> |
|---|---------|
| 0 | 4 H     |
| 1 | 8H      |

For the single-precision and double-precision variant: is an arrangement specifier, encoded in "sz:Q":

| SZ | Q | <t></t>  |
|----|---|----------|
| 0  | 0 | 2S       |
| 0  | 1 | 4 S      |
| 1  | 0 | RESERVED |
| 1  | 1 | 2D       |

<Vn>

Is the name of the SIMD&FP source register, encoded in the "Rn" field.

## Operation

```
CheckFPAdvSIMDEnabled64();
bits(datasize) operand = V[n, datasize];
bits(datasize) result;
bits(esize) element;

for e = 0 to elements-1
    element = Elem[operand, e, esize];
    if neg then
        element = FPNeg(element);
    else
        element = FPAbs(element);
    Elem[result, e, esize] = element;
V[d, datasize] = result;
```

 $Internal\ version\ only: is a\ v33.64,\ AdvSIMD\ v29.12,\ pseudocode\ no\_diffs\_2023\_09\_RC2,\ sve\ v2023-06\_rel\ ;\ Build\ timestamp:\ 2023-09-18T17:56$ 

Copyright © 2010-2023 Arm Limited or its affiliates. All rights reserved. This document is Non-Confidential.

Sh Pseu