MBDyn-1.7.3
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups
nonlinpb.h
Go to the documentation of this file.
1 /* $Header: /var/cvs/mbdyn/mbdyn/mbdyn-1.0/mbdyn/base/nonlinpb.h,v 1.21 2017/01/12 14:46:10 masarati Exp $ */
2 /*
3  * MBDyn (C) is a multibody analysis code.
4  * http://www.mbdyn.org
5  *
6  * Copyright (C) 1996-2017
7  *
8  * Pierangelo Masarati <masarati@aero.polimi.it>
9  * Paolo Mantegazza <mantegazza@aero.polimi.it>
10  *
11  * Dipartimento di Ingegneria Aerospaziale - Politecnico di Milano
12  * via La Masa, 34 - 20156 Milano, Italy
13  * http://www.aero.polimi.it
14  *
15  * Changing this copyright notice is forbidden.
16  *
17  * This program is free software; you can redistribute it and/or modify
18  * it under the terms of the GNU General Public License as published by
19  * the Free Software Foundation (version 2 of the License).
20  *
21  *
22  * This program is distributed in the hope that it will be useful,
23  * but WITHOUT ANY WARRANTY; without even the implied warranty of
24  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
25  * GNU General Public License for more details.
26  *
27  * You should have received a copy of the GNU General Public License
28  * along with this program; if not, write to the Free Software
29  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
30  */
31 
32  /*
33  *
34  * Copyright (C) 2003-2017
35  * Giuseppe Quaranta <quaranta@aero.polimi.it>
36  *
37  * interfaccia dello Step integrator con il nonlinear solver
38  */
39 
40 #ifndef NONLINPB_H
41 #define NONLINPB_H
42 
43 #include <solman.h>
44 
46 
48 {
49 public:
50  /* Distruttore */
51  virtual ~NonlinearProblem(void) { };
52 
53  virtual void Residual(VectorHandler* pRes) const = 0;
54 
55  virtual void Jacobian(MatrixHandler* pJac) const = 0;
56 
57  virtual void Update(const VectorHandler* pSol) const = 0;
58 
59  /* scale factor for tests */
60  virtual doublereal TestScale(const NonlinearSolverTest *pTest,
61  doublereal& dAlgebraicEquations) const = 0;
62 
63  virtual void EvalProd(doublereal Tau, const VectorHandler& f0,
64  const VectorHandler& w, VectorHandler& z) const = 0;
65 };
66 
67 #endif /* NONLINPB_H */
68 
virtual void Jacobian(MatrixHandler *pJac) const =0
virtual doublereal TestScale(const NonlinearSolverTest *pTest, doublereal &dAlgebraicEquations) const =0
static double * f0
virtual void Residual(VectorHandler *pRes) const =0
virtual void EvalProd(doublereal Tau, const VectorHandler &f0, const VectorHandler &w, VectorHandler &z) const =0
virtual ~NonlinearProblem(void)
Definition: nonlinpb.h:51
virtual void Update(const VectorHandler *pSol) const =0
double doublereal
Definition: colamd.c:52