И просто для иллюстрации всего, что было упомянуто до сих пор:
main.c
#include <assert.h>
#include <x86intrin.h>
int main(void) {
/* 32-bit. */
{
__m128 x = _mm_set_ps(1.5f, 2.5f, 3.5f, 4.5f);
/* _MM_EXTRACT_FLOAT */
float f;
_MM_EXTRACT_FLOAT(f, x, 3);
assert(f == 1.5f);
_MM_EXTRACT_FLOAT(f, x, 2);
assert(f == 2.5f);
_MM_EXTRACT_FLOAT(f, x, 1);
assert(f == 3.5f);
_MM_EXTRACT_FLOAT(f, x, 0);
assert(f == 4.5f);
/* _mm_cvtss_f32 + _mm_shuffle_ps */
assert(_mm_cvtss_f32(x) == 4.5f);
assert(_mm_cvtss_f32(_mm_shuffle_ps(x, x, 1)) == 3.5f);
assert(_mm_cvtss_f32(_mm_shuffle_ps(x, x, 2)) == 2.5f);
assert(_mm_cvtss_f32(_mm_shuffle_ps(x, x, 3)) == 1.5f);
}
/* 64-bit. */
{
__m128d x = _mm_set_pd(1.5, 2.5);
/* _mm_cvtsd_f64 + _mm_unpackhi_pd */
assert(_mm_cvtsd_f64(x) == 2.5);
assert(_mm_cvtsd_f64(_mm_unpackhi_pd(x, x)) == 1.5);
}
}
GitHub upstream .
Скомпилируйте иrun:
gcc -ggdb3 -O0 -std=c99 -Wall -Wextra -pedantic -o main.out main.c
./main.out
Двойники, указанные в: _mm_cvtsd_f64 аналог для плавающей запятой высшего порядка
Проверено на Ubuntu 19.04 amd64.