aboutsummaryrefslogtreecommitdiffhomepage
path: root/test/mixingtypes.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'test/mixingtypes.cpp')
-rw-r--r--test/mixingtypes.cpp12
1 files changed, 12 insertions, 0 deletions
diff --git a/test/mixingtypes.cpp b/test/mixingtypes.cpp
index dee4f35df..cf2207114 100644
--- a/test/mixingtypes.cpp
+++ b/test/mixingtypes.cpp
@@ -75,6 +75,18 @@ template<int SizeAtCompileType> void mixingtypes(int size = SizeAtCompileType)
VERIFY_IS_APPROX(vcf / sf , vcf / complex<float>(sf));
VERIFY_IS_APPROX(vf / scf , vf.template cast<complex<float> >() / scf);
+ // check scalar increment
+ VERIFY_IS_APPROX(vcf.array() + sf , vcf.array() + complex<float>(sf));
+ VERIFY_IS_APPROX(sd + vcd.array(), complex<double>(sd) + vcd.array());
+ VERIFY_IS_APPROX(vf.array() + scf, vf.template cast<complex<float> >().array() + scf);
+ VERIFY_IS_APPROX(scd + vd.array() , scd + vd.template cast<complex<double> >().array());
+
+ // check scalar subtractions
+ VERIFY_IS_APPROX(vcf.array() - sf , vcf.array() - complex<float>(sf));
+ VERIFY_IS_APPROX(sd - vcd.array(), complex<double>(sd) - vcd.array());
+ VERIFY_IS_APPROX(vf.array() - scf, vf.template cast<complex<float> >().array() - scf);
+ VERIFY_IS_APPROX(scd - vd.array() , scd - vd.template cast<complex<double> >().array());
+
// check dot product
vf.dot(vf);
#if 0 // we get other compilation errors here than just static asserts