home *** CD-ROM | disk | FTP | other *** search
/ Computerworld 1996 March / Computerworld_1996-03_cd.bin / idg_cd3 / grafika / fraktaly / frasr192 / mpmath.h < prev    next >
C/C++ Source or Header  |  1995-01-12  |  7KB  |  200 lines

  1. /*
  2.  *  REMOVED FORMAL PARAMETERS FROM FUNCTION DEFINITIONS (1/4/92)
  3.  */
  4.  
  5.  
  6. #ifndef MPMATH_H
  7. #define MPMATH_H
  8.  
  9. #ifndef _CMPLX_DEFINED
  10. #include "cmplx.h"
  11. #endif
  12.  
  13. #ifdef XFRACT
  14. #define far
  15. #endif
  16.  
  17.  
  18. #ifndef XFRACT
  19. struct MP {
  20.    int Exp;
  21.         unsigned long Mant;
  22. };
  23. #else
  24. struct MP {
  25.    double val;
  26. };
  27. #endif
  28.  
  29. struct MPC {
  30.         struct MP x, y;
  31. };
  32.  
  33. extern int MPOverflow;
  34. extern int DivideOverflow;
  35.  
  36. /* Mark Peterson's expanded floating point operators.  Automatically uses
  37.    either the 8086 or 80386 processor type specified in global 'cpu'. If
  38.    the operation results in an overflow (result < 2**(2**14), or division
  39.    by zero) the global 'MPoverflow' is set to one. */
  40.  
  41. /* function pointer support added by Tim Wegner 12/07/89 */
  42. extern int         (*pMPcmp)(struct MP , struct MP );
  43. extern struct MP  *(*pMPmul)(struct MP , struct MP );
  44. extern struct MP  *(*pMPdiv)(struct MP , struct MP );
  45. extern struct MP  *(*pMPadd)(struct MP , struct MP );
  46. extern struct MP  *(*pMPsub)(struct MP , struct MP );
  47. extern struct MP  *(*pd2MP)(double )                ;
  48. extern double     *(*pMP2d)(struct MP )             ;
  49.  
  50.  
  51. /*** Formula Declarations ***/
  52. enum MATH_TYPE { D_MATH, M_MATH, L_MATH };
  53. extern enum MATH_TYPE MathType;
  54.  
  55. #define fDiv(x, y, z) (void)((*(long*)&z) = RegDivFloat(*(long*)&x, *(long*)&y))
  56. #define fMul16(x, y, z) (void)((*(long*)&z) = r16Mul(*(long*)&x, *(long*)&y))
  57. #define fShift(x, Shift, z) (void)((*(long*)&z) = \
  58.    RegSftFloat(*(long*)&x, Shift))
  59. #define Fg2Float(x, f, z) (void)((*(long*)&z) = RegFg2Float(x, f))
  60. #define Float2Fg(x, f) RegFloat2Fg(*(long*)&x, f)
  61. #define fLog14(x, z) (void)((*(long*)&z) = \
  62.         RegFg2Float(LogFloat14(*(long*)&x), 16))
  63. #define fExp14(x, z) (void)((*(long*)&z) = ExpFloat14(*(long*)&x));
  64. #define fSqrt14(x, z) fLog14(x, z); fShift(z, -1, z); fExp14(z, z)
  65.  
  66. /* the following are declared 4 dimensional as an experiment */
  67. /* changeing declarations to _CMPLX and _LCMPLX restores the code */
  68. /* to 2D */
  69. union Arg {
  70.    _CMPLX     d;
  71.    struct MPC m;
  72.    _LCMPLX    l;
  73. /*
  74.    _DHCMPLX   dh; 
  75.    _LHCMPLX   lh; */  
  76. };
  77.  
  78. struct ConstArg {
  79.    char *s;
  80.    int len;
  81.    union Arg a;
  82. };
  83.  
  84. extern union Arg *Arg1,*Arg2;
  85.  
  86. extern void lStkSin(void),lStkCos(void),lStkSinh(void),lStkCosh(void),lStkLog(void),lStkExp(void),lStkSqr(void);
  87. extern void dStkSin(void),dStkCos(void),dStkSinh(void),dStkCosh(void),dStkLog(void),dStkExp(void),dStkSqr(void);
  88.  
  89. extern void (*ltrig0)(void);
  90. extern void (*ltrig1)(void);
  91. extern void (*ltrig2)(void);
  92. extern void (*ltrig3)(void);
  93. extern void (*dtrig0)(void);
  94. extern void (*dtrig1)(void);
  95. extern void (*dtrig2)(void);
  96. extern void (*dtrig3)(void);
  97.  
  98. /* -------------------------------------------------------------------- */
  99. /*   The following #defines allow the complex transcendental functions    */
  100. /*   in parser.c to be used here thus avoiding duplicated code.     */
  101. /* -------------------------------------------------------------------- */
  102. #ifndef XFRACT
  103.  
  104. #define CMPLXmod(z)      (sqr((z).x)+sqr((z).y))
  105. #define CMPLXconj(z)    ((z).y =  -((z).y))
  106. #define LCMPLXmod(z)       (lsqr((z).x)+lsqr((z).y))
  107. #define LCMPLXconj(z)    ((z).y =  -((z).y))
  108.  
  109.  
  110. #define LCMPLXtrig0(arg,out) Arg1->l = (arg); ltrig0(); (out)=Arg1->l
  111. #define LCMPLXtrig1(arg,out) Arg1->l = (arg); ltrig1(); (out)=Arg1->l
  112. #define LCMPLXtrig2(arg,out) Arg1->l = (arg); ltrig2(); (out)=Arg1->l
  113. #define LCMPLXtrig3(arg,out) Arg1->l = (arg); ltrig3(); (out)=Arg1->l
  114.  
  115. #endif /* XFRACT */
  116.  
  117. #define  CMPLXtrig0(arg,out) Arg1->d = (arg); dtrig0(); (out)=Arg1->d
  118. #define  CMPLXtrig1(arg,out) Arg1->d = (arg); dtrig1(); (out)=Arg1->d
  119. #define  CMPLXtrig2(arg,out) Arg1->d = (arg); dtrig2(); (out)=Arg1->d
  120. #define  CMPLXtrig3(arg,out) Arg1->d = (arg); dtrig3(); (out)=Arg1->d
  121.  
  122. #ifndef XFRACT
  123.  
  124. #define LCMPLXsin(arg,out)   Arg1->l = (arg); lStkSin();  (out) = Arg1->l
  125. #define LCMPLXcos(arg,out)   Arg1->l = (arg); lStkCos();  (out) = Arg1->l
  126. #define LCMPLXsinh(arg,out)  Arg1->l = (arg); lStkSinh(); (out) = Arg1->l
  127. #define LCMPLXcosh(arg,out)  Arg1->l = (arg); lStkCosh(); (out) = Arg1->l
  128. #define LCMPLXlog(arg,out)   Arg1->l = (arg); lStkLog();  (out) = Arg1->l
  129. #define LCMPLXexp(arg,out)   Arg1->l = (arg); lStkExp();  (out) = Arg1->l
  130. /*
  131. #define LCMPLXsqr(arg,out)   Arg1->l = (arg); lStkSqr();  (out) = Arg1->l
  132. */
  133. #define LCMPLXsqr(arg,out)   \
  134.    (out).x = lsqr((arg).x) - lsqr((arg).y);\
  135.    (out).y = multiply((arg).x, (arg).y, bitshiftless1)
  136. #define LCMPLXsqr_old(out)     \
  137.    (out).y = multiply(lold.x, lold.y, bitshiftless1);\
  138.    (out).x = ltempsqrx - ltempsqry
  139.  
  140. #define LCMPLXpwr(arg1,arg2,out)    Arg2->l = (arg1); Arg1->l = (arg2);\
  141.      lStkPwr(); Arg1++; Arg2++; (out) = Arg2->l
  142. #define LCMPLXmult(arg1,arg2,out)    Arg2->l = (arg1); Arg1->l = (arg2);\
  143.      lStkMul(); Arg1++; Arg2++; (out) = Arg2->l
  144. #define LCMPLXadd(arg1,arg2,out)    \
  145.     (out).x = (arg1).x + (arg2).x; (out).y = (arg1).y + (arg2).y
  146. #define LCMPLXsub(arg1,arg2,out)    \
  147.     (out).x = (arg1).x - (arg2).x; (out).y = (arg1).y - (arg2).y
  148.  
  149. #define LCMPLXtimesreal(arg,real,out)    \
  150.     (out).x = multiply((arg).x,(real),bitshift);\
  151.     (out).y = multiply((arg).y,(real),bitshift)
  152.  
  153. #define LCMPLXrecip(arg,out)    \
  154. { long denom; denom = lsqr((arg).x) + lsqr((arg).y);\
  155. if(denom==0L) overflow=1; else {(out).x = divide((arg).x,denom,bitshift);\
  156. (out).y = -divide((arg).y,denom,bitshift);}}
  157. #endif /* XFRACT */
  158.  
  159. #define CMPLXsin(arg,out)    Arg1->d = (arg); dStkSin();  (out) = Arg1->d
  160. #define CMPLXcos(arg,out)    Arg1->d = (arg); dStkCos();  (out) = Arg1->d
  161. #define CMPLXsinh(arg,out)   Arg1->d = (arg); dStkSinh(); (out) = Arg1->d
  162. #define CMPLXcosh(arg,out)   Arg1->d = (arg); dStkCosh(); (out) = Arg1->d
  163. #define CMPLXlog(arg,out)    Arg1->d = (arg); dStkLog();  (out) = Arg1->d
  164. #define CMPLXexp(arg,out)    FPUcplxexp(&(arg), &(out))
  165. /*
  166. #define CMPLXsqr(arg,out)    Arg1->d = (arg); dStkSqr();  (out) = Arg1->d
  167. */
  168. #define CMPLXsqr(arg,out)    \
  169.    (out).x = sqr((arg).x) - sqr((arg).y);\
  170.    (out).y = ((arg).x+(arg).x) * (arg).y
  171. #define CMPLXsqr_old(out)    \
  172.    (out).y = (old.x+old.x) * old.y;\
  173.    (out).x = tempsqrx - tempsqry
  174.  
  175. #define CMPLXpwr(arg1,arg2,out)   (out)= ComplexPower((arg1), (arg2))
  176. #define CMPLXmult1(arg1,arg2,out)    Arg2->d = (arg1); Arg1->d = (arg2);\
  177.      dStkMul(); Arg1++; Arg2++; (out) = Arg2->d
  178. #define CMPLXmult(arg1,arg2,out)  \
  179.     {\
  180.        _CMPLX TmP;\
  181.        TmP.x = (arg1).x*(arg2).x - (arg1).y*(arg2).y;\
  182.        TmP.y = (arg1).x*(arg2).y + (arg1).y*(arg2).x;\
  183.        (out) = TmP;\
  184.      }
  185. #define CMPLXadd(arg1,arg2,out)    \
  186.     (out).x = (arg1).x + (arg2).x; (out).y = (arg1).y + (arg2).y
  187. #define CMPLXsub(arg1,arg2,out)    \
  188.     (out).x = (arg1).x - (arg2).x; (out).y = (arg1).y - (arg2).y
  189. #define CMPLXtimesreal(arg,real,out)   \
  190.     (out).x = (arg).x*(real);\
  191.     (out).y = (arg).y*(real)
  192.  
  193. #define CMPLXrecip(arg,out)    \
  194.    { double denom; denom = sqr((arg).x) + sqr((arg).y);\
  195.      if(denom==0.0) {(out).x = 1.0e10;(out).y = 1.0e10;}else\
  196.     { (out).x =  (arg).x/denom;\
  197.      (out).y = -(arg).y/denom;}}
  198.  
  199. #endif
  200.