| Base<br>Instructions                                                                                                    | SIMD&FP<br>Instructions                  | <u>SVE</u><br><u>Instructions</u>                          | SME<br>Instructions                           | Index by<br>Encoding |
|-------------------------------------------------------------------------------------------------------------------------|------------------------------------------|------------------------------------------------------------|-----------------------------------------------|----------------------|
| BFMIN                                                                                                                   |                                          |                                                            |                                               |                      |
| BFloat16 float                                                                                                          | ting-point minin                         | num (predicated                                            | )                                             |                      |
| Determine the mix<br>vector and corres<br>destructively place<br>source vector.<br>When FPCR.AH is                      | ponding BFloat<br>e the results in       | 16 elements of the correspondi                             | he first source ve                            | ector and            |
| <ul><li>When FPC NaN.</li></ul>                                                                                         | CR.DN is 0, if eit<br>CR.DN is 1, if eit |                                                            | e zero.<br>NaN, the result<br>NaN, the result | <u>-</u>             |
| When FPCR.AH is                                                                                                         | s 1, the behavior                        | is as follows:                                             |                                               |                      |
| result is th<br>• If either el                                                                                          | ne second eleme                          | nt.<br>, regardless of t                                   | he sign of either<br>he value of FPCF         |                      |
| Inactive elements<br>This instruction for<br>ID_AA64ZFR0_EL<br>implemented.                                             | ollows SVE2.1 n                          | on-widening BF                                             | loat16 numerical                              |                      |
| SVE2<br>(FEAT_SVE_B16B16)                                                                                               |                                          |                                                            |                                               |                      |
| 3130292827262524<br>0 1 1 0 0 1 0 1<br>S                                                                                |                                          | 201918171615141<br>0 0 1 1 1 1 0 0                         | 3121110987654<br>D Pg Zm                      | 3 2 1 0<br>Zdn       |
| BFMIN <z< td=""><td>dn&gt;.H, <pg>/M,</pg></td><td><zdn>.H, <zm< td=""><td>&gt; . H</td><td></td></zm<></zdn></td></z<> | dn>.H, <pg>/M,</pg>                      | <zdn>.H, <zm< td=""><td>&gt; . H</td><td></td></zm<></zdn> | > . H                                         |                      |
| <pre>if (!HaveSVE integer g = integer dn = integer m =</pre>                                                            | = <u>UInt</u> (Zdn);                     | <u>ME2</u> ())    !IsI                                     | FeatureImplemen                               | nted (FEAT_SVE_B     |

## **Assembler Symbols**

| <zdn></zdn> | Is the name of the first source and destination scalable vector register, encoded in the "Zdn" field. |  |
|-------------|-------------------------------------------------------------------------------------------------------|--|
| <pg></pg>   | Is the name of the governing scalable predicate register P0-P7, encoded in the "Pg" field.            |  |

<Zm>

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

## **Operation**

```
CheckSVEEnabled();
constant integer VL = CurrentVL;
constant integer PL = VL DIV 8;
constant integer elements = VL DIV 16;
bits(PL) mask = P[g, PL];
bits(VL) operand1 = Z[dn, VL];
bits(VL) operand2 = if AnyActiveElement(mask, 16) then Z[m, VL] else Zebits(VL) result;

for e = 0 to elements-1
   bits(16) element1 = Elem[operand1, e, 16];
   if ActivePredicateElement(mask, e, 16) then
        bits(16) element2 = Elem[operand2, e, 16];
        Elem[result, e, 16] = BFMin(element1, element2, FPCR[]);
else
        Elem[result, e, 16] = element1;
Z[dn, VL] = result;
```

## **Operational information**

This instruction might be immediately preceded in program order by a MOVPRFX instruction. The MOVPRFX instruction must conform to all of the following requirements, otherwise the behavior of the MOVPRFX and this instruction is unpredictable:

- The MOVPRFX instruction must be unpredicated, or be predicated using the same governing predicate register and source element size as this instruction.
- The MOVPRFX instruction must specify the same destination register as this instruction.
- The destination register must not refer to architectural register state referenced by any other source operand register of this instruction.

<u>Base</u> <u>SIMD&FP</u> <u>SVE</u> <u>SME</u> <u>Index by</u> <u>Instructions</u> <u>Instructions</u> <u>Instructions</u> <u>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

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

Sh Pseu