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
use dos_clients_io::gmt_m1::segment::{HardpointsForces, RBM};
use gmt_dos_actors::{
io::{Data, Read, Size, Write},
Update,
};
use hardpoints_dynamics::HardpointsDynamics;
use std::sync::Arc;
mod loadcell;
pub use loadcell::LoadCells;
type M = nalgebra::Matrix6<f64>;
type V = nalgebra::Vector6<f64>;
pub struct Hardpoints {
dynamics: HardpointsDynamics,
rbm_2_hp: M,
m1_hpk: f64,
}
impl Hardpoints {
pub fn new(stiffness: f64, rbm_2_hp: M) -> Self {
Self {
dynamics: HardpointsDynamics::new(),
rbm_2_hp,
m1_hpk: stiffness,
}
}
}
impl<const ID: u8> Size<RBM<ID>> for Hardpoints {
fn len(&self) -> usize {
6
}
}
impl<const ID: u8> Size<HardpointsForces<ID>> for Hardpoints {
fn len(&self) -> usize {
6
}
}
impl<const ID: u8> Read<RBM<ID>> for Hardpoints {
fn read(&mut self, data: Arc<Data<RBM<ID>>>) {
let hp = self.rbm_2_hp * V::from_column_slice(&data);
self.dynamics.inputs.In1 = hp
.as_slice()
.try_into()
.expect("failed to import `RBM` in `HardpointsDynamics` input");
}
}
impl Update for Hardpoints {
fn update(&mut self) {
self.dynamics.step();
}
}
impl<const ID: u8> Write<HardpointsForces<ID>> for Hardpoints {
fn write(&mut self) -> Option<Arc<Data<HardpointsForces<ID>>>> {
let data: Vec<f64> = self
.dynamics
.outputs
.Out1
.iter()
.map(|d| *d * self.m1_hpk)
.collect();
Some(Arc::new(Data::new(data)))
}
}