diff options
author | Lars-Dominik Braun <lars@6xq.net> | 2015-02-11 17:39:28 +0100 |
---|---|---|
committer | Lars-Dominik Braun <lars@6xq.net> | 2015-05-02 21:36:44 +0200 |
commit | b8a1610a4c976c03c1a9a442487b6b0ba90cc01c (patch) | |
tree | c4c8cca3097c205d680224a5337bcd8988926c91 | |
parent | 568a58f7260766eba3257e0341db00170e0ad08e (diff) | |
download | pucket-b8a1610a4c976c03c1a9a442487b6b0ba90cc01c.tar.gz pucket-b8a1610a4c976c03c1a9a442487b6b0ba90cc01c.tar.bz2 pucket-b8a1610a4c976c03c1a9a442487b6b0ba90cc01c.zip |
Vectorize variants
Slightly worse with amdlibm, slightly better with gcc’s builtins (no
optimization) and worse with optimization
-rw-r--r-- | private.h | 8 | ||||
-rw-r--r-- | variations.c | 1211 |
2 files changed, 562 insertions, 657 deletions
@@ -99,9 +99,10 @@ typedef struct { } flam3_iter_constants; -typedef struct { +typedef double double2 __attribute__ ((vector_size (sizeof (double)*2))); - double tx,ty; /* Starting coordinates */ +typedef struct { + double2 t; double precalc_atan, precalc_sina; /* Precalculated, if needed */ double precalc_cosa, precalc_sqrt; @@ -110,8 +111,7 @@ typedef struct { flam3_xform *xform; /* For the important values */ /* Output Coords */ - - double p0, p1; + double2 p; /* Pointer to the isaac RNG state */ randctx *rc; diff --git a/variations.c b/variations.c index 6d425ca..1426332 100644 --- a/variations.c +++ b/variations.c @@ -144,29 +144,27 @@ char *flam3_variation_names[1+flam3_nvariations] = { * VARIATION FUNCTIONS * must be of the form void (void *, double) */ -static void var0_linear (flam3_iter_helper *f, double weight) { +static double2 var0_linear (flam3_iter_helper *f, double weight) { /* linear */ /* nx = tx; ny = ty; p[0] += v * nx; p[1] += v * ny; */ - f->p0 += weight * f->tx; - f->p1 += weight * f->ty; + return weight * f->t; } -static void var1_sinusoidal (flam3_iter_helper *f, double weight) { +static double2 var1_sinusoidal (flam3_iter_helper *f, double weight) { /* sinusoidal */ /* nx = sin(tx); ny = sin(ty); p[0] += v * nx; p[1] += v * ny; */ - f->p0 += weight * sin(f->tx); - f->p1 += weight * sin(f->ty); + return weight * (double2) {sin(f->t[0]), sin(f->t[1])}; } -static void var2_spherical (flam3_iter_helper *f, double weight) { +static double2 var2_spherical (flam3_iter_helper *f, double weight) { /* spherical */ /* double r2 = tx * tx + ty * ty + 1e-6; nx = tx / r2; @@ -174,13 +172,12 @@ static void var2_spherical (flam3_iter_helper *f, double weight) { p[0] += v * nx; p[1] += v * ny; */ - double r2 = weight / ( f->precalc_sumsq + EPS); + const double r2 = weight / ( f->precalc_sumsq + EPS); - f->p0 += r2 * f->tx; - f->p1 += r2 * f->ty; + return r2 * f->t; } -static void var3_swirl (flam3_iter_helper *f, double weight) { +static double2 var3_swirl (flam3_iter_helper *f, double weight) { /* swirl */ /* double r2 = tx * tx + ty * ty; /k here is fun double c1 = sin(r2); @@ -192,19 +189,19 @@ static void var3_swirl (flam3_iter_helper *f, double weight) { double r2 = f->precalc_sumsq; double c1,c2; - double nx,ny; sincos(r2,&c1,&c2); // double c1 = sin(r2); // double c2 = cos(r2); - nx = c1 * f->tx - c2 * f->ty; - ny = c2 * f->tx + c1 * f->ty; + const double2 n = (double2) { + c1 * f->t[0] - c2 * f->t[1], + c2 * f->t[0] + c1 * f->t[1], + }; - f->p0 += weight * nx; - f->p1 += weight * ny; + return weight * n; } -static void var4_horseshoe (flam3_iter_helper *f, double weight) { +static double2 var4_horseshoe (flam3_iter_helper *f, double weight) { /* horseshoe */ /* a = atan2(tx, ty); c1 = sin(a); @@ -214,41 +211,43 @@ static void var4_horseshoe (flam3_iter_helper *f, double weight) { p[0] += v * nx; p[1] += v * ny; */ - double r = weight / (f->precalc_sqrt + EPS); + const double r = weight / (f->precalc_sqrt + EPS); - f->p0 += (f->tx - f->ty) * (f->tx + f->ty) * r; - f->p1 += 2.0 * f->tx * f->ty * r; + return r * (double2) { + (f->t[0] - f->t[1]) * (f->t[0] + f->t[1]), + 2.0 * f->t[0] * f->t[1], + }; } -static void var5_polar (flam3_iter_helper *f, double weight) { +static double2 var5_polar (flam3_iter_helper *f, double weight) { /* polar */ /* nx = atan2(tx, ty) / M_PI; ny = sqrt(tx * tx + ty * ty) - 1.0; p[0] += v * nx; p[1] += v * ny; */ - double nx = f->precalc_atan * M_1_PI; - double ny = f->precalc_sqrt - 1.0; + const double2 n = (double2) { + f->precalc_atan * M_1_PI, + f->precalc_sqrt - 1.0, + }; - f->p0 += weight * nx; - f->p1 += weight * ny; + return weight * n; } -static void var6_handkerchief (flam3_iter_helper *f, double weight) { +static double2 var6_handkerchief (flam3_iter_helper *f, double weight) { /* folded handkerchief */ /* a = atan2(tx, ty); r = sqrt(tx*tx + ty*ty); p[0] += v * sin(a+r) * r; p[1] += v * cos(a-r) * r; */ - double a = f->precalc_atan; - double r = f->precalc_sqrt; + const double a = f->precalc_atan; + const double r = f->precalc_sqrt; - f->p0 += weight * r * sin(a+r); - f->p1 += weight * r * cos(a-r); + return weight * r * (double2) { sin(a+r), cos(a-r) }; } -static void var7_heart (flam3_iter_helper *f, double weight) { +static double2 var7_heart (flam3_iter_helper *f, double weight) { /* heart */ /* a = atan2(tx, ty); r = sqrt(tx*tx + ty*ty); @@ -256,17 +255,16 @@ static void var7_heart (flam3_iter_helper *f, double weight) { p[0] += v * sin(a) * r; p[1] += v * cos(a) * -r; */ - double a = f->precalc_sqrt * f->precalc_atan; + const double a = f->precalc_sqrt * f->precalc_atan; double ca,sa; - double r = weight * f->precalc_sqrt; + const double r = weight * f->precalc_sqrt; sincos(a,&sa,&ca); - f->p0 += r * sa; - f->p1 += (-r) * ca; + return (double2) { r * sa, (-r) * ca }; } -static void var8_disc (flam3_iter_helper *f, double weight) { +static double2 var8_disc (flam3_iter_helper *f, double weight) { /* disc */ /* nx = tx * M_PI; ny = ty * M_PI; @@ -275,60 +273,56 @@ static void var8_disc (flam3_iter_helper *f, double weight) { p[0] += v * sin(r) * a / M_PI; p[1] += v * cos(r) * a / M_PI; */ - double a = f->precalc_atan * M_1_PI; - double r = M_PI * f->precalc_sqrt; + const double a = f->precalc_atan * M_1_PI; + const double r = M_PI * f->precalc_sqrt; double sr,cr; sincos(r,&sr,&cr); - f->p0 += weight * sr * a; - f->p1 += weight * cr * a; + return weight * (double2) { sr, cr } * a; } -static void var9_spiral (flam3_iter_helper *f, double weight) { +static double2 var9_spiral (flam3_iter_helper *f, double weight) { /* spiral */ /* a = atan2(tx, ty); r = sqrt(tx*tx + ty*ty) + 1e-6; p[0] += v * (cos(a) + sin(r)) / r; p[1] += v * (sin(a) - cos(r)) / r; */ - double r = f->precalc_sqrt + EPS; - double r1 = weight/r; + const double r = f->precalc_sqrt + EPS; + const double r1 = weight/r; double sr,cr; sincos(r,&sr,&cr); - f->p0 += r1 * (f->precalc_cosa + sr); - f->p1 += r1 * (f->precalc_sina - cr); + return r1 * (double2) { f->precalc_cosa + sr, f->precalc_sina - cr }; } -static void var10_hyperbolic (flam3_iter_helper *f, double weight) { +static double2 var10_hyperbolic (flam3_iter_helper *f, double weight) { /* hyperbolic */ /* a = atan2(tx, ty); r = sqrt(tx*tx + ty*ty) + 1e-6; p[0] += v * sin(a) / r; p[1] += v * cos(a) * r; */ - double r = f->precalc_sqrt + EPS; + const double r = f->precalc_sqrt + EPS; - f->p0 += weight * f->precalc_sina / r; - f->p1 += weight * f->precalc_cosa * r; + return weight * (double2) { f->precalc_sina / r, f->precalc_cosa * r}; } -static void var11_diamond (flam3_iter_helper *f, double weight) { +static double2 var11_diamond (flam3_iter_helper *f, double weight) { /* diamond */ /* a = atan2(tx, ty); r = sqrt(tx*tx + ty*ty); p[0] += v * sin(a) * cos(r); p[1] += v * cos(a) * sin(r); */ - double r = f->precalc_sqrt; + const double r = f->precalc_sqrt; double sr,cr; sincos(r,&sr,&cr); - f->p0 += weight * f->precalc_sina * cr; - f->p1 += weight * f->precalc_cosa * sr; + return weight * (double2) { f->precalc_sina * cr, f->precalc_cosa * sr }; } -static void var12_ex (flam3_iter_helper *f, double weight) { +static double2 var12_ex (flam3_iter_helper *f, double weight) { /* ex */ /* a = atan2(tx, ty); r = sqrt(tx*tx + ty*ty); @@ -339,20 +333,17 @@ static void var12_ex (flam3_iter_helper *f, double weight) { p[0] += v * (m0 + m1); p[1] += v * (m0 - m1); */ - double a = f->precalc_atan; - double r = f->precalc_sqrt; + const double a = f->precalc_atan; + const double r = f->precalc_sqrt; - double n0 = sin(a+r); - double n1 = cos(a-r); + const double2 n = (double2) { sin(a+r), cos(a-r) }; - double m0 = n0 * n0 * n0 * r; - double m1 = n1 * n1 * n1 * r; + const double2 m = n * n * n * r; - f->p0 += weight * (m0 + m1); - f->p1 += weight * (m0 - m1); + return weight * (double2) { m[0] + m[1], m[0] - m[1] }; } -static void var13_julia (flam3_iter_helper *f, double weight) { +static double2 var13_julia (flam3_iter_helper *f, double weight) { /* julia */ /* a = atan2(tx, ty)/2.0; if (flam3_random_bit()) a += M_PI; @@ -373,11 +364,10 @@ static void var13_julia (flam3_iter_helper *f, double weight) { sincos(a,&sa,&ca); - f->p0 += r * ca; - f->p1 += r * sa; + return r * (double2) { ca, sa }; } -static void var14_bent (flam3_iter_helper *f, double weight) { +static double2 var14_bent (flam3_iter_helper *f, double weight) { /* bent */ /* nx = tx; ny = ty; @@ -386,19 +376,13 @@ static void var14_bent (flam3_iter_helper *f, double weight) { p[0] += v * nx; p[1] += v * ny; */ - double nx = f->tx; - double ny = f->ty; - - if (nx < 0.0) - nx = nx * 2.0; - if (ny < 0.0) - ny = ny / 2.0; - - f->p0 += weight * nx; - f->p1 += weight * ny; + return weight * f->t * (double2) { + f->t[0] < 0.0 ? 2.0 : 1.0, + f->t[1] < 0.0 ? 0.5 : 1.0, + }; } -static void var15_waves (flam3_iter_helper *f, double weight) { +static double2 var15_waves (flam3_iter_helper *f, double weight) { /* waves */ /* dx = coef[2][0]; dy = coef[2][1]; @@ -407,17 +391,17 @@ static void var15_waves (flam3_iter_helper *f, double weight) { p[0] += v * nx; p[1] += v * ny; */ - double c10 = f->xform->c[1][0]; - double c11 = f->xform->c[1][1]; + const double2 c1 = (double2) {f->xform->c[1][0], f->xform->c[1][1] }; - double nx = f->tx + c10 * sin( f->ty * f->xform->waves_dx2 ); - double ny = f->ty + c11 * sin( f->tx * f->xform->waves_dy2 ); + const double2 n = f->t + c1 * (double2) { + sin( f->t[1] * f->xform->waves_dx2 ), + sin( f->t[0] * f->xform->waves_dy2 ), + }; - f->p0 += weight * nx; - f->p1 += weight * ny; + return weight * n; } -static void var16_fisheye (flam3_iter_helper *f, double weight) { +static double2 var16_fisheye (flam3_iter_helper *f, double weight) { /* fisheye */ /* a = atan2(tx, ty); r = sqrt(tx*tx + ty*ty); @@ -429,13 +413,15 @@ static void var16_fisheye (flam3_iter_helper *f, double weight) { double r = f->precalc_sqrt; - r = 2 * weight / (r+1); + r = 2.0 * weight / (r+1.0); + + /* XXX this seems to be wrong */ + const double2 tswap = (double2) { f->t[1], f->t[0] }; - f->p0 += r * f->ty; - f->p1 += r * f->tx; + return r * tswap; } -static void var17_popcorn (flam3_iter_helper *f, double weight) { +static double2 var17_popcorn (flam3_iter_helper *f, double weight) { /* popcorn */ /* dx = tan(3*ty); dy = tan(3*tx); @@ -444,17 +430,18 @@ static void var17_popcorn (flam3_iter_helper *f, double weight) { p[0] += v * nx; p[1] += v * ny; */ - double dx = tan(3*f->ty); - double dy = tan(3*f->tx); + const double dx = tan(3.0*f->t[1]); + const double dy = tan(3.0*f->t[0]); - double nx = f->tx + f->xform->c[2][0] * sin(dx); - double ny = f->ty + f->xform->c[2][1] * sin(dy); + const double2 n = f->t + (double2) { + f->xform->c[2][0] * sin(dx), + f->xform->c[2][1] * sin(dy) + }; - f->p0 += weight * nx; - f->p1 += weight * ny; + return weight * n; } -static void var18_exponential (flam3_iter_helper *f, double weight) { +static double2 var18_exponential (flam3_iter_helper *f, double weight) { /* exponential */ /* dx = exp(tx-1.0); dy = M_PI * ty; @@ -463,18 +450,16 @@ static void var18_exponential (flam3_iter_helper *f, double weight) { p[0] += v * nx; p[1] += v * ny; */ - double dx = weight * exp(f->tx - 1.0); - double dy = M_PI * f->ty; + double dx = weight * exp(f->t[0] - 1.0); + double dy = M_PI * f->t[1]; double sdy,cdy; sincos(dy,&sdy,&cdy); - - f->p0 += dx * cdy; - f->p1 += dx * sdy; + return dx * (double2) { cdy, sdy }; } -static void var19_power (flam3_iter_helper *f, double weight) { +static double2 var19_power (flam3_iter_helper *f, double weight) { /* power */ /* a = atan2(tx, ty); sa = sin(a); @@ -485,32 +470,29 @@ static void var19_power (flam3_iter_helper *f, double weight) { p[0] += v * nx; p[1] += v * ny; */ - double r = weight * pow(f->precalc_sqrt, f->precalc_sina); + const double r = weight * pow(f->precalc_sqrt, f->precalc_sina); - f->p0 += r * f->precalc_cosa; - f->p1 += r * f->precalc_sina; + return r * (double2) { f->precalc_cosa, f->precalc_sina }; } -static void var20_cosine (flam3_iter_helper *f, double weight) { +static double2 var20_cosine (flam3_iter_helper *f, double weight) { /* cosine */ /* nx = cos(tx * M_PI) * cosh(ty); ny = -sin(tx * M_PI) * sinh(ty); p[0] += v * nx; p[1] += v * ny; */ - double a = f->tx * M_PI; + const double a = f->t[0] * M_PI; double sa,ca; - double nx,ny; sincos(a,&sa,&ca); - nx = ca * cosh(f->ty); - ny = -sa * sinh(f->ty); - f->p0 += weight * nx; - f->p1 += weight * ny; + const double2 n = (double2) { ca * cosh(f->t[1]), -sa * sinh(f->t[1]) }; + + return weight * n; } -static void var21_rings (flam3_iter_helper *f, double weight) { +static double2 var21_rings (flam3_iter_helper *f, double weight) { /* rings */ /* dx = coef[2][0]; dx = dx * dx + EPS; @@ -522,15 +504,14 @@ static void var21_rings (flam3_iter_helper *f, double weight) { p[0] += v * nx; p[1] += v * ny; */ - double dx = f->xform->c[2][0] * f->xform->c[2][0] + EPS; + const double dx = f->xform->c[2][0] * f->xform->c[2][0] + EPS; double r = f->precalc_sqrt; r = weight * (fmod(r+dx, 2*dx) - dx + r * (1 - dx)); - f->p0 += r * f->precalc_cosa; - f->p1 += r * f->precalc_sina; + return r * (double2) { f->precalc_cosa, f->precalc_sina }; } -static void var22_fan (flam3_iter_helper *f, double weight) { +static double2 var22_fan (flam3_iter_helper *f, double weight) { /* fan */ /* dx = coef[2][0]; dy = coef[2][1]; @@ -544,22 +525,21 @@ static void var22_fan (flam3_iter_helper *f, double weight) { p[0] += v * nx; p[1] += v * ny; */ - double dx = M_PI * (f->xform->c[2][0] * f->xform->c[2][0] + EPS); - double dy = f->xform->c[2][1]; - double dx2 = 0.5 * dx; + const double dx = M_PI * (f->xform->c[2][0] * f->xform->c[2][0] + EPS); + const double dy = f->xform->c[2][1]; + const double dx2 = 0.5 * dx; double a = f->precalc_atan; - double r = weight * f->precalc_sqrt; + const double r = weight * f->precalc_sqrt; double sa,ca; a += (fmod(a+dy,dx) > dx2) ? -dx2 : dx2; sincos(a,&sa,&ca); - f->p0 += r * ca; - f->p1 += r * sa; + return r * (double2) { ca, sa }; } -static void var23_blob (flam3_iter_helper *f, double weight) { +static double2 var23_blob (flam3_iter_helper *f, double weight) { /* blob */ /* a = atan2(tx, ty); r = sqrt(tx*tx + ty*ty); @@ -571,17 +551,16 @@ static void var23_blob (flam3_iter_helper *f, double weight) { p[1] += v * ny; */ double r = f->precalc_sqrt; - double a = f->precalc_atan; - double bdiff = f->xform->blob_high - f->xform->blob_low; + const double a = f->precalc_atan; + const double bdiff = f->xform->blob_high - f->xform->blob_low; r = r * (f->xform->blob_low + bdiff * (0.5 + 0.5 * sin(f->xform->blob_waves * a))); - f->p0 += weight * f->precalc_sina * r; - f->p1 += weight * f->precalc_cosa * r; + return weight * (double2) { f->precalc_sina, f->precalc_cosa } * r; } -static void var24_pdj (flam3_iter_helper *f, double weight) { +static double2 var24_pdj (flam3_iter_helper *f, double weight) { /* pdj */ /* nx1 = cos(pdjb * tx); nx2 = sin(pdjc * tx); @@ -591,16 +570,17 @@ static void var24_pdj (flam3_iter_helper *f, double weight) { p[0] += v * (ny1 - nx1); p[1] += v * (nx2 - ny2); */ - double nx1 = cos(f->xform->pdj_b * f->tx); - double nx2 = sin(f->xform->pdj_c * f->tx); - double ny1 = sin(f->xform->pdj_a * f->ty); - double ny2 = cos(f->xform->pdj_d * f->ty); + const double2 a = (double2) { + sin(f->xform->pdj_a * f->t[1]), + sin(f->xform->pdj_c * f->t[0]) }; + const double2 b = (double2) { + cos(f->xform->pdj_b * f->t[0]), + cos(f->xform->pdj_d * f->t[1]) }; - f->p0 += weight * (ny1 - nx1); - f->p1 += weight * (nx2 - ny2); + return weight * (a - b); } -static void var25_fan2 (flam3_iter_helper *f, double weight) { +static double2 var25_fan2 (flam3_iter_helper *f, double weight) { /* fan2 */ /* a = precalc_atan; r = precalc_sqrt; @@ -638,11 +618,10 @@ static void var25_fan2 (flam3_iter_helper *f, double weight) { sincos(a,&sa,&ca); - f->p0 += r * sa; - f->p1 += r * ca; + return r * (double2) { sa, ca }; } -static void var26_rings2 (flam3_iter_helper *f, double weight) { +static double2 var26_rings2 (flam3_iter_helper *f, double weight) { /* rings2 */ /* r = precalc_sqrt; dx = rings2val * rings2val + EPS; @@ -657,48 +636,43 @@ static void var26_rings2 (flam3_iter_helper *f, double weight) { r += -2.0*dx*(int)((r+dx)/(2.0*dx)) + r * (1.0-dx); - f->p0 += weight * f->precalc_sina * r; - f->p1 += weight * f->precalc_cosa * r; + return weight * (double2) { f->precalc_sina, f->precalc_cosa } * r; } -static void var27_eyefish (flam3_iter_helper *f, double weight) { +static double2 var27_eyefish (flam3_iter_helper *f, double weight) { /* eyefish */ /* r = 2.0 * v / (precalc_sqrt + 1.0); p[0] += r*tx; p[1] += r*ty; */ - double r = (weight * 2.0) / (f->precalc_sqrt + 1.0); + const double r = (weight * 2.0) / (f->precalc_sqrt + 1.0); - f->p0 += r * f->tx; - f->p1 += r * f->ty; + return r * f->t; } -static void var28_bubble (flam3_iter_helper *f, double weight) { +static double2 var28_bubble (flam3_iter_helper *f, double weight) { /* bubble */ - double r = weight / (0.25 * (f->precalc_sumsq) + 1); + const double r = weight / (0.25 * (f->precalc_sumsq) + 1); - f->p0 += r * f->tx; - f->p1 += r * f->ty; + return r * f->t; } -static void var29_cylinder (flam3_iter_helper *f, double weight) { +static double2 var29_cylinder (flam3_iter_helper *f, double weight) { /* cylinder (01/06) */ - f->p0 += weight * sin(f->tx); - f->p1 += weight * f->ty; + return weight * (double2) { sin(f->t[0]), f->t[1] }; } -static void var30_perspective (flam3_iter_helper *f, double weight) { +static double2 var30_perspective (flam3_iter_helper *f, double weight) { /* perspective (01/06) */ - double t = 1.0 / (f->xform->perspective_dist - f->ty * f->xform->persp_vsin); + const double t = 1.0 / (f->xform->perspective_dist - f->t[1] * f->xform->persp_vsin); - f->p0 += weight * f->xform->perspective_dist * f->tx * t; - f->p1 += weight * f->xform->persp_vfcos * f->ty * t; + return weight * (double2) { f->xform->perspective_dist, f->xform->persp_vfcos } * f->t * t; } -static void var31_noise (flam3_iter_helper *f, double weight) { +static double2 var31_noise (flam3_iter_helper *f, double weight) { /* noise (03/06) */ double tmpr, sinr, cosr, r; @@ -708,11 +682,10 @@ static void var31_noise (flam3_iter_helper *f, double weight) { r = weight * flam3_random_isaac_01(f->rc); - f->p0 += f->tx * r * cosr; - f->p1 += f->ty * r * sinr; + return f->t * r * (double2) { cosr, sinr }; } -static void var32_juliaN_generic (flam3_iter_helper *f, double weight) { +static double2 var32_juliaN_generic (flam3_iter_helper *f, double weight) { /* juliaN (03/06) */ int t_rnd = trunc((f->xform->julian_rN)*flam3_random_isaac_01(f->rc)); @@ -723,11 +696,10 @@ static void var32_juliaN_generic (flam3_iter_helper *f, double weight) { double sina, cosa; sincos(tmpr,&sina,&cosa); - f->p0 += r * cosa; - f->p1 += r * sina; + return r * (double2) { cosa, sina }; } -static void var33_juliaScope_generic (flam3_iter_helper *f, double weight) { +static double2 var33_juliaScope_generic (flam3_iter_helper *f, double weight) { /* juliaScope (03/06) */ int t_rnd = trunc((f->xform->juliascope_rN) * flam3_random_isaac_01(f->rc)); @@ -744,11 +716,10 @@ static void var33_juliaScope_generic (flam3_iter_helper *f, double weight) { r = weight * pow(f->precalc_sumsq, f->xform->juliascope_cn); - f->p0 += r * cosa; - f->p1 += r * sina; + return r * (double2) { cosa, sina }; } -static void var34_blur (flam3_iter_helper *f, double weight) { +static double2 var34_blur (flam3_iter_helper *f, double weight) { /* blur (03/06) */ double tmpr, sinr, cosr, r; @@ -758,11 +729,10 @@ static void var34_blur (flam3_iter_helper *f, double weight) { r = weight * flam3_random_isaac_01(f->rc); - f->p0 += r * cosr; - f->p1 += r * sinr; + return r * (double2) { cosr, sinr }; } -static void var35_gaussian (flam3_iter_helper *f, double weight) { +static double2 var35_gaussian (flam3_iter_helper *f, double weight) { /* gaussian (09/06) */ double ang, r, sina, cosa; @@ -773,11 +743,10 @@ static void var35_gaussian (flam3_iter_helper *f, double weight) { r = weight * ( flam3_random_isaac_01(f->rc) + flam3_random_isaac_01(f->rc) + flam3_random_isaac_01(f->rc) + flam3_random_isaac_01(f->rc) - 2.0 ); - f->p0 += r * cosa; - f->p1 += r * sina; + return r * (double2) { cosa, sina }; } -static void var36_radial_blur (flam3_iter_helper *f, double weight) { +static double2 var36_radial_blur (flam3_iter_helper *f, double weight) { /* radial blur (09/06) */ /* removed random storage 6/07 */ @@ -793,11 +762,10 @@ static void var36_radial_blur (flam3_iter_helper *f, double weight) { sincos(tmpa,&sa,&ca); rz = f->xform->radialBlur_zoomvar * rndG - 1; - f->p0 += ra * ca + rz * f->tx; - f->p1 += ra * sa + rz * f->ty; + return ra * (double2) { ca, sa } + rz * f->t; } -static void var37_pie(flam3_iter_helper *f, double weight) { +static double2 var37_pie(flam3_iter_helper *f, double weight) { /* pie by Joel Faber (June 2006) */ double a, r, sa, ca; @@ -809,11 +777,10 @@ static void var37_pie(flam3_iter_helper *f, double weight) { r = weight * flam3_random_isaac_01(f->rc); sincos(a,&sa,&ca); - f->p0 += r * ca; - f->p1 += r * sa; + return r * (double2) { ca, sa }; } -static void var38_ngon(flam3_iter_helper *f, double weight) { +static double2 var38_ngon(flam3_iter_helper *f, double weight) { /* ngon by Joel Faber (09/06) */ double r_factor,theta,phi,b, amp; @@ -830,36 +797,30 @@ static void var38_ngon(flam3_iter_helper *f, double weight) { amp = f->xform->ngon_corners * (1.0 / (cos(phi) + EPS) - 1.0) + f->xform->ngon_circle; amp /= (r_factor + EPS); - f->p0 += weight * f->tx * amp; - f->p1 += weight * f->ty * amp; + return weight * f->t * amp; } -static void var39_curl(flam3_iter_helper *f, double weight) +static double2 var39_curl(flam3_iter_helper *f, double weight) { - double re = 1.0 + f->xform->curl_c1 * f->tx + f->xform->curl_c2 * (f->tx * f->tx - f->ty * f->ty); - double im = f->xform->curl_c1 * f->ty + 2.0 * f->xform->curl_c2 * f->tx * f->ty; + double re = 1.0 + f->xform->curl_c1 * f->t[0] + f->xform->curl_c2 * (f->t[0] * f->t[0] - f->t[1] * f->t[1]); + double im = f->xform->curl_c1 * f->t[1] + 2.0 * f->xform->curl_c2 * f->t[0] * f->t[1]; double r = weight / (re*re + im*im); - f->p0 += (f->tx * re + f->ty * im) * r; - f->p1 += (f->ty * re - f->tx * im) * r; + double2 tswap = (double2) { f->t[1], -f->t[0] }; + + return (f->t * re + tswap * im) * r; } -static void var40_rectangles(flam3_iter_helper *f, double weight) +static double2 var40_rectangles(flam3_iter_helper *f, double weight) { - if (f->xform->rectangles_x==0) - f->p0 += weight * f->tx; - else - f->p0 += weight * ((2 * floor(f->tx / f->xform->rectangles_x) + 1) * f->xform->rectangles_x - f->tx); - - if (f->xform->rectangles_y==0) - f->p1 += weight * f->ty; - else - f->p1 += weight * ((2 * floor(f->ty / f->xform->rectangles_y) + 1) * f->xform->rectangles_y - f->ty); - + return weight * (double2) { + f->xform->rectangles_x==0 ? f->t[0] : ((2 * floor(f->t[0] / f->xform->rectangles_x) + 1) * f->xform->rectangles_x - f->t[0]), + f->xform->rectangles_y==0 ? f->t[1] : ((2 * floor(f->t[1] / f->xform->rectangles_y) + 1) * f->xform->rectangles_y - f->t[1]), + }; } -static void var41_arch(flam3_iter_helper *f, double weight) +static double2 var41_arch(flam3_iter_helper *f, double weight) { /* Z+ variation Jan 07 procedure TXForm.Arch; @@ -882,12 +843,11 @@ static void var41_arch(flam3_iter_helper *f, double weight) double sinr,cosr; sincos(ang,&sinr,&cosr); - f->p0 += weight * sinr; - f->p1 += weight * (sinr*sinr)/cosr; + return weight * (double2) { sinr, (sinr*sinr)/cosr }; } -static void var42_tangent(flam3_iter_helper *f, double weight) +static double2 var42_tangent(flam3_iter_helper *f, double weight) { /* Z+ variation Jan 07 procedure TXForm.Tangent; @@ -897,12 +857,11 @@ static void var42_tangent(flam3_iter_helper *f, double weight) end; */ - f->p0 += weight * sin(f->tx)/cos(f->ty); - f->p1 += weight * tan(f->ty); + return weight * (double2) { sin(f->t[0])/cos(f->t[1]), tan(f->t[1]) }; } -static void var43_square(flam3_iter_helper *f, double weight) +static double2 var43_square(flam3_iter_helper *f, double weight) { /* Z+ variation Jan 07 procedure TXForm.SquareBlur; @@ -912,12 +871,14 @@ static void var43_square(flam3_iter_helper *f, double weight) end; */ - f->p0 += weight * (flam3_random_isaac_01(f->rc) - 0.5); - f->p1 += weight * (flam3_random_isaac_01(f->rc) - 0.5); + return weight * ((double2) { + flam3_random_isaac_01(f->rc), + flam3_random_isaac_01(f->rc), + } - 0.5); } -static void var44_rays(flam3_iter_helper *f, double weight) +static double2 var44_rays(flam3_iter_helper *f, double weight) { /* Z+ variation Jan 07 procedure TXForm.Rays; @@ -943,12 +904,11 @@ static void var44_rays(flam3_iter_helper *f, double weight) double tanr = weight * tan(ang) * r; - f->p0 += tanr * cos(f->tx); - f->p1 += tanr * sin(f->ty); + return tanr * (double2) { cos(f->t[0]), sin(f->t[1]) }; } -static void var45_blade(flam3_iter_helper *f, double weight) +static double2 var45_blade(flam3_iter_helper *f, double weight) { /* Z+ variation Jan 07 procedure TXForm.Blade; @@ -973,12 +933,11 @@ static void var45_blade(flam3_iter_helper *f, double weight) sincos(r,&sinr,&cosr); - f->p0 += weight * f->tx * (cosr + sinr); - f->p1 += weight * f->tx * (cosr - sinr); + return weight * f->t[0] * (cosr + (double2) { sinr, -sinr }); } -static void var46_secant2(flam3_iter_helper *f, double weight) +static double2 var46_secant2(flam3_iter_helper *f, double weight) { /* Intended as a 'fixed' version of secant */ @@ -992,15 +951,10 @@ static void var46_secant2(flam3_iter_helper *f, double weight) double cr = cos(r); double icr = 1.0/cr; - f->p0 += weight * f->tx; - - if (cr<0) - f->p1 += weight*(icr + 1); - else - f->p1 += weight*(icr - 1); + return weight * (double2) { f->t[0], cr<0 ? (icr + 1) : (icr - 1) }; } -static void var47_twintrian(flam3_iter_helper *f, double weight) +static double2 var47_twintrian(flam3_iter_helper *f, double weight) { /* Z+ variation Jan 07 procedure TXForm.TwinTrian; @@ -1030,12 +984,12 @@ static void var47_twintrian(flam3_iter_helper *f, double weight) if (badvalue(diff)) diff = -30.0; - f->p0 += weight * f->tx * diff; - f->p1 += weight * f->tx * (diff - sinr*M_PI); + + return weight * f->t[0] * (diff - (double2) { 0.0, sinr*M_PI }); } -static void var48_cross(flam3_iter_helper *f, double weight) +static double2 var48_cross(flam3_iter_helper *f, double weight) { /* Z+ variation Jan 07 procedure TXForm.Cross; @@ -1048,15 +1002,13 @@ static void var48_cross(flam3_iter_helper *f, double weight) end; */ - double s = f->tx*f->tx - f->ty*f->ty; + double s = f->t[0]*f->t[0] - f->t[1]*f->t[1]; double r = weight * sqrt(1.0 / (s*s+EPS)); - f->p0 += f->tx * r; - f->p1 += f->ty * r; - + return r * f->t; } -static void var49_disc2(flam3_iter_helper *f, double weight) +static double2 var49_disc2(flam3_iter_helper *f, double weight) { /* Z+ variation Jan 07 c := vvar/PI; @@ -1085,16 +1037,18 @@ static void var49_disc2(flam3_iter_helper *f, double weight) double r,t,sinr, cosr; - t = f->xform->disc2_timespi * (f->tx + f->ty); + t = f->xform->disc2_timespi * (f->t[0] + f->t[1]); sincos(t,&sinr,&cosr); r = weight * f->precalc_atan / M_PI; - f->p0 += (sinr + f->xform->disc2_cosadd) * r; - f->p1 += (cosr + f->xform->disc2_sinadd) * r; + return r * (double2) { + sinr + f->xform->disc2_cosadd, + cosr + f->xform->disc2_sinadd, + }; } -static void var50_supershape(flam3_iter_helper *f, double weight) { +static double2 var50_supershape(flam3_iter_helper *f, double weight) { double theta; double t1,t2,r; @@ -1116,11 +1070,10 @@ static void var50_supershape(flam3_iter_helper *f, double weight) { r = weight * ( (myrnd*flam3_random_isaac_01(f->rc) + (1.0-myrnd)*f->precalc_sqrt) - f->xform->super_shape_holes) * pow(t1+t2,f->xform->super_shape_pneg1_n1) / f->precalc_sqrt; - f->p0 += r * f->tx; - f->p1 += r * f->ty; + return r * f->t; } -static void var51_flower(flam3_iter_helper *f, double weight) { +static double2 var51_flower(flam3_iter_helper *f, double weight) { /* cyberxaos, 4/2007 */ /* theta := arctan2(FTy^, FTx^); r := (random-holes)*cos(petals*theta); @@ -1131,26 +1084,24 @@ static void var51_flower(flam3_iter_helper *f, double weight) { double r = weight * (flam3_random_isaac_01(f->rc) - f->xform->flower_holes) * cos(f->xform->flower_petals*theta) / f->precalc_sqrt; - f->p0 += r * f->tx; - f->p1 += r * f->ty; + return r * f->t; } -static void var52_conic(flam3_iter_helper *f, double weight) { +static double2 var52_conic(flam3_iter_helper *f, double weight) { /* cyberxaos, 4/2007 */ /* theta := arctan2(FTy^, FTx^); r := (random - holes)*((eccentricity)/(1+eccentricity*cos(theta))); FPx^ := FPx^ + vvar*r*cos(theta); FPy^ := FPy^ + vvar*r*sin(theta); */ - double ct = f->tx / f->precalc_sqrt; + double ct = f->t[0] / f->precalc_sqrt; double r = weight * (flam3_random_isaac_01(f->rc) - f->xform->conic_holes) * f->xform->conic_eccentricity / (1 + f->xform->conic_eccentricity*ct) / f->precalc_sqrt; - f->p0 += r * f->tx; - f->p1 += r * f->ty; + return r * f->t; } -static void var53_parabola(flam3_iter_helper *f, double weight) { +static double2 var53_parabola(flam3_iter_helper *f, double weight) { /* cyberxaos, 4/2007 */ /* r := sqrt(sqr(FTx^) + sqr(FTy^)); FPx^ := FPx^ + parabola_height*vvar*sin(r)*sin(r)*random; @@ -1161,139 +1112,121 @@ static void var53_parabola(flam3_iter_helper *f, double weight) { sincos(r,&sr,&cr); - f->p0 += f->xform->parabola_height * weight * sr*sr * flam3_random_isaac_01(f->rc); - f->p1 += f->xform->parabola_width * weight * cr * flam3_random_isaac_01(f->rc); + return weight * (double2) { + f->xform->parabola_height * sr*sr * flam3_random_isaac_01(f->rc), + f->xform->parabola_width * cr * flam3_random_isaac_01(f->rc), + }; } -static void var54_bent2 (flam3_iter_helper *f, double weight) { +static double2 var54_bent2 (flam3_iter_helper *f, double weight) { /* Bent2 in the Apophysis Plugin Pack */ - double nx = f->tx; - double ny = f->ty; - - if (nx < 0.0) - nx = nx * f->xform->bent2_x; - if (ny < 0.0) - ny = ny * f->xform->bent2_y; - - f->p0 += weight * nx; - f->p1 += weight * ny; + return weight * f->t * (double2) { + f->t[0] < 0.0 ? f->xform->bent2_x : 1.0, + f->t[1] < 0.0 ? f->xform->bent2_y : 1.0, + }; } -static void var55_bipolar (flam3_iter_helper *f, double weight) { +static double2 var55_bipolar (flam3_iter_helper *f, double weight) { /* Bipolar in the Apophysis Plugin Pack */ double x2y2 = f->precalc_sumsq; double t = x2y2+1; - double x2 = 2*f->tx; + double x2 = 2*f->t[0]; double ps = -M_PI_2 * f->xform->bipolar_shift; - double y = 0.5 * atan2(2.0 * f->ty, x2y2 - 1.0) + ps; + double y = 0.5 * atan2(2.0 * f->t[1], x2y2 - 1.0) + ps; if (y > M_PI_2) y = -M_PI_2 + fmod(y + M_PI_2, M_PI); else if (y < -M_PI_2) y = M_PI_2 - fmod(M_PI_2 - y, M_PI); - f->p0 += weight * 0.25 * M_2_PI * log ( (t+x2) / (t-x2) ); - f->p1 += weight * M_2_PI * y; + return weight * M_2_PI * (double2) { + 0.25 * log ( (t+x2) / (t-x2) ), + y, + }; } -static void var56_boarders (flam3_iter_helper *f, double weight) { +static double2 var56_boarders (flam3_iter_helper *f, double weight) { /* Boarders in the Apophysis Plugin Pack */ - double roundX, roundY, offsetX, offsetY; - - roundX = rint(f->tx); - roundY = rint(f->ty); - offsetX = f->tx - roundX; - offsetY = f->ty - roundY; + double2 round = (double2) { rint(f->t[0]), rint(f->t[1]) }; + double2 offset = f->t - round; if (flam3_random_isaac_01(f->rc) >= 0.75) { - f->p0 += weight*(offsetX*0.5 + roundX); - f->p1 += weight*(offsetY*0.5 + roundY); + return weight*(offset*0.5 + round); } else { - if (fabs(offsetX) >= fabs(offsetY)) { + if (fabs(offset[0]) >= fabs(offset[1])) { - if (offsetX >= 0.0) { - f->p0 += weight*(offsetX*0.5 + roundX + 0.25); - f->p1 += weight*(offsetY*0.5 + roundY + 0.25 * offsetY / offsetX); + if (offset[0] >= 0.0) { + return weight*(offset*0.5 + round + 0.25 * (double2) { 1.0, offset[1] / offset[0] }); } else { - f->p0 += weight*(offsetX*0.5 + roundX - 0.25); - f->p1 += weight*(offsetY*0.5 + roundY - 0.25 * offsetY / offsetX); + return weight*(offset*0.5 + round - 0.25 * (double2) { 1.0, offset[1] / offset[0] }); } } else { - - if (offsetY >= 0.0) { - f->p1 += weight*(offsetY*0.5 + roundY + 0.25); - f->p0 += weight*(offsetX*0.5 + roundX + offsetX/offsetY*0.25); + if (offset[1] >= 0.0) { + return weight*(offset*0.5 + round + (double2) { offset[0]/offset[1]*0.25, 0.25 }); } else { - f->p1 += weight*(offsetY*0.5 + roundY - 0.25); - f->p0 += weight*(offsetX*0.5 + roundX - offsetX/offsetY*0.25); + return weight*(offset*0.5 + round - (double2) { offset[0]/offset[1]*0.25, 0.25 }); } } } } -static void var57_butterfly (flam3_iter_helper *f, double weight) { +static double2 var57_butterfly (flam3_iter_helper *f, double weight) { /* Butterfly in the Apophysis Plugin Pack */ /* wx is weight*4/sqrt(3*pi) */ double wx = weight*1.3029400317411197908970256609023; - double y2 = f->ty*2.0; - double r = wx*sqrt(fabs(f->ty * f->tx)/(EPS + f->tx*f->tx + y2*y2)); + double y2 = f->t[1]*2.0; + double r = wx*sqrt(fabs(f->t[1] * f->t[0])/(EPS + f->t[0]*f->t[0] + y2*y2)); - f->p0 += r * f->tx; - f->p1 += r * y2; + return r * (double2) { f->t[0], y2 }; } -static void var58_cell (flam3_iter_helper *f, double weight) { +static double2 var58_cell (flam3_iter_helper *f, double weight) { /* Cell in the Apophysis Plugin Pack */ double inv_cell_size = 1.0/f->xform->cell_size; /* calculate input cell */ - int x = floor(f->tx*inv_cell_size); - int y = floor(f->ty*inv_cell_size); + double2 b = (double2) { + floor(f->t[0]*inv_cell_size), + floor(f->t[1]*inv_cell_size), + }; /* Offset from cell origin */ - double dx = f->tx - x*f->xform->cell_size; - double dy = f->ty - y*f->xform->cell_size; + double2 a = f->t - b*f->xform->cell_size; /* interleave cells */ - if (y >= 0) { - if (x >= 0) { - y *= 2; - x *= 2; + if (b[1] >= 0.0) { + if (b[0] >= 0.0) { + b *= 2.0; } else { - y *= 2; - x = -(2*x+1); + b = (double2) { -1.0, 1.0 } * (b*2.0 + (double2) { 1.0, 0.0 }); } } else { - if (x >= 0) { - y = -(2*y+1); - x *= 2; + if (b[0] >= 0.0) { + b = (double2) { 1.0, -1.0 } * (b*2.0 + (double2) { 0.0, 1.0 }); } else { - y = -(2*y+1); - x = -(2*x+1); + b = -(2.0*b+1.0); } } - f->p0 += weight * (dx + x*f->xform->cell_size); - f->p1 -= weight * (dy + y*f->xform->cell_size); - + return weight * (a + b*f->xform->cell_size); } -static void var59_cpow (flam3_iter_helper *f, double weight) { +static double2 var59_cpow (flam3_iter_helper *f, double weight) { /* Cpow in the Apophysis Plugin Pack */ @@ -1309,12 +1242,11 @@ static void var59_cpow (flam3_iter_helper *f, double weight) { sincos(ang,&sa,&ca); - f->p0 += m * ca; - f->p1 += m * sa; + return m * (double2) { ca, sa }; } -static void var60_curve (flam3_iter_helper *f, double weight) { +static double2 var60_curve (flam3_iter_helper *f, double weight) { /* Curve in the Apophysis Plugin Pack */ @@ -1325,22 +1257,24 @@ static void var60_curve (flam3_iter_helper *f, double weight) { if (pc_ylen<1E-20) pc_ylen = 1E-20; - f->p0 += weight * (f->tx + f->xform->curve_xamp * exp(-f->ty*f->ty/pc_xlen)); - f->p1 += weight * (f->ty + f->xform->curve_yamp * exp(-f->tx*f->tx/pc_ylen)); + return weight * f->t + (double2) { + f->xform->curve_xamp * exp(-f->t[1]*f->t[1]/pc_xlen), + f->xform->curve_yamp * exp(-f->t[0]*f->t[0]/pc_ylen), + }; } -static void var61_edisc (flam3_iter_helper *f, double weight) { +static double2 var61_edisc (flam3_iter_helper *f, double weight) { /* Edisc in the Apophysis Plugin Pack */ double tmp = f->precalc_sumsq + 1.0; - double tmp2 = 2.0 * f->tx; + double tmp2 = 2.0 * f->t[0]; double r1 = sqrt(tmp+tmp2); double r2 = sqrt(tmp-tmp2); double xmax = (r1+r2) * 0.5; double a1 = log(xmax + sqrt(xmax - 1.0)); - double a2 = -acos(f->tx/xmax); + double a2 = -acos(f->t[0]/xmax); double w = weight / 11.57034632; double snv,csv,snhu,cshu; @@ -1349,21 +1283,20 @@ static void var61_edisc (flam3_iter_helper *f, double weight) { snhu = sinh(a2); cshu = cosh(a2); - if (f->ty > 0.0) snv = -snv; + if (f->t[1] > 0.0) snv = -snv; - f->p0 += w * cshu * csv; - f->p1 += w * snhu * snv; + return w * (double2) { cshu * csv, snhu * snv }; } -static void var62_elliptic (flam3_iter_helper *f, double weight) { +static double2 var62_elliptic (flam3_iter_helper *f, double weight) { /* Elliptic in the Apophysis Plugin Pack */ double tmp = f->precalc_sumsq + 1.0; - double x2 = 2.0 * f->tx; + double x2 = 2.0 * f->t[0]; double xmax = 0.5 * (sqrt(tmp+x2) + sqrt(tmp-x2)); - double a = f->tx / xmax; + double a = f->t[0] / xmax; double b = 1.0 - a*a; double ssx = xmax - 1.0; double w = weight / M_PI_2; @@ -1378,16 +1311,14 @@ static void var62_elliptic (flam3_iter_helper *f, double weight) { else ssx = sqrt(ssx); - f->p0 += w * atan2(a,b); + return w * (double2) { + atan2(a,b), + (f->t[1] > 0.0 ? 1.0 : -1.0) * log(xmax + ssx), + }; - if (f->ty > 0) - f->p1 += w * log(xmax + ssx); - else - f->p1 -= w * log(xmax + ssx); - } -static void var63_escher (flam3_iter_helper *f, double weight) { +static double2 var63_escher (flam3_iter_helper *f, double weight) { /* Escher in the Apophysis Plugin Pack */ @@ -1409,56 +1340,57 @@ static void var63_escher (flam3_iter_helper *f, double weight) { sincos(n,&sn,&cn); - f->p0 += m * cn; - f->p1 += m * sn; - + return m * (double2) { cn, sn }; + } -static void var64_foci (flam3_iter_helper *f, double weight) { +static double2 var64_foci (flam3_iter_helper *f, double weight) { /* Foci in the Apophysis Plugin Pack */ - double expx = exp(f->tx) * 0.5; + double expx = exp(f->t[0]) * 0.5; double expnx = 0.25 / expx; double sn,cn,tmp; - sincos(f->ty,&sn,&cn); + sincos(f->t[1],&sn,&cn); tmp = weight/(expx + expnx - cn); - f->p0 += tmp * (expx - expnx); - f->p1 += tmp * sn; + return tmp * (double2) { expx - expnx, sn }; } -static void var65_lazysusan (flam3_iter_helper *f, double weight) { +static double2 var65_lazysusan (flam3_iter_helper *f, double weight) { /* Lazysusan in the Apophysis Plugin Pack */ - double x = f->tx - f->xform->lazysusan_x; - double y = f->ty + f->xform->lazysusan_y; - double r = sqrt(x*x + y*y); + double2 b = f->t + (double2) { -f->xform->lazysusan_x, f->xform->lazysusan_y }; + double r = sqrt(b[0]*b[0] + b[1]*b[1]); double sina, cosa; if (r<weight) { - double a = atan2(y,x) + f->xform->lazysusan_spin + + double a = atan2(b[1],b[0]) + f->xform->lazysusan_spin + f->xform->lazysusan_twist*(weight-r); sincos(a,&sina,&cosa); r = weight * r; - f->p0 += r*cosa + f->xform->lazysusan_x; - f->p1 += r*sina - f->xform->lazysusan_y; + return r * (double2) { cosa, sina } + (double2) { + f->xform->lazysusan_x, + -f->xform->lazysusan_y, + }; } else { r = weight * (1.0 + f->xform->lazysusan_space / r); - f->p0 += r*x + f->xform->lazysusan_x; - f->p1 += r*y - f->xform->lazysusan_y; + return r * b + (double2) { + f->xform->lazysusan_x, + -f->xform->lazysusan_y, + }; } } -static void var66_loonie (flam3_iter_helper *f, double weight) { +static double2 var66_loonie (flam3_iter_helper *f, double weight) { /* Loonie in the Apophysis Plugin Pack */ @@ -1473,16 +1405,14 @@ static void var66_loonie (flam3_iter_helper *f, double weight) { if (r2 < w2) { double r = weight * sqrt(w2/r2 - 1.0); - f->p0 += r * f->tx; - f->p1 += r * f->ty; + return r * f->t; } else { - f->p0 += weight * f->tx; - f->p1 += weight * f->ty; + return weight * f->t; } } -static void var67_pre_blur (flam3_iter_helper *f, double weight) { +static double2 var67_pre_blur (flam3_iter_helper *f, double weight) { /* pre-xform: PreBlur (Apo 2.08) */ @@ -1495,35 +1425,36 @@ static void var67_pre_blur (flam3_iter_helper *f, double weight) { sincos(rndA,&sinA,&cosA); /* Note: original coordinate changed */ - f->tx += rndG * cosA; - f->ty += rndG * sinA; - + return rndG * (double2) { cosA, sinA }; + } -static void var68_modulus (flam3_iter_helper *f, double weight) { +static double2 var68_modulus (flam3_iter_helper *f, double weight) { /* Modulus in the Apophysis Plugin Pack */ double xr = 2*f->xform->modulus_x; double yr = 2*f->xform->modulus_y; + double a, b; - if (f->tx > f->xform->modulus_x) - f->p0 += weight * (-f->xform->modulus_x + fmod(f->tx + f->xform->modulus_x, xr)); - else if (f->tx < -f->xform->modulus_x) - f->p0 += weight * ( f->xform->modulus_x - fmod(f->xform->modulus_x - f->tx, xr)); + if (f->t[0] > f->xform->modulus_x) + a = (-f->xform->modulus_x + fmod(f->t[0] + f->xform->modulus_x, xr)); + else if (f->t[0] < -f->xform->modulus_x) + a = ( f->xform->modulus_x - fmod(f->xform->modulus_x - f->t[0], xr)); else - f->p0 += weight * f->tx; + a = f->t[0]; - if (f->ty > f->xform->modulus_y) - f->p1 += weight * (-f->xform->modulus_y + fmod(f->ty + f->xform->modulus_y, yr)); - else if (f->ty < -f->xform->modulus_y) - f->p1 += weight * ( f->xform->modulus_y - fmod(f->xform->modulus_y - f->ty, yr)); + if (f->t[1] > f->xform->modulus_y) + b = (-f->xform->modulus_y + fmod(f->t[1] + f->xform->modulus_y, yr)); + else if (f->t[1] < -f->xform->modulus_y) + b = ( f->xform->modulus_y - fmod(f->xform->modulus_y - f->t[1], yr)); else - f->p1 += weight * f->ty; + b = f->t[1]; + return weight * (double2) { a, b }; } -static void var69_oscope (flam3_iter_helper *f, double weight) { +static double2 var69_oscope (flam3_iter_helper *f, double weight) { /* oscilloscope from the apophysis plugin pack */ @@ -1531,41 +1462,36 @@ static void var69_oscope (flam3_iter_helper *f, double weight) { double t; if (f->xform->oscope_damping == 0.0) - t = f->xform->oscope_amplitude * cos(tpf*f->tx) + f->xform->oscope_separation; + t = f->xform->oscope_amplitude * cos(tpf*f->t[0]) + f->xform->oscope_separation; else { - t = f->xform->oscope_amplitude * exp(-fabs(f->tx)*f->xform->oscope_damping) - * cos(tpf*f->tx) + f->xform->oscope_separation; + t = f->xform->oscope_amplitude * exp(-fabs(f->t[0])*f->xform->oscope_damping) + * cos(tpf*f->t[0]) + f->xform->oscope_separation; } - if (fabs(f->ty) <= t) { - f->p0 += weight*f->tx; - f->p1 -= weight*f->ty; - } else { - f->p0 += weight*f->tx; - f->p1 += weight*f->ty; - } + return (double2) { 1.0, fabs(f->t[1]) <= t ? -1.0 : 1.0 } * weight * f->t; } -static void var70_polar2 (flam3_iter_helper *f, double weight) { +static double2 var70_polar2 (flam3_iter_helper *f, double weight) { /* polar2 from the apophysis plugin pack */ double p2v = weight / M_PI; - f->p0 += p2v * f->precalc_atan; - f->p1 += p2v/2.0 * log(f->precalc_sumsq); + return (double2) { p2v * f->precalc_atan, p2v/2.0 * log(f->precalc_sumsq) }; } -static void var71_popcorn2 (flam3_iter_helper *f, double weight) { +static double2 var71_popcorn2 (flam3_iter_helper *f, double weight) { /* popcorn2 from the apophysis plugin pack */ - f->p0 += weight * ( f->tx + f->xform->popcorn2_x * sin(tan(f->ty*f->xform->popcorn2_c))); - f->p1 += weight * ( f->ty + f->xform->popcorn2_y * sin(tan(f->tx*f->xform->popcorn2_c))); + return weight * (f->t + (double2) { + f->xform->popcorn2_x * sin(tan(f->t[1]*f->xform->popcorn2_c)), + f->xform->popcorn2_y * sin(tan(f->t[0]*f->xform->popcorn2_c)), + }); } -static void var72_scry (flam3_iter_helper *f, double weight) { +static double2 var72_scry (flam3_iter_helper *f, double weight) { /* scry from the apophysis plugin pack */ /* note that scry does not multiply by weight, but as the */ @@ -1581,77 +1507,74 @@ static void var72_scry (flam3_iter_helper *f, double weight) { double t = f->precalc_sumsq; double r = 1.0 / (f->precalc_sqrt * (t + 1.0/(weight+EPS))); - f->p0 += f->tx * r; - f->p1 += f->ty * r; + return r * f->t; } -static void var73_separation (flam3_iter_helper *f, double weight) { +static double2 var73_separation (flam3_iter_helper *f, double weight) { /* separation from the apophysis plugin pack */ - double sx2 = f->xform->separation_x * f->xform->separation_x; - double sy2 = f->xform->separation_y * f->xform->separation_y; - - if (f->tx > 0.0) - f->p0 += weight * (sqrt(f->tx*f->tx + sx2)- f->tx*f->xform->separation_xinside); - else - f->p0 -= weight * (sqrt(f->tx*f->tx + sx2)+ f->tx*f->xform->separation_xinside); - - if (f->ty > 0.0) - f->p1 += weight * (sqrt(f->ty*f->ty + sy2)- f->ty*f->xform->separation_yinside); - else - f->p1 -= weight * (sqrt(f->ty*f->ty + sy2)+ f->ty*f->xform->separation_yinside); + const double sx2 = f->xform->separation_x * f->xform->separation_x; + const double sy2 = f->xform->separation_y * f->xform->separation_y; + const double2 a = (double2) { + sqrt(f->t[0]*f->t[0] + sx2), + sqrt(f->t[1]*f->t[1] + sy2), + }; + const double2 b = (double2) { + f->t[0]*f->xform->separation_xinside, + f->t[1]*f->xform->separation_yinside, + }; + const double2 sign = (double2) { + f->t[0] > 0.0 ? 1.0 : -1.0, + f->t[1] > 0.0 ? 1.0 : -1.0, + }; + const double2 bsign = (double2) { + f->t[0] > 0.0 ? -1.0 : 1.0, + f->t[1] > 0.0 ? -1.0 : 1.0, + }; + + return sign * (weight * (a + bsign * b)); } -static void var74_split (flam3_iter_helper *f, double weight) { +static double2 var74_split (flam3_iter_helper *f, double weight) { /* Split from apo plugins pack */ - if (cos(f->tx*f->xform->split_xsize*M_PI) >= 0) - f->p1 += weight*f->ty; - else - f->p1 -= weight*f->ty; - - if (cos(f->ty*f->xform->split_ysize*M_PI) >= 0) - f->p0 += weight * f->tx; - else - f->p0 -= weight * f->tx; - + return weight * (double2) { + cos(f->t[1]*f->xform->split_ysize*M_PI) >= 0 ? 1.0 : -1.0, + cos(f->t[0]*f->xform->split_xsize*M_PI) >= 0 ? 1.0 : -1.0, + } * f->t; } -static void var75_splits (flam3_iter_helper *f, double weight) { +static double2 var75_splits (flam3_iter_helper *f, double weight) { /* Splits from apo plugins pack */ - if (f->tx >= 0) - f->p0 += weight*(f->tx+f->xform->splits_x); - else - f->p0 += weight*(f->tx-f->xform->splits_x); - - if (f->ty >= 0) - f->p1 += weight*(f->ty+f->xform->splits_y); - else - f->p1 += weight*(f->ty-f->xform->splits_y); - + return weight * (f->t + (double2) { + f->t[0] >= 0 ? f->xform->splits_x : -f->xform->splits_x, + f->t[1] >= 0 ? f->xform->splits_y : -f->xform->splits_y, + }); } -static void var76_stripes (flam3_iter_helper *f, double weight) { +static double2 var76_stripes (flam3_iter_helper *f, double weight) { /* Stripes from apo plugins pack */ double roundx,offsetx; - roundx = floor(f->tx + 0.5); - offsetx = f->tx - roundx; + roundx = floor(f->t[0] + 0.5); + offsetx = f->t[0] - roundx; - f->p0 += weight * (offsetx*(1.0-f->xform->stripes_space)+roundx); - f->p1 += weight * (f->ty + offsetx*offsetx*f->xform->stripes_warp); + return weight * (double2) { + offsetx*(1.0-f->xform->stripes_space)+roundx, + f->t[1] + offsetx*offsetx*f->xform->stripes_warp, + }; } -static void var77_wedge (flam3_iter_helper *f, double weight) { +static double2 var77_wedge (flam3_iter_helper *f, double weight) { /* Wedge from apo plugins pack */ @@ -1668,12 +1591,11 @@ static void var77_wedge (flam3_iter_helper *f, double weight) { r = weight * (r + f->xform->wedge_hole); - f->p0 += r*ca; - f->p1 += r*sa; + return r * (double2) { ca, sa }; } -static void var78_wedge_julia (flam3_iter_helper *f, double weight) { +static double2 var78_wedge_julia (flam3_iter_helper *f, double weight) { /* wedge_julia from apo plugin pack */ @@ -1687,11 +1609,10 @@ static void var78_wedge_julia (flam3_iter_helper *f, double weight) { sincos(a,&sa,&ca); - f->p0 += r * ca; - f->p1 += r * sa; + return r * (double2) { ca, sa }; } -static void var79_wedge_sph (flam3_iter_helper *f, double weight) { +static double2 var79_wedge_sph (flam3_iter_helper *f, double weight) { /* Wedge_sph from apo plugins pack */ @@ -1707,12 +1628,11 @@ static void var79_wedge_sph (flam3_iter_helper *f, double weight) { sincos(a,&sa,&ca); r = weight * (r + f->xform->wedge_sph_hole); - f->p0 += r*ca; - f->p1 += r*sa; + return r * (double2) { ca, sa }; } -static void var80_whorl (flam3_iter_helper *f, double weight) { +static double2 var80_whorl (flam3_iter_helper *f, double weight) { /* whorl from apo plugins pack */ @@ -1732,216 +1652,200 @@ static void var80_whorl (flam3_iter_helper *f, double weight) { sincos(a,&sa,&ca); - f->p0 += weight*r*ca; - f->p1 += weight*r*sa; + return weight * r * (double2) { ca, sa }; } -static void var81_waves2 (flam3_iter_helper *f, double weight) { +static double2 var81_waves2 (flam3_iter_helper *f, double weight) { /* waves2 from Joel F */ - f->p0 += weight*(f->tx + f->xform->waves2_scalex*sin(f->ty * f->xform->waves2_freqx)); - f->p1 += weight*(f->ty + f->xform->waves2_scaley*sin(f->tx * f->xform->waves2_freqy)); + return weight * (f->t + (double2) { + f->xform->waves2_scalex*sin(f->t[1] * f->xform->waves2_freqx), + f->xform->waves2_scaley*sin(f->t[0] * f->xform->waves2_freqy), + }); } /* complex vars by cothe */ /* exp log sin cos tan sec csc cot sinh cosh tanh sech csch coth */ -static void var82_exp (flam3_iter_helper *f, double weight) { +static double2 var82_exp (flam3_iter_helper *f, double weight) { //Exponential EXP - double expe = exp(f->tx); + double expe = exp(f->t[0]); double expcos,expsin; - sincos(f->ty,&expsin,&expcos); - f->p0 += weight * expe * expcos; - f->p1 += weight * expe * expsin; + sincos(f->t[1],&expsin,&expcos); + return weight * expe * (double2) { expcos, expsin }; } -static void var83_log (flam3_iter_helper *f, double weight) { +static double2 var83_log (flam3_iter_helper *f, double weight) { //Natural Logarithm LOG // needs precalc_atanyx and precalc_sumsq - f->p0 += weight * 0.5 * log(f->precalc_sumsq); - f->p1 += weight * f->precalc_atanyx; + return weight * (double2) { 0.5 * log(f->precalc_sumsq), f->precalc_atanyx }; } -static void var84_sin (flam3_iter_helper *f, double weight) { +static double2 var84_sin (flam3_iter_helper *f, double weight) { //Sine SIN double sinsin,sinacos,sinsinh,sincosh; - sincos(f->tx,&sinsin,&sinacos); - sinsinh = sinh(f->ty); - sincosh = cosh(f->ty); - f->p0 += weight * sinsin * sincosh; - f->p1 += weight * sinacos * sinsinh; + sincos(f->t[0],&sinsin,&sinacos); + sinsinh = sinh(f->t[1]); + sincosh = cosh(f->t[1]); + return weight * (double2) { sinsin * sincosh, sinacos * sinsinh }; } -static void var85_cos (flam3_iter_helper *f, double weight) { +static double2 var85_cos (flam3_iter_helper *f, double weight) { //Cosine COS double cossin,coscos,cossinh,coscosh; - sincos(f->tx,&cossin,&coscos); - cossinh = sinh(f->ty); - coscosh = cosh(f->ty); - f->p0 += weight * coscos * coscosh; - f->p1 -= weight * cossin * cossinh; + sincos(f->t[0],&cossin,&coscos); + cossinh = sinh(f->t[1]); + coscosh = cosh(f->t[1]); + return weight * (double2) { coscos * coscosh, cossin * cossinh }; } -static void var86_tan (flam3_iter_helper *f, double weight) { +static double2 var86_tan (flam3_iter_helper *f, double weight) { //Tangent TAN double tansin,tancos,tansinh,tancosh; double tanden; - sincos(2*f->tx,&tansin,&tancos); - tansinh = sinh(2.0*f->ty); - tancosh = cosh(2.0*f->ty); + sincos(2*f->t[0],&tansin,&tancos); + tansinh = sinh(2.0*f->t[1]); + tancosh = cosh(2.0*f->t[1]); tanden = 1.0/(tancos + tancosh); - f->p0 += weight * tanden * tansin; - f->p1 += weight * tanden * tansinh; + return weight * tanden * (double2) { tansin, tansinh }; } -static void var87_sec (flam3_iter_helper *f, double weight) { +static double2 var87_sec (flam3_iter_helper *f, double weight) { //Secant SEC double secsin,seccos,secsinh,seccosh; double secden; - sincos(f->tx,&secsin,&seccos); - secsinh = sinh(f->ty); - seccosh = cosh(f->ty); - secden = 2.0/(cos(2*f->tx) + cosh(2*f->ty)); - f->p0 += weight * secden * seccos * seccosh; - f->p1 += weight * secden * secsin * secsinh; + sincos(f->t[0],&secsin,&seccos); + secsinh = sinh(f->t[1]); + seccosh = cosh(f->t[1]); + secden = 2.0/(cos(2*f->t[0]) + cosh(2*f->t[1])); + return weight * secden * (double2) { seccos * seccosh, secsin * secsinh }; } -static void var88_csc (flam3_iter_helper *f, double weight) { +static double2 var88_csc (flam3_iter_helper *f, double weight) { //Cosecant CSC double cscsin,csccos,cscsinh,csccosh; double cscden; - sincos(f->tx,&cscsin,&csccos); - cscsinh = sinh(f->ty); - csccosh = cosh(f->ty); - cscden = 2.0/(cosh(2.0*f->ty) - cos(2.0*f->tx)); - f->p0 += weight * cscden * cscsin * csccosh; - f->p1 -= weight * cscden * csccos * cscsinh; + sincos(f->t[0],&cscsin,&csccos); + cscsinh = sinh(f->t[1]); + csccosh = cosh(f->t[1]); + cscden = 2.0/(cosh(2.0*f->t[1]) - cos(2.0*f->t[0])); + return weight * cscden * (double2) { cscsin * csccosh, csccos * cscsinh }; } -static void var89_cot (flam3_iter_helper *f, double weight) { +static double2 var89_cot (flam3_iter_helper *f, double weight) { //Cotangent COT double cotsin,cotcos,cotsinh,cotcosh; double cotden; - sincos(2.0*f->tx,&cotsin,&cotcos); - cotsinh = sinh(2.0*f->ty); - cotcosh = cosh(2.0*f->ty); + sincos(2.0*f->t[0],&cotsin,&cotcos); + cotsinh = sinh(2.0*f->t[1]); + cotcosh = cosh(2.0*f->t[1]); cotden = 1.0/(cotcosh - cotcos); - f->p0 += weight * cotden * cotsin; - f->p1 += weight * cotden * -1 * cotsinh; + return weight * cotden * (double2) { cotsin, -1.0 * cotsinh }; } -static void var90_sinh (flam3_iter_helper *f, double weight) { +static double2 var90_sinh (flam3_iter_helper *f, double weight) { //Hyperbolic Sine SINH double sinhsin,sinhcos,sinhsinh,sinhcosh; - sincos(f->ty,&sinhsin,&sinhcos); - sinhsinh = sinh(f->tx); - sinhcosh = cosh(f->tx); - f->p0 += weight * sinhsinh * sinhcos; - f->p1 += weight * sinhcosh * sinhsin; + sincos(f->t[1],&sinhsin,&sinhcos); + sinhsinh = sinh(f->t[0]); + sinhcosh = cosh(f->t[0]); + return weight * (double2) { sinhsinh * sinhcos, sinhcosh * sinhsin }; } -static void var91_cosh (flam3_iter_helper *f, double weight) { +static double2 var91_cosh (flam3_iter_helper *f, double weight) { //Hyperbolic Cosine COSH double coshsin,coshcos,coshsinh,coshcosh; - sincos(f->ty,&coshsin,&coshcos); - coshsinh = sinh(f->tx); - coshcosh = cosh(f->tx); - f->p0 += weight * coshcosh * coshcos; - f->p1 += weight * coshsinh * coshsin; + sincos(f->t[1],&coshsin,&coshcos); + coshsinh = sinh(f->t[0]); + coshcosh = cosh(f->t[0]); + return weight * (double2) { coshcosh * coshcos, coshsinh * coshsin }; } -static void var92_tanh (flam3_iter_helper *f, double weight) { +static double2 var92_tanh (flam3_iter_helper *f, double weight) { //Hyperbolic Tangent TANH double tanhsin,tanhcos,tanhsinh,tanhcosh; double tanhden; - sincos(2.0*f->ty,&tanhsin,&tanhcos); - tanhsinh = sinh(2.0*f->tx); - tanhcosh = cosh(2.0*f->tx); + sincos(2.0*f->t[1],&tanhsin,&tanhcos); + tanhsinh = sinh(2.0*f->t[0]); + tanhcosh = cosh(2.0*f->t[0]); tanhden = 1.0/(tanhcos + tanhcosh); - f->p0 += weight * tanhden * tanhsinh; - f->p1 += weight * tanhden * tanhsin; + return weight * tanhden * (double2) { tanhsinh, tanhsin }; } -static void var93_sech (flam3_iter_helper *f, double weight) { +static double2 var93_sech (flam3_iter_helper *f, double weight) { //Hyperbolic Secant SECH double sechsin,sechcos,sechsinh,sechcosh; double sechden; - sincos(f->ty,&sechsin,&sechcos); - sechsinh = sinh(f->tx); - sechcosh = cosh(f->tx); - sechden = 2.0/(cos(2.0*f->ty) + cosh(2.0*f->tx)); - f->p0 += weight * sechden * sechcos * sechcosh; - f->p1 -= weight * sechden * sechsin * sechsinh; + sincos(f->t[1],&sechsin,&sechcos); + sechsinh = sinh(f->t[0]); + sechcosh = cosh(f->t[0]); + sechden = 2.0/(cos(2.0*f->t[1]) + cosh(2.0*f->t[0])); + return weight * sechden * (double2) { sechcos * sechcosh, sechsin * sechsinh }; } -static void var94_csch (flam3_iter_helper *f, double weight) { +static double2 var94_csch (flam3_iter_helper *f, double weight) { //Hyperbolic Cosecant CSCH double cschsin,cschcos,cschsinh,cschcosh; double cschden; - sincos(f->ty,&cschsin,&cschcos); - cschsinh = sinh(f->tx); - cschcosh = cosh(f->tx); - cschden = 2.0/(cosh(2.0*f->tx) - cos(2.0*f->ty)); - f->p0 += weight * cschden * cschsinh * cschcos; - f->p1 -= weight * cschden * cschcosh * cschsin; + sincos(f->t[1],&cschsin,&cschcos); + cschsinh = sinh(f->t[0]); + cschcosh = cosh(f->t[0]); + cschden = 2.0/(cosh(2.0*f->t[0]) - cos(2.0*f->t[1])); + return weight * cschden * (double2) { cschsinh * cschcos, cschcosh * cschsin }; } -static void var95_coth (flam3_iter_helper *f, double weight) { +static double2 var95_coth (flam3_iter_helper *f, double weight) { //Hyperbolic Cotangent COTH double cothsin,cothcos,cothsinh,cothcosh; double cothden; - sincos(2.0*f->ty,&cothsin,&cothcos); - cothsinh = sinh(2.0*f->tx); - cothcosh = cosh(2.0*f->tx); + sincos(2.0*f->t[1],&cothsin,&cothcos); + cothsinh = sinh(2.0*f->t[0]); + cothcosh = cosh(2.0*f->t[0]); cothden = 1.0/(cothcosh - cothcos); - f->p0 += weight * cothden * cothsinh; - f->p1 += weight * cothden * cothsin; + return weight * cothden * (double2) { cothsinh, cothsin }; } -static void var96_auger (flam3_iter_helper *f, double weight) { +static double2 var96_auger (flam3_iter_helper *f, double weight) { // Auger, by Xyrus01 - double s = sin(f->xform->auger_freq * f->tx); - double t = sin(f->xform->auger_freq * f->ty); - double dy = f->ty + f->xform->auger_weight*(f->xform->auger_scale*s/2.0 + fabs(f->ty)*s); - double dx = f->tx + f->xform->auger_weight*(f->xform->auger_scale*t/2.0 + fabs(f->tx)*t); + double s = sin(f->xform->auger_freq * f->t[0]); + double t = sin(f->xform->auger_freq * f->t[1]); + double dy = f->t[1] + f->xform->auger_weight*(f->xform->auger_scale*s/2.0 + fabs(f->t[1])*s); + double dx = f->t[0] + f->xform->auger_weight*(f->xform->auger_scale*t/2.0 + fabs(f->t[0])*t); - f->p0 += weight * (f->tx + f->xform->auger_sym*(dx-f->tx)); - f->p1 += weight * dy; + return weight * (double2) { f->t[0] + f->xform->auger_sym*(dx-f->t[0]), dy }; } -static void var97_flux (flam3_iter_helper *f, double weight) { +static double2 var97_flux (flam3_iter_helper *f, double weight) { // Flux, by meckie - double xpw = f->tx + weight; - double xmw = f->tx - weight; - double avgr = weight * (2 + f->xform->flux_spread) * sqrt( sqrt(f->ty*f->ty + xpw*xpw) / sqrt(f->ty*f->ty + xmw*xmw)); - double avga = ( atan2(f->ty, xmw) - atan2(f->ty,xpw) ) * 0.5; + double xpw = f->t[0] + weight; + double xmw = f->t[0] - weight; + double avgr = weight * (2 + f->xform->flux_spread) * sqrt( sqrt(f->t[1]*f->t[1] + xpw*xpw) / sqrt(f->t[1]*f->t[1] + xmw*xmw)); + double avga = ( atan2(f->t[1], xmw) - atan2(f->t[1],xpw) ) * 0.5; double s = sin(avga); double c = cos(avga); - f->p0 += avgr * cos(avga); - f->p1 += avgr * sin(avga); + return avgr * (double2) { cos(avga), sin(avga) }; } -static void var98_mobius (flam3_iter_helper *f, double weight) { +static double2 var98_mobius (flam3_iter_helper *f, double weight) { // Mobius, by eralex double re_u, im_u, re_v, im_v, rad_v; - re_u = f->xform->mobius_re_a * f->tx - f->xform->mobius_im_a * f->ty + f->xform->mobius_re_b; - im_u = f->xform->mobius_re_a * f->ty + f->xform->mobius_im_a * f->tx + f->xform->mobius_im_b; - re_v = f->xform->mobius_re_c * f->tx - f->xform->mobius_im_c * f->ty + f->xform->mobius_re_d; - im_v = f->xform->mobius_re_c * f->ty + f->xform->mobius_im_c * f->tx + f->xform->mobius_im_d; + re_u = f->xform->mobius_re_a * f->t[0] - f->xform->mobius_im_a * f->t[1] + f->xform->mobius_re_b; + im_u = f->xform->mobius_re_a * f->t[1] + f->xform->mobius_im_a * f->t[0] + f->xform->mobius_im_b; + re_v = f->xform->mobius_re_c * f->t[0] - f->xform->mobius_im_c * f->t[1] + f->xform->mobius_re_d; + im_v = f->xform->mobius_re_c * f->t[1] + f->xform->mobius_im_c * f->t[0] + f->xform->mobius_im_d; rad_v = weight / (re_v*re_v + im_v*im_v); - f->p0 += rad_v * (re_u*re_v + im_u*im_v); - f->p1 += rad_v * (im_u*re_v - re_u*im_v); + return rad_v * (double2) { (re_u*re_v + im_u*im_v), (im_u*re_v - re_u*im_v) }; } @@ -2150,38 +2054,39 @@ int apply_xform(flam3_genome *cp, int fn, double *p, double *q, randctx *rc) //fprintf(stderr,"%d : %f %f %f\n",fn,cp->xform[fn].c[0][0],cp->xform[fn].c[1][0],cp->xform[fn].c[2][0]); - f.tx = cp->xform[fn].c[0][0] * p[0] + cp->xform[fn].c[1][0] * p[1] + cp->xform[fn].c[2][0]; - f.ty = cp->xform[fn].c[0][1] * p[0] + cp->xform[fn].c[1][1] * p[1] + cp->xform[fn].c[2][1]; + f.t = (double2) { + cp->xform[fn].c[0][0] * p[0] + cp->xform[fn].c[1][0] * p[1] + cp->xform[fn].c[2][0], + cp->xform[fn].c[0][1] * p[0] + cp->xform[fn].c[1][1] * p[1] + cp->xform[fn].c[2][1] + }; /* Pre-xforms go here, and modify the f.tx and f.ty values */ if (cp->xform[fn].has_preblur!=0.0) var67_pre_blur(&f, cp->xform[fn].has_preblur); /* Always calculate sumsq and sqrt */ - f.precalc_sumsq = f.tx*f.tx + f.ty*f.ty; + f.precalc_sumsq = f.t[0]*f.t[0] + f.t[1]*f.t[1]; f.precalc_sqrt = sqrt(f.precalc_sumsq); /* Check to see if we can precalculate any parts */ /* Precalculate atanxy, sin, cos */ if (cp->xform[fn].precalc_atan_xy_flag > 0) { - f.precalc_atan = atan2(f.tx,f.ty); + f.precalc_atan = atan2(f.t[0],f.t[1]); } if (cp->xform[fn].precalc_angles_flag > 0) { - f.precalc_sina = f.tx / f.precalc_sqrt; - f.precalc_cosa = f.ty / f.precalc_sqrt; + f.precalc_sina = f.t[0] / f.precalc_sqrt; + f.precalc_cosa = f.t[1] / f.precalc_sqrt; } /* Precalc atanyx */ if (cp->xform[fn].precalc_atan_yx_flag > 0) { - f.precalc_atanyx = atan2(f.ty,f.tx); + f.precalc_atanyx = atan2(f.t[1],f.t[0]); } - f.p0 = 0.0; - f.p1 = 0.0; f.xform = &(cp->xform[fn]); + double2 accum = (double2) {0.0, 0.0}; for (var_n=0; var_n < cp->xform[fn].num_active_vars; var_n++) { weight = cp->xform[fn].active_var_weights[var_n]; @@ -2189,211 +2094,211 @@ int apply_xform(flam3_genome *cp, int fn, double *p, double *q, randctx *rc) switch (cp->xform[fn].varFunc[var_n]) { case (VAR_LINEAR): - var0_linear(&f, weight); break; + accum += var0_linear(&f, weight); break; case (VAR_SINUSOIDAL): - var1_sinusoidal(&f, weight); break; + accum += var1_sinusoidal(&f, weight); break; case (VAR_SPHERICAL): - var2_spherical(&f, weight); break; + accum += var2_spherical(&f, weight); break; case (VAR_SWIRL): - var3_swirl(&f, weight); break; + accum += var3_swirl(&f, weight); break; case (VAR_HORSESHOE): - var4_horseshoe(&f, weight); break; + accum += var4_horseshoe(&f, weight); break; case (VAR_POLAR): - var5_polar(&f, weight); break; + accum += var5_polar(&f, weight); break; case (VAR_HANDKERCHIEF): - var6_handkerchief(&f, weight); break; + accum += var6_handkerchief(&f, weight); break; case (VAR_HEART): - var7_heart(&f, weight); break; + accum += var7_heart(&f, weight); break; case (VAR_DISC): - var8_disc(&f, weight); break; + accum += var8_disc(&f, weight); break; case (VAR_SPIRAL): - var9_spiral(&f, weight); break; + accum += var9_spiral(&f, weight); break; case (VAR_HYPERBOLIC): - var10_hyperbolic(&f, weight); break; + accum += var10_hyperbolic(&f, weight); break; case (VAR_DIAMOND): - var11_diamond(&f, weight); break; + accum += var11_diamond(&f, weight); break; case (VAR_EX): - var12_ex(&f, weight); break; + accum += var12_ex(&f, weight); break; case (VAR_JULIA): - var13_julia(&f, weight); break; + accum += var13_julia(&f, weight); break; case (VAR_BENT): - var14_bent(&f, weight); break; + accum += var14_bent(&f, weight); break; case (VAR_WAVES): - var15_waves(&f, weight); break; + accum += var15_waves(&f, weight); break; case (VAR_FISHEYE): - var16_fisheye(&f, weight); break; + accum += var16_fisheye(&f, weight); break; case (VAR_POPCORN): - var17_popcorn(&f, weight); break; + accum += var17_popcorn(&f, weight); break; case (VAR_EXPONENTIAL): - var18_exponential(&f, weight); break; + accum += var18_exponential(&f, weight); break; case (VAR_POWER): - var19_power(&f, weight); break; + accum += var19_power(&f, weight); break; case (VAR_COSINE): - var20_cosine(&f, weight); break; + accum += var20_cosine(&f, weight); break; case (VAR_RINGS): - var21_rings(&f, weight); break; + accum += var21_rings(&f, weight); break; case (VAR_FAN): - var22_fan(&f, weight); break; + accum += var22_fan(&f, weight); break; case (VAR_BLOB): - var23_blob(&f, weight); break; + accum += var23_blob(&f, weight); break; case (VAR_PDJ): - var24_pdj(&f, weight); break; + accum += var24_pdj(&f, weight); break; case (VAR_FAN2): - var25_fan2(&f, weight); break; + accum += var25_fan2(&f, weight); break; case (VAR_RINGS2): - var26_rings2(&f, weight); break; + accum += var26_rings2(&f, weight); break; case (VAR_EYEFISH): - var27_eyefish(&f, weight); break; + accum += var27_eyefish(&f, weight); break; case (VAR_BUBBLE): - var28_bubble(&f, weight); break; + accum += var28_bubble(&f, weight); break; case (VAR_CYLINDER): - var29_cylinder(&f, weight); break; + accum += var29_cylinder(&f, weight); break; case (VAR_PERSPECTIVE): - var30_perspective(&f, weight); break; + accum += var30_perspective(&f, weight); break; case (VAR_NOISE): - var31_noise(&f, weight); break; + accum += var31_noise(&f, weight); break; case (VAR_JULIAN): - var32_juliaN_generic(&f, weight); break; + accum += var32_juliaN_generic(&f, weight); break; case (VAR_JULIASCOPE): - var33_juliaScope_generic(&f, weight);break; + accum += var33_juliaScope_generic(&f, weight);break; case (VAR_BLUR): - var34_blur(&f, weight); break; + accum += var34_blur(&f, weight); break; case (VAR_GAUSSIAN_BLUR): - var35_gaussian(&f, weight); break; + accum += var35_gaussian(&f, weight); break; case (VAR_RADIAL_BLUR): - var36_radial_blur(&f, weight); break; + accum += var36_radial_blur(&f, weight); break; case (VAR_PIE): - var37_pie(&f, weight); break; + accum += var37_pie(&f, weight); break; case (VAR_NGON): - var38_ngon(&f, weight); break; + accum += var38_ngon(&f, weight); break; case (VAR_CURL): - var39_curl(&f, weight); break; + accum += var39_curl(&f, weight); break; case (VAR_RECTANGLES): - var40_rectangles(&f, weight); break; + accum += var40_rectangles(&f, weight); break; case (VAR_ARCH): - var41_arch(&f, weight); break; + accum += var41_arch(&f, weight); break; case (VAR_TANGENT): - var42_tangent(&f, weight); break; + accum += var42_tangent(&f, weight); break; case (VAR_SQUARE): - var43_square(&f, weight); break; + accum += var43_square(&f, weight); break; case (VAR_RAYS): - var44_rays(&f, weight); break; + accum += var44_rays(&f, weight); break; case (VAR_BLADE): - var45_blade(&f, weight); break; + accum += var45_blade(&f, weight); break; case (VAR_SECANT2): - var46_secant2(&f, weight); break; + accum += var46_secant2(&f, weight); break; case (VAR_TWINTRIAN): - var47_twintrian(&f, weight); break; + accum += var47_twintrian(&f, weight); break; case (VAR_CROSS): - var48_cross(&f, weight); break; + accum += var48_cross(&f, weight); break; case (VAR_DISC2): - var49_disc2(&f, weight); break; + accum += var49_disc2(&f, weight); break; case (VAR_SUPER_SHAPE): - var50_supershape(&f, weight); break; + accum += var50_supershape(&f, weight); break; case (VAR_FLOWER): - var51_flower(&f, weight); break; + accum += var51_flower(&f, weight); break; case (VAR_CONIC): - var52_conic(&f, weight); break; + accum += var52_conic(&f, weight); break; case (VAR_PARABOLA): - var53_parabola(&f, weight); break; + accum += var53_parabola(&f, weight); break; case (VAR_BENT2): - var54_bent2(&f, weight); break; + accum += var54_bent2(&f, weight); break; case (VAR_BIPOLAR): - var55_bipolar(&f, weight); break; + accum += var55_bipolar(&f, weight); break; case (VAR_BOARDERS): - var56_boarders(&f, weight); break; + accum += var56_boarders(&f, weight); break; case (VAR_BUTTERFLY): - var57_butterfly(&f, weight); break; + accum += var57_butterfly(&f, weight); break; case (VAR_CELL): - var58_cell(&f, weight); break; + accum += var58_cell(&f, weight); break; case (VAR_CPOW): - var59_cpow(&f, weight); break; + accum += var59_cpow(&f, weight); break; case (VAR_CURVE): - var60_curve(&f, weight); break; + accum += var60_curve(&f, weight); break; case (VAR_EDISC): - var61_edisc(&f, weight); break; + accum += var61_edisc(&f, weight); break; case (VAR_ELLIPTIC): - var62_elliptic(&f, weight); break; + accum += var62_elliptic(&f, weight); break; case (VAR_ESCHER): - var63_escher(&f, weight); break; + accum += var63_escher(&f, weight); break; case (VAR_FOCI): - var64_foci(&f, weight); break; + accum += var64_foci(&f, weight); break; case (VAR_LAZYSUSAN): - var65_lazysusan(&f, weight); break; + accum += var65_lazysusan(&f, weight); break; case (VAR_LOONIE): - var66_loonie(&f, weight); break; + accum += var66_loonie(&f, weight); break; case (VAR_MODULUS): - var68_modulus(&f, weight); break; + accum += var68_modulus(&f, weight); break; case (VAR_OSCILLOSCOPE): - var69_oscope(&f, weight); break; + accum += var69_oscope(&f, weight); break; case (VAR_POLAR2): - var70_polar2(&f, weight); break; + accum += var70_polar2(&f, weight); break; case (VAR_POPCORN2): - var71_popcorn2(&f, weight); break; + accum += var71_popcorn2(&f, weight); break; case (VAR_SCRY): - var72_scry(&f, weight); break; + accum += var72_scry(&f, weight); break; case (VAR_SEPARATION): - var73_separation(&f, weight); break; + accum += var73_separation(&f, weight); break; case (VAR_SPLIT): - var74_split(&f, weight); break; + accum += var74_split(&f, weight); break; case (VAR_SPLITS): - var75_splits(&f, weight); break; + accum += var75_splits(&f, weight); break; case (VAR_STRIPES): - var76_stripes(&f, weight); break; + accum += var76_stripes(&f, weight); break; case (VAR_WEDGE): - var77_wedge(&f, weight); break; + accum += var77_wedge(&f, weight); break; case (VAR_WEDGE_JULIA): - var78_wedge_julia(&f, weight); break; + accum += var78_wedge_julia(&f, weight); break; case (VAR_WEDGE_SPH): - var79_wedge_sph(&f, weight); break; + accum += var79_wedge_sph(&f, weight); break; case (VAR_WHORL): - var80_whorl(&f, weight); break; + accum += var80_whorl(&f, weight); break; case (VAR_WAVES2): - var81_waves2(&f, weight); break; + accum += var81_waves2(&f, weight); break; case (VAR_EXP): - var82_exp(&f, weight); break; + accum += var82_exp(&f, weight); break; case (VAR_LOG): - var83_log(&f, weight); break; + accum += var83_log(&f, weight); break; case (VAR_SIN): - var84_sin(&f, weight); break; + accum += var84_sin(&f, weight); break; case (VAR_COS): - var85_cos(&f, weight); break; + accum += var85_cos(&f, weight); break; case (VAR_TAN): - var86_tan(&f, weight); break; + accum += var86_tan(&f, weight); break; case (VAR_SEC): - var87_sec(&f, weight); break; + accum += var87_sec(&f, weight); break; case (VAR_CSC): - var88_csc(&f, weight); break; + accum += var88_csc(&f, weight); break; case (VAR_COT): - var89_cot(&f, weight); break; + accum += var89_cot(&f, weight); break; case (VAR_SINH): - var90_sinh(&f, weight); break; + accum += var90_sinh(&f, weight); break; case (VAR_COSH): - var91_cosh(&f, weight); break; + accum += var91_cosh(&f, weight); break; case (VAR_TANH): - var92_tanh(&f, weight); break; + accum += var92_tanh(&f, weight); break; case (VAR_SECH): - var93_sech(&f, weight); break; + accum += var93_sech(&f, weight); break; case (VAR_CSCH): - var94_csch(&f, weight); break; + accum += var94_csch(&f, weight); break; case (VAR_COTH): - var95_coth(&f, weight); break; + accum += var95_coth(&f, weight); break; case (VAR_AUGER): - var96_auger(&f, weight); break; + accum += var96_auger(&f, weight); break; case (VAR_FLUX): - var97_flux(&f, weight); break; + accum += var97_flux(&f, weight); break; case (VAR_MOBIUS): - var98_mobius(&f, weight); break; + accum += var98_mobius(&f, weight); break; } } /* apply the post transform */ if (cp->xform[fn].has_post) { - q[0] = cp->xform[fn].post[0][0] * f.p0 + cp->xform[fn].post[1][0] * f.p1 + cp->xform[fn].post[2][0]; - q[1] = cp->xform[fn].post[0][1] * f.p0 + cp->xform[fn].post[1][1] * f.p1 + cp->xform[fn].post[2][1]; + q[0] = cp->xform[fn].post[0][0] * accum[0] + cp->xform[fn].post[1][0] * accum[1] + cp->xform[fn].post[2][0]; + q[1] = cp->xform[fn].post[0][1] * accum[0] + cp->xform[fn].post[1][1] * accum[1] + cp->xform[fn].post[2][1]; } else { - q[0] = f.p0; - q[1] = f.p1; + q[0] = accum[0]; + q[1] = accum[1]; } /* Check for badvalues and return randoms if bad */ |