def test_domain_range_scale_CMYK_to_CMY(self): """ Test :func:`colour.models.rgb.cmyk.CMYK_to_CMY` definition domain and range scale support. """ CMYK = np.array([0.00000000, 0.93246304, 0.91030457, 0.54379481]) CMY = CMYK_to_CMY(CMYK) d_r = (("reference", 1), ("1", 1), ("100", 100)) for scale, factor in d_r: with domain_range_scale(scale): np.testing.assert_almost_equal(CMYK_to_CMY(CMYK * factor), CMY * factor, decimal=7)
def test_n_dimensional_CMYK_to_CMY(self): """ Test :func:`colour.models.rgb.cmyk.CMYK_to_CMY` definition n-dimensional arrays support. """ CMYK = np.array([0.00000000, 0.93246304, 0.91030457, 0.54379481]) CMY = CMYK_to_CMY(CMYK) CMYK = np.tile(CMYK, (6, 1)) CMY = np.tile(CMY, (6, 1)) np.testing.assert_almost_equal(CMYK_to_CMY(CMYK), CMY, decimal=7) CMYK = np.reshape(CMYK, (2, 3, 4)) CMY = np.reshape(CMY, (2, 3, 3)) np.testing.assert_almost_equal(CMYK_to_CMY(CMYK), CMY, decimal=7)
def test_nan_CMYK_to_CMY(self): """ Test :func:`colour.models.rgb.cmyk.CMYK_to_CMY` definition nan support. """ cases = [-1.0, 0.0, 1.0, -np.inf, np.inf, np.nan] cases = set(permutations(cases * 3, r=4)) for case in cases: CMYK = np.array(case) CMYK_to_CMY(CMYK)
def test_CMYK_to_CMY(self): """ Tests :func:`colour.models.rgb.cmyk.CMYK_to_CMY` definition. """ np.testing.assert_almost_equal( CMYK_to_CMY( np.array([0.00000000, 0.93246304, 0.91030457, 0.54379481])), np.array([0.54379481, 0.96918929, 0.95908048]), decimal=7) np.testing.assert_almost_equal( CMYK_to_CMY( np.array([0.00000000, 1.00000000, 1.00000000, 0.15000000])), np.array([0.15000000, 1.00000000, 1.00000000]), decimal=7) np.testing.assert_almost_equal( CMYK_to_CMY( np.array([0.15000000, 0.00000000, 0.00000000, 0.00000000])), np.array([0.15000000, 0.00000000, 0.00000000]), decimal=7)