1
0
Fork 0
flightgear/src/FDM/UIUCModel/uiuc_menu_ice.cpp

1268 lines
30 KiB
C++
Raw Normal View History

/**********************************************************************
FILENAME: uiuc_menu_ice.cpp
----------------------------------------------------------------------
DESCRIPTION: reads input data for specified aircraft and creates
approporiate data storage space
----------------------------------------------------------------------
STATUS: alpha version
----------------------------------------------------------------------
REFERENCES: based on "menu reader" format of Michael Selig
----------------------------------------------------------------------
HISTORY: 04/04/2003 initial release
----------------------------------------------------------------------
AUTHOR(S): Robert Deters <rdeters@uiuc.edu>
Michael Selig <m-selig@uiuc.edu>
----------------------------------------------------------------------
VARIABLES:
----------------------------------------------------------------------
INPUTS: n/a
----------------------------------------------------------------------
OUTPUTS: n/a
----------------------------------------------------------------------
CALLED BY: uiuc_menu()
----------------------------------------------------------------------
CALLS TO: check_float() if needed
d_2_to_3() if needed
d_1_to_2() if needed
i_1_to_2() if needed
d_1_to_1() if needed
----------------------------------------------------------------------
COPYRIGHT: (C) 2003 by Michael Selig
This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
USA or view http://www.gnu.org/copyleft/gpl.html.
**********************************************************************/
#include <simgear/compiler.h>
#if defined( __MWERKS__ )
// -dw- optimizer chokes (big-time) trying to optimize humongous
// loop/switch statements
#pragma optimization_level 0
#endif
#include <cstdlib>
#include <string>
#include STL_IOSTREAM
#include "uiuc_menu_ice.h"
SG_USING_STD(cerr);
SG_USING_STD(cout);
SG_USING_STD(endl);
#ifndef _MSC_VER
SG_USING_STD(exit);
#endif
void parse_ice( const string& linetoken2, const string& linetoken3,
const string& linetoken4, const string& linetoken5,
const string& linetoken6, const string& linetoken7,
const string& linetoken8, const string& linetoken9,
const string& linetoken10, const string& aircraft_directory,
LIST command_line ) {
double token_value;
int token_value_convert1, token_value_convert2, token_value_convert3;
double datafile_xArray[100][100], datafile_yArray[100];
double datafile_zArray[100][100];
int datafile_nxArray[100], datafile_ny;
istrstream token3(linetoken3.c_str());
istrstream token4(linetoken4.c_str());
istrstream token5(linetoken5.c_str());
istrstream token6(linetoken6.c_str());
istrstream token7(linetoken7.c_str());
istrstream token8(linetoken8.c_str());
istrstream token9(linetoken9.c_str());
istrstream token10(linetoken10.c_str());
static bool tactilefadef_first = true;
switch(ice_map[linetoken2])
{
case iceTime_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
ice_model = true;
iceTime = token_value;
break;
}
case transientTime_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
transientTime = token_value;
break;
}
case eta_ice_final_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
eta_ice_final = token_value;
break;
}
case beta_probe_wing_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
beta_model = true;
x_probe_wing = token_value;
break;
}
case beta_probe_tail_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
beta_model = true;
x_probe_tail = token_value;
break;
}
case kCDo_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCDo = token_value;
break;
}
case kCDK_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCDK = token_value;
break;
}
case kCD_a_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCD_a = token_value;
break;
}
case kCD_adot_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCD_adot = token_value;
break;
}
case kCD_q_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCD_q = token_value;
break;
}
case kCD_de_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCD_de = token_value;
break;
}
case kCXo_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCXo = token_value;
break;
}
case kCXK_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCXK = token_value;
break;
}
case kCX_a_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCX_a = token_value;
break;
}
case kCX_a2_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCX_a2 = token_value;
break;
}
case kCX_a3_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCX_a3 = token_value;
break;
}
case kCX_adot_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCX_adot = token_value;
break;
}
case kCX_q_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCX_q = token_value;
break;
}
case kCX_de_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCX_de = token_value;
break;
}
case kCX_dr_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCX_dr = token_value;
break;
}
case kCX_df_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCX_df = token_value;
break;
}
case kCX_adf_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCX_adf = token_value;
break;
}
case kCLo_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCLo = token_value;
break;
}
case kCL_a_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCL_a = token_value;
break;
}
case kCL_adot_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCL_adot = token_value;
break;
}
case kCL_q_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCL_q = token_value;
break;
}
case kCL_de_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCL_de = token_value;
break;
}
case kCZo_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCZo = token_value;
break;
}
case kCZ_a_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCZ_a = token_value;
break;
}
case kCZ_a2_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCZ_a2 = token_value;
break;
}
case kCZ_a3_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCZ_a3 = token_value;
break;
}
case kCZ_adot_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCZ_adot = token_value;
break;
}
case kCZ_q_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCZ_q = token_value;
break;
}
case kCZ_de_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCZ_de = token_value;
break;
}
case kCZ_deb2_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCZ_deb2 = token_value;
break;
}
case kCZ_df_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCZ_df = token_value;
break;
}
case kCZ_adf_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCZ_adf = token_value;
break;
}
case kCmo_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCmo = token_value;
break;
}
case kCm_a_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCm_a = token_value;
break;
}
case kCm_a2_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCm_a2 = token_value;
break;
}
case kCm_adot_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCm_adot = token_value;
break;
}
case kCm_q_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCm_q = token_value;
break;
}
case kCm_de_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCm_de = token_value;
break;
}
case kCm_b2_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCm_b2 = token_value;
break;
}
case kCm_r_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCm_r = token_value;
break;
}
case kCm_df_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCm_df = token_value;
break;
}
case kCYo_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCYo = token_value;
break;
}
case kCY_beta_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCY_beta = token_value;
break;
}
case kCY_p_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCY_p = token_value;
break;
}
case kCY_r_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCY_r = token_value;
break;
}
case kCY_da_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCY_da = token_value;
break;
}
case kCY_dr_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCY_dr = token_value;
break;
}
case kCY_dra_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCY_dra = token_value;
break;
}
case kCY_bdot_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCY_bdot = token_value;
break;
}
case kClo_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kClo = token_value;
break;
}
case kCl_beta_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCl_beta = token_value;
break;
}
case kCl_p_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCl_p = token_value;
break;
}
case kCl_r_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCl_r = token_value;
break;
}
case kCl_da_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCl_da = token_value;
break;
}
case kCl_dr_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCl_dr = token_value;
break;
}
case kCl_daa_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCl_daa = token_value;
break;
}
case kCno_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCno = token_value;
break;
}
case kCn_beta_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCn_beta = token_value;
break;
}
case kCn_p_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCn_p = token_value;
break;
}
case kCn_r_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCn_r = token_value;
break;
}
case kCn_da_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCn_da = token_value;
break;
}
case kCn_dr_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCn_dr = token_value;
break;
}
case kCn_q_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCn_q = token_value;
break;
}
case kCn_b3_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
kCn_b3 = token_value;
break;
}
case bootTime_flag:
{
int index;
if (check_float(linetoken4))
token4 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
token3 >> index;
if (index < 0 || index >= 20)
uiuc_warnings_errors(1, *command_line);
bootTime[index] = token_value;
bootTrue[index] = true;
break;
}
case eta_wing_left_input_flag:
{
eta_from_file = true;
eta_wing_left_input = true;
eta_wing_left_input_file = aircraft_directory + linetoken3;
token4 >> token_value_convert1;
token5 >> token_value_convert2;
convert_y = uiuc_convert(token_value_convert1);
convert_x = uiuc_convert(token_value_convert2);
uiuc_1DdataFileReader(eta_wing_left_input_file,
eta_wing_left_input_timeArray,
eta_wing_left_input_daArray,
eta_wing_left_input_ntime);
token6 >> token_value;
eta_wing_left_input_startTime = token_value;
break;
}
case eta_wing_right_input_flag:
{
eta_from_file = true;
eta_wing_right_input = true;
eta_wing_right_input_file = aircraft_directory + linetoken3;
token4 >> token_value_convert1;
token5 >> token_value_convert2;
convert_y = uiuc_convert(token_value_convert1);
convert_x = uiuc_convert(token_value_convert2);
uiuc_1DdataFileReader(eta_wing_right_input_file,
eta_wing_right_input_timeArray,
eta_wing_right_input_daArray,
eta_wing_right_input_ntime);
token6 >> token_value;
eta_wing_right_input_startTime = token_value;
break;
}
case eta_tail_input_flag:
{
eta_from_file = true;
eta_tail_input = true;
eta_tail_input_file = aircraft_directory + linetoken3;
token4 >> token_value_convert1;
token5 >> token_value_convert2;
convert_y = uiuc_convert(token_value_convert1);
convert_x = uiuc_convert(token_value_convert2);
uiuc_1DdataFileReader(eta_tail_input_file,
eta_tail_input_timeArray,
eta_tail_input_daArray,
eta_tail_input_ntime);
token6 >> token_value;
eta_tail_input_startTime = token_value;
break;
}
case nonlin_ice_case_flag:
{
token3 >> nonlin_ice_case;
break;
}
case eta_tail_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
eta_tail = token_value;
break;
}
case eta_wing_left_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
eta_wing_left = token_value;
break;
}
case eta_wing_right_flag:
{
if (check_float(linetoken3))
token3 >> token_value;
else
uiuc_warnings_errors(1, *command_line);
eta_wing_right = token_value;
break;
}
case demo_eps_alpha_max_flag:
{
demo_eps_alpha_max = true;
demo_eps_alpha_max_file = aircraft_directory + linetoken3;
token4 >> token_value_convert1;
token5 >> token_value_convert2;
convert_y = uiuc_convert(token_value_convert1);
convert_x = uiuc_convert(token_value_convert2);
uiuc_1DdataFileReader(demo_eps_alpha_max_file,
demo_eps_alpha_max_timeArray,
demo_eps_alpha_max_daArray,
demo_eps_alpha_max_ntime);
token6 >> token_value;
demo_eps_alpha_max_startTime = token_value;
break;
}
case demo_eps_pitch_max_flag:
{
demo_eps_pitch_max = true;
demo_eps_pitch_max_file = aircraft_directory + linetoken3;
token4 >> token_value_convert1;
token5 >> token_value_convert2;
convert_y = uiuc_convert(token_value_convert1);
convert_x = uiuc_convert(token_value_convert2);
uiuc_1DdataFileReader(demo_eps_pitch_max_file,
demo_eps_pitch_max_timeArray,
demo_eps_pitch_max_daArray,
demo_eps_pitch_max_ntime);
token6 >> token_value;
demo_eps_pitch_max_startTime = token_value;
break;
}
case demo_eps_pitch_min_flag:
{
demo_eps_pitch_min = true;
demo_eps_pitch_min_file = aircraft_directory + linetoken3;
token4 >> token_value_convert1;
token5 >> token_value_convert2;
convert_y = uiuc_convert(token_value_convert1);
convert_x = uiuc_convert(token_value_convert2);
uiuc_1DdataFileReader(demo_eps_pitch_min_file,
demo_eps_pitch_min_timeArray,
demo_eps_pitch_min_daArray,
demo_eps_pitch_min_ntime);
token6 >> token_value;
demo_eps_pitch_min_startTime = token_value;
break;
}
case demo_eps_roll_max_flag:
{
demo_eps_roll_max = true;
demo_eps_roll_max_file = aircraft_directory + linetoken3;
token4 >> token_value_convert1;
token5 >> token_value_convert2;
convert_y = uiuc_convert(token_value_convert1);
convert_x = uiuc_convert(token_value_convert2);
uiuc_1DdataFileReader(demo_eps_roll_max_file,
demo_eps_roll_max_timeArray,
demo_eps_roll_max_daArray,
demo_eps_roll_max_ntime);
token6 >> token_value;
demo_eps_roll_max_startTime = token_value;
break;
}
case demo_eps_thrust_min_flag:
{
demo_eps_thrust_min = true;
demo_eps_thrust_min_file = aircraft_directory + linetoken3;
token4 >> token_value_convert1;
token5 >> token_value_convert2;
convert_y = uiuc_convert(token_value_convert1);
convert_x = uiuc_convert(token_value_convert2);
uiuc_1DdataFileReader(demo_eps_thrust_min_file,
demo_eps_thrust_min_timeArray,
demo_eps_thrust_min_daArray,
demo_eps_thrust_min_ntime);
token6 >> token_value;
demo_eps_thrust_min_startTime = token_value;
break;
}
case demo_eps_airspeed_max_flag:
{
demo_eps_airspeed_max = true;
demo_eps_airspeed_max_file = aircraft_directory + linetoken3;
token4 >> token_value_convert1;
token5 >> token_value_convert2;
convert_y = uiuc_convert(token_value_convert1);
convert_x = uiuc_convert(token_value_convert2);
uiuc_1DdataFileReader(demo_eps_airspeed_max_file,
demo_eps_airspeed_max_timeArray,
demo_eps_airspeed_max_daArray,
demo_eps_airspeed_max_ntime);
token6 >> token_value;
demo_eps_airspeed_max_startTime = token_value;
break;
}
case demo_eps_airspeed_min_flag:
{
demo_eps_airspeed_min = true;
demo_eps_airspeed_min_file = aircraft_directory + linetoken3;
token4 >> token_value_convert1;
token5 >> token_value_convert2;
convert_y = uiuc_convert(token_value_convert1);
convert_x = uiuc_convert(token_value_convert2);
uiuc_1DdataFileReader(demo_eps_airspeed_min_file,
demo_eps_airspeed_min_timeArray,
demo_eps_airspeed_min_daArray,
demo_eps_airspeed_min_ntime);
token6 >> token_value;
demo_eps_airspeed_min_startTime = token_value;
break;
}
case demo_eps_flap_max_flag:
{
demo_eps_flap_max = true;
demo_eps_flap_max_file = aircraft_directory + linetoken3;
token4 >> token_value_convert1;
token5 >> token_value_convert2;
convert_y = uiuc_convert(token_value_convert1);
convert_x = uiuc_convert(token_value_convert2);
uiuc_1DdataFileReader(demo_eps_flap_max_file,
demo_eps_flap_max_timeArray,
demo_eps_flap_max_daArray,
demo_eps_flap_max_ntime);
token6 >> token_value;
demo_eps_flap_max_startTime = token_value;
break;
}
case demo_boot_cycle_tail_flag:
{
demo_boot_cycle_tail = true;
demo_boot_cycle_tail_file = aircraft_directory + linetoken3;
token4 >> token_value_convert1;
token5 >> token_value_convert2;
convert_y = uiuc_convert(token_value_convert1);
convert_x = uiuc_convert(token_value_convert2);
uiuc_1DdataFileReader(demo_boot_cycle_tail_file,
demo_boot_cycle_tail_timeArray,
demo_boot_cycle_tail_daArray,
demo_boot_cycle_tail_ntime);
token6 >> token_value;
demo_boot_cycle_tail_startTime = token_value;
break;
}
case demo_boot_cycle_wing_left_flag:
{
demo_boot_cycle_wing_left = true;
demo_boot_cycle_wing_left_file = aircraft_directory + linetoken3;
token4 >> token_value_convert1;
token5 >> token_value_convert2;
convert_y = uiuc_convert(token_value_convert1);
convert_x = uiuc_convert(token_value_convert2);
uiuc_1DdataFileReader(demo_boot_cycle_wing_left_file,
demo_boot_cycle_wing_left_timeArray,
demo_boot_cycle_wing_left_daArray,
demo_boot_cycle_wing_left_ntime);
token6 >> token_value;
demo_boot_cycle_wing_left_startTime = token_value;
break;
}
case demo_boot_cycle_wing_right_flag:
{
demo_boot_cycle_wing_right = true;
demo_boot_cycle_wing_right_file = aircraft_directory + linetoken3;
token4 >> token_value_convert1;
token5 >> token_value_convert2;
convert_y = uiuc_convert(token_value_convert1);
convert_x = uiuc_convert(token_value_convert2);
uiuc_1DdataFileReader(demo_boot_cycle_wing_right_file,
demo_boot_cycle_wing_right_timeArray,
demo_boot_cycle_wing_right_daArray,
demo_boot_cycle_wing_right_ntime);
token6 >> token_value;
demo_boot_cycle_wing_right_startTime = token_value;
break;
}
case demo_eps_pitch_input_flag:
{
demo_eps_pitch_input = true;
demo_eps_pitch_input_file = aircraft_directory + linetoken3;
token4 >> token_value_convert1;
token5 >> token_value_convert2;
convert_y = uiuc_convert(token_value_convert1);
convert_x = uiuc_convert(token_value_convert2);
uiuc_1DdataFileReader(demo_eps_pitch_input_file,
demo_eps_pitch_input_timeArray,
demo_eps_pitch_input_daArray,
demo_eps_pitch_input_ntime);
token6 >> token_value;
demo_eps_pitch_input_startTime = token_value;
break;
}
case demo_ap_Theta_ref_deg_flag:
{
demo_ap_Theta_ref_deg = true;
demo_ap_Theta_ref_deg_file = aircraft_directory + linetoken3;
token4 >> token_value_convert1;
token5 >> token_value_convert2;
convert_y = uiuc_convert(token_value_convert1);
convert_x = uiuc_convert(token_value_convert2);
uiuc_1DdataFileReader(demo_ap_Theta_ref_deg_file,
demo_ap_Theta_ref_deg_timeArray,
demo_ap_Theta_ref_deg_daArray,
demo_ap_Theta_ref_deg_ntime);
token6 >> token_value;
demo_ap_Theta_ref_deg_startTime = token_value;
break;
}
case demo_ap_pah_on_flag:
{
demo_ap_pah_on = true;
demo_ap_pah_on_file = aircraft_directory + linetoken3;
token4 >> token_value_convert1;
token5 >> token_value_convert2;
convert_y = uiuc_convert(token_value_convert1);
convert_x = uiuc_convert(token_value_convert2);
uiuc_1DdataFileReader(demo_ap_pah_on_file,
demo_ap_pah_on_timeArray,
demo_ap_pah_on_daArray,
demo_ap_pah_on_ntime);
token6 >> token_value;
demo_ap_pah_on_startTime = token_value;
break;
}
case tactilefadef_flag:
{
int tactilefadef_index, i;
string tactilefadef_file;
double flap_value;
tactilefadef = true;
tactilefadef_file = aircraft_directory + linetoken3;
token4 >> tactilefadef_index;
if (tactilefadef_index < 0 || tactilefadef_index >= 30)
uiuc_warnings_errors(1, *command_line);
if (tactilefadef_index > tactilefadef_nf)
tactilefadef_nf = tactilefadef_index;
token5 >> flap_value;
tactilefadef_fArray[tactilefadef_index] = flap_value;
token6 >> token_value_convert1;
token7 >> token_value_convert2;
token8 >> token_value_convert3;
token9 >> tactilefadef_nice;
convert_z = uiuc_convert(token_value_convert1);
convert_x = uiuc_convert(token_value_convert2);
convert_y = uiuc_convert(token_value_convert3);
/* call 2D File Reader with file name (tactilefadef_file) and
conversion factors; function returns array of
elevator deflections (deArray) and corresponding
alpha (aArray) and delta CZ (CZArray) values and
max number of terms in alpha arrays (nAlphaArray)
and delfection array (nde) */
uiuc_2DdataFileReader(tactilefadef_file,
datafile_xArray,
datafile_yArray,
datafile_zArray,
datafile_nxArray,
datafile_ny);
d_2_to_3(datafile_xArray, tactilefadef_aArray, tactilefadef_index);
d_1_to_2(datafile_yArray, tactilefadef_deArray, tactilefadef_index);
d_2_to_3(datafile_zArray, tactilefadef_tactileArray, tactilefadef_index);
i_1_to_2(datafile_nxArray, tactilefadef_nAlphaArray, tactilefadef_index);
tactilefadef_nde[tactilefadef_index] = datafile_ny;
if (tactilefadef_first==true)
{
if (tactilefadef_nice == 1)
{
tactilefadef_na_nice = datafile_nxArray[1];
tactilefadef_nde_nice = datafile_ny;
d_1_to_1(datafile_yArray, tactilefadef_deArray_nice);
for (i=1; i<=tactilefadef_na_nice; i++)
tactilefadef_aArray_nice[i] = datafile_xArray[1][i];
}
tactilefadef_first=false;
}
break;
}
case tactile_pitch_flag:
{
tactile_pitch = 1;
break;
}
case demo_tactile_flag:
{
demo_tactile = true;
demo_tactile_file = aircraft_directory + linetoken3;
token4 >> token_value_convert1;
token5 >> token_value_convert2;
convert_y = uiuc_convert(token_value_convert1);
convert_x = uiuc_convert(token_value_convert2);
uiuc_1DdataFileReader(demo_tactile_file,
demo_tactile_timeArray,
demo_tactile_daArray,
demo_tactile_ntime);
token6 >> token_value;
demo_tactile_startTime = token_value;
break;
}
case demo_ice_tail_flag:
{
demo_ice_tail = true;
demo_ice_tail_file = aircraft_directory + linetoken3;
token4 >> token_value_convert1;
token5 >> token_value_convert2;
convert_y = uiuc_convert(token_value_convert1);
convert_x = uiuc_convert(token_value_convert2);
uiuc_1DdataFileReader(demo_ice_tail_file,
demo_ice_tail_timeArray,
demo_ice_tail_daArray,
demo_ice_tail_ntime);
token6 >> token_value;
demo_ice_tail_startTime = token_value;
break;
}
case demo_ice_left_flag:
{
demo_ice_left = true;
demo_ice_left_file = aircraft_directory + linetoken3;
token4 >> token_value_convert1;
token5 >> token_value_convert2;
convert_y = uiuc_convert(token_value_convert1);
convert_x = uiuc_convert(token_value_convert2);
uiuc_1DdataFileReader(demo_ice_left_file,
demo_ice_left_timeArray,
demo_ice_left_daArray,
demo_ice_left_ntime);
token6 >> token_value;
demo_ice_left_startTime = token_value;
break;
}
case demo_ice_right_flag:
{
demo_ice_right = true;
demo_ice_right_file = aircraft_directory + linetoken3;
token4 >> token_value_convert1;
token5 >> token_value_convert2;
convert_y = uiuc_convert(token_value_convert1);
convert_x = uiuc_convert(token_value_convert2);
uiuc_1DdataFileReader(demo_ice_right_file,
demo_ice_right_timeArray,
demo_ice_right_daArray,
demo_ice_right_ntime);
token6 >> token_value;
demo_ice_right_startTime = token_value;
break;
}
default:
{
if (ignore_unknown_keywords) {
// do nothing
} else {
// print error message
uiuc_warnings_errors(2, *command_line);
}
break;
}
};
}