Commit 5a68b1ac authored by Michael Niedermayer's avatar Michael Niedermayer

mandelbrot: add inner drawing method to show converence time

Signed-off-by: 's avatarMichael Niedermayer <michaelni@gmx.at>
parent 5582e557
...@@ -43,6 +43,7 @@ enum Outer{ ...@@ -43,6 +43,7 @@ enum Outer{
enum Inner{ enum Inner{
BLACK, BLACK,
PERIOD, PERIOD,
CONVTIME,
}; };
typedef struct Point { typedef struct Point {
...@@ -94,6 +95,7 @@ static const AVOption mandelbrot_options[] = { ...@@ -94,6 +95,7 @@ static const AVOption mandelbrot_options[] = {
{"inner", "set inner coloring mode", OFFSET(inner), AV_OPT_TYPE_INT, {.dbl=BLACK}, 0, INT_MAX, 0, "inner"}, {"inner", "set inner coloring mode", OFFSET(inner), AV_OPT_TYPE_INT, {.dbl=BLACK}, 0, INT_MAX, 0, "inner"},
{"black", "set black mode", 0, AV_OPT_TYPE_CONST, {.dbl=BLACK}, INT_MIN, INT_MAX, 0, "inner" }, {"black", "set black mode", 0, AV_OPT_TYPE_CONST, {.dbl=BLACK}, INT_MIN, INT_MAX, 0, "inner" },
{"period", "set period mode", 0, AV_OPT_TYPE_CONST, {.dbl=PERIOD}, INT_MIN, INT_MAX, 0, "inner" }, {"period", "set period mode", 0, AV_OPT_TYPE_CONST, {.dbl=PERIOD}, INT_MIN, INT_MAX, 0, "inner" },
{"convergence", "show time until convergence", 0, AV_OPT_TYPE_CONST, {.dbl=CONVTIME}, INT_MIN, INT_MAX, 0, "inner" },
{NULL}, {NULL},
}; };
...@@ -252,7 +254,8 @@ static void draw_mandelbrot(AVFilterContext *ctx, uint32_t *color, int linesize, ...@@ -252,7 +254,8 @@ static void draw_mandelbrot(AVFilterContext *ctx, uint32_t *color, int linesize,
mb->zyklus[i][1]= zi; mb->zyklus[i][1]= zi;
} }
} }
if(!c && mb->inner==PERIOD){ if(!c){
if(mb->inner==PERIOD){
int j; int j;
for(j=i-1; j; j--) for(j=i-1; j; j--)
if(SQR(mb->zyklus[j][0]-zr) + SQR(mb->zyklus[j][1]-zi) < 0.0000000000000001) if(SQR(mb->zyklus[j][0]-zr) + SQR(mb->zyklus[j][1]-zi) < 0.0000000000000001)
...@@ -261,6 +264,9 @@ static void draw_mandelbrot(AVFilterContext *ctx, uint32_t *color, int linesize, ...@@ -261,6 +264,9 @@ static void draw_mandelbrot(AVFilterContext *ctx, uint32_t *color, int linesize,
c= i-j; c= i-j;
c= ((c<<5)&0xE0) + ((c<<16)&0xE000) + ((c<<27)&0xE00000); c= ((c<<5)&0xE0) + ((c<<16)&0xE000) + ((c<<27)&0xE00000);
} }
}else if(mb->inner==CONVTIME){
c= (i*255/mb->maxiter)*0x010101;
}
} }
c |= 0xFF000000; c |= 0xFF000000;
color[x + y*linesize]= c; color[x + y*linesize]= c;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment