DESERT 4.0.0
uwgmposition.h
Go to the documentation of this file.
1//
2// Copyright (c) 2017 Regents of the SIGNET lab, University of Padova.
3// All rights reserved.
4//
5// Redistribution and use in source and binary forms, with or without
6// modification, are permitted provided that the following conditions
7// are met:
8// 1. Redistributions of source code must retain the above copyright
9// notice, this list of conditions and the following disclaimer.
10// 2. Redistributions in binary form must reproduce the above copyright
11// notice, this list of conditions and the following disclaimer in the
12// documentation and/or other materials provided with the distribution.
13// 3. Neither the name of the University of Padova (SIGNET lab) nor the
14// names of its contributors may be used to endorse or promote products
15// derived from this software without specific prior written permission.
16//
17// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
19// TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
20// PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
21// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
22// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
23// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
24// OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
25// WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
26// OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
27// ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28//
29
40#ifndef _UWGAUSSMARKOVMOBMODEL_
41#define _UWGAUSSMARKOVMOBMODEL_
42
43#include "node-core.h"
44
45#define sgn(x) (((x) == 0.0) ? 0.0 : ((x) / fabs(x)))
46#define pi (4 * atan(1.0))
47
55
59class UwGMPosition : public Position
60{
61
62public:
67
71 virtual ~UwGMPosition();
72
83 virtual int command(int argc, const char *const *argv);
84
85protected:
93 virtual double getX();
94
102 virtual double getY();
103
111 virtual double getZ();
112
119 double alpha_;
122 double alphaPitch_;
123 double speedMean_;
126 double pitchMean_;
137 double updateTime_;
140 double speed_;
141 double direction_;
142 double pitch_;
143 int debug_;
145private:
151 virtual void update(double now);
157 double Gaussian();
158
159 double vx;
160 double vy;
161 double vz;
162};
163
164#endif // _UWGAUSSMARKOVMOBMODEL_
Definition uwgmposition.h:60
virtual void update(double now)
Definition uwgmposition.cpp:146
double Gaussian()
Definition uwgmposition.cpp:140
double vx
Definition uwgmposition.h:159
double vz
Definition uwgmposition.h:161
virtual int command(int argc, const char *const *argv)
Definition uwgmposition.cpp:103
double alpha_
Definition uwgmposition.h:119
int debug_
Definition uwgmposition.h:143
double speedMean_
Definition uwgmposition.h:123
double pitchMean_
Definition uwgmposition.h:126
double direction_
Definition uwgmposition.h:141
virtual ~UwGMPosition()
Definition uwgmposition.cpp:98
virtual double getX()
Definition uwgmposition.cpp:296
UwGMPosition()
Definition uwgmposition.cpp:66
BoundType bound_
Definition uwgmposition.h:127
double directionMean_
Definition uwgmposition.h:125
double yFieldWidth_
Definition uwgmposition.h:115
double nextUpdateTime_
Definition uwgmposition.h:138
virtual double getY()
Definition uwgmposition.cpp:305
double vy
Definition uwgmposition.h:160
virtual double getZ()
Definition uwgmposition.cpp:314
double speed_
Definition uwgmposition.h:140
double xFieldWidth_
Definition uwgmposition.h:113
double zFieldWidth_
Definition uwgmposition.h:117
double updateTime_
Definition uwgmposition.h:137
double pitch_
Definition uwgmposition.h:142
double alphaPitch_
Definition uwgmposition.h:122
BoundType
Defines the behaviour of the node when it reaches an edge of the simulation field.
Definition uwgmposition.h:54
@ THOROIDAL
Definition uwgmposition.h:54
@ SPHERIC
Definition uwgmposition.h:54
@ REBOUNCE
Definition uwgmposition.h:54
@ HARDWALL
Definition uwgmposition.h:54