-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfTrimAconst.m
155 lines (122 loc) · 3.82 KB
/
fTrimAconst.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
function [results,rudderangle]=trim(geo,state,trimaxis,trimwing,trimrudder,solvertype)
%Trimfunction for TORNADO
%
%
% Trimaxis is the body axis of momentum to trim around:
% 1=l (roll);
% 2=m (pitch);
% 3=n (yaw);
%
% Trimwing is the wing number to change incidence on to acieve trim
%
% Trimrudder is the rudder (control effector) to change setting of in order
% to acieve trim.
%
% Output:
% rudderangle is either the needed change in incedence of a wing, Or the
% rudder setting needed to acieve trim.
%%%%%%%%
results.matrix=ones(9,6,1);
twistdelta=0.001;
converged=0;
rudderangle=0;
%% Checking input
if trimaxis==1
elseif trimaxis==2
elseif trimaxis==3
else
terror(18)
results=[];
return
end
if trimwing*trimrudder>0
terror(19)
results=[];
return
end
if trimrudder>0;
if sum(sum(geo.flapped'))==0
terror(2)
results=[];
return
end
end
if sum(sum(geo.flapped'))<trimrudder
terror(2)
results=[];
return
end
if trimwing<1
if trimrudder<1
terror(20)
results=[];
return
end
end
%% Computing baseline results
[lattice,ref]=fLattice_setup2(geo,state,solvertype);
[results]=solver9(results,state,geo,lattice,ref);
[results]=coeff_create3(results,lattice,state,ref,geo);
if trimaxis==1
m0=results.Cl;
elseif trimaxis==2
m0=results.Cm;
elseif trimaxis==3
m0=results.Cn;
end
k=0;
rudderangle=0;
%% Iterating
while converged==0; %Looping until converged condition
k=k+1;
rudderangle=rudderangle+twistdelta;
[lattice,ref]=fLattice_setup2(geo,state,solvertype);
if trimwing>0
%change twist
%geo.TW(trimwing,:,:)=geo.TW(trimwing,:,:)+twistdelta;
Raxle=[0 cos(geo.dihed(trimwing,1)) sin(geo.dihed(trimwing,1))];
%Setting the rotation axle to the dihedral of the trimmimng wings
%first partition.
hinge_pos=[geo.startx(trimwing)+0.25*geo.c(trimwing) geo.starty(trimwing) geo.startz(trimwing) ];
%Rotating wing about c/4 root chord point.
lattice=wingrotation2(trimwing,geo,lattice,Raxle,hinge_pos,rudderangle);
end
if trimrudder>0
%change ruddersetting
[n,m]=find(geo.flapped');
geo.flap_vector(m(trimrudder),n(trimrudder))=rudderangle;
[lattice,ref]=fLattice_setup2(geo,state,solvertype);
end
[results]=solver9(results,state,geo,lattice,ref);
[results]=coeff_create3(results,lattice,state,ref,geo);
if trimaxis==1
m1=results.Cl;
elseif trimaxis==2
m1=results.Cm;
elseif trimaxis==3
m1=results.Cn;
end
if abs(m1)<0.001
converged=1;
tdisp('C O N V E R G E D ! ! !')
%return
end
if k>9
tdisp('NOT CONVERGED!!!')
results=[];
return
end
dm_dTW=(m1-m0)/twistdelta;
m0=m1;
twistdelta=-m0/dm_dTW;
end
results.matrix(:,:)=[results.CL results.CL_a results.CL_b results.CL_P results.CL_Q results.CL_R
results.CD results.CD_a results.CD_b results.CD_P results.CD_Q results.CD_R
results.CC results.CC_a results.CC_b results.CC_P results.CC_Q results.CC_R
results.Cl results.Cl_a results.Cl_b results.Cl_P results.Cl_Q results.Cl_R
results.Cm results.Cm_a results.Cm_b results.Cm_P results.Cm_Q results.Cm_R
results.Cn results.Cn_a results.Cn_b results.Cn_P results.Cn_Q results.Cn_R
results.CX results.CX_a results.CX_b results.CX_P results.CX_Q results.CX_R
results.CY results.CY_a results.CY_b results.CY_P results.CY_Q results.CY_R
results.CZ results.CZ_a results.CZ_b results.CZ_P results.CZ_Q results.CZ_R];
end