diff options
Diffstat (limited to 'src/blind-invert-luma.c')
| -rw-r--r-- | src/blind-invert-luma.c | 73 |
1 files changed, 73 insertions, 0 deletions
diff --git a/src/blind-invert-luma.c b/src/blind-invert-luma.c new file mode 100644 index 0000000..aa3b260 --- /dev/null +++ b/src/blind-invert-luma.c @@ -0,0 +1,73 @@ +/* See LICENSE file for copyright and license details. */ +#include "stream.h" +#include "util.h" + +#include <fcntl.h> +#include <stdint.h> +#include <string.h> +#include <unistd.h> + +USAGE("[-i] mask-stream") + +static void +process_xyza(struct stream *colour, struct stream *mask, size_t n) +{ + size_t i; + double w, y; + for (i = 0; i < n; i += colour->pixel_size) { + w = ((double *)(mask->buf + i))[1]; + w *= ((double *)(mask->buf + i))[3]; + y = ((double *)(colour->buf + i))[3]; + y = (1 - y) * w + y * (1 - w); + ((double *)(colour->buf + i))[3] = y; + } +} + +static void +process_xyza_i(struct stream *colour, struct stream *mask, size_t n) +{ + size_t i; + double w, y; + for (i = 0; i < n; i += colour->pixel_size) { + w = 1 - ((double *)(mask->buf + i))[1]; + w *= ((double *)(mask->buf + i))[3]; + y = ((double *)(colour->buf + i))[3]; + y = (1 - y) * w + y * (1 - w); + ((double *)(colour->buf + i))[3] = y; + } +} + +int +main(int argc, char *argv[]) +{ + int invert = 0; + struct stream colour, mask; + void (*process)(struct stream *colour, struct stream *mask, size_t n) = NULL; + + ARGBEGIN { + case 'i': + invert = 1; + break; + default: + usage(); + } ARGEND; + + if (argc != 1) + usage(); + + colour.file = "<stdin>"; + colour.fd = STDIN_FILENO; + einit_stream(&colour); + + mask.file = argv[0]; + mask.fd = eopen(mask.file, O_RDONLY); + einit_stream(&mask); + + if (!strcmp(colour.pixfmt, "xyza")) + process = invert ? process_xyza_i : process_xyza; + else + eprintf("pixel format %s is not supported, try xyza\n", colour.pixfmt); + + process_two_streams(&colour, &mask, STDOUT_FILENO, "<stdout>", process); + return 0; +} |
