mirror of
https://gitlab.com/libeigen/eigen.git
synced 2026-04-10 11:34:33 +08:00
Implement a faster fix for sin/cos of large entries that also correctly handle INF input.
This commit is contained in:
@@ -579,6 +579,22 @@ template<typename Scalar,typename Packet> void packetmath_real()
|
||||
VERIFY(data2[0]<=Scalar(1.) && data2[0]>=Scalar(-1.));
|
||||
VERIFY(data2[1]<=Scalar(1.) && data2[1]>=Scalar(-1.));
|
||||
}
|
||||
|
||||
data1[0] = std::numeric_limits<Scalar>::infinity();
|
||||
data1[1] = -std::numeric_limits<Scalar>::infinity();
|
||||
h.store(data2, internal::psin(h.load(data1)));
|
||||
VERIFY((numext::isnan)(data2[0]));
|
||||
VERIFY((numext::isnan)(data2[1]));
|
||||
|
||||
h.store(data2, internal::pcos(h.load(data1)));
|
||||
VERIFY((numext::isnan)(data2[0]));
|
||||
VERIFY((numext::isnan)(data2[1]));
|
||||
|
||||
data1[0] = std::numeric_limits<Scalar>::quiet_NaN();
|
||||
h.store(data2, internal::psin(h.load(data1)));
|
||||
VERIFY((numext::isnan)(data2[0]));
|
||||
h.store(data2, internal::pcos(h.load(data1)));
|
||||
VERIFY((numext::isnan)(data2[0]));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user