FloatImg/tools/fimgstats.c

123 lines
2.6 KiB
C
Raw Normal View History

2019-03-04 02:22:55 +11:00
/*
* FIMGSTATS
*/
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include "../floatimg.h"
int verbosity; /* global */
int make_csv;
/* --------------------------------------------------------------------- */
int various_numbers(FloatImg *fimg, int k)
{
float moyennes[4];
int foo;
2020-03-23 23:03:14 +11:00
// float fvalue;
2020-03-03 00:51:34 +11:00
float vals[6];
2019-03-04 02:22:55 +11:00
2020-03-03 00:51:34 +11:00
if (verbosity) {
2019-03-04 02:22:55 +11:00
fprintf(stderr, " numbers from %p :\n", fimg);
2020-03-03 00:51:34 +11:00
}
2019-03-04 02:22:55 +11:00
fimg_printhead(fimg);
fprintf(stderr, "surface %d\n", fimg->width * fimg->height);
fimg_meanvalues(fimg, moyennes);
fprintf(stderr, "mean values:\n");
for (foo=0; foo<4; foo++)
printf(" %c %14.6f\n", "RGBA"[foo], moyennes[foo]);
2020-03-03 00:51:34 +11:00
/*
2019-03-04 02:22:55 +11:00
fvalue = fimg_get_maxvalue(fimg);
2020-03-03 00:51:34 +11:00
printf("max value %f\n", fvalue);
*/
2019-09-25 18:21:00 +11:00
foo = fimg_count_negativ(fimg);
if (foo) {
fprintf(stderr, "%d negative values\n", foo);
}
2019-03-04 02:22:55 +11:00
2020-03-03 00:51:34 +11:00
foo = fimg_get_minmax_rgb(fimg, vals);
if (foo) {
fprintf(stderr, "%s: err %d on fimg_get_minmax_rgb\n",
__func__, foo);
return foo;
}
2020-08-05 07:07:40 +11:00
printf("Rmin %12.4g Rmax %12.4g delta %12g\n",
vals[0], vals[1], vals[1]-vals[0]);
printf("Gmin %12.4g Gmax %12.4g %12g\n",
vals[2], vals[3], vals[3]-vals[2]);
printf("Bmin %12.4g Bmax %12.4g %12g\n",
vals[4], vals[5], vals[5]-vals[4]);
2020-03-03 00:51:34 +11:00
2019-03-04 02:22:55 +11:00
return 0;
}
/* --------------------------------------------------------------------- */
int various_numbers_from_file(char *fname, int k)
{
FloatImg fimg;
int foo;
2019-09-29 09:06:05 +11:00
fprintf(stderr, "------ numbers from '%s' :\n", fname);
2019-03-04 02:22:55 +11:00
foo = fimg_create_from_dump(fname, &fimg);
if (foo) {
fprintf(stderr, "create fimg from '%s' -> %d\n", fname, foo);
return -2;
}
various_numbers(&fimg, k);
fimg_destroy(&fimg);
return 0;
}
/* --------------------------------------------------------------------- */
static void help(int k)
{
fputs( "usage : fimgstats [options] file.fimg\n"
"\t-c\tmake a machinable csv\n"
"\t-v\tincrease verbosity\n"
, stderr);
}
/* --------------------------------------------------------------------- */
int main(int argc, char *argv[])
{
int foo, opt;
extern char *optarg;
extern int optind, opterr, optopt;
if (argc == 1) {
foo = fimg_print_version(1); help(0);
exit(0);
}
2020-03-03 00:51:34 +11:00
2020-06-19 08:43:41 +11:00
while ((opt = getopt(argc, argv, "chv")) != -1) {
2019-03-04 02:22:55 +11:00
switch(opt) {
case 'c': make_csv++; break;
case 'v': verbosity++; break;
2020-06-19 08:43:41 +11:00
case 'h': /* tombe dedans */
2019-03-04 02:22:55 +11:00
default: help(1); exit(1);
}
}
2020-06-19 08:43:41 +11:00
if (NULL==argv[optind]) {
fprintf(stderr, "optind %d is wtf\n", optind);
return 1;
}
2019-03-04 02:22:55 +11:00
foo = various_numbers_from_file(argv[optind], 0);
2019-07-16 09:19:59 +11:00
if (foo) {
fprintf(stderr, "got a %d ?\n", foo);
}
2019-03-04 02:22:55 +11:00
return 0;
}
/* --------------------------------------------------------------------- */