30 int cdim,
double accuracy,
31 int seed,
double *colors,
33 double *color_diff_sum0) {
38 static const int iter_max = 100;
40 double black[] = {0, 0, 0};
43 const int max_level =
d2i(fmin(30, fmax(1, -log(accuracy) / log(2.))));
46 color_rgb rgb = { .
r = 255*0.5, .g = 0, .b = 0 };
48 red[0] = lab.
l; red[1] = lab.
a; red[2] = lab.
b;
57 *color_diff0 = 1000; *color_diff_sum0 = 1000;
59 for (
int i = 0; i < cdim; i++) colors[i] = 0;
60 *color_diff0 = sqrt(cdim); *color_diff_sum0 = sqrt(cdim);
71 *color_diff0 = 1000; *color_diff_sum0 = 1000;
74 for (
int i = 0; i < cdim; i++) colors[i] = 0;
75 for (
int i = 0; i < cdim; i++) colors[cdim+i] = 0;
77 *color_diff0 = sqrt(cdim); *color_diff_sum0 = sqrt(cdim);
82 const int *ia =
A->ia;
83 const int *ja =
A->ja;
87 const double cspace_size = 0.7;
88 double center[] = {cspace_size * 0.5, cspace_size * 0.5, cspace_size * 0.5};
89 const double width = cspace_size * 0.5;
93 for (
int i = 0; i < n*cdim; i++) colors[i] = cspace_size*
drand();
95 double *x =
gv_calloc(cdim * n,
sizeof(
double));
96 double *wgt = weightedQ ?
gv_calloc(n,
sizeof(
double)) :
NULL;
98 double color_diff = 0;
99 double color_diff_old = -1;
100 double color_diff_sum = 0;
101 double color_diff_sum_old = -1;
103 while (iter++ < iter_max && (color_diff > color_diff_old || (color_diff == color_diff_old && color_diff_sum > color_diff_sum_old))){
104 color_diff_old = color_diff;
105 color_diff_sum_old = color_diff_sum;
106 for (
int i = 0; i < n; i++){
108 for (
int j = ia[i]; j < ia[i+1]; j++){
109 if (ja[j] == i)
continue;
110 memcpy(&(x[k*cdim]), &(colors[ja[j]*cdim]),
sizeof(
double)*cdim);
111 if (wgt && a) wgt[k] = a[j];
114 cc = &(colors[i*cdim]);
123 color_diff = dist_max;
124 color_diff_sum = dist_max;
126 color_diff =
MIN(dist_max, color_diff);
127 color_diff_sum += dist_max;
131 GV_DEBUG(
"iter ---- %d ---, color_diff = %f, color_diff_sum = %f", iter,
132 color_diff, color_diff_sum);
137 for (
int i = 0; i < n; i++){
139 colors[i * cdim + 1],
140 colors[i * cdim + 2]);
142 colors[i*cdim] = (rgb.
r)/255;
143 colors[i*cdim+1] = (rgb.
g)/255;
144 colors[i*cdim+2] = (rgb.
b)/255;
147 *color_diff0 = color_diff;
148 *color_diff_sum0 = color_diff_sum;
155 int cdim,
double accuracy,
156 int seed,
double *colors) {
159 double color_diff_sum;
162 int iter, seed_max = -1;
163 double color_diff_max = -1;
166 for (i = 0; i < iter; i++){
169 if (color_diff_max < color_diff){
170 seed_max =
seed; color_diff_max = color_diff;
181 int seed,
int *cdim0,
double **colors) {
183 int ncomps, *comps =
NULL;
189 int maxcolors = 10000, max_qtree_level = 10, r, g, b;
191 if (color_list) color_scheme = color_list;
194 if (strcmp(color_scheme,
"lab") == 0){
199 fprintf(stderr,
"out of memory\n");
202 }
else if (strcmp(color_scheme,
"rgb") == 0){
205 }
else if (strcmp(color_scheme,
"gray") == 0){
208 }
else if (sscanf(color_scheme,
"#%02X%02X%02X", &r, &g, &b) == 3 ){
211 assert(color_points);
221 if (accuracy <= 0) accuracy = 0.0001;
229 *colors =
gv_calloc(cdim * n,
sizeof(
double));
230 double *ctmp =
gv_calloc(cdim * n,
sizeof(
double));
237 for (i = 0; i < ncomps; i++){
238 nn = comps_ptr[i+1] - comps_ptr[i];
242 for (j = comps_ptr[i]; j < comps_ptr[i+1]; j++){
243 jj = j - comps_ptr[i];
244 memcpy(&((*colors)[comps[j]*cdim]), &(ctmp[jj*cdim]), cdim*
sizeof(
double));
void QuadTree_get_nearest(QuadTree qt, double *x, double *ymin, int *imin, double *min)
QuadTree QuadTree_new_from_point_list(int dim, int n, int max_level, double *coord)
void QuadTree_delete(QuadTree q)
SparseMatrix SparseMatrix_get_submatrix(SparseMatrix A, int nrow, int ncol, int *rindices, int *cindices)
SparseMatrix SparseMatrix_symmetrize(SparseMatrix A, bool pattern_symmetric_only)
void SparseMatrix_delete(SparseMatrix A)
int * SparseMatrix_weakly_connected_components(SparseMatrix A0, int *ncomp, int **comps)
Memory allocation wrappers that exit on failure.
static void * gv_calloc(size_t nmemb, size_t size)
const char * color_palettes_get(const char *color_palette_name)
helpers for verbose/debug printing
void furtherest_point_in_list(int k, int dim, double *wgt, double *pts, QuadTree qt, int max_level, double *dist_max, double **argmax)
void furtherest_point(int k, int dim, double *wgt, double *pts, double *center, double width, int max_level, double *dist_max, double **argmax)
Arithmetic helper functions.
static const char black[]
QuadTree lab_gamut_quadtree(const int *lightness, int max_qtree_level)
construct a quadtree of the LAB gamut points
void LAB2RGB_real_01(double *color)
color_lab color_lab_init(double l, double a, double b)
color_lab RGB2LAB(color_rgb color)
double * color_blend_rgb2lab(const char *color_list, const int maxpoints)
color_rgb LAB2RGB(color_lab color)
static void node_distinct_coloring_internal(int scheme, QuadTree qt, bool weightedQ, SparseMatrix A, int cdim, double accuracy, int seed, double *colors)
int node_distinct_coloring(const char *color_scheme, int *lightness, bool weightedQ, SparseMatrix A0, double accuracy, int seed, int *cdim0, double **colors)
static void node_distinct_coloring_internal2(int scheme, QuadTree qt, bool weightedQ, SparseMatrix A, int cdim, double accuracy, int seed, double *colors, double *color_diff0, double *color_diff_sum0)
double b
l: 0 to 100, a,b: -128 to 128
static point center(point vertex[], size_t n)