• Skip to content
  • Skip to link menu
KDE API Reference
  • KDE API Reference
  • kdeedu API Reference
  • KDE Home
  • Contact Us
 

step/stepcore

  • sources
  • kde-4.12
  • kdeedu
  • step
  • stepcore
gslsolver.cc
Go to the documentation of this file.
1 /* This file is part of StepCore library.
2  Copyright (C) 2007 Vladimir Kuznetsov <ks.vladimir@gmail.com>
3 
4  StepCore library is free software; you can redistribute it and/or modify
5  it under the terms of the GNU General Public License as published by
6  the Free Software Foundation; either version 2 of the License, or
7  (at your option) any later version.
8 
9  StepCore library is distributed in the hope that it will be useful,
10  but WITHOUT ANY WARRANTY; without even the implied warranty of
11  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  GNU General Public License for more details.
13 
14  You should have received a copy of the GNU General Public License
15  along with StepCore; if not, write to the Free Software
16  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
17 */
18 
19 #include "gslsolver.h"
20 
21 #ifdef STEPCORE_WITH_GSL
22 
23 #include "util.h"
24 #include <cstring>
25 #include <cmath>
26 #include <QtGlobal>
27 
28 namespace StepCore
29 {
30 
31 STEPCORE_META_OBJECT(GslGenericSolver, QT_TRANSLATE_NOOP("ObjectClass", "GslGenericSolver"), QT_TR_NOOP("GSL generic solver"), MetaObject::ABSTRACT, STEPCORE_SUPER_CLASS(Solver),)
32 
33 STEPCORE_META_OBJECT(GslSolver, QT_TRANSLATE_NOOP("ObjectClass", "GslSolver"), QT_TR_NOOP("GSL non-adaptive solver"), MetaObject::ABSTRACT,
34  STEPCORE_SUPER_CLASS(GslGenericSolver),)
35 
36 STEPCORE_META_OBJECT(GslAdaptiveSolver, QT_TRANSLATE_NOOP("ObjectClass", "GslAdaptiveSolver"), QT_TR_NOOP("GSL adaptive solver"), MetaObject::ABSTRACT,
37  STEPCORE_SUPER_CLASS(GslGenericSolver),)
38 
39 STEPCORE_META_OBJECT(GslRK2Solver, QT_TRANSLATE_NOOP("ObjectClass", "GslRK2Solver"), QT_TR_NOOP("Runge-Kutta second-order solver from GSL library"),
40  0, STEPCORE_SUPER_CLASS(GslSolver),)
41 STEPCORE_META_OBJECT(GslAdaptiveRK2Solver, QT_TRANSLATE_NOOP("ObjectClass", "GslAdaptiveRK2Solver"), QT_TR_NOOP("Adaptive Runge-Kutta second-order solver from GSL library"),
42  0, STEPCORE_SUPER_CLASS(GslAdaptiveSolver),)
43 
44 STEPCORE_META_OBJECT(GslRK4Solver, QT_TRANSLATE_NOOP("ObjectClass", "GslRK4Solver"), QT_TR_NOOP("Runge-Kutta classical fourth-order solver from GSL library"),
45  0, STEPCORE_SUPER_CLASS(GslSolver),)
46 STEPCORE_META_OBJECT(GslAdaptiveRK4Solver, QT_TRANSLATE_NOOP("ObjectClass", "GslAdaptiveRK4Solver"), QT_TR_NOOP("Adaptive Runge-Kutta classical fourth-order solver from GSL library"),
47  0, STEPCORE_SUPER_CLASS(GslAdaptiveSolver),)
48 
49 STEPCORE_META_OBJECT(GslRKF45Solver, QT_TRANSLATE_NOOP("ObjectClass", "GslRKF45Solver"), QT_TR_NOOP("Runge-Kutta-Fehlberg (4,5) solver from GSL library"),
50  0, STEPCORE_SUPER_CLASS(GslSolver),)
51 STEPCORE_META_OBJECT(GslAdaptiveRKF45Solver, QT_TRANSLATE_NOOP("ObjectClass", "GslAdaptiveRKF45Solver"), QT_TR_NOOP("Adaptive Runge-Kutta-Fehlberg (4,5) solver from GSL library"),
52  0, STEPCORE_SUPER_CLASS(GslAdaptiveSolver),)
53 
54 STEPCORE_META_OBJECT(GslRKCKSolver, QT_TRANSLATE_NOOP("ObjectClass", "GslRKCKSolver"), QT_TR_NOOP("Runge-Kutta Cash-Karp (4,5) solver from GSL library"),
55  0, STEPCORE_SUPER_CLASS(GslSolver),)
56 STEPCORE_META_OBJECT(GslAdaptiveRKCKSolver, QT_TRANSLATE_NOOP("ObjectClass", "GslAdaptiveRKCKSolver"), QT_TR_NOOP("Adaptive Runge-Kutta Cash-Karp (4,5) solver from GSL library"),
57  0, STEPCORE_SUPER_CLASS(GslAdaptiveSolver),)
58 
59 STEPCORE_META_OBJECT(GslRK8PDSolver, QT_TRANSLATE_NOOP("ObjectClass", "GslRK8PDSolver"), QT_TR_NOOP("Runge-Kutta Prince-Dormand (8,9) solver from GSL library"),
60  0, STEPCORE_SUPER_CLASS(GslSolver),)
61 STEPCORE_META_OBJECT(GslAdaptiveRK8PDSolver, QT_TRANSLATE_NOOP("ObjectClass", "GslAdaptiveRK8PDSolver"), QT_TR_NOOP("Adaptive Runge-Kutta Prince-Dormand (8,9) solver from GSL library"),
62  0, STEPCORE_SUPER_CLASS(GslAdaptiveSolver),)
63 
64 STEPCORE_META_OBJECT(GslRK2IMPSolver, QT_TRANSLATE_NOOP("ObjectClass", "GslRK2IMPSolver"), QT_TR_NOOP("Runge-Kutta implicit second-order solver from GSL library"),
65  0, STEPCORE_SUPER_CLASS(GslSolver),)
66 STEPCORE_META_OBJECT(GslAdaptiveRK2IMPSolver, QT_TRANSLATE_NOOP("ObjectClass", "GslAdaptiveRK2IMPSolver"), QT_TR_NOOP("Adaptive Runge-Kutta implicit second-order solver from GSL library"),
67  0, STEPCORE_SUPER_CLASS(GslAdaptiveSolver),)
68 
69 STEPCORE_META_OBJECT(GslRK4IMPSolver, QT_TRANSLATE_NOOP("ObjectClass", "GslRK4IMPSolver"), QT_TR_NOOP("Runge-Kutta implicit fourth-order solver from GSL library"),
70  0, STEPCORE_SUPER_CLASS(GslSolver),)
71 STEPCORE_META_OBJECT(GslAdaptiveRK4IMPSolver, QT_TRANSLATE_NOOP("ObjectClass", "GslAdaptiveRK4IMPSolver"), QT_TR_NOOP("Adaptive Runge-Kutta implicit fource-order solver from GSL library"),
72  0, STEPCORE_SUPER_CLASS(GslAdaptiveSolver),)
73 
74 
75 void GslGenericSolver::init()
76 {
77  _yerr.resize(_dimension);
78  _ytemp.resize(_dimension);
79  _ydiff.resize(_dimension);
80  _dydt_in.resize(_dimension);
81  _dydt_out.resize(_dimension);
82 
83  _gslStep = gsl_odeiv_step_alloc(_gslStepType, _dimension);
84  STEPCORE_ASSERT_NOABORT(NULL != _gslStep);
85 
86  _gslSystem.function = gslFunction;
87  _gslSystem.jacobian = NULL;
88  _gslSystem.dimension = _dimension;
89  _gslSystem.params = this;
90 
91  if(_adaptive) {
92  _gslControl = gsl_odeiv_control_y_new(_toleranceAbs, _toleranceRel);
93  STEPCORE_ASSERT_NOABORT(NULL != _gslControl);
94  _gslEvolve = gsl_odeiv_evolve_alloc(_dimension);
95  STEPCORE_ASSERT_NOABORT(NULL != _gslEvolve);
96  } else {
97  _gslControl = NULL;
98  _gslEvolve = NULL;
99  }
100 }
101 
102 void GslGenericSolver::fini()
103 {
104  if(_gslStep != NULL) gsl_odeiv_step_free(_gslStep);
105  if(_gslControl != NULL) gsl_odeiv_control_free(_gslControl);
106  if(_gslEvolve != NULL) gsl_odeiv_evolve_free(_gslEvolve);
107 }
108 
109 int GslGenericSolver::gslFunction(double t, const double* y, double* f, void* params)
110 {
111  GslGenericSolver* s = static_cast<GslGenericSolver*>(params);
112  return s->_function(t, y, 0, f, 0, s->_params);
113 }
114 
115 int GslGenericSolver::doCalcFn(double* t, const VectorXd* y,
116  const VectorXd* yvar, VectorXd* f, VectorXd* fvar)
117 {
118  //int ret = GSL_ODEIV_FN_EVAL(&_gslSystem, *t, y, _ydiff);
119  int ret = _function(*t, y->data(), yvar?yvar->data():0, f ? f->data() : _ydiff.data(),
120  fvar?fvar->data():0, _params);
121  //if(f != NULL) std::memcpy(f, _ydiff, _dimension*sizeof(*f));
122  return ret;
123  //_hasSavedState = true;
124 }
125 
126 int GslGenericSolver::doEvolve(double* t, double t1, VectorXd* y, VectorXd* yvar)
127 {
128  STEPCORE_ASSERT_NOABORT(*t + _stepSize != *t);
129  STEPCORE_ASSERT_NOABORT(*t != t1);
130  //STEPCORE_ASSERT_NOABORT(_dimension != 0);
131 
132  /*
133  if(_hasSavedState) {
134  std::memcpy(_ydiff_in, _ydiff_out, _dimension*sizeof(*_ydiff_in));
135  } else {
136  GSL_ODEIV_FN_EVAL(&_gslSystem, *t, y, _ydiff_in);
137  _hasSavedState = true;
138  }
139  */
140 
141  int gsl_result;
142  _ytemp = *y;
143 
144  if(!_adaptive) {
145  gsl_result = GSL_ODEIV_FN_EVAL(&_gslSystem, *t, y->data(), _dydt_in.data());
146  if(gsl_result != 0) return gsl_result;
147  }
148 
149  while(*t < t1) {
150  double tt = *t;
151  if(_adaptive) {
152  gsl_odeiv_evolve_reset(_gslEvolve); // XXX
153  gsl_result = gsl_odeiv_evolve_apply(_gslEvolve, _gslControl, _gslStep, &_gslSystem,
154  &tt, t1, &_stepSize, _ytemp.data());
155  _yerr = VectorXd::Map(_gslEvolve->yerr, _dimension);
156  } else {
157  STEPCORE_ASSERT_NOABORT(t1-tt > _stepSize/100);
158  gsl_result = gsl_odeiv_step_apply(_gslStep, tt, (_stepSize < t1-tt ? _stepSize : t1-tt),
159  _ytemp.data(), _yerr.data(), _dydt_in.data(),
160  _dydt_out.data(), &_gslSystem);
161  tt = _stepSize < t1-tt ? tt + _stepSize : t1;
162  }
163  if(gsl_result != 0) return gsl_result;
164 
165  // XXX: Do we need to check it ?
166  _localError = 0;
167  _localErrorRatio = 0;
168  for(int i=0; i<_dimension; ++i) {
169  double error = fabs(_yerr[i]);
170  if(error > _localError) _localError = error;
171  double errorRatio = error / (_toleranceAbs + _toleranceRel * fabs(_ytemp[i]));
172  if(errorRatio > _localErrorRatio) _localErrorRatio = errorRatio;
173  }
174  if(_localErrorRatio > 1.1) return ToleranceError;
175 
176  *t = tt;
177  *y = _ytemp;
178  if(!_adaptive) _dydt_in = _dydt_out;
179  }
180 
181  return OK;
182 }
183 
184 } // namespace StepCore
185 
186 #endif // STEPCORE_WITH_GSL
187 
STEPCORE_ASSERT_NOABORT
#define STEPCORE_ASSERT_NOABORT(expr)
Definition: util.h:58
StepCore::STEPCORE_SUPER_CLASS
STEPCORE_SUPER_CLASS(CollisionSolver)
StepCore::QT_TRANSLATE_NOOP
QT_TRANSLATE_NOOP("ObjectClass","GJKCollisionSolver")
gslsolver.h
GslGenericSolver, GslSolver and GslAdaptiveSolver classes.
StepCore::MetaObject::ABSTRACT
Class is abstract.
Definition: object.h:180
util.h
Internal file.
StepCore::QT_TR_NOOP
QT_TR_NOOP("Errors class for CoulombForce")
StepCore::STEPCORE_META_OBJECT
STEPCORE_META_OBJECT(CollisionSolver, QT_TRANSLATE_NOOP("ObjectClass","CollisionSolver"),"CollisionSolver", MetaObject::ABSTRACT, STEPCORE_SUPER_CLASS(Object), STEPCORE_PROPERTY_RW(double, toleranceAbs, QT_TRANSLATE_NOOP("PropertyName","toleranceAbs"), STEPCORE_UNITS_1, QT_TR_NOOP("Allowed absolute tolerance"), toleranceAbs, setToleranceAbs) STEPCORE_PROPERTY_R_D(double, localError, QT_TRANSLATE_NOOP("PropertyName","localError"), STEPCORE_UNITS_1, QT_TR_NOOP("Maximal local error during last step"), localError)) STEPCORE_META_OBJECT(GJKCollisionSolver
StepCore::VectorXd
Eigen::VectorXd VectorXd
Definition: vector.h:38
This file is part of the KDE documentation.
Documentation copyright © 1996-2014 The KDE developers.
Generated on Tue Oct 14 2014 22:43:06 by doxygen 1.8.7 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.

step/stepcore

Skip menu "step/stepcore"
  • Main Page
  • Namespace List
  • Namespace Members
  • Alphabetical List
  • Class List
  • Class Hierarchy
  • Class Members
  • File List
  • File Members
  • Modules
  • Related Pages

kdeedu API Reference

Skip menu "kdeedu API Reference"
  • Analitza
  •     lib
  • kalgebra
  • kalzium
  •   libscience
  • kanagram
  • kig
  •   lib
  • klettres
  • kstars
  • libkdeedu
  •   keduvocdocument
  • marble
  • parley
  • rocs
  •   App
  •   RocsCore
  •   VisualEditor
  •   stepcore

Search



Report problems with this website to our bug tracking system.
Contact the specific authors with questions and comments about the page contents.

KDE® and the K Desktop Environment® logo are registered trademarks of KDE e.V. | Legal