-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrummy_individual.hpp
executable file
·117 lines (94 loc) · 3.91 KB
/
rummy_individual.hpp
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
#ifndef RUMMY_INDIVIDUAL_HPP
#define RUMMY_INDIVIDUAL_HPP
#include <simulation/individual.hpp>
#include <types/movement/pose2d.hpp>
#include <tools/random/random_generator.hpp>
#include <tuple>
#include <Eigen/Core>
#include <chrono>
#include <random>
namespace simu {
namespace simulation {
namespace defaults {
struct RummyIndividualParams {
bool use_closest_individual = false;
float radius = 25.;
// interactions
int perceived_agents = 1;
float gamma_rand = 0.3;
float gamma_wall = 0.23;
float gamma_sym = 0.;
float gamma_asym = 0.;
float dw = 6.;
float dc = 0.7;
float alpha_w = 0.;
float gamma_attraction = 0.3;
float gamma_alignment = 0.3;
// kicks
float vmean = 40.;
float vmin = 1.;
float vmem = 0.9;
float vmem12 = 0.5;
float vcut = 35.;
float taumean = 0.525;
float taumin = 0.2;
float tau0 = 0.8;
// simu
int itermax = 1000;
};
} // namespace defaults
enum Order {
DECREASING,
INCREASING
};
class RummyIndividual;
using RummyIndividualPtr = std::shared_ptr<RummyIndividual>;
using state_t = std::tuple<Eigen::VectorXd, Eigen::VectorXd, Eigen::VectorXd, Eigen::VectorXd>;
using const_state_t = const std::tuple<Eigen::VectorXd, Eigen::VectorXd, Eigen::VectorXd, Eigen::VectorXd>&;
class RummyIndividual : public Individual<double, double> {
public:
RummyIndividual(int id, defaults::RummyIndividualParams params = defaults::RummyIndividualParams());
virtual ~RummyIndividual();
void reinit();
virtual void coast(const std::shared_ptr<Simulation> sim);
virtual void prepare_kick(const std::shared_ptr<Simulation> sim);
virtual bool kick(const std::shared_ptr<Simulation> sim);
virtual void stimulate(const std::shared_ptr<Simulation> sim) override;
virtual void move(const std::shared_ptr<Simulation> sim) override;
virtual float kick_duration() const;
virtual float t0() const;
virtual float& t0();
virtual float tau() const;
virtual float& tau();
virtual Pose2d<float> kick_pose() const;
virtual float speed() const;
virtual Pose2d<float> pose() const;
virtual Pose2d<float>& pose();
virtual Pose2d<float> traj_pose() const;
virtual float traj_speed() const;
const defaults::RummyIndividualParams& params() const;
defaults::RummyIndividualParams& params();
protected:
std::tuple<float, float> compute_interactions(const state_t& state, std::vector<int> neighs, const std::shared_ptr<Simulation> sim);
state_t compute_state(const std::vector<RummyIndividualPtr>& fish) const;
std::vector<int> sort_neighbours(
const Eigen::VectorXd& values, const int kicker_idx, Order order = Order::INCREASING) const;
double angle_to_pipi(double difference) const;
defaults::RummyIndividualParams _params;
Position<position_type_t> _desired_position;
Speed<speed_type_t> _desired_speed;
uint64_t _num_jumps;
uint64_t _num_kicks;
uint64_t _num_uturn;
float _t0;
float _tau;
Pose2d<float> _pose;
Pose2d<float> _traj_pose;
Pose2d<float> _kick_pose;
float _speed;
float _traj_speed;
std::vector<int> _most_inf_idcs;
};
} // namespace simulation
} // namespace simu
#endif