Condividi tramite


_mm_msub_ss

È necessario Visual Studio 2010 SP1.

Specifici di Microsoft

Genera l'istruzione FMA4 XMM vfmsubss per eseguire una funzione multiply-subtract a virgola mobile con un unico arrotondamento dei valori a virgola mobile meno significativi delle origini.

__m128 _mm_msub_ss (
   __m128 src1,
   __m128 src2,
   __m128 src3
);

Parametri

  • [in] src1
    Parametro a 128 bit che contiene un valore a virgola mobile a 32 bit nella parola doppia inferiore.

  • [in] src2
    Parametro a 128 bit che contiene un valore a virgola mobile a 32 bit nella parola doppia inferiore.

  • [in] src3
    Parametro a 128 bit che contiene un valore a virgola mobile a 32 bit nella parola doppia inferiore.

Valore restituito

Risultato a 128 bit r che contiene quattro valori a virgola mobile a 32 bit.

r[0] := src1[0] * src2[0] - src3[0];
r[1] := r[2] = r[3] = 0.;

Requisiti

Intrinseco

Architettura

_mm_msub_ss

FMA4

File di intestazione <intrin.h>

Note

Il valore a virgola mobile e precisione singola meno significativo in src1 viene moltiplicato per il valore corrispondente in src2, il valore corrispondente in src3 viene sottratto dal prodotto e il risultato viene archiviato come valore corrispondente nella destinazione. Gli altri valori in src1 src2 e src3 vengono ignorati e i tre valori a virgola mobile più significativi del risultato vengono impostati su 0.

La funzione multiply- subtract viene eseguita con un unico arrotondamento alla fine, come se i risultati intermedi venissero calcolati a precisione infinita.

L'istruzione vfmsubss è parte della famiglia FMA4 di istruzioni. Prima di utilizzare questo intrinseco, è necessario assicurarsi che il processore supporti questa istruzione. Per determinare il supporto hardware per questa istruzione, chiamare l'intrinseco __cpuid con InfoType = 0x80000001 e il bit di controllo 16 di CPUInfo[2] (ECX). Questo bit è 1 quando l'istruzione è supportata, e 0 in caso contrario.

Esempio

#include <stdio.h>
#include <intrin.h>
int main()
{
    __m128 a, b, c, d;
    int i;
    for (i = 0; i < 4; i++) {
        a.m128_f32[i] = i;
        b.m128_f32[i] = 2.;
        c.m128_f32[i] = 3.;
    }
    d = _mm_msub_ss(a, b, c);
    for (i = 0; i < 4; i++) printf_s(" %.3f", d.m128_f32[i]);
    printf_s("\n");
}
  

Vedere anche

Riferimenti

__cpuid, __cpuidex

Altre risorse

_mm256_msub_ps

_mm_msub_ps

_mm_msub_sd

_mm_macc_ss

_mm_nmacc_ss

_mm_nmsub_ss

Oggetti intrinseci FMA4 aggiunti per Visual Studio 2010 SP1

Cronologia delle modifiche

Data

Cronologia

Motivo

Marzo 2011

È stato aggiunto questo contenuto.

Modifica di funzionalità in SP1.