MBDyn-1.7.3
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups
sah.cc
Go to the documentation of this file.
1 /* $Header: /var/cvs/mbdyn/mbdyn/mbdyn-1.0/mbdyn/base/sah.cc,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 #include "mbconfig.h" /* This goes first in every *.c,*.cc file */
33 
34 #include "sah.h"
35 
36 /* SampleAndHold - begin */
37 
39  const DofOwner* pDO,
40  const ScalarNode *pN,
41  DriveCaller *pDC,
42  const doublereal &dSP,
43  flag fOut)
44 : ParameterNode(uL, pDO, 0., fOut),
45 pNode(pN),
46 Time(pDC),
47 dSamplePeriod(dSP)
48 {
49  ASSERT(pN != 0);
50  ASSERT(pDC != 0);
51  ASSERT(dSP > 0.);
52 
54 }
55 
57 {
58  NO_OP;
59 }
60 
61 /* Contributo del nodo al file di restart */
62 std::ostream&
63 SampleAndHold::Restart(std::ostream& out) const
64 {
65  return out << "# sample and hold parameter to be implemented"
66  << std::endl;
67 }
68 
69 void
71  VectorHandler& /* X */, VectorHandler& /* XP */ ,
73 {
75  dX = pNode->dGetX();
76 }
77 
78 /* Aggiorna i valori interni */
79 void
81  const VectorHandler& /* XP */ )
82 {
83  doublereal dT = Time.dGet();
84  if (dT >= dSampleTime) {
85  dX = pNode->dGetX();
87  }
88 }
89 
90 /* SampleAndHold - end */
91 
virtual std::ostream & Restart(std::ostream &out) const
Definition: sah.cc:63
long int flag
Definition: mbdyn.h:43
virtual void SetValue(DataManager *pDM, VectorHandler &X, VectorHandler &XP, SimulationEntity::Hints *ph=0)
Definition: sah.cc:70
const doublereal dSamplePeriod
Definition: sah.h:44
virtual ~SampleAndHold(void)
Definition: sah.cc:56
virtual const doublereal & dGetX(void) const =0
#define NO_OP
Definition: myassert.h:74
doublereal dSampleTime
Definition: sah.h:45
std::vector< Hint * > Hints
Definition: simentity.h:89
doublereal dX
Definition: node.h:405
const DriveOwner Time
Definition: sah.h:43
SampleAndHold(unsigned int uL, const DofOwner *pDO, const ScalarNode *pN, DriveCaller *pDC, const doublereal &dSP, flag fOut)
Definition: sah.cc:38
const ScalarNode * pNode
Definition: sah.h:42
virtual void Update(const class VectorHandler &, const class VectorHandler &)
Definition: sah.cc:80
#define ASSERT(expression)
Definition: colamd.c:977
doublereal dGet(const doublereal &dVar) const
Definition: drive.cc:664
double doublereal
Definition: colamd.c:52