home *** CD-ROM | disk | FTP | other *** search
/ Geek Gadgets 1 / ADE-1.bin / ade-dist / octave-1.1.1p1-src.tgz / tar.out / fsf / octave / liboctave / DAEFunc.h < prev    next >
C/C++ Source or Header  |  1996-09-28  |  2KB  |  90 lines

  1. // DAEFunc.h                                             -*- C++ -*-
  2. /*
  3.  
  4. Copyright (C) 1992, 1993, 1994, 1995 John W. Eaton
  5.  
  6. This file is part of Octave.
  7.  
  8. Octave is free software; you can redistribute it and/or modify it
  9. under the terms of the GNU General Public License as published by the
  10. Free Software Foundation; either version 2, or (at your option) any
  11. later version.
  12.  
  13. Octave is distributed in the hope that it will be useful, but WITHOUT
  14. ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  15. FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
  16. for more details.
  17.  
  18. You should have received a copy of the GNU General Public License
  19. along with Octave; see the file COPYING.  If not, write to the Free
  20. Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
  21.  
  22. */
  23.  
  24. #if !defined (octave_DAEFunc_h)
  25. #define octave_DAEFunc_h 1
  26.  
  27. class Matrix;
  28. class ColumnVector;
  29.  
  30. extern "C++" {
  31.  
  32. #ifndef Vector
  33. #define Vector ColumnVector
  34. #endif
  35.  
  36. #if !defined (octave_DAEFunc_typedefs)
  37. #define octave_DAEFunc_typedefs 1
  38.  
  39. #endif
  40.  
  41. class DAEFunc
  42. {
  43. public:
  44.  
  45.   struct DAEJac
  46.     {
  47.       Matrix *dfdxdot;
  48.       Matrix *dfdx;
  49.     };
  50.  
  51.   typedef Vector (*DAERHSFunc) (const Vector& x,
  52.                 const Vector& xdot, double); 
  53.  
  54.   typedef DAEJac (*DAEJacFunc) (const Vector& x,
  55.                 const Vector& xdot, double);
  56.  
  57.   DAEFunc (void);
  58.   DAEFunc (DAERHSFunc f);
  59.   DAEFunc (DAERHSFunc f, DAEJacFunc j);
  60.  
  61.   DAEFunc (const DAEFunc& a);
  62.  
  63.   DAEFunc& operator = (const DAEFunc& a);
  64.  
  65.   DAERHSFunc function (void) const;
  66.  
  67.   DAEFunc& set_function (DAERHSFunc f);
  68.  
  69.   DAEJacFunc jacobian_function (void) const;
  70.  
  71.   DAEFunc& set_jacobian_function (DAEJacFunc f);
  72.  
  73. protected:
  74.  
  75.   DAERHSFunc fun;
  76.  
  77.   DAEJacFunc jac;
  78. };
  79.  
  80. } // extern "C++"
  81.  
  82. #endif
  83.  
  84. /*
  85. ;;; Local Variables: ***
  86. ;;; mode: C++ ***
  87. ;;; page-delimiter: "^/\\*" ***
  88. ;;; End: ***
  89. */
  90.