4#include "dl_syscalls.h"
12#include <nlohmann/json.hpp>
19#include "motion-master.pb.h"
76#define JSON_TO_DOUBLE(jx) jx.is_number() ? static_cast<double>(jx) : 0.0
171const std::map<MotionMasterWarning, std::string>
175 "Slave profile: The amplitude is outside of the configured limits - "
176 "using a limit value as the new amplitude!"},
180 {0x2110,
"Short circuit/earth leakage (input)"},
181 {0x2120,
"Earth leakage (input)"},
182 {0x2121,
"Earth leakage phase L1"},
183 {0x2122,
"Earth leakage phase L2"},
184 {0x2123,
"Earth leakage phase L3"},
185 {0x2130,
"Short circuit (input)"},
186 {0x2131,
"Short circuit phases L1-L2"},
187 {0x2132,
"Short circuit phases L2-L3"},
188 {0x2133,
"Short circuit phases L3-L1"},
189 {0x2211,
"Internal current no.1"},
190 {0x2212,
"Internal current no.2"},
191 {0x2213,
"Over-current in ramp function"},
192 {0x2214,
"Over-current in the sequence"},
193 {0x2220,
"Continuous over current (device internal)"},
194 {0x2221,
"Continuous over current no.1"},
195 {0x2222,
"Continuous over current no.2"},
196 {0x2230,
"Short circuit/earth leakage (device internal)"},
197 {0x2240,
"Earth leakage (device internal)"},
198 {0x2250,
"Short circuit (device internal)"},
199 {0x2310,
"Continuous over current"},
200 {0x2311,
"Continuous over current no.1"},
201 {0x2312,
"Continuous over current no.2"},
202 {0x2320,
"Short circuit/earth leakage (motor-side)"},
203 {0x2330,
"Earth leakage (motor-side)"},
204 {0x2331,
"Earth leakage phase U"},
205 {0x2332,
"Earth leakage phase V"},
206 {0x2333,
"Earth leakage phase W"},
207 {0x2340,
"Short circuit (motor-side)"},
208 {0x2341,
"Short circuit phases U-V"},
209 {0x2342,
"Earth leakage phase V-W"},
210 {0x2343,
"Earth leakage phase W-U"},
211 {0x2350,
"Load level fault (I2t, thermal state)"},
212 {0x2351,
"Load level warning (I2t, thermal state)"},
213 {0x3110,
"Mains overvoltage"},
214 {0x3111,
"Mains overvoltage phase L1"},
215 {0x3112,
"Mains overvoltage phase L2"},
216 {0x3113,
"Mains overvoltage phase L3"},
217 {0x3120,
"Mains undervoltage"},
218 {0x3121,
"Mains undervoltage phase L1"},
219 {0x3122,
"Mains undervoltage phase L2"},
220 {0x3123,
"Mains undervoltage phase L3"},
221 {0x3130,
"Phase failure"},
222 {0x3131,
"Phase failure L1"},
223 {0x3132,
"Phase failure L2"},
224 {0x3133,
"Phase failure L3"},
225 {0x3134,
"Phase sequence"},
226 {0x3140,
"Mains frequency"},
227 {0x3141,
"Mains frequency too great"},
228 {0x3142,
"Mains frequency too small"},
229 {0x3210,
"DC link overvoltage"},
230 {0x3211,
"Overvoltage no. 1"},
231 {0x3212,
"Overvoltage no. 2"},
232 {0x3220,
"DC link undervoltage"},
233 {0x3221,
"Undervoltage no. 1"},
234 {0x3222,
"Undervoltage no. 2"},
235 {0x3230,
"Load error"},
236 {0x3310,
"Output overvoltage"},
237 {0x3311,
"Output overvoltage phase U"},
238 {0x3312,
"Output overvoltage phase V"},
239 {0x3313,
"Output overvoltage phase W"},
240 {0x3320,
"Armature circuit"},
241 {0x3321,
"Armature circuit interrupted"},
242 {0x3330,
"Field circuit"},
243 {0x3331,
"Field circuit interrupted"},
244 {0x4110,
"Excess ambient temperature"},
245 {0x4120,
"Too low ambient temperature"},
246 {0x4130,
"Temperature supply air"},
247 {0x4140,
"Temperature air outlet"},
248 {0x4210,
"Excess temperature device"},
249 {0x4220,
"Too low temperature device"},
250 {0x4300,
"Temperature drive"},
251 {0x4310,
"Excess temperature drive"},
252 {0x4320,
"Too low temperature drive"},
253 {0x4400,
"Temperature supply"},
254 {0x4410,
"Excess temperature supply"},
255 {0x4420,
"Too low temperature supply"},
257 {0x5110,
"Supply low voltage"},
258 {0x5111,
"U1 = supply ±15V"},
259 {0x5112,
"U2 = supply +24 V"},
260 {0x5113,
"U3 = supply +5 V"},
261 {0x5114,
"U4 = manufacturer-specific"},
262 {0x5115,
"U5 = manufacturer-specific"},
263 {0x5116,
"U6 = manufacturer-specific"},
264 {0x5117,
"U7 = manufacturer-specific"},
265 {0x5118,
"U8 = manufacturer-specific"},
266 {0x5119,
"U9 = manufacturer-specific"},
267 {0x5120,
"Supply intermediate circuit"},
269 {0x5210,
"Measurement circuit"},
270 {0x5220,
"Computing circuit"},
271 {0x5300,
"Operating unit"},
272 {0x5400,
"Power section"},
273 {0x5410,
"Output stages"},
275 {0x5430,
"Input stages"},
276 {0x5440,
"Contacts"},
277 {0x5441,
"Contact 1 = manufacturer-specific"},
278 {0x5442,
"Contact 2 = manufacturer-specific"},
279 {0x5443,
"Contact 3 = manufacturer-specific"},
280 {0x5444,
"Contact 4 = manufacturer-specific"},
281 {0x5445,
"Contact 5 = manufacturer-specific"},
286 {0x5454,
"S4 = manufacturer-specific"},
287 {0x5455,
"S5 = manufacturer-specific"},
288 {0x5456,
"S6 = manufacturer-specific"},
289 {0x5457,
"S7 = manufacturer-specific"},
290 {0x5458,
"S8 = manufacturer-specific"},
291 {0x5459,
"S9 = manufacturer-specific"},
292 {0x5500,
"Hardware memory"},
294 {0x5520,
"ROM/EPROM"},
296 {0x6010,
"Software reset (watchdog)"},
297 {0x6301,
"to 630Fh Data record no. 1 to no. 15"},
298 {0x6310,
"Loss of parameters"},
299 {0x6320,
"Parameter error"},
301 {0x7110,
"Brake chopper"},
302 {0x7111,
"Failure brake chopper"},
303 {0x7112,
"Over current brake chopper"},
304 {0x7113,
"Protective circuit brake chopper"},
306 {0x7121,
"Motor blocked"},
307 {0x7122,
"Motor error or commutation malfunction."},
308 {0x7123,
"Motor tilted"},
309 {0x7200,
"Measurement circuit"},
311 {0x7301,
"Tacho fault"},
312 {0x7302,
"Tacho wrong polarity"},
313 {0x7303,
"Resolver 1 fault"},
314 {0x7304,
"Resolver 2 fault"},
315 {0x7305,
"Incremental encoder 1 fault"},
316 {0x7306,
"Incremental encoder 2 fault"},
317 {0x7307,
"Incremental encoder 3 fault"},
319 {0x7320,
"Position"},
320 {0x7400,
"Computation circuit"},
321 {0x7500,
"Communication"},
322 {0x7510,
"Serial interface no. 1"},
323 {0x7520,
"Serial interface no. 2"},
324 {0x7600,
"Data storage (external)"},
325 {0x8300,
"Torque control"},
326 {0x8311,
"Excess torque"},
327 {0x8312,
"Difficult start up"},
328 {0x8313,
"Standstill torque"},
329 {0x8321,
"Insufficient torque"},
330 {0x8331,
"Torque fault"},
331 {0x8400,
"Velocity speed controller"},
332 {0x8500,
"Position controller"},
333 {0x8600,
"Positioning controller"},
334 {0x8611,
"Following error"},
335 {0x8612,
"Reference limit"},
336 {0x8700,
"Sync controller"},
337 {0x8800,
"Winding controller"},
338 {0x8900,
"Process data monitoring"},
340 {0xF001,
"Deceleration"},
341 {0xF002,
"Sub-synchronous run"},
342 {0xF003,
"Stroke operation"},
344 {0xFF03,
"Warning - Excess temperature device"},
345 {0xFF04,
"Pull brake voltage higher than measured on DC bus"},
346 {0xFF05,
"Hold brake voltage higher than measured on DC bus"},
347 {0xFF06,
"Open circuit: High FET in phase A"},
348 {0xFF07,
"Open circuit: Low FET in phase A"},
349 {0xFF08,
"Open circuit: High FET in phase B"},
350 {0xFF09,
"Open circuit: Low FET in phase B"},
351 {0xFF0A,
"Open circuit: High FET in phase C"},
352 {0xFF0B,
"Open circuit: Low FET in phase C"},
353 {0xFF0C,
"Commutation offset is missing"}};
355const std::map<int32_t, std::map<int32_t, int32_t>>
357 {8500, {{01, 20480}, {02, 24576}, {03, 16384}}},
358 {8501, {{01, 8192}, {02, 8192}, {03, 16384}}},
359 {8502, {{01, 20480}, {02, 24576}, {03, 16384}}},
360 {8503, {{01, 8192}, {02, 8192}, {03, 16384}}},
361 {8504, {{01, 20480}, {02, 24576}, {03, 16384}}},
362 {8505, {{01, 8192}, {02, 8192}, {03, 16384}}},
363 {9500, {{00, 32768}, {01, 32768}, {02, 32768}}},
364 {9501, {{01, 81920}, {02, 81920}}},
365 {9502, {{01, 16384}}},
366 {9506, {{01, 32768}}},
367 {9507, {{01, 81920}}},
368 {9508, {{01, 16384}}},
369 {9600, {{01, 32768}}},
370 {9601, {{01, 81920}}},
371 {9602, {{01, 16384}}},
372 {9606, {{01, 32768}}},
373 {9607, {{01, 81920}}},
374 {9608, {{01, 16384}}}};
376const std::map<int32_t, std::map<int32_t, int32_t>>
378 {8500, {{01, 40960}, {02, 49152}, {03, 32768}}},
379 {8501, {{01, 16384}, {02, 16384}, {03, 16384}}},
380 {8502, {{01, 40960}, {02, 49152}, {03, 32768}}},
381 {8503, {{01, 16384}, {02, 16384}, {03, 16384}}},
382 {8504, {{01, 40960}, {02, 49152}, {03, 32768}}},
383 {8505, {{01, 16384}, {02, 16384}, {03, 16384}}},
384 {9500, {{00, 32768}, {01, 32768}, {02, 32768}}},
385 {9501, {{01, 81920}, {02, 81920}}},
386 {9502, {{01, 16384}}},
387 {9506, {{01, 32768}}},
388 {9507, {{01, 81920}}},
389 {9508, {{01, 16384}}},
390 {9600, {{01, 32768}}},
391 {9601, {{01, 81920}}},
392 {9602, {{01, 16384}}},
393 {9606, {{01, 32768}}},
394 {9607, {{01, 81920}}},
395 {9608, {{01, 16384}}}};
435int32_t set_default_thread_priority();
448int32_t set_max_thread_priority();
470 std::map<int32_t, int32_t>& pdo_position_map);
481std::string execute_system_command(
const char* cmd);
504 return ((a ^ b) >> (
sizeof(T) * 8 - 1));
567std::vector<double>
linspace(
double lb,
double ub,
size_t n);
639 const std::vector<uint8_t>& csv_data);
661uint32_t
random_uint32(uint32_t min = 0, uint32_t max = UINT32_MAX);
818std::vector<uint8_t>
zip(
const std::string& file_name,
819 std::vector<uint8_t> data);
830std::vector<uint8_t>
unzip(
const std::vector<uint8_t>& data);
850std::list<std::string>
get_file_parts(std::list<std::string> file_list,
851 const std::string& file_name);
862 uint8_t encoder_ordinal);
873 T min_value = x[x.size() - 1];
875 for (int32_t i = x.size() - 2; i >= 0; i--) {
876 if (x[i] <= min_value) {
895 if (numbers.empty()) {
899 return std::accumulate(numbers.begin(), numbers.end(), 0.0) / numbers.size();
911 if (numbers.empty()) {
917 std::vector<double> tmp(numbers.size());
918 std::transform(numbers.begin(), numbers.end(), tmp.begin(),
919 [mean](
double x) { return x - mean; });
921 double sq_sum = std::inner_product(tmp.begin(), tmp.end(), tmp.begin(), 0.0);
922 return std::sqrt(sq_sum / (numbers.size() - 1));
937 std::vector<T> section(numbers.begin() + start, numbers.begin() + end);
939 if (section.empty()) {
943 return std::accumulate(section.begin(), section.end(), 0.0) / section.size();
956 v.erase(v.begin(), v.begin() + length);
957 v.erase(v.end() - length, v.end());
971 return f.wait_for(std::chrono::seconds(0)) == std::future_status::ready;
972 }
catch (std::future_error& e) {
986 return static_cast<std::underlying_type_t<T>
>(e);
998static std::vector<T> diff(std::vector<T> vector) {
999 std::vector<T> result;
1000 result.reserve(vector.size() - 1);
1002 for (
size_t i = 1; i < vector.size(); i++) {
1003 result.push_back(vector[i] - vector[i - 1]);
1012template <
typename... Args>
1014 int size_s = std::snprintf(
nullptr, 0, format.c_str(), args...) +
1017 throw std::runtime_error(
"Error during formatting.");
1019 auto size =
static_cast<size_t>(size_s);
1020 std::unique_ptr<char[]> buf(
new char[size]);
1021 std::snprintf(buf.get(), size, format.c_str(), args...);
1022 return std::string(buf.get(),
1023 buf.get() + size - 1);
1042 std::deque<double> input_data_;
1043 std::deque<double> output_data_;
1044 double fc_, a0_, a1_, a2_, b0_, b1_, b2_;
1062 std::deque<double> input_data_;
1063 std::deque<double> output_data_;
1064 double fc_, a0_, a1_, a2_, a3_, a4_, b0_, b1_, b2_, b3_, b4_;
1070 const std::string& s2);
std::vector< uint8_t > unzip(const std::vector< uint8_t > &data)
Unzip data containing a single file.
Definition util.cc:1480
const std::map< int32_t, std::string > slave_error_map_
Definition util.h:179
ControllerGains get_position_controller_gains(Cia402Drive &cia402_drive)
Get the current position controller gains of a drive.
Definition util.cc:278
const char *const HARDWARE_DESCRIPTION_FILENAME
Definition util.h:24
double compute_section_mean(const std::vector< T > &numbers, size_t start, size_t end)
Compute the mean of a section of a given vector of integers.
Definition util.h:935
ControllerGains convert_auto_tuning_controller_gains(ControllerGains gains, uint32_t singleturn_resolution)
Convert gains to inc pos values and rpm velocity values.
Definition util.cc:1358
const std::map< int32_t, std::map< int32_t, int32_t > > adc_current_ratio_fw_v4_4_2_map
Definition util.h:377
uint64_t wait_for_signal(int signal_fd)
Wait for the system signal.
std::string controllerTypeToString(ControllerType ct)
Definition util.cc:148
uint32_t register_sync_signal()
Register a thread sync signal.
bool string_ends_with(const std::string &value, const std::string &ending)
Check if a string ends with another string.
Definition util.cc:433
const std::map< int32_t, std::map< int32_t, int32_t > > adc_current_ratio_fw_v4_4_1_map
Definition util.h:356
std::string generate_uuid(size_t length)
Generate a UUID of a custom length.
Definition util.cc:610
bool set_velocity_controller_gains(Cia402Drive &cia402_drive, const ControllerGains &gains)
Set the velocity controller gains.
Definition util.cc:380
semver::version get_firmware_version(Cia402Drive &cia402_drive)
Get the (semver) version of the used firmware.
Definition util.cc:894
std::string get_slave_error_message(int32_t error_code)
Return the appropriate error message.
Definition util.cc:48
int32_t find_local_min_index_from_right(std::vector< T > &x)
Find a local minimum (from right) in the supplied vector.
Definition util.h:872
struct AutoTuningDriveConfigurationClass AutoTuningDriveConfiguration
const char *const STACK_INFO_FILENAME
Definition util.h:25
bool validate_sii_data(const std::vector< uint8_t > &content, uint32_t device_id)
Validate an SII data before writing.
double compute_mean(const std::vector< T > &numbers)
Compute mean given a vector of numbers.
Definition util.h:894
bool opposite_signs(const T &a, const T &b)
Check if parameters have opposite signs.
Definition util.h:503
bool get_plant_model_from_flash(Cia402Drive &cia402_drive, PlantModel *m)
Get the plant model from the flash memory of the device.
Definition util.cc:941
const char *const ESI_FILENAME
Definition util.h:27
const std::map< MotionMasterWarning, std::string > motion_master_warning_to_message_map_
Definition util.h:172
void unregister_sync_signal(uint32_t signal_id)
Unregister a thread sync signal.
int32_t limit_int32_target(int64_t target)
Limit a target to integer 32 if necessary.
Definition util.cc:622
std::string run_env_info()
Get all sorts of run environment information.
Definition util.cc:642
const char *const CONFIG_FILENAME
Definition util.h:28
bool compareStringsCaseInsensitive(const std::string &s1, const std::string &s2)
Definition util.cc:1697
int32_t wrap_target_position(int32_t target, int32_t max_limit, int32_t min_limit)
Wrap the target position over limit.
std::vector< double > linspace(double lb, double ub, size_t n)
Generate equally spaced points inside an interval.
Definition util.cc:262
CirculoType
Definition util.h:58
@ kCirculo7
Definition util.h:60
@ kCirculo9Smm
Definition util.h:63
@ kCirculo7Smm
Definition util.h:61
@ kCirculo9
Definition util.h:62
PositionControlStrategy
Definition util.h:163
@ kSimple
Definition util.h:163
@ kNone
Definition util.h:163
@ kCascaded
Definition util.h:163
ControllerType
Definition util.h:54
@ kPpi
Definition util.h:54
@ kPiP
Definition util.h:54
uint64_t wait_for_sync_signal(uint32_t signal_id)
Wait for the system sync signal.
std::string etg1004_unit_string(uint32_t etg1004_unit_value)
Convert ETG.1004 unit format to string.
Definition util.cc:84
EncoderLocation
Definition util.h:74
@ kMotorShaft
Definition util.h:74
@ kDrivingShaft
Definition util.h:74
MotionMasterWarning
Definition util.h:165
@ WAR_PROFILE_TARGET_LIMITED
Definition util.h:167
@ WAR_INTERNAL_LIMIT_REACHED
Definition util.h:168
@ WAR_NONE
Definition util.h:166
const char *const VARIANT_FILENAME
Definition util.h:30
std::vector< uint8_t > read_file_content(const std::string &path)
Read a file into a byte (uint8_t) vector.
Definition util.cc:441
uint8_t calculate_crc(const std::vector< uint8_t > &data)
Definition util.cc:571
uint32_t generate_od_entry_map_key(uint16_t index, uint8_t subindex)
Generate a map key for an OD entry using index/subindex.
Definition util.cc:1521
unsigned char random_char()
Generate a random character.
Definition util.cc:603
std::vector< uint8_t > zip(const std::string &file_name, std::vector< uint8_t > data)
Zip a single file.
Definition util.cc:1428
bool file_exists(const std::string &path)
Check if a file exists on the system where Motion Master is running.
Definition util.cc:856
std::string get_master_warning_message(MotionMasterWarning warning)
Return the appropriate warning message.
Definition util.cc:40
bool set_position_controller_gains(Cia402Drive &cia402_drive, const ControllerGains &gains)
Set the position controller gains.
Definition util.cc:332
bool check_gains(Cia402Drive &cia402_drive)
Check if the required gains are properly set.
Definition util.cc:402
CirculoEncoderType
Definition util.h:66
@ kCirculo7Inner
Definition util.h:68
@ kCirculo9Outer
Definition util.h:71
@ kUndefined
Definition util.h:67
@ kCirculo7Outer
Definition util.h:69
@ kCirculo9Inner
Definition util.h:70
bool abs_compare(float a, float b)
Compare absolute values of the input parameters.
Definition util.cc:199
void interruptable_wait(size_t seconds)
Blocks for the set amount of time, but allows to be interrupted.
Definition util.cc:201
uint32_t random_uint32(uint32_t min=0, uint32_t max=UINT32_MAX)
Generate a random unsigned 32-bit integer in a certain range.
Definition util.cc:596
double compute_standard_deviation(const std::vector< T > &numbers)
Compute the standard deviation given a vector of numbers.
Definition util.h:910
std::list< std::string > get_file_parts(std::list< std::string > file_list, const std::string &file_name)
Process the provided file list and find the file or its parts.
Definition util.cc:1525
std::vector< T > erase_edge_elements(std::vector< T > v, size_t length)
Remove a number of the first and last elements in the vector.
Definition util.h:955
int get_soem_slaves_responding()
Definition util.cc:1691
EncoderLocation get_encoder_location(Cia402Drive &cia402_drive, uint8_t encoder_ordinal)
Get the location of an encoder.
Definition util.cc:1569
int32_t get_pdo_id(uint16_t index, uint8_t subindex, std::map< int32_t, int32_t > &pdo_position_map)
Uses a special map and its keys to get the PDO array positions.
Definition util.cc:135
const char *const STACK_IMAGE_FILENAME
Definition util.h:26
std::string string_bytes_to_hex_array_string(const std::string &bytes)
Convert bytes (as string) to a string of hex values.
Definition util.cc:861
bool is_fw_based_on_v5(Cia402Drive &cia402_drive)
Check if the device requires the newer encoder configuration (FW >= v5 or FW >= v0....
Definition util.cc:1397
EcatSlaveFoeError
Definition util.h:397
@ kAccessDenied
Definition util.h:399
@ kNotBootstrap
Definition util.h:406
@ kProgramError
Definition util.h:408
@ kBootstrapOnly
Definition util.h:405
@ kNoRights
Definition util.h:407
@ kIllegal
Definition util.h:401
@ kAlreadyExists
Definition util.h:403
@ kNotFound
Definition util.h:398
@ kPacketNumberWrong
Definition util.h:402
@ kNoUser
Definition util.h:404
@ kDiskFull
Definition util.h:400
bool is_future_done(std::future< R > const &f)
Check if the future has finished executing.
Definition util.h:969
bool is_fw_at_least(Cia402Drive &cia402_drive, const std::string &version)
Check if the drive uses at least a certain FW version.
Definition util.cc:1414
struct TuningParametersClass TuningParameters
struct SystemParametersClass SystemParameters
const char *const PLANT_MODEL_FILENAME
Definition util.h:29
std::string get_firmware_version_string(Cia402Drive &cia402_drive)
Get the (string) version of the used firmware.
Definition util.cc:873
std::string string_format(const std::string &format, Args... args)
Format a string like printf()
Definition util.h:1013
auto to_integral(T e)
Return an integral type value of an enum class.
Definition util.h:985
AutoTuningDriveConfiguration get_auto_tuning_drive_configuration(Cia402Drive &cia402_drive)
Get the configuration required for full auto-tuning.
Definition util.cc:971
CirculoType get_circulo_type(int32_t hardware_id)
Get the Circulo type based on the hardware ID.
void set_csv_configuration(VirtualDevice *virtual_device, const std::vector< uint8_t > &csv_data)
Set the configuration parameter values from CSV data.
Definition util.cc:471
Definition cia402_drive.h:120
Holds position and velocity PID gains for a controller.
Definition standalone_autotuning.h:60
HighPassFilter(uint16_t cutoff_frequency, double ts)
Definition util.cc:1656
double filter(double value)
Definition util.cc:1677
double filter(double value)
Definition util.cc:1643
LowPassFilter(uint16_t cutoff_frequency, double ts)
Definition util.cc:1626
Definition virtual_device.h:22
uint8_t * value
Definition co_dictionary.h:9
uint16_t index
Definition co_dictionary.h:0
@ kUnspecified
Definition global.h:34
uint16_t notch_fw
Definition util.h:85
int32_t R
Definition util.h:90
int32_t L
Definition util.h:89
nlohmann::json to_json()
Definition util.h:101
double tc_kp
Definition util.h:93
uint16_t notch_fc
Definition util.h:86
int16_t vel_ff_gain
Definition util.h:87
uint16_t tc_st
Definition util.h:96
uint16_t tc_damping
Definition util.h:97
double max_vel_noise
Definition util.h:100
uint32_t vdc
Definition util.h:91
uint8_t vel_lp_type
Definition util.h:80
uint8_t switch_F
Definition util.h:95
uint32_t vel_lp_fc
Definition util.h:81
bool notch_en
Definition util.h:84
double tc_ki
Definition util.h:94
uint8_t pos_lp_type
Definition util.h:82
uint32_t pos_lp_fc
Definition util.h:83
std::string software_version
Definition util.h:98
unsigned int rated_torque
Definition util.h:99
uint16_t vel_ff_fc
Definition util.h:88
double current_ratio
Definition util.h:92
double end_frequency
Definition util.h:36
uint16_t torque_amplitude
Definition util.h:37
double start_frequency
Definition util.h:35
std::string bode_file_content
Definition util.h:51
std::vector< double > denominator
Definition util.h:34
uint8_t signal_type
Definition util.h:39
double duration_seconds
Definition util.h:38
nlohmann::json to_json()
Definition util.h:40
std::vector< double > numerator
Definition util.h:33
uint32_t nominal_torque
Definition util.h:131
double time_step
Definition util.h:130
uint32_t max_torque_mnm_
Definition util.h:132
uint32_t singleturn_resolution
Definition util.h:133
int16_t alpha_mult
Definition util.h:148
double end_frequency
Definition util.h:141
double warn_torque_const
Definition util.h:156
double cutoff_frequency
Definition util.h:142
double lb
Definition util.h:159
uint16_t torque_amplitude
Definition util.h:139
float velocity_loop_bandwidth
Definition util.h:152
float velocity_damping
Definition util.h:153
double start_frequency
Definition util.h:140
ControllerType controller_type
Definition util.h:145
double duration_seconds
Definition util.h:138
double position_damping
Definition util.h:147
double ub
Definition util.h:160
double settling_time
Definition util.h:146
uint8_t order
Definition util.h:149