make core-intrinsics cfg'ed
This commit is contained in:
parent
c73c6e7407
commit
1f3aa2c116
|
@ -1,4 +1,4 @@
|
||||||
#![feature(core_intrinsics)]
|
#![cfg_attr(feature = "fast-float", feature(core_intrinsics))]
|
||||||
#![feature(array_windows)]
|
#![feature(array_windows)]
|
||||||
#![feature(array_chunks)]
|
#![feature(array_chunks)]
|
||||||
|
|
||||||
|
|
|
@ -353,6 +353,12 @@ mod fastfloat {
|
||||||
Self(f)
|
Self(f)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
impl From<FastFloat> for Float {
|
||||||
|
#[inline(always)]
|
||||||
|
fn from(f: FastFloat) -> Self {
|
||||||
|
f.0
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
#[cfg(feature = "fast-float")]
|
#[cfg(feature = "fast-float")]
|
||||||
use fastfloat::FastFloat;
|
use fastfloat::FastFloat;
|
||||||
|
@ -838,14 +844,17 @@ pub(crate) fn diff_op_col_simd(
|
||||||
}
|
}
|
||||||
|
|
||||||
#[inline(always)]
|
#[inline(always)]
|
||||||
fn product_fast<'a>(
|
fn dotproduct<'a>(u: impl Iterator<Item = &'a Float>, v: impl Iterator<Item = &'a Float>) -> Float {
|
||||||
u: impl Iterator<Item = &'a Float>,
|
u.zip(v).fold(0.0, |acc, (&u, &v)| {
|
||||||
v: impl Iterator<Item = &'a Float>,
|
#[cfg(feature = "fast-float")]
|
||||||
) -> Float {
|
unsafe {
|
||||||
use std::intrinsics::{fadd_fast, fmul_fast};
|
// We do not care about the order of multiplication nor addition
|
||||||
u.zip(v).fold(0.0, |acc, (&u, &v)| unsafe {
|
(FastFloat::from(acc) + FastFloat::from(u) * FastFloat::from(v)).into()
|
||||||
// We do not care about the order of multiplication nor addition
|
}
|
||||||
fadd_fast(acc, fmul_fast(u, v))
|
#[cfg(not(feature = "fast-float"))]
|
||||||
|
{
|
||||||
|
acc + u * v
|
||||||
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1043,7 +1052,7 @@ pub(crate) fn diff_op_row(
|
||||||
assert!(prev.len() >= 2 * block.len());
|
assert!(prev.len() >= 2 * block.len());
|
||||||
|
|
||||||
for (bl, f) in block.iter().zip(fut.iter_mut()) {
|
for (bl, f) in block.iter().zip(fut.iter_mut()) {
|
||||||
let diff = product_fast(bl.iter(), prev[..bl.len()].iter());
|
let diff = dotproduct(bl.iter(), prev[..bl.len()].iter());
|
||||||
*f = diff * idx;
|
*f = diff * idx;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1057,12 +1066,12 @@ pub(crate) fn diff_op_row(
|
||||||
.zip(fut.iter_mut().skip(block.len()))
|
.zip(fut.iter_mut().skip(block.len()))
|
||||||
.take(nx - 2 * block.len())
|
.take(nx - 2 * block.len())
|
||||||
{
|
{
|
||||||
let diff = product_fast(diag.iter(), window.iter());
|
let diff = dotproduct(diag.iter(), window.iter());
|
||||||
*f = diff * idx;
|
*f = diff * idx;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (bl, f) in block.iter().zip(fut.iter_mut().rev()) {
|
for (bl, f) in block.iter().zip(fut.iter_mut().rev()) {
|
||||||
let diff = product_fast(bl.iter(), prev.iter().rev());
|
let diff = dotproduct(bl.iter(), prev.iter().rev());
|
||||||
|
|
||||||
*f = idx
|
*f = idx
|
||||||
* if symmetry == Symmetry::Symmetric {
|
* if symmetry == Symmetry::Symmetric {
|
||||||
|
|
Loading…
Reference in New Issue