home *** CD-ROM | disk | FTP | other *** search
/ OS/2 Shareware BBS: Graphics / Graphics.zip / povsrc31.zip / hcmplx.h < prev    next >
C/C++ Source or Header  |  1999-10-20  |  4KB  |  85 lines

  1. /****************************************************************************
  2. *                   hcmplx.h
  3. *
  4. *  This module contains all defines, typedefs, and prototypes for HCMPLX.C.
  5. *
  6. *  from Persistence of Vision(tm) Ray Tracer
  7. *  Copyright 1996,1999 Persistence of Vision Team
  8. *---------------------------------------------------------------------------
  9. *  NOTICE: This source code file is provided so that users may experiment
  10. *  with enhancements to POV-Ray and to port the software to platforms other
  11. *  than those supported by the POV-Ray Team.  There are strict rules under
  12. *  which you are permitted to use this file.  The rules are in the file
  13. *  named POVLEGAL.DOC which should be distributed with this file.
  14. *  If POVLEGAL.DOC is not available or for more info please contact the POV-Ray
  15. *  Team Coordinator by email to team-coord@povray.org or visit us on the web at
  16. *  http://www.povray.org. The latest version of POV-Ray may be found at this site.
  17. *
  18. * This program is based on the popular DKB raytracer version 2.12.
  19. * DKBTrace was originally written by David K. Buck.
  20. * DKBTrace Ver 2.0-2.12 were written by David K. Buck & Aaron A. Collins.
  21. *
  22. *****************************************************************************/
  23.  
  24. #ifndef HCMPLX_H
  25. #define HCMPLX_H
  26.  
  27. /*****************************************************************************
  28. * Global preprocessor defines
  29. ******************************************************************************/
  30.  
  31. /*****************************************************************************
  32. * Global typedefs
  33. ******************************************************************************/
  34.  
  35. /*****************************************************************************
  36. * Global variables
  37. ******************************************************************************/
  38.  
  39. /*****************************************************************************
  40. * Global functions
  41. ******************************************************************************/
  42.  
  43. int F_Bound_HCompl (RAY *, FRACTAL *, DBL *, DBL *);
  44. void Normal_Calc_HCompl (VECTOR, int, FRACTAL *);
  45. int Iteration_HCompl (VECTOR, FRACTAL *);
  46. int D_Iteration_HCompl (VECTOR, FRACTAL *, DBL *);
  47.  
  48. int F_Bound_HCompl_z3 (RAY *, FRACTAL *, DBL *, DBL *);
  49. void Normal_Calc_HCompl_z3 (VECTOR, int, FRACTAL *);
  50. int Iteration_HCompl_z3 (VECTOR, FRACTAL *);
  51. int D_Iteration_HCompl_z3 (VECTOR, FRACTAL *, DBL *);
  52.  
  53. int F_Bound_HCompl_Reciprocal (RAY *, FRACTAL *, DBL *, DBL *);
  54. void Normal_Calc_HCompl_Reciprocal (VECTOR, int, FRACTAL *);
  55. int Iteration_HCompl_Reciprocal (VECTOR, FRACTAL *);
  56. int D_Iteration_HCompl_Reciprocal (VECTOR, FRACTAL *, DBL *);
  57.  
  58. int F_Bound_HCompl_Func (RAY *, FRACTAL *, DBL *, DBL *);
  59. void Normal_Calc_HCompl_Func (VECTOR, int, FRACTAL *);
  60. int Iteration_HCompl_Func (VECTOR, FRACTAL *);
  61. int D_Iteration_HCompl_Func (VECTOR, FRACTAL *, DBL *);
  62.  
  63. void Complex_Exp (CMPLX *target, CMPLX *source);
  64. void Complex_Log (CMPLX *target, CMPLX *source);
  65. void Complex_Sin (CMPLX *target, CMPLX *source);
  66. void Complex_ASin (CMPLX *target, CMPLX *source);
  67. void Complex_Sinh (CMPLX *target, CMPLX *source);
  68. void Complex_ASinh (CMPLX *target, CMPLX *source);
  69. void Complex_Cos (CMPLX *target, CMPLX *source);
  70. void Complex_ACos (CMPLX *target, CMPLX *source);
  71. void Complex_Cosh (CMPLX *target, CMPLX *source);
  72. void Complex_ACosh (CMPLX *target, CMPLX *source);
  73. void Complex_Tan (CMPLX *target, CMPLX *source);
  74. void Complex_ATan (CMPLX *target, CMPLX *source);
  75. void Complex_Tanh (CMPLX *target, CMPLX *source);
  76. void Complex_ATanh (CMPLX *target, CMPLX *source);
  77. void Complex_Sqrt (CMPLX *target, CMPLX *source);
  78. void Complex_Pwr (CMPLX *target, CMPLX *source);
  79.  
  80. void Complex_Mult (CMPLX *target, CMPLX *source1, CMPLX *source2);
  81. void Complex_Div (CMPLX *target, CMPLX *source1, CMPLX *source2);
  82. void Complex_Power (CMPLX *target, CMPLX *source1, CMPLX *source2);
  83.  
  84. #endif
  85.