Compare commits
No commits in common. "3bd387f0a9ade7c340f06e6c875fce04679662b5" and "12347e90669d7fb88b65e1f2f2963c4210f611b7" have entirely different histories.
3bd387f0a9
...
12347e9066
@ -20,7 +20,7 @@
|
|||||||
* https://git.tetalab.org/tTh/FloatImg
|
* https://git.tetalab.org/tTh/FloatImg
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define FIMG_VERSION (230)
|
#define FIMG_VERSION (229)
|
||||||
#define RELEASE_NAME ("noname")
|
#define RELEASE_NAME ("noname")
|
||||||
#define PATCH_LEVEL ("aaaa")
|
#define PATCH_LEVEL ("aaaa")
|
||||||
|
|
||||||
|
@ -29,12 +29,12 @@ fprintf(stderr, "%8.3f %8.3f %8.3f\n", M[6], M[7], M[8]);
|
|||||||
|
|
||||||
sum = 0.0;
|
sum = 0.0;
|
||||||
for (idx=0; idx<9; idx++) sum += M[idx];
|
for (idx=0; idx<9; idx++) sum += M[idx];
|
||||||
fprintf(stderr, " sum: %8.3f\n", sum);
|
fprintf(stderr, " sum %8.3f\n", sum);
|
||||||
fprintf(stderr, " mult: %8.3f\n", filtr->mult);
|
fprintf(stderr, " mult %8.3f\n", filtr->mult);
|
||||||
fprintf(stderr, " offset: %8.3f\n", filtr->offset);
|
fprintf(stderr, " offset %8.3f\n", filtr->offset);
|
||||||
|
|
||||||
value = (sum * filtr->mult) + filtr->offset;
|
value = (sum * filtr->mult) + filtr->offset;
|
||||||
fprintf(stderr, " value: %8.3f\n", value);
|
fprintf(stderr, " value %8.3f ???\n", value);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -46,9 +46,9 @@ float *pr, *pg, *pb; /* alias for src pix filds */
|
|||||||
float *M; /* alias of filter matrix */
|
float *M; /* alias of filter matrix */
|
||||||
double dval;
|
double dval;
|
||||||
|
|
||||||
// #if DEBUG_LEVEL
|
#if DEBUG_LEVEL
|
||||||
fprintf(stderr, ">>> %s ( %p %p %p )\n", __func__, src, dst, filtr);
|
fprintf(stderr, ">>> %s ( %p %p %p )\n", __func__, src, dst, filtr);
|
||||||
// #endif
|
#endif
|
||||||
|
|
||||||
if (src->type != FIMG_TYPE_RGB) {
|
if (src->type != FIMG_TYPE_RGB) {
|
||||||
fprintf(stderr, "%s: src type %d invalid\n", __func__, src->type);
|
fprintf(stderr, "%s: src type %d invalid\n", __func__, src->type);
|
||||||
@ -59,12 +59,12 @@ if (dst->type != FIMG_TYPE_RGB) {
|
|||||||
return -99;
|
return -99;
|
||||||
}
|
}
|
||||||
if (fimg_images_not_compatible(src, dst)) {
|
if (fimg_images_not_compatible(src, dst)) {
|
||||||
fprintf(stderr, "%s: src & dst not compatibles\n", __func__);
|
fprintf(stderr, "%s: src & dst not comatibles\n", __func__);
|
||||||
return -98;
|
return -98;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (verbosity > 1) {
|
if (verbosity > 1) {
|
||||||
fimg_show_filter((char *)__func__, filtr);
|
fimg_show_filter(__func__, filtr);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* aliasing some vars for cleaner code */
|
/* aliasing some vars for cleaner code */
|
||||||
@ -73,7 +73,9 @@ w = src->width; h = src->height;
|
|||||||
M = filtr->matrix;
|
M = filtr->matrix;
|
||||||
|
|
||||||
for (y=1; y < h-1; y++) {
|
for (y=1; y < h-1; y++) {
|
||||||
|
|
||||||
for (x=1; x < w-1; x++) {
|
for (x=1; x < w-1; x++) {
|
||||||
|
|
||||||
of = x + (y * w);
|
of = x + (y * w);
|
||||||
|
|
||||||
dval = M[0] * pr[of-(w+1)] +
|
dval = M[0] * pr[of-(w+1)] +
|
||||||
@ -140,7 +142,9 @@ if (img->type != FIMG_TYPE_RGB) {
|
|||||||
pr = img->R; pg = img->G; pb = img->B;
|
pr = img->R; pg = img->G; pb = img->B;
|
||||||
|
|
||||||
for (y=1; y < img->height-1; y++) {
|
for (y=1; y < img->height-1; y++) {
|
||||||
|
|
||||||
for (x=1; x < img->width-1; x++) {
|
for (x=1; x < img->width-1; x++) {
|
||||||
|
|
||||||
offset = x + (y * img->width);
|
offset = x + (y * img->width);
|
||||||
|
|
||||||
cr = pr[offset] + pr[offset+1] +
|
cr = pr[offset] + pr[offset+1] +
|
||||||
@ -155,6 +159,7 @@ for (y=1; y < img->height-1; y++) {
|
|||||||
pr[offset] = cr / 4.0;
|
pr[offset] = cr / 4.0;
|
||||||
pg[offset] = cg / 4.0;
|
pg[offset] = cg / 4.0;
|
||||||
pb[offset] = cb / 4.0;
|
pb[offset] = cb / 4.0;
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -232,9 +237,6 @@ return foo;
|
|||||||
}
|
}
|
||||||
/* -------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------- */
|
||||||
/* -------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------- */
|
||||||
/*
|
|
||||||
* XXX inplace filtering is a BAD IDEA
|
|
||||||
*/
|
|
||||||
int fimg_lissage_3x3(FloatImg *img)
|
int fimg_lissage_3x3(FloatImg *img)
|
||||||
{
|
{
|
||||||
int foo;
|
int foo;
|
||||||
@ -263,13 +265,6 @@ if (foo) {
|
|||||||
fprintf(stderr, "%s: lowpass -> %d\n", __func__, foo);
|
fprintf(stderr, "%s: lowpass -> %d\n", __func__, foo);
|
||||||
abort();
|
abort();
|
||||||
}
|
}
|
||||||
|
|
||||||
foo = fimg_copy_data(&tmp, img);
|
|
||||||
if (foo) {
|
|
||||||
fprintf(stderr, "%s: copy data -> %d\n", __func__, foo);
|
|
||||||
abort();
|
|
||||||
}
|
|
||||||
|
|
||||||
foo = fimg_destroy(&tmp);
|
foo = fimg_destroy(&tmp);
|
||||||
if (foo) {
|
if (foo) {
|
||||||
fprintf(stderr, "%s: destroy -> %d\n", __func__, foo);
|
fprintf(stderr, "%s: destroy -> %d\n", __func__, foo);
|
||||||
|
@ -8,7 +8,7 @@ cp tools/mkfimg tools/fimg2pnm tools/fimgops \
|
|||||||
tools/png2fimg tools/fimgstats tools/fimgfx \
|
tools/png2fimg tools/fimgstats tools/fimgfx \
|
||||||
tools/cumulfimgs tools/fimg2text \
|
tools/cumulfimgs tools/fimg2text \
|
||||||
tools/fimghalfsize \
|
tools/fimghalfsize \
|
||||||
tools/fimgmetadata tools/fimgfilters \
|
tools/fimgmetadata \
|
||||||
tools/fimgextract \
|
tools/fimgextract \
|
||||||
/usr/local/bin
|
/usr/local/bin
|
||||||
|
|
||||||
|
@ -116,9 +116,7 @@ int fimg_cos_01(FloatImg *s, FloatImg *d, double maxval)
|
|||||||
int nbre, idx;
|
int nbre, idx;
|
||||||
double dval;
|
double dval;
|
||||||
|
|
||||||
#if DEBUG_LEVEL
|
|
||||||
fprintf(stderr, ">>> %s ( %p %p %g )\n", __func__, s, d, maxval);
|
fprintf(stderr, ">>> %s ( %p %p %g )\n", __func__, s, d, maxval);
|
||||||
#endif
|
|
||||||
|
|
||||||
if (s->type != FIMG_TYPE_RGB) {
|
if (s->type != FIMG_TYPE_RGB) {
|
||||||
fprintf(stderr, "%s: type %d invalide\n",
|
fprintf(stderr, "%s: type %d invalide\n",
|
||||||
|
@ -21,10 +21,14 @@ int x, y;
|
|||||||
float rgb[3];
|
float rgb[3];
|
||||||
|
|
||||||
#if DEBUG_LEVEL
|
#if DEBUG_LEVEL
|
||||||
fprintf(stderr, ">>> %s ( %p '%s' 0x%x )\n", __func__,
|
fprintf(stderr, ">>> %25s ( %p '%s' %d )\n", __func__,
|
||||||
src, fname, flags);
|
src, fname, flags);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
if (0 != flags) {
|
||||||
|
fprintf(stderr, "bad flags in %s\n", __func__);
|
||||||
|
}
|
||||||
|
|
||||||
fp = NULL; /* molly guard */
|
fp = NULL; /* molly guard */
|
||||||
if (strcmp("-", fname)) { /* real file */
|
if (strcmp("-", fname)) { /* real file */
|
||||||
fprintf(stderr, "real file '%s'\n", fname);
|
fprintf(stderr, "real file '%s'\n", fname);
|
||||||
@ -34,12 +38,6 @@ else {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fp = stdout; /* XXX */
|
fp = stdout; /* XXX */
|
||||||
|
|
||||||
/*
|
|
||||||
* put a first line, so we can load those data with R
|
|
||||||
*/
|
|
||||||
if (flags & 1) { fputs("X Y R G B\n", fp); }
|
|
||||||
|
|
||||||
for (y=0; y<src->height; y+=steps) {
|
for (y=0; y<src->height; y+=steps) {
|
||||||
for (x=0; x<src->width; x+=steps) {
|
for (x=0; x<src->width; x+=steps) {
|
||||||
fimg_get_rgb(src, x, y, rgb);
|
fimg_get_rgb(src, x, y, rgb);
|
||||||
@ -51,9 +49,6 @@ for (y=0; y<src->height; y+=steps) {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
/* --------------------------------------------------------------------- */
|
/* --------------------------------------------------------------------- */
|
||||||
/*
|
|
||||||
* This function must be in the libfloatimg !
|
|
||||||
*/
|
|
||||||
static int normalize(FloatImg *pimg, float vmax)
|
static int normalize(FloatImg *pimg, float vmax)
|
||||||
{
|
{
|
||||||
float mmv[6], maxi, coef;
|
float mmv[6], maxi, coef;
|
||||||
@ -90,15 +85,14 @@ return 0;
|
|||||||
}
|
}
|
||||||
/* --------------------------------------------------------------------- */
|
/* --------------------------------------------------------------------- */
|
||||||
int convertir_fimg_en_machinable(char *srcname, char *dstname,
|
int convertir_fimg_en_machinable(char *srcname, char *dstname,
|
||||||
int steps, float norm, int header)
|
int steps, float norm)
|
||||||
{
|
{
|
||||||
int foo, infos[3];
|
int foo, infos[3];
|
||||||
int flg;
|
|
||||||
FloatImg fimg;
|
FloatImg fimg;
|
||||||
|
|
||||||
#if DEBUG_LEVEL
|
#if DEBUG_LEVEL
|
||||||
fprintf(stderr, ">>> %s ( '%s' '%s' %d %f %d )\n", __func__,
|
fprintf(stderr, ">>> %25s ( '%s' '%s' %d %f )\n", __func__,
|
||||||
srcname, dstname, steps, norm, header);
|
srcname, dstname, steps, norm);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (steps < 1) {
|
if (steps < 1) {
|
||||||
@ -106,14 +100,12 @@ if (steps < 1) {
|
|||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
flg = 0;
|
|
||||||
if (header) flg |= 1;
|
|
||||||
|
|
||||||
foo = fimg_fileinfos(srcname, infos);
|
foo = fimg_fileinfos(srcname, infos);
|
||||||
if (foo) {
|
if (foo) {
|
||||||
fprintf(stderr, "'%s' get dims -> %d\n", srcname, foo);
|
fprintf(stderr, "'%s' get dims -> %d\n", srcname, foo);
|
||||||
return foo;
|
return foo;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (verbosity) {
|
if (verbosity) {
|
||||||
fprintf(stderr, "%s: image '%s' is %d x %d %s\n",
|
fprintf(stderr, "%s: image '%s' is %d x %d %s\n",
|
||||||
__func__,
|
__func__,
|
||||||
@ -127,12 +119,16 @@ if (foo) {
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (verbosity) {
|
||||||
|
// fimg_describe(&fimg, srcname);
|
||||||
|
fprintf(stderr, "normalize to %f\n", norm);
|
||||||
|
}
|
||||||
if (norm > 0.0) {
|
if (norm > 0.0) {
|
||||||
if (verbosity) fprintf(stderr, "normalize to %f\n", norm);
|
// fprintf(stderr, "normalize %p\n", &fimg);
|
||||||
foo = normalize(&fimg, norm);
|
foo = normalize(&fimg, norm);
|
||||||
}
|
}
|
||||||
|
|
||||||
foo = export_as_machinable(&fimg, dstname, steps, flg);
|
foo = export_as_machinable(&fimg, dstname, steps, 0);
|
||||||
if (foo) {
|
if (foo) {
|
||||||
fprintf(stderr,"%s: err %d on export\n", __func__, foo);
|
fprintf(stderr,"%s: err %d on export\n", __func__, foo);
|
||||||
}
|
}
|
||||||
@ -145,10 +141,9 @@ void help(int k)
|
|||||||
{
|
{
|
||||||
puts("usage:\n\tfimg2text [options] foo.fimg > bar.csv");
|
puts("usage:\n\tfimg2text [options] foo.fimg > bar.csv");
|
||||||
puts("options:");
|
puts("options:");
|
||||||
puts("\t-n Value\tnormalize picture if Value > 0.0");
|
|
||||||
puts("\t-s N\t\tsteps on x & y");
|
|
||||||
puts("\t-T\t\tadd header with colon name");
|
|
||||||
puts("\t-v\t\tincrease verbosity");
|
puts("\t-v\t\tincrease verbosity");
|
||||||
|
puts("\t-n 3.14\t\tnormalize picture");
|
||||||
|
puts("\t-s N\t\tsteps on x & y");
|
||||||
if (verbosity) {
|
if (verbosity) {
|
||||||
printf("*** compiled: %s at %s\n", __DATE__, __TIME__);
|
printf("*** compiled: %s at %s\n", __DATE__, __TIME__);
|
||||||
fimg_print_version(k);
|
fimg_print_version(k);
|
||||||
@ -161,17 +156,15 @@ int main(int argc, char *argv[])
|
|||||||
{
|
{
|
||||||
int foo, opt;
|
int foo, opt;
|
||||||
int steps = 1;
|
int steps = 1;
|
||||||
int header = 0;
|
float norm_val = 222.0; /* < 0 : don't normalize */
|
||||||
float norm_val = -1; /* < 0 : don't normalize */
|
|
||||||
// char separator = ' ';
|
// char separator = ' ';
|
||||||
|
|
||||||
while ((opt = getopt(argc, argv, "f:hn:s:Tv")) != -1) {
|
while ((opt = getopt(argc, argv, "f:hn:s:v")) != -1) {
|
||||||
switch(opt) {
|
switch(opt) {
|
||||||
// case 'f': separator = optarg[0]; break;
|
// case 'f': separator = optarg[0]; break;
|
||||||
case 'v': verbosity++; break;
|
case 'v': verbosity++; break;
|
||||||
case 'h': help(1); exit(1);
|
case 'h': help(1); exit(1);
|
||||||
case 's': steps = atoi(optarg); break;
|
case 's': steps = atoi(optarg); break;
|
||||||
case 'T': header = 1; break;
|
|
||||||
case 'n': norm_val = atof(optarg); break;
|
case 'n': norm_val = atof(optarg); break;
|
||||||
default: exit(1);
|
default: exit(1);
|
||||||
}
|
}
|
||||||
@ -182,8 +175,7 @@ if (1 != argc-optind) {
|
|||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
foo = convertir_fimg_en_machinable(argv[optind], "-",
|
foo = convertir_fimg_en_machinable(argv[optind], "-", steps, norm_val);
|
||||||
steps, norm_val, header);
|
|
||||||
if (foo) {
|
if (foo) {
|
||||||
fprintf(stderr, "%s : got a %d from convertor\n", argv[0], foo);
|
fprintf(stderr, "%s : got a %d from convertor\n", argv[0], foo);
|
||||||
return 1;
|
return 1;
|
||||||
|
@ -1,78 +0,0 @@
|
|||||||
/*
|
|
||||||
FIMGFILTERS
|
|
||||||
===========
|
|
||||||
new: Sun Oct 8 05:51:05 UTC 2023
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include <stdint.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <unistd.h>
|
|
||||||
#include <time.h>
|
|
||||||
|
|
||||||
#include "../floatimg.h"
|
|
||||||
|
|
||||||
int verbosity;
|
|
||||||
|
|
||||||
/* --------------------------------------------------------------------- */
|
|
||||||
int filtre_image(char *infname, char *outfname)
|
|
||||||
{
|
|
||||||
FloatImg src, dst;
|
|
||||||
int foo;
|
|
||||||
|
|
||||||
static FimgFilter3x3 filtre = {
|
|
||||||
{
|
|
||||||
2.0, 3.0, 2.0,
|
|
||||||
3.0, 4.0, 3.0,
|
|
||||||
2.0, 3.0, 2.0,
|
|
||||||
},
|
|
||||||
1.0/24.0, 0.0
|
|
||||||
};
|
|
||||||
|
|
||||||
fprintf(stderr, ">>> %s ( '%s' '%s' )\n", __func__, infname, outfname);
|
|
||||||
|
|
||||||
fimg_show_filter(NULL, &filtre);
|
|
||||||
|
|
||||||
if ((foo = fimg_create_from_dump(infname, &src))) {
|
|
||||||
fprintf(stderr, "read error on '%s' is %d\n", infname, foo);
|
|
||||||
exit(2);
|
|
||||||
}
|
|
||||||
if ((foo = fimg_clone(&src, &dst, 0))) {
|
|
||||||
fprintf(stderr, "clone error on %p is %d\n", &src, foo);
|
|
||||||
exit(3);
|
|
||||||
}
|
|
||||||
|
|
||||||
foo = fimg_filter_3x3(&src, &dst, &filtre);
|
|
||||||
if (foo) {
|
|
||||||
fprintf(stderr, "%s: filtre -> %d\n", __func__, foo);
|
|
||||||
exit(4);
|
|
||||||
}
|
|
||||||
|
|
||||||
foo = fimg_dump_to_file(&dst, outfname, 0);
|
|
||||||
if (foo) {
|
|
||||||
fprintf(stderr, "dumping to file give us a %d\n", foo);
|
|
||||||
}
|
|
||||||
|
|
||||||
return -12;
|
|
||||||
}
|
|
||||||
/* --------------------------------------------------------------------- */
|
|
||||||
|
|
||||||
int main(int argc, char *argv[])
|
|
||||||
{
|
|
||||||
int foo;
|
|
||||||
|
|
||||||
if (3 != argc) {
|
|
||||||
fprintf(stderr, "usage: %s in.fimg out.fimg\n", argv[0]);
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
fprintf(stderr, " +++ %s +++\n", argv[0]);
|
|
||||||
|
|
||||||
foo = filtre_image(argv[1], argv[2]);
|
|
||||||
fprintf(stderr, " filtrage -> %d\n", foo);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
/* --------------------------------------------------------------------- */
|
|
||||||
|
|
@ -39,7 +39,7 @@ int foo;
|
|||||||
float vals[6];
|
float vals[6];
|
||||||
|
|
||||||
if (verbosity) {
|
if (verbosity) {
|
||||||
fprintf(stderr, "%s from %p :\n", __func__, fimg);
|
fprintf(stderr, "%s numbers from %p :\n", __func__, fimg);
|
||||||
}
|
}
|
||||||
|
|
||||||
fimg_printhead(fimg);
|
fimg_printhead(fimg);
|
||||||
|
@ -128,7 +128,7 @@ for (foo=0; foo<argc; foo++)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (type < 0) {
|
if (type < 0) {
|
||||||
fprintf(stderr, "%s: type '%s' is unknow\n", argv[0], tname);
|
fprintf(stderr, "type '%s' is unknow\n", tname);
|
||||||
exit(2);
|
exit(2);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -153,6 +153,12 @@ switch (nbargs) {
|
|||||||
|
|
||||||
fname = argv[optind];
|
fname = argv[optind];
|
||||||
|
|
||||||
|
if (verbosity>1) {
|
||||||
|
fprintf(stderr, "*** mkfimg *** %s %s *** pid %ld\n",
|
||||||
|
__DATE__, __TIME__, (long)getpid());
|
||||||
|
fimg_print_version(0);
|
||||||
|
}
|
||||||
|
|
||||||
if (verbosity) fprintf(stderr, "::: %s is making '%s' %dx%d, type %d\n",
|
if (verbosity) fprintf(stderr, "::: %s is making '%s' %dx%d, type %d\n",
|
||||||
argv[0], fname, width, height, type);
|
argv[0], fname, width, height, type);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user