-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathsailor_inverted_linear_model.cpp
82 lines (66 loc) · 2.3 KB
/
sailor_inverted_linear_model.cpp
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
// General Things
#include <stdlib.h>
#include <stdio.h>
#include <math.h>
#include "avalon.h"
// General rtx-Things
#include <rtx/getopt.h>
#include <rtx/main.h>
#include <rtx/error.h>
#include <rtx/timer.h>
#include <rtx/thread.h>
#include <rtx/message.h>
double sailor_inverted_linear_model(double heading_speed, double torque_des,
double speed_x, double speed_y)
{
double dens_water = 1025.0;
double A_rudder = 0.085;
double dist_rudder_CenterOfRotation = 1.7;
double max_rudder_decrease_factor;
double v_r_tot; //in m/s
double d_water;
double incid_angle;
double rudder_angle;
int sign_rudder_angle = 1;
//v_r_tot = sqrt((speed_x*speed_x) + ((speed_y - dist_rudder_CenterOfRotation*heading_speed)*(speed_y - dist_rudder_CenterOfRotation*heading_speed)));
v_r_tot = speed_x;
// d_water = atan2((speed_y - dist_rudder_CenterOfRotation*heading_speed),speed_x)*180/AV_PI;
d_water = 0;
//change rudder direction if we are sailing backwards:
if(v_r_tot > 0.1)
{
sign_rudder_angle = 1;
}
else if(v_r_tot < -0.1)
{
sign_rudder_angle = -1;
}
rudder_angle = sign_rudder_angle * (torque_des / (AV_MODEL_LIN_COEFF*dist_rudder_CenterOfRotation*dens_water*v_r_tot*v_r_tot*A_rudder) *180.0/AV_PI);
if(v_r_tot < 1.0)
{
max_rudder_decrease_factor = v_r_tot * (1.0 - 10.0 / AV_MAX_RUDDER_ANGLE) + (10.0 / AV_MAX_RUDDER_ANGLE);
}
else if( v_r_tot >= 1.0)
{
max_rudder_decrease_factor = 1.0;
}
if(rudder_angle > max_rudder_decrease_factor * AV_MAX_RUDDER_ANGLE)
{
rudder_angle = max_rudder_decrease_factor * AV_MAX_RUDDER_ANGLE;
}
else if (rudder_angle < -max_rudder_decrease_factor * AV_MAX_RUDDER_ANGLE)
{
rudder_angle = -max_rudder_decrease_factor * AV_MAX_RUDDER_ANGLE;
}
#if 0
FILE * model_file;
FILE * model_plot;
model_file = fopen("model_file.txt","a+");
fprintf(model_file,"approach velocity: %f, speed_y: %f, speed_x: %f, theta_dot: %f, rudderangle:%f \n",v_r_tot, speed_y, speed_x, heading_speed, rudder_angle);
fclose(model_file);
model_plot = fopen("model_plot.txt","a+");
fprintf(model_plot,"%f %f %f %f %f \n",v_r_tot, speed_y, speed_x, heading_speed, rudder_angle);
fclose(model_plot);
#endif
return rudder_angle;
}