ciede2000.js 1.34 KB
var expect    = require('chai').expect,
	dataInLab = require('./dataInLab.js'),
	iq        = require('../../../dist/iq')

		describe(`CIEDE2000`, function () {
			const ciede2000 = new (iq.distance.CIEDE2000)();
			ciede2000.setWhitePoint(255, 255, 255, 0);
			doTests(ciede2000);
		});

function doTests (ciede2000) {
	describe('color distance should be correctly calculated (Lab)', function () {
		dataInLab.forEach(item => {
			it(`Colors: Lab1 = ${dir(item.Lab1)}, Lab2 = ${dir(item.Lab2)}`, function () {
				var raw = ciede2000.calculateRawInLab(item.Lab1, item.Lab2),
					dE  = Number(Math.sqrt(raw).toFixed(4));

				expect(dE).to.be.equal(item.distance);
			});
		})
	});

	describe('normalized distance should be less than 1', function () {
		dataInLab.forEach(item => {
			const rgb1   = iq.conversion.lab2rgb(item.Lab1.L, item.Lab1.a, item.Lab1.b),
				  rgb2   = iq.conversion.lab2rgb(item.Lab2.L, item.Lab2.a, item.Lab2.b),
				  point1 = iq.utils.Point.createByRGBA(rgb1.r, rgb1.g, rgb1.b, 0),
				  point2 = iq.utils.Point.createByRGBA(rgb2.r, rgb2.g, rgb2.b, 0);

			it(`Colors: Lab1 = ${dir(item.Lab1)}, Lab2 = ${dir(item.Lab2)}`, function () {
				var normalized = ciede2000.calculateNormalized(point1, point2);
				expect(normalized).to.be.at.most(1);
				// console.log(normalized)
			});
		})
	});
}

function dir (obj) {
	return JSON.stringify(obj);
}