WarpTwin
Documentation for WarpTwin models and classes.
Loading...
Searching...
No Matches
SimpleDisturbanceWindModel.h
Go to the documentation of this file.
1/******************************************************************************
2* Copyright (c) ATTX INC 2025. All Rights Reserved.
3*
4* This software and associated documentation (the "Software") are the
5* proprietary and confidential information of ATTX, INC. The Software is
6* furnished under a license agreement between ATTX and the user organization
7* and may be used or copied only in accordance with the terms of the agreement.
8* Refer to 'license/attx_license.adoc' for standard license terms.
9*
10* EXPORT CONTROL NOTICE: THIS SOFTWARE MAY INCLUDE CONTENT CONTROLLED UNDER THE
11* INTERNATIONAL TRAFFIC IN ARMS REGULATIONS (ITAR) OR THE EXPORT ADMINISTRATION
12* REGULATIONS (EAR99). No part of the Software may be used, reproduced, or
13* transmitted in any form or by any means, for any purpose, without the express
14* written permission of ATTX, INC.
15******************************************************************************/
16/*
17Simple disturbance wind model header file
18
19Author: James Tabony
20*/
21/*
22Metadata for MS GUI:
23imdata = {"exclude" : True}
24*/
25
26#ifndef MODELS_ENVIRONMENT_SIMPLE_DISTURBANCE_WIND_MODEL_H
27#define MODELS_ENVIRONMENT_SIMPLE_DISTURBANCE_WIND_MODEL_H
28
29#include "simulation/Model.h"
31#include "utils/Interpolate2D.h"
32
33namespace warptwin {
34
52 MODEL(SimpleDisturbanceWindModel)
53 public:
54 // Model params
55 // NAME TYPE DEFAULT VALUE
58 SIGNAL(wind_speed_ref, double, 15.4333)
60 SIGNAL(altitude_surface, double, 0.0)
62 SIGNAL(seed_value, int, 0)
64
65 // Model inputs
66 // NAME TYPE DEFAULT VALUE
69 SIGNAL(altitude, double, 0.0)
71
72 // Model outputs
73 // NAME TYPE DEFAULT VALUE
80 SIGNAL(wind_dist__MWF, CartesianVector3, CartesianVector3({0.0, 0.0, 0.0}))
82
83 protected:
84 int16 start() override;
85 int16 execute() override;
86
88 void _configureInternal();
89
90 // Internal variables for turbulence intensity and scale length in each direction
97
98 // Interal variable for the altitude in feet
100
101 // Internal variables for the output wind components (feet/second)
105
106 // Internal model for generating a random number under a uniform distribution
108
109 // Internal model for linear interlopolation
111 };
112
113}
114
115#endif
#define SIGNAL(NAME, TYPE, INITIAL_VALUE)
Definition appmacros.h:27
#define START_PARAMS
Definition appmacros.h:42
#define END_OUTPUTS
Definition appmacros.h:33
#define END_PARAMS
Definition appmacros.h:47
#define START_OUTPUTS
Definition appmacros.h:28
#define END_INPUTS
Definition appmacros.h:40
#define START_INPUTS
Definition appmacros.h:35
A class for performing simple x-y linear interpolation.
Definition Interpolate2D.h:50
Class to generate random numbers according to normal distribution.
Definition NormalRandom.hpp:40
#define CartesianVector3
Definition mathmacros.h:43
Class to propagate CR3BP dynamics in characteristic units.
Definition statistics.hpp:22
Interpolate2D _interpolate2D_model
Definition SimpleDisturbanceWindModel.h:110
int16 start() override
Class to execute logging.
SIGNAL(_mu, double, warpos::earth_wgs84.mu)
double _wind_u_feet
Definition SimpleDisturbanceWindModel.h:102
double _turb_intensity_v
Definition SimpleDisturbanceWindModel.h:92
NormalRandom< double > * _normal_random
Definition SimpleDisturbanceWindModel.h:107
double _turb_intensity_u
Definition SimpleDisturbanceWindModel.h:91
double _scale_length_w
Definition SimpleDisturbanceWindModel.h:96
void _configureInternal()
Function to configure sensor – runs in all constructors.
double _wind_v_feet
Definition SimpleDisturbanceWindModel.h:103
double _altitude_feet
Definition SimpleDisturbanceWindModel.h:99
@ MODEL
Simplified dynamics model representing motion in the circular restricted 3 body problem.
Definition ImNode.h:31
double _turb_intensity_w
Definition SimpleDisturbanceWindModel.h:93
double _scale_length_v
Definition SimpleDisturbanceWindModel.h:95
int16 execute() override
Function to check monitor input conditions and set trigger flag accordingly. Should be implemented in...
double _wind_w_feet
Definition SimpleDisturbanceWindModel.h:104
double _scale_length_u
Definition SimpleDisturbanceWindModel.h:94