public void ConvertXyyToSRgbSmart()
{
const double f11 = 330000.0 / 88229.0;
const double f12 = -275000.0 / 264687.0;
const double f13 = -44000.0 / 88229.0;
const double f21 = -12500.0 / 12367.0;
const double f22 = 612500.0 / 333909.0;
const double f23 = 4625.0 / 111303.0;
const double f31 = -30000.0 / 29963.0;
const double f32 = -340000.0 / 269667.0;
const double f33 = 5000.0 / 4731.0;
double x = Component1;
double y = Component2;
double bigY = Component3;
double scale = bigY / y;
double r = (f11 * x + f12 * y + f13) * scale;
double g = (f21 * x + f22 * y + f23) * scale;
double b = (f31 * x + f32 * y + f33) * scale;
SetSRgbSmart(r, g, b, bigY);
}
private static Tuple<double, double, double> XyYToSRgb(double x, double y, double bigY) { ColorVector color = new ColorVector(x, y, bigY); color.ConvertXyyToSRgbSmart(); return Tuple.Create(color.Component1, color.Component2, color.Component3); }