blob: 2fb61bba5d083ee1843f3d1e2b40f92bb31b5a33 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
#pragma once
#include <emmintrin.h>
inline double sqrtsd(double val) {
__m128d src = _mm_load_sd(&val);
__m128d dst = _mm_sqrt_sd(src, src);
_mm_store_sd(&val, dst);
return val;
}
inline constexpr double minsd(double a, double b) {
return (a < b) ? a : b;
}
inline constexpr double maxsd(double a, double b) {
return (b < a) ? a : b;
}
inline constexpr double clampsd(double v, double lo, double hi) {
return minsd(maxsd(v, lo), hi);
}
|