aboutsummaryrefslogtreecommitdiffstats
path: root/src/blind-sine-wave.c
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--src/blind-sine-wave.c54
1 files changed, 18 insertions, 36 deletions
diff --git a/src/blind-sine-wave.c b/src/blind-sine-wave.c
index 7e3cc5a..85bba2b 100644
--- a/src/blind-sine-wave.c
+++ b/src/blind-sine-wave.c
@@ -5,51 +5,34 @@ USAGE("[-e]")
static int equal = 0;
-
#define PROCESS(TYPE, SUFFIX)\
static void\
process_##SUFFIX(struct stream *stream)\
{\
- size_t i, n;\
- TYPE x, y, z, a;\
+ size_t i, j, n;\
+ TYPE v, *p;\
do {\
- n = stream->ptr / stream->pixel_size;\
if (equal) {\
+ n = stream->ptr / stream->pixel_size;\
for (i = 0; i < n; i++) {\
- a = ((TYPE *)(stream->buf))[4 * i + 3];\
- a = posmod(a, (TYPE)2);\
- a = a > 1 ? 2 - a : a;\
- a = 1 - (cos(a * (TYPE)M_PI) + 1) / 2;\
- ((TYPE *)(stream->buf))[4 * i + 0] = a;\
- ((TYPE *)(stream->buf))[4 * i + 1] = a;\
- ((TYPE *)(stream->buf))[4 * i + 2] = a;\
- ((TYPE *)(stream->buf))[4 * i + 3] = a;\
+ p = (TYPE *)(stream->buf) + i * stream->n_chan;\
+ v = posmod(*p, (TYPE)2);\
+ v = v > 1 ? 2 - v : v;\
+ v = 1 - (cos(v * (TYPE)M_PI) + 1) / 2;\
+ for (j = 0; j < stream->n_chan; j++)\
+ p[j] = v;\
}\
+ n *= stream->pixel_size;\
} else {\
+ n = stream->ptr / stream->chan_size;\
for (i = 0; i < n; i++) {\
- x = ((TYPE *)(stream->buf))[4 * i + 0];\
- y = ((TYPE *)(stream->buf))[4 * i + 1];\
- z = ((TYPE *)(stream->buf))[4 * i + 2];\
- a = ((TYPE *)(stream->buf))[4 * i + 3];\
- x = posmod(x, (TYPE)1);\
- y = posmod(y, (TYPE)1);\
- z = posmod(z, (TYPE)1);\
- a = posmod(a, (TYPE)1);\
- x = x > 1 ? 2 - x : x;\
- y = y > 1 ? 2 - y : y;\
- z = z > 1 ? 2 - z : z;\
- a = a > 1 ? 2 - a : a;\
- x = 1 - (cos(x * (TYPE)M_PI) + 1) / 2;\
- y = 1 - (cos(y * (TYPE)M_PI) + 1) / 2;\
- z = 1 - (cos(z * (TYPE)M_PI) + 1) / 2;\
- a = 1 - (cos(a * (TYPE)M_PI) + 1) / 2;\
- ((TYPE *)(stream->buf))[4 * i + 0] = x;\
- ((TYPE *)(stream->buf))[4 * i + 1] = y;\
- ((TYPE *)(stream->buf))[4 * i + 2] = z;\
- ((TYPE *)(stream->buf))[4 * i + 3] = a;\
+ p = (TYPE *)(stream->buf) + i;\
+ v = posmod(*p, (TYPE)2);\
+ v = v > 1 ? 2 - v : v;\
+ *p = 1 - (cos(v * (TYPE)M_PI) + 1) / 2;\
}\
+ n *= stream->chan_size;\
}\
- n *= stream->pixel_size;\
ewriteall(STDOUT_FILENO, stream->buf, n, "<stdout>");\
memmove(stream->buf, stream->buf + n, stream->ptr -= n);\
} while (eread_stream(stream, SIZE_MAX));\
@@ -60,7 +43,6 @@ static int equal = 0;
PROCESS(double, lf)
PROCESS(float, f)
-
int
main(int argc, char *argv[])
{
@@ -80,9 +62,9 @@ main(int argc, char *argv[])
eopen_stream(&stream, NULL);
- if (!strcmp(stream.pixfmt, "xyza"))
+ if (stream.encoding == DOUBLE)
process = process_lf;
- else if (!strcmp(stream.pixfmt, "xyza f"))
+ else if (stream.encoding == FLOAT)
process = process_f;
else
eprintf("pixel format %s is not supported, try xyza\n", stream.pixfmt);