9 #ifndef MI_MATH_SPECTRUM_H
10 #define MI_MATH_SPECTRUM_H
92 #if defined(DEBUG) || (defined(_MSC_VER) && _MSC_VER <= 1310)
100 Float32 v = (Traits::has_signaling_NaN)
322 return Spectrum( lhs[0] + rhs[0], lhs[1] + rhs[1], lhs[2] + rhs[2]);
330 return Spectrum( lhs[0] - rhs[0], lhs[1] - rhs[1], lhs[2] - rhs[2]);
338 return Spectrum( lhs[0] * rhs[0], lhs[1] * rhs[1], lhs[2] * rhs[2]);
346 return Spectrum( lhs[0] / rhs[0], lhs[1] / rhs[1], lhs[2] / rhs[2]);
353 return Spectrum( -c[0], -c[1], -c[2]);
386 return Spectrum( c[0] * s, c[1] * s, c[2] * s);
393 return Spectrum( s * c[0], s * c[1], s* c[2]);
401 return Spectrum( c[0] * f, c[1] * f, c[2] * f);
426 return (c[0] != 0.0f) && (c[1] != 0.0f) && (c[2] != 0.0f);
433 return (c[0] != 0.0f) || (c[1] != 0.0f) || (c[2] != 0.0f);
474 clamp( c[1], low[1], high[1]),
475 clamp( c[2], low[2], high[2]));
484 clamp( c[1], low[1], high),
485 clamp( c[2], low[2], high));
494 clamp( c[1], low, high[1]),
495 clamp( c[2], low, high[2]));
503 clamp( c[1], low, high),
504 clamp( c[2], low, high));
634 lerp( c1[1], c2[1], t[1]),
635 lerp( c1[2], c2[2], t[2]));
649 lerp( c1[1], c2[1], t),
650 lerp( c1[2], c2[2], t));
752 sincos( a[0], s[0], c[0]);
753 sincos( a[1], s[1], c[1]);
754 sincos( a[2], s[2], c[2]);
869 #endif // MI_MATH_SPECTRUM_H