| <u>by</u> | <u>Sh</u>   |
|-----------|-------------|
| ing       | <u>Pseu</u> |

Base<br/>InstructionsSIMD&FP<br/>InstructionsSVE<br/>InstructionsSME<br/>InstructionsIndex by<br/>Encoding

## **FADDQV**

Floating-point add recursive reduction of quadword vector segments

Floating-point addition of the same element numbers from each 128-bit source vector segment using a recursive pairwise reduction, placing each result into the corresponding element number of the 128-bit SIMD&FP destination register. Inactive elements in the source vector are treated as +0.0.

## SVE2 (FEAT SVE2p1)

```
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 1 1 0 0 1 0 0 size 0 1 0 0 0 0 1 0 1 Pg Zn Vd
```

```
FADDQV <Vd>.<T>, <Pg>, <Zn>.<Tb>
```

```
if !HaveSVE2p1() && !HaveSME2p1() then UNDEFINED;
if size == '00' then UNDEFINED;
constant integer esize = 8 << UInt(size);
integer g = UInt(Pg);
integer n = UInt(Zn);
integer d = UInt(Vd);</pre>
```

## **Assembler Symbols**

<Vd>

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

<T>

Is an arrangement specifier, encoded in "size":

| size | <t></t>  |
|------|----------|
| 0.0  | RESERVED |
| 01   | 8H       |
| 10   | 4S       |
| 11   | 2D       |

<Pq>

Is the name of the governing scalable predicate register P0-P7, encoded in the "Pg" field.

<Zn>

Is the name of the source scalable vector register, encoded in the "Zn" field.

Is the size specifier, encoded in "size":

| size | <tb></tb> |
|------|-----------|
| 0.0  | RESERVED  |
| 01   | Н         |
| 10   | S         |
| 11   | D         |

## **Operation**

```
CheckSVEEnabled();
constant integer VL = CurrentVL;
constant integer PL = VL DIV 8;
constant integer segments = VL DIV 128;
constant integer elempersegment = 128 DIV esize;
bits(PL) mask = \underline{P}[g, PL];
bits (VL) operand = if \underline{\text{AnyActiveElement}} (mask, esize) then \underline{Z}[n, \text{ VL}] else
bits(esize) identity = FPZero('0', esize);
bits (128) result = \frac{Zeros}{} (128);
constant integer p2bits = CeilPow2 (segments*esize);
constant integer p2elems = p2bits DIV esize;
for e = 0 to elempersegment-1
    bits(p2bits) stmp;
    bits(esize) dtmp;
    for s = 0 to p2elems-1
         if s < segments && <a href="ActivePredicateElement">ActivePredicateElement</a> (mask, s * elempersegments)
             Elem[stmp, s, esize] = Elem[operand, s * elempersegment + e
              Elem[stmp, s, esize] = identity;
    dtmp = Reduce(ReduceOp_FADD, stmp, esize);
    Elem[result, e, esize] = dtmp;
V[d, 128] = result;
```

<u>Base SIMD&FP SVE SME Index by Instructions Instructions Instructions Encoding</u>

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 Sh

Pseu

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