HCMPLX.H 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  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. #ifndef HCMPLX_H
  24. #define HCMPLX_H
  25. /*****************************************************************************
  26. * Global preprocessor defines
  27. ******************************************************************************/
  28. /*****************************************************************************
  29. * Global typedefs
  30. ******************************************************************************/
  31. /*****************************************************************************
  32. * Global variables
  33. ******************************************************************************/
  34. /*****************************************************************************
  35. * Global functions
  36. ******************************************************************************/
  37. int F_Bound_HCompl (RAY *, FRACTAL *, DBL *, DBL *);
  38. void Normal_Calc_HCompl (VECTOR, int, FRACTAL *);
  39. int Iteration_HCompl (VECTOR, FRACTAL *);
  40. int D_Iteration_HCompl (VECTOR, FRACTAL *, DBL *);
  41. int F_Bound_HCompl_z3 (RAY *, FRACTAL *, DBL *, DBL *);
  42. void Normal_Calc_HCompl_z3 (VECTOR, int, FRACTAL *);
  43. int Iteration_HCompl_z3 (VECTOR, FRACTAL *);
  44. int D_Iteration_HCompl_z3 (VECTOR, FRACTAL *, DBL *);
  45. int F_Bound_HCompl_Reciprocal (RAY *, FRACTAL *, DBL *, DBL *);
  46. void Normal_Calc_HCompl_Reciprocal (VECTOR, int, FRACTAL *);
  47. int Iteration_HCompl_Reciprocal (VECTOR, FRACTAL *);
  48. int D_Iteration_HCompl_Reciprocal (VECTOR, FRACTAL *, DBL *);
  49. int F_Bound_HCompl_Func (RAY *, FRACTAL *, DBL *, DBL *);
  50. void Normal_Calc_HCompl_Func (VECTOR, int, FRACTAL *);
  51. int Iteration_HCompl_Func (VECTOR, FRACTAL *);
  52. int D_Iteration_HCompl_Func (VECTOR, FRACTAL *, DBL *);
  53. void Complex_Exp (CMPLX *target, CMPLX *source);
  54. void Complex_Log (CMPLX *target, CMPLX *source);
  55. void Complex_Sin (CMPLX *target, CMPLX *source);
  56. void Complex_ASin (CMPLX *target, CMPLX *source);
  57. void Complex_Sinh (CMPLX *target, CMPLX *source);
  58. void Complex_ASinh (CMPLX *target, CMPLX *source);
  59. void Complex_Cos (CMPLX *target, CMPLX *source);
  60. void Complex_ACos (CMPLX *target, CMPLX *source);
  61. void Complex_Cosh (CMPLX *target, CMPLX *source);
  62. void Complex_ACosh (CMPLX *target, CMPLX *source);
  63. void Complex_Tan (CMPLX *target, CMPLX *source);
  64. void Complex_ATan (CMPLX *target, CMPLX *source);
  65. void Complex_Tanh (CMPLX *target, CMPLX *source);
  66. void Complex_ATanh (CMPLX *target, CMPLX *source);
  67. void Complex_Sqrt (CMPLX *target, CMPLX *source);
  68. void Complex_Pwr (CMPLX *target, CMPLX *source);
  69. void Complex_Mult (CMPLX *target, CMPLX *source1, CMPLX *source2);
  70. void Complex_Div (CMPLX *target, CMPLX *source1, CMPLX *source2);
  71. void Complex_Power (CMPLX *target, CMPLX *source1, CMPLX *source2);
  72. #endif