FloatImg/funcs/equalize.c

55 lines
1.4 KiB
C
Raw Normal View History

2020-04-12 08:18:33 +11:00
/*
* FLOATIMG
2020-08-13 16:25:55 +11:00
* egalisation dynamique approximative
2020-04-12 08:18:33 +11:00
* #coronamaison Thu 09 Apr 2020 03:37:10 PM CEST
*/
#include <stdio.h>
#include <string.h>
2021-05-18 07:38:56 +11:00
#include <stdint.h>
2020-04-12 08:18:33 +11:00
#include "../floatimg.h"
extern int verbosity;
/* --------------------------------------------------------------------- */
2020-08-13 16:25:55 +11:00
int fimg_equalize_compute(FloatImg *src, void *vptr, float vmax)
2020-04-12 08:18:33 +11:00
{
float minmax[6];
int foo;
2020-08-13 16:25:55 +11:00
float dr, dg, db;
2020-04-12 08:18:33 +11:00
#if DEBUG_LEVEL
2020-10-09 10:26:07 +11:00
fprintf(stderr, ">>> %s ( %p %p %f )\n", __func__, src, vptr, vmax);
2020-04-12 08:18:33 +11:00
#endif
2020-08-13 16:25:55 +11:00
memset(minmax, 0, 6*sizeof(float));
2020-04-12 08:18:33 +11:00
foo = fimg_get_minmax_rgb(src, minmax);
2020-08-13 16:25:55 +11:00
if (foo) {
fprintf(stderr, "err %d get minmax in %s\n", foo, __func__);
return foo;
}
dr = minmax[1] - minmax[0];
dg = minmax[3] - minmax[2];
db = minmax[5] - minmax[4];
2020-10-09 10:26:07 +11:00
printf("Rmin %12.4g max %12.4g delta %12.4g\n", minmax[0], minmax[1], dr);
printf("Gmin %12.4g max %12.4g delta %12.4g\n", minmax[2], minmax[3], dg);
printf("Bmin %12.4g max %12.4g delta %12.4g\n", minmax[4], minmax[5], db);
2020-04-12 08:18:33 +11:00
if ( (minmax[0]<0.0) || (minmax[2]<0.0) || (minmax[4]<0.0) ) {
fprintf(stderr, "%s: negative value ?\n", __func__);
return -4;
}
2020-08-13 16:25:55 +11:00
// printf("deltas %12.4g %12.4g %12.4g\n", dr, dg, db);
2020-04-12 08:18:33 +11:00
return 0;
}
/* --------------------------------------------------------------------- */
/* --------------------------------------------------------------------- */
/* --------------------------------------------------------------------- */