MBDyn-1.7.3
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups
shdrive.cc
Go to the documentation of this file.
1 /* $Header: /var/cvs/mbdyn/mbdyn/mbdyn-1.0/mbdyn/base/shdrive.cc,v 1.9 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 /* Drive che usa i gradi di liberta' */
33 
34 #include "mbconfig.h" /* This goes first in every *.c,*.cc file */
35 
36 #include "shdrive.h"
37 
39  const DriveCaller *pFunc, const DriveCaller *pTrigger,
40  const doublereal dVal0)
41 : DriveCaller(pDH), dVal0(dVal0)
42 {
43  iSHDriveNumber = pDrvHdl->iSHInit(pFunc, pTrigger, dVal0);
44 }
45 
47  integer iSHDriveNumber)
48 : DriveCaller(pDH), iSHDriveNumber(iSHDriveNumber)
49 {
50  dVal0 = pDrvHdl->dGetSHVal0(iSHDriveNumber);
51 }
52 
54 {
55  NO_OP;
56 }
57 
58 /* Copia */
61 {
62  DriveCaller* pDC = 0;
66  return pDC;
67 }
68 
69 /* Scrive il contributo del DriveCaller al file di restart */
70 std::ostream&
71 SHDriveCaller::Restart(std::ostream& out) const
72 {
73  out
74  << " sample and hold, ",
76  << ", ",
78  if (dVal0) {
79  out << ", initial value, " << dVal0;
80  }
81 
82  return out;
83 }
doublereal dVal0
Definition: shdrive.h:50
integer iSHDriveNumber
Definition: shdrive.h:49
const DriveCaller * pGetSHTrigger(integer iNumber) const
Definition: drive.cc:330
integer iSHInit(const DriveCaller *pFunc, const DriveCaller *pTrigger, const doublereal dVal0)
Definition: drive.cc:310
#define NO_OP
Definition: myassert.h:74
virtual DriveCaller * pCopy(void) const
Definition: shdrive.cc:60
virtual std::ostream & Restart(std::ostream &out) const =0
SHDriveCaller(const DriveHandler *pDH, const DriveCaller *pFunc, const DriveCaller *pTrigger, const doublereal dVal0)
Definition: shdrive.cc:38
const DriveCaller * pGetSHFunc(integer iNumber) const
Definition: drive.cc:324
DriveHandler * pDrvHdl
Definition: drive.h:444
#define SAFENEWWITHCONSTRUCTOR(pnt, item, constructor)
Definition: mynewmem.h:698
virtual ~SHDriveCaller(void)
Definition: shdrive.cc:53
double doublereal
Definition: colamd.c:52
long int integer
Definition: colamd.c:51
const doublereal dGetSHVal0(integer iNumber) const
Definition: drive.cc:336
virtual std::ostream & Restart(std::ostream &out) const
Definition: shdrive.cc:71