#include #include #ifdef __TURBOC__ #include #elif !defined(__386BSD__) #include #endif /* see Fractint.c for a description of the "include" hierarchy */ #include "port.h" #include "prototyp.h" #include "helpdefs.h" #include "fractype.h" #ifndef XFRACT #define MPCmod(m) (*pMPadd(*pMPmul((m).x, (m).x), *pMPmul((m).y, (m).y))) #endif /* -------------------------------------------------------------------- */ /* Setup (once per fractal image) routines */ /* -------------------------------------------------------------------- */ MandelSetup() /* Mandelbrot Routine */ { if (debugflag != 90 && ! invert && decomp[0] == 0 && rqlim == 4.0 && bitshift == 29 && potflag == 0 && biomorph == -1 && inside > -59 && outside >= -1 && useinitorbit != 1 && using_jiim == 0 && bailoutest == Mod && (orbitsave&2) == 0) calctype = calcmand; /* the normal case - use CALCMAND */ else { /* special case: use the main processing loop */ calctype = StandardFractal; longparm = &linit; } return(1); } JuliaSetup() /* Julia Routine */ { if (debugflag != 90 && ! invert && decomp[0] == 0 && rqlim == 4.0 && bitshift == 29 && potflag == 0 && biomorph == -1 && inside > -59 && outside >= -1 && !finattract && using_jiim == 0 && bailoutest == Mod && (orbitsave&2) == 0) calctype = calcmand; /* the normal case - use CALCMAND */ else { /* special case: use the main processing loop */ calctype = StandardFractal; longparm = &lparm; get_julia_attractor (0.0, 0.0); /* another attractor? */ } return(1); } NewtonSetup() /* Newton/NewtBasin Routines */ { int i; if (debugflag != 1010) { if(fpu != 0) { if(fractype == MPNEWTON) fractype = NEWTON; else if(fractype == MPNEWTBASIN) fractype = NEWTBASIN; } else { if(fractype == NEWTON) fractype = MPNEWTON; else if(fractype == NEWTBASIN) fractype = MPNEWTBASIN; } curfractalspecific = &fractalspecific[fractype]; } /* set up table of roots of 1 along unit circle */ degree = (int)parm.x; if(degree < 2) degree = 3; /* defaults to 3, but 2 is possible */ root = 1; /* precalculated values */ roverd = (double)root / (double)degree; d1overd = (double)(degree - 1) / (double)degree; maxcolor = 0; threshold = .3*PI/degree; /* less than half distance between roots */ #ifndef XFRACT if (fractype == MPNEWTON || fractype == MPNEWTBASIN) { mproverd = *pd2MP(roverd); mpd1overd = *pd2MP(d1overd); mpthreshold = *pd2MP(threshold); mpone = *pd2MP(1.0); } #endif floatmin = FLT_MIN; floatmax = FLT_MAX; basin = 0; if(roots != staticroots) { free(roots); roots = staticroots; } if (fractype==NEWTBASIN) { if(parm.y) basin = 2; /*stripes */ else basin = 1; if(degree > 16) { if((roots=(_CMPLX *)malloc(degree*sizeof(_CMPLX)))==NULL) { roots = staticroots; degree = 16; } } else roots = staticroots; /* list of roots to discover where we converged for newtbasin */ for(i=0;i 16) { if((MPCroots=(struct MPC *)malloc(degree*sizeof(struct MPC)))==NULL) { MPCroots = (struct MPC *)staticroots; degree = 16; } } else MPCroots = (struct MPC *)staticroots; /* list of roots to discover where we converged for newtbasin */ for(i=0;icalctype); return(0); /* effectively disable solid-guessing */ } UnitySetup() { periodicitycheck = 0; FgOne = (1L << bitshift); FgTwo = FgOne + FgOne; return(1); } MandelfpSetup() { bf_math = 0; c_exp = (int)param[2]; pwr.x = param[2] - 1.0; pwr.y = param[3]; floatparm = &init; switch (fractype) { case MARKSMANDELFP: if(c_exp < 1){ c_exp = 1; param[2] = 1; } if(!(c_exp & 1)) symmetry = XYAXIS_NOPARM; /* odd exponents */ if(c_exp & 1) symmetry = XAXIS_NOPARM; break; case MANDELFP: /* floating point code could probably be altered to handle many of the situations that otherwise are using StandardFractal(). calcmandfp() can currently handle invert, any rqlim, potflag zmag, epsilon cross, and all the current outside options Wes Loewer 11/03/91 */ if (debugflag != 90 && !distest && decomp[0] == 0 && biomorph == -1 && (inside >= -1 || inside == -59 || inside == -100) /* uncomment this next line if more outside options are added */ /* && outside >= -5 */ && useinitorbit != 1 && using_jiim == 0 && bailoutest == Mod && (orbitsave&2) == 0) { calctype = calcmandfp; /* the normal case - use calcmandfp */ calcmandfpasmstart(); } else { /* special case: use the main processing loop */ calctype = StandardFractal; } break; case FPMANDELZPOWER: if((double)c_exp == param[2] && (c_exp & 1)) /* odd exponents */ symmetry = XYAXIS_NOPARM; if(param[3] != 0) symmetry = NOSYM; if(param[3] == 0.0 && debugflag != 6000 && (double)c_exp == param[2]) fractalspecific[fractype].orbitcalc = floatZpowerFractal; else fractalspecific[fractype].orbitcalc = floatCmplxZpowerFractal; break; case MAGNET1M: case MAGNET2M: attr[0].x = 1.0; /* 1.0 + 0.0i always attracts */ attr[0].y = 0.0; /* - both MAGNET1 and MAGNET2 */ attrperiod[0] = 1; attractors = 1; break; case SPIDERFP: if(periodicitycheck==1) /* if not user set */ periodicitycheck=4; break; case MANDELEXP: symmetry = XAXIS_NOPARM; break; /* Added to account for symmetry in manfn+exp and manfn+zsqrd */ /* JCO 2/29/92 */ case FPMANTRIGPLUSEXP: case FPMANTRIGPLUSZSQRD: if(parm.y == 0.0) symmetry = XAXIS; else symmetry = NOSYM; if ((trigndx[0] == LOG) || (trigndx[0] == 14)) /* LOG or FLIP */ symmetry = NOSYM; break; case QUATFP: floatparm = &tmp; attractors = 0; periodicitycheck = 0; break; case HYPERCMPLXFP: floatparm = &tmp; attractors = 0; periodicitycheck = 0; if(trigndx[0] == 14) /* FLIP */ symmetry = NOSYM; break; case TIMSERRORFP: if(trigndx[0] == 14) /* FLIP */ symmetry = NOSYM; break; case MARKSMANDELPWRFP: if(trigndx[0] == 14) /* FLIP */ symmetry = NOSYM; break; default: break; } return(1); } JuliafpSetup() { c_exp = (int)param[2]; floatparm = &parm; if(fractype==COMPLEXMARKSJUL) { pwr.x = param[2] - 1.0; pwr.y = param[3]; coefficient = ComplexPower(*floatparm, pwr); } switch (fractype) { case JULIAFP: /* floating point code could probably be altered to handle many of the situations that otherwise are using StandardFractal(). calcmandfp() can currently handle invert, any rqlim, potflag zmag, epsilon cross, and all the current outside options Wes Loewer 11/03/91 */ if (debugflag != 90 && !distest && decomp[0] == 0 && biomorph == -1 && (inside >= -1 || inside == -59 || inside == -100) /* uncomment this next line if more outside options are added */ /* && outside >= -5 */ && useinitorbit != 1 && !finattract && using_jiim == 0 && bailoutest == Mod && (orbitsave&2) == 0) { calctype = calcmandfp; /* the normal case - use calcmandfp */ calcmandfpasmstart(); } else { /* special case: use the main processing loop */ calctype = StandardFractal; get_julia_attractor (0.0, 0.0); /* another attractor? */ } break; case FPJULIAZPOWER: if((c_exp & 1) || param[3] != 0.0 || (double)c_exp != param[2] ) symmetry = NOSYM; if(param[3] == 0.0 && debugflag != 6000 && (double)c_exp == param[2]) fractalspecific[fractype].orbitcalc = floatZpowerFractal; else fractalspecific[fractype].orbitcalc = floatCmplxZpowerFractal; get_julia_attractor (param[0], param[1]); /* another attractor? */ break; case MAGNET2J: FloatPreCalcMagnet2(); case MAGNET1J: attr[0].x = 1.0; /* 1.0 + 0.0i always attracts */ attr[0].y = 0.0; /* - both MAGNET1 and MAGNET2 */ attrperiod[0] = 1; attractors = 1; get_julia_attractor (0.0, 0.0); /* another attractor? */ break; case LAMBDAFP: get_julia_attractor (0.0, 0.0); /* another attractor? */ get_julia_attractor (0.5, 0.0); /* another attractor? */ break; case LAMBDAEXP: if(parm.y == 0.0) symmetry=XAXIS; get_julia_attractor (0.0, 0.0); /* another attractor? */ break; /* Added to account for symmetry in julfn+exp and julfn+zsqrd */ /* JCO 2/29/92 */ case FPJULTRIGPLUSEXP: case FPJULTRIGPLUSZSQRD: if(parm.y == 0.0) symmetry = XAXIS; else symmetry = NOSYM; if ((trigndx[0] == LOG) || (trigndx[0] == 14)) /* LOG or FLIP */ symmetry = NOSYM; get_julia_attractor (0.0, 0.0); /* another attractor? */ break; case HYPERCMPLXJFP: if(trigndx[0] != SQR) symmetry=NOSYM; case QUATJULFP: attractors = 0; /* attractors broken since code checks r,i not j,k */ periodicitycheck = 0; if(param[4] != 0.0 || param[5] != 0) symmetry = NOSYM; break; default: get_julia_attractor (0.0, 0.0); /* another attractor? */ break; } return(1); } MandellongSetup() { FgHalf = fudge >> 1; c_exp = (int)param[2]; if(fractype==MARKSMANDEL && c_exp < 1){ c_exp = 1; param[2] = 1; } if((fractype==MARKSMANDEL && !(c_exp & 1)) || (fractype==LMANDELZPOWER && (c_exp & 1))) symmetry = XYAXIS_NOPARM; /* odd exponents */ if((fractype==MARKSMANDEL && (c_exp & 1)) || fractype==LMANDELEXP) symmetry = XAXIS_NOPARM; if(fractype==SPIDER && periodicitycheck==1) periodicitycheck=4; longparm = &linit; if(fractype==LMANDELZPOWER) { if(param[3] == 0.0 && debugflag != 6000 && (double)c_exp == param[2]) fractalspecific[fractype].orbitcalc = longZpowerFractal; else fractalspecific[fractype].orbitcalc = longCmplxZpowerFractal; if(param[3] != 0 || (double)c_exp != param[2] ) symmetry = NOSYM; } /* Added to account for symmetry in manfn+exp and manfn+zsqrd */ /* JCO 2/29/92 */ if((fractype==LMANTRIGPLUSEXP)||(fractype==LMANTRIGPLUSZSQRD)) { if(parm.y == 0.0) symmetry = XAXIS; else symmetry = NOSYM; if ((trigndx[0] == LOG) || (trigndx[0] == 14)) /* LOG or FLIP */ symmetry = NOSYM; } if(fractype == TIMSERROR) { if(trigndx[0] == 14) /* FLIP */ symmetry = NOSYM; } if(fractype == MARKSMANDELPWR) { if(trigndx[0] == 14) /* FLIP */ symmetry = NOSYM; } return(1); } JulialongSetup() { c_exp = (int)param[2]; longparm = &lparm; switch (fractype) { case LJULIAZPOWER: if((c_exp & 1) || param[3] != 0.0 || (double)c_exp != param[2]) symmetry = NOSYM; if(param[3] == 0.0 && debugflag != 6000 && (double)c_exp == param[2]) fractalspecific[fractype].orbitcalc = longZpowerFractal; else fractalspecific[fractype].orbitcalc = longCmplxZpowerFractal; break; case LAMBDA: get_julia_attractor (0.0, 0.0); /* another attractor? */ get_julia_attractor (0.5, 0.0); /* another attractor? */ break; case LLAMBDAEXP: if(lparm.y == 0) symmetry = XAXIS; break; /* Added to account for symmetry in julfn+exp and julfn+zsqrd */ /* JCO 2/29/92 */ case LJULTRIGPLUSEXP: case LJULTRIGPLUSZSQRD: if(parm.y == 0.0) symmetry = XAXIS; else symmetry = NOSYM; if ((trigndx[0] == LOG) || (trigndx[0] == 14)) /* LOG or FLIP */ symmetry = NOSYM; get_julia_attractor (0.0, 0.0); /* another attractor? */ break; default: get_julia_attractor (0.0, 0.0); /* another attractor? */ break; } return(1); } TrigPlusSqrlongSetup() { curfractalspecific->per_pixel = julia_per_pixel; curfractalspecific->orbitcalc = TrigPlusSqrFractal; if(lparm.x == fudge && lparm.y == 0L && lparm2.y == 0L && debugflag != 90) { if(lparm2.x == fudge) /* Scott variant */ curfractalspecific->orbitcalc = ScottTrigPlusSqrFractal; else if(lparm2.x == -fudge) /* Skinner variant */ curfractalspecific->orbitcalc = SkinnerTrigSubSqrFractal; } return(JulialongSetup()); } TrigPlusSqrfpSetup() { curfractalspecific->per_pixel = juliafp_per_pixel; curfractalspecific->orbitcalc = TrigPlusSqrfpFractal; if(parm.x == 1.0 && parm.y == 0.0 && parm2.y == 0.0 && debugflag != 90) { if(parm2.x == 1.0) /* Scott variant */ curfractalspecific->orbitcalc = ScottTrigPlusSqrfpFractal; else if(parm2.x == -1.0) /* Skinner variant */ curfractalspecific->orbitcalc = SkinnerTrigSubSqrfpFractal; } return(JuliafpSetup()); } TrigPlusTriglongSetup() { FnPlusFnSym(); if(trigndx[1] == SQR) return(TrigPlusSqrlongSetup()); curfractalspecific->per_pixel = long_julia_per_pixel; curfractalspecific->orbitcalc = TrigPlusTrigFractal; if(lparm.x == fudge && lparm.y == 0L && lparm2.y == 0L && debugflag != 90) { if(lparm2.x == fudge) /* Scott variant */ curfractalspecific->orbitcalc = ScottTrigPlusTrigFractal; else if(lparm2.x == -fudge) /* Skinner variant */ curfractalspecific->orbitcalc = SkinnerTrigSubTrigFractal; } return(JulialongSetup()); } TrigPlusTrigfpSetup() { FnPlusFnSym(); if(trigndx[1] == SQR) return(TrigPlusSqrfpSetup()); curfractalspecific->per_pixel = otherjuliafp_per_pixel; curfractalspecific->orbitcalc = TrigPlusTrigfpFractal; if(parm.x == 1.0 && parm.y == 0.0 && parm2.y == 0.0 && debugflag != 90) { if(parm2.x == 1.0) /* Scott variant */ curfractalspecific->orbitcalc = ScottTrigPlusTrigfpFractal; else if(parm2.x == -1.0) /* Skinner variant */ curfractalspecific->orbitcalc = SkinnerTrigSubTrigfpFractal; } return(JuliafpSetup()); } FnPlusFnSym() /* set symmetry matrix for fn+fn type */ { static char far fnplusfn[7][7] = {/* fn2 ->sin cos sinh cosh exp log sqr */ /* fn1 */ /* sin */ {PI_SYM,XAXIS, XYAXIS, XAXIS, XAXIS, XAXIS, XAXIS}, /* cos */ {XAXIS, PI_SYM,XAXIS, XYAXIS,XAXIS, XAXIS, XAXIS}, /* sinh*/ {XYAXIS,XAXIS, XYAXIS, XAXIS, XAXIS, XAXIS, XAXIS}, /* cosh*/ {XAXIS, XYAXIS,XAXIS, XYAXIS,XAXIS, XAXIS, XAXIS}, /* exp */ {XAXIS, XYAXIS,XAXIS, XAXIS, XYAXIS,XAXIS, XAXIS}, /* log */ {XAXIS, XAXIS, XAXIS, XAXIS, XAXIS, XAXIS, XAXIS}, /* sqr */ {XAXIS, XAXIS, XAXIS, XAXIS, XAXIS, XAXIS, XYAXIS} }; if(parm.y == 0.0 && parm2.y == 0.0) { if(trigndx[0] < 7 && trigndx[1] < 7) /* bounds of array JCO 5/6/92*/ symmetry = fnplusfn[trigndx[0]][trigndx[1]]; /* JCO 5/6/92 */ if(trigndx[0] == 14 || trigndx[1] == 14) /* FLIP */ symmetry = NOSYM; } /* defaults to XAXIS symmetry JCO 5/6/92 */ else symmetry = NOSYM; return(0); } LambdaTrigOrTrigSetup() { /* default symmetry is ORIGIN JCO 2/29/92 (changed from PI_SYM) */ longparm = &lparm; /* added to consolidate code 10/1/92 JCO */ floatparm = &parm; if ((trigndx[0] == EXP) || (trigndx[1] == EXP)) symmetry = NOSYM; /* JCO 1/9/93 */ if ((trigndx[0] == LOG) || (trigndx[1] == LOG)) symmetry = XAXIS; get_julia_attractor (0.0, 0.0); /* an attractor? */ return(1); } JuliaTrigOrTrigSetup() { /* default symmetry is XAXIS */ longparm = &lparm; /* added to consolidate code 10/1/92 JCO */ floatparm = &parm; if(parm.y != 0.0) symmetry = NOSYM; if(trigndx[0] == 14 || trigndx[1] == 14) /* FLIP */ symmetry = NOSYM; get_julia_attractor (0.0, 0.0); /* an attractor? */ return(1); } ManlamTrigOrTrigSetup() { /* psuedo */ /* default symmetry is XAXIS */ longparm = &linit; /* added to consolidate code 10/1/92 JCO */ floatparm = &init; if (trigndx[0] == SQR) symmetry = NOSYM; if ((trigndx[0] == LOG) || (trigndx[1] == LOG)) symmetry = NOSYM; return(1); } MandelTrigOrTrigSetup() { /* default symmetry is XAXIS_NOPARM */ longparm = &linit; /* added to consolidate code 10/1/92 JCO */ floatparm = &init; if ((trigndx[0] == 14) || (trigndx[1] == 14)) /* FLIP JCO 5/28/92 */ symmetry = NOSYM; return(1); } ZXTrigPlusZSetup() { /* static char far ZXTrigPlusZSym1[] = */ /* fn1 -> sin cos sinh cosh exp log sqr */ /* {XAXIS,XYAXIS,XAXIS,XYAXIS,XAXIS,NOSYM,XYAXIS}; */ /* static char far ZXTrigPlusZSym2[] = */ /* fn1 -> sin cos sinh cosh exp log sqr */ /* {NOSYM,ORIGIN,NOSYM,ORIGIN,NOSYM,NOSYM,ORIGIN}; */ if(param[1] == 0.0 && param[3] == 0.0) /* symmetry = ZXTrigPlusZSym1[trigndx[0]]; */ switch(trigndx[0]) { case COS: /* changed to two case statments and made any added */ case COSH: /* functions default to XAXIS symmetry. JCO 5/25/92 */ case SQR: case 9: /* 'real' cos */ symmetry = XYAXIS; break; case 14: /* FLIP JCO 2/29/92 */ symmetry = YAXIS; break; case LOG: symmetry = NOSYM; break; default: symmetry = XAXIS; break; } else /* symmetry = ZXTrigPlusZSym2[trigndx[0]]; */ switch(trigndx[0]) { case COS: case COSH: case SQR: case 9: /* 'real' cos */ symmetry = ORIGIN; break; case 14: /* FLIP JCO 2/29/92 */ symmetry = NOSYM; break; default: symmetry = NOSYM; break; } if(curfractalspecific->isinteger) { curfractalspecific->orbitcalc = ZXTrigPlusZFractal; if(lparm.x == fudge && lparm.y == 0L && lparm2.y == 0L && debugflag != 90) { if(lparm2.x == fudge) /* Scott variant */ curfractalspecific->orbitcalc = ScottZXTrigPlusZFractal; else if(lparm2.x == -fudge) /* Skinner variant */ curfractalspecific->orbitcalc = SkinnerZXTrigSubZFractal; } return(JulialongSetup()); } else { curfractalspecific->orbitcalc = ZXTrigPlusZfpFractal; if(parm.x == 1.0 && parm.y == 0.0 && parm2.y == 0.0 && debugflag != 90) { if(parm2.x == 1.0) /* Scott variant */ curfractalspecific->orbitcalc = ScottZXTrigPlusZfpFractal; else if(parm2.x == -1.0) /* Skinner variant */ curfractalspecific->orbitcalc = SkinnerZXTrigSubZfpFractal; } } return(JuliafpSetup()); } LambdaTrigSetup() { int isinteger; if((isinteger = curfractalspecific->isinteger) != 0) curfractalspecific->orbitcalc = LambdaTrigFractal; else curfractalspecific->orbitcalc = LambdaTrigfpFractal; switch(trigndx[0]) { case SIN: case COS: case 9: /* 'real' cos, added this and default for additional functions */ symmetry = PI_SYM; if(isinteger) curfractalspecific->orbitcalc = LambdaTrigFractal1; else curfractalspecific->orbitcalc = LambdaTrigfpFractal1; break; case SINH: case COSH: symmetry = ORIGIN; if(isinteger) curfractalspecific->orbitcalc = LambdaTrigFractal2; else curfractalspecific->orbitcalc = LambdaTrigfpFractal2; break; case SQR: symmetry = ORIGIN; break; case EXP: if(isinteger) curfractalspecific->orbitcalc = LongLambdaexponentFractal; else curfractalspecific->orbitcalc = LambdaexponentFractal; symmetry = NOSYM; /* JCO 1/9/93 */ break; case LOG: symmetry = NOSYM; break; default: /* default for additional functions */ symmetry = ORIGIN; /* JCO 5/8/92 */ break; } get_julia_attractor (0.0, 0.0); /* an attractor? */ if(isinteger) return(JulialongSetup()); else return(JuliafpSetup()); } JuliafnPlusZsqrdSetup() { /* static char far fnpluszsqrd[] = */ /* fn1 -> sin cos sinh cosh sqr exp log */ /* sin {NOSYM,ORIGIN,NOSYM,ORIGIN,ORIGIN,NOSYM,NOSYM}; */ /* symmetry = fnpluszsqrd[trigndx[0]]; JCO 5/8/92 */ switch(trigndx[0]) /* fix sqr symmetry & add additional functions */ { case COS: /* cosxx */ case COSH: case SQR: case 9: /* 'real' cos */ case 10: /* tan */ case 11: /* tanh */ symmetry = ORIGIN; /* default is for NOSYM symmetry */ } if(curfractalspecific->isinteger) return(JulialongSetup()); else return(JuliafpSetup()); } SqrTrigSetup() { /* static char far SqrTrigSym[] = */ /* fn1 -> sin cos sinh cosh sqr exp log */ /* {PI_SYM,PI_SYM,XYAXIS,XYAXIS,XYAXIS,XAXIS,XAXIS}; */ /* symmetry = SqrTrigSym[trigndx[0]]; JCO 5/9/92 */ switch(trigndx[0]) /* fix sqr symmetry & add additional functions */ { case SIN: case COS: /* cosxx */ case 9: /* 'real' cos */ symmetry = PI_SYM; /* default is for XAXIS symmetry */ } if(curfractalspecific->isinteger) return(JulialongSetup()); else return(JuliafpSetup()); } FnXFnSetup() { static char far fnxfn[7][7] = {/* fn2 ->sin cos sinh cosh exp log sqr */ /* fn1 */ /* sin */ {PI_SYM,YAXIS, XYAXIS,XYAXIS,XAXIS, NOSYM, XYAXIS}, /* cos */ {YAXIS, PI_SYM,XYAXIS,XYAXIS,XAXIS, NOSYM, XYAXIS}, /* sinh*/ {XYAXIS,XYAXIS,XYAXIS,XYAXIS,XAXIS, NOSYM, XYAXIS}, /* cosh*/ {XYAXIS,XYAXIS,XYAXIS,XYAXIS,XAXIS, NOSYM, XYAXIS}, /* exp */ {XAXIS, XAXIS, XAXIS, XAXIS, XAXIS, NOSYM, XYAXIS}, /* log */ {NOSYM, NOSYM, NOSYM, NOSYM, NOSYM, XAXIS, NOSYM}, /* sqr */ {XYAXIS,XYAXIS,XYAXIS,XYAXIS,XYAXIS,NOSYM, XYAXIS}, }; /* if(trigndx[0]==EXP || trigndx[0]==LOG || trigndx[1]==EXP || trigndx[1]==LOG) symmetry = XAXIS; else if((trigndx[0]==SIN && trigndx[1]==SIN)||(trigndx[0]==COS && trigndx[1]==COS)) symmetry = PI_SYM; else if((trigndx[0]==SIN && trigndx[1]==COS)||(trigndx[0]==COS && trigndx[1]==SIN)) symmetry = YAXIS; else symmetry = XYAXIS; */ if(trigndx[0] < 7 && trigndx[1] < 7) /* bounds of array JCO 5/22/92*/ symmetry = fnxfn[trigndx[0]][trigndx[1]]; /* JCO 5/22/92 */ /* defaults to XAXIS symmetry JCO 5/22/92 */ else { /* added to complete the symmetry JCO 5/22/92 */ if (trigndx[0]==LOG || trigndx[1] ==LOG) symmetry = NOSYM; if (trigndx[0]==9 || trigndx[1] ==9) { /* 'real' cos */ if (trigndx[0]==SIN || trigndx[1] ==SIN) symmetry = PI_SYM; if (trigndx[0]==COS || trigndx[1] ==COS) symmetry = PI_SYM; } if (trigndx[0]==9 && trigndx[1] ==9) symmetry = PI_SYM; } if(curfractalspecific->isinteger) return(JulialongSetup()); else return(JuliafpSetup()); } MandelTrigSetup() { int isinteger; if((isinteger = curfractalspecific->isinteger) != 0) curfractalspecific->orbitcalc = LambdaTrigFractal; else curfractalspecific->orbitcalc = LambdaTrigfpFractal; symmetry = XYAXIS_NOPARM; switch(trigndx[0]) { case SIN: case COS: if(isinteger) curfractalspecific->orbitcalc = LambdaTrigFractal1; else curfractalspecific->orbitcalc = LambdaTrigfpFractal1; break; case SINH: case COSH: if(isinteger) curfractalspecific->orbitcalc = LambdaTrigFractal2; else curfractalspecific->orbitcalc = LambdaTrigfpFractal2; break; case EXP: symmetry = XAXIS_NOPARM; if(isinteger) curfractalspecific->orbitcalc = LongLambdaexponentFractal; else curfractalspecific->orbitcalc = LambdaexponentFractal; break; case LOG: symmetry = XAXIS_NOPARM; break; default: /* added for additional functions, JCO 5/25/92 */ symmetry = XYAXIS_NOPARM; break; } if(isinteger) return(MandellongSetup()); else return(MandelfpSetup()); } MarksJuliaSetup() { #ifndef XFRACT if(param[2] < 1) param[2] = 1; c_exp = (int)param[2]; longparm = &lparm; lold = *longparm; if(c_exp > 3) lcpower(&lold,c_exp-1,&lcoefficient,bitshift); else if(c_exp == 3) { lcoefficient.x = multiply(lold.x,lold.x,bitshift) - multiply(lold.y,lold.y,bitshift); lcoefficient.y = multiply(lold.x,lold.y,bitshiftless1); } else if(c_exp == 2) lcoefficient = lold; else if(c_exp < 2) { lcoefficient.x = 1L << bitshift; lcoefficient.y = 0L; } get_julia_attractor (0.0, 0.0); /* an attractor? */ #endif return(1); } MarksJuliafpSetup() { if(param[2] < 1) param[2] = 1; c_exp = (int)param[2]; floatparm = &parm; old = *floatparm; if(c_exp > 3) cpower(&old,c_exp-1,&coefficient); else if(c_exp == 3) { coefficient.x = sqr(old.x) - sqr(old.y); coefficient.y = old.x * old.y * 2; } else if(c_exp == 2) coefficient = old; else if(c_exp < 2) { coefficient.x = 1.0; coefficient.y = 0.0; } get_julia_attractor (0.0, 0.0); /* an attractor? */ return(1); } SierpinskiSetup() { /* sierpinski */ periodicitycheck = 0; /* disable periodicity checks */ ltmp.x = 1; ltmp.x = ltmp.x << bitshift; /* ltmp.x = 1 */ ltmp.y = ltmp.x >> 1; /* ltmp.y = .5 */ return(1); } SierpinskiFPSetup() { /* sierpinski */ periodicitycheck = 0; /* disable periodicity checks */ tmp.x = 1; tmp.y = 0.5; return(1); } HalleySetup() { /* Halley */ periodicitycheck=0; if(usr_floatflag) fractype = HALLEY; /* float on */ else fractype = MPHALLEY; curfractalspecific = &fractalspecific[fractype]; degree = (int)parm.x; if(degree < 2) degree = 2; param[0] = (double)degree; /* precalculated values */ AplusOne = degree + 1; /* a+1 */ Ap1deg = AplusOne * degree; #ifndef XFRACT if(fractype == MPHALLEY) { setMPfunctions(); mpAplusOne = *pd2MP((double)AplusOne); mpAp1deg = *pd2MP((double)Ap1deg); mpctmpparm.x = *pd2MP(parm.y); mpctmpparm.y = *pd2MP(parm2.y); mptmpparm2x = *pd2MP(parm2.x); mpone = *pd2MP(1.0); } #endif if(degree % 2) symmetry = XAXIS; /* odd */ else symmetry = XYAXIS; /* even */ return(1); } PhoenixSetup() { longparm = &lparm; /* added to consolidate code 10/1/92 JCO */ floatparm = &parm; degree = (int)parm2.x; if(degree < 2 && degree > -3) degree = 0; param[2] = (double)degree; if(degree == 0){ if(usr_floatflag) curfractalspecific->orbitcalc = PhoenixFractal; else curfractalspecific->orbitcalc = LongPhoenixFractal; } if(degree >= 2){ degree = degree - 1; if(usr_floatflag) curfractalspecific->orbitcalc = PhoenixPlusFractal; else curfractalspecific->orbitcalc = LongPhoenixPlusFractal; } if(degree <= -3){ degree = abs(degree) - 2; if(usr_floatflag) curfractalspecific->orbitcalc = PhoenixMinusFractal; else curfractalspecific->orbitcalc = LongPhoenixMinusFractal; } return(1); } PhoenixCplxSetup() { longparm = &lparm; floatparm = &parm; degree = (int)param[4]; if(degree < 2 && degree > -3) degree = 0; param[4] = (double)degree; if(degree == 0){ if(parm2.x != 0 || parm2.y != 0) symmetry = NOSYM; else symmetry = ORIGIN; if(parm.y == 0 && parm2.y == 0) symmetry = XAXIS; if(usr_floatflag) curfractalspecific->orbitcalc = PhoenixFractalcplx; else curfractalspecific->orbitcalc = LongPhoenixFractalcplx; } if(degree >= 2){ degree = degree - 1; if(parm.y == 0 && parm2.y == 0) symmetry = XAXIS; else symmetry = NOSYM; if(usr_floatflag) curfractalspecific->orbitcalc = PhoenixCplxPlusFractal; else curfractalspecific->orbitcalc = LongPhoenixCplxPlusFractal; } if(degree <= -3){ degree = abs(degree) - 2; if(parm.y == 0 && parm2.y == 0) symmetry = XAXIS; else symmetry = NOSYM; if(usr_floatflag) curfractalspecific->orbitcalc = PhoenixCplxMinusFractal; else curfractalspecific->orbitcalc = LongPhoenixCplxMinusFractal; } return(1); } MandPhoenixSetup() { longparm = &linit; /* added to consolidate code 10/1/92 JCO */ floatparm = &init; degree = (int)parm2.x; if(degree < 2 && degree > -3) degree = 0; param[2] = (double)degree; if(degree == 0){ if(usr_floatflag) curfractalspecific->orbitcalc = PhoenixFractal; else curfractalspecific->orbitcalc = LongPhoenixFractal; } if(degree >= 2){ degree = degree - 1; if(usr_floatflag) curfractalspecific->orbitcalc = PhoenixPlusFractal; else curfractalspecific->orbitcalc = LongPhoenixPlusFractal; } if(degree <= -3){ degree = abs(degree) - 2; if(usr_floatflag) curfractalspecific->orbitcalc = PhoenixMinusFractal; else curfractalspecific->orbitcalc = LongPhoenixMinusFractal; } return(1); } MandPhoenixCplxSetup() { longparm = &linit; /* added to consolidate code 10/1/92 JCO */ floatparm = &init; degree = (int)param[4]; if(degree < 2 && degree > -3) degree = 0; param[4] = (double)degree; if(parm.y != 0 || parm2.y != 0) symmetry = NOSYM; if(degree == 0){ if(usr_floatflag) curfractalspecific->orbitcalc = PhoenixFractalcplx; else curfractalspecific->orbitcalc = LongPhoenixFractalcplx; } if(degree >= 2){ degree = degree - 1; if(usr_floatflag) curfractalspecific->orbitcalc = PhoenixCplxPlusFractal; else curfractalspecific->orbitcalc = LongPhoenixCplxPlusFractal; } if(degree <= -3){ degree = abs(degree) - 2; if(usr_floatflag) curfractalspecific->orbitcalc = PhoenixCplxMinusFractal; else curfractalspecific->orbitcalc = LongPhoenixCplxMinusFractal; } return(1); } StandardSetup() { if(fractype==UNITYFP) periodicitycheck=0; return(1); } VLSetup() { if (param[0] < 0.0) param[0] = 0.0; if (param[1] < 0.0) param[1] = 0.0; if (param[0] > 1.0) param[0] = 1.0; if (param[1] > 1.0) param[1] = 1.0; floatparm = &parm; return 1; }