aboutsummaryrefslogtreecommitdiffstats
path: root/src/blind-invert-luma.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/blind-invert-luma.c')
-rw-r--r--src/blind-invert-luma.c73
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;
+}