added time stamp to robot states

This commit is contained in:
Ruixiang Du
2021-07-15 15:25:49 +08:00
parent e96b078c05
commit f74ee40fc3
32 changed files with 248 additions and 328 deletions

View File

@@ -13,34 +13,38 @@
#include <iostream>
#include "ugv_sdk/mobile_robot/scout_robot.hpp"
#include "ugv_sdk/utilities/protocol_detector.hpp"
using namespace westonrobot;
int main(int argc, char **argv) {
std::string protocol_version;
std::string device_name;
if (argc == 3) {
protocol_version = {argv[1]};
device_name = {argv[2]};
std::cout << "Use protocol " << protocol_version << " on interface "
<< device_name << std::endl;
if (argc == 2) {
device_name = {argv[1]};
std::cout << "Selected interface " << device_name << std::endl;
} else {
std::cout << "Usage: app_scout_demo <protocol-version> <interface>"
<< std::endl
<< "Example 1: ./app_scout_demo v1 can0" << std::endl;
<< "Example 1: ./app_scout_demo can0" << std::endl;
return -1;
}
std::unique_ptr<ScoutRobot> scout;
if (protocol_version == "v1") {
ProtocolDectctor detector;
detector.Connect("can0");
auto proto = detector.DetectProtocolVersion(5);
if (proto == ProtocolVersion::AGX_V1) {
std::cout << "Detected protocol: AGX_V1" << std::endl;
scout = std::unique_ptr<ScoutRobot>(
new ScoutRobot(ProtocolVersion::AGX_V1, true));
} else if (protocol_version == "v2") {
} else if (proto == ProtocolVersion::AGX_V2) {
std::cout << "Detected protocol: AGX_V2" << std::endl;
scout = std::unique_ptr<ScoutRobot>(
new ScoutRobot(ProtocolVersion::AGX_V2, true));
} else {
std::cout << "Error: invalid protocol version string" << std::endl;
std::cout << "Detected protocol: UNKONWN" << std::endl;
return -1;
}
@@ -51,9 +55,6 @@ int main(int argc, char **argv) {
if (scout->GetParserProtocolVersion() == ProtocolVersion::AGX_V2) {
scout->EnableCommandedMode();
std::cout << "Protocol version 2" << std::endl;
} else {
std::cout << "Protocol version 1" << std::endl;
}
// light control
@@ -66,11 +67,9 @@ int main(int argc, char **argv) {
std::cout << "Light: breath" << std::endl;
scout->SetLightCommand(BREATH, 0, BREATH, 0);
sleep(3);
std::cout << "Light: custom 30-80" << std::endl;
scout->SetLightCommand(CUSTOM, 30, CUSTOM, 80);
std::cout << "Light: custom 30-40" << std::endl;
scout->SetLightCommand(CUSTOM, 30, CUSTOM, 40);
sleep(3);
// std::cout << "Light: diabled cmd control" << std::endl;
// scout->DisableLightControl();
scout->SetLightCommand(CONST_OFF, 0, CONST_OFF, 0);
int count = 0;
@@ -88,11 +87,17 @@ int main(int argc, char **argv) {
<< " , vehicle state: "
<< static_cast<int>(state.system_state.vehicle_state)
<< " , error code: " << std::hex << state.system_state.error_code
<< std::dec
<< ", battery voltage: " << state.system_state.battery_voltage
<< std::endl;
std::cout << "velocity (linear, angular): "
<< state.motion_state.linear_velocity << ", "
<< state.motion_state.angular_velocity << std::endl;
std::cout << "core state age (ms): "
<< std::chrono::duration_cast<std::chrono::milliseconds>(
AgxMsgRefClock::now() - state.time_stamp)
.count()
<< std::endl;
auto actuator = scout->GetActuatorState();
if (scout->GetParserProtocolVersion() == ProtocolVersion::AGX_V1) {
@@ -104,7 +109,25 @@ int main(int argc, char **argv) {
actuator.actuator_state[i].driver_temp,
actuator.actuator_state[i].motor_temp);
}
std::cout << "actuator state age (ms): "
<< std::chrono::duration_cast<std::chrono::milliseconds>(
AgxMsgRefClock::now() - actuator.time_stamp)
.count()
<< std::endl;
} else {
for (int i = 0; i < 4; ++i) {
printf("motor %d: current %f, rpm %d, driver temp %f, motor temp %f\n",
actuator.actuator_hs_state[i].motor_id,
actuator.actuator_hs_state[i].current,
actuator.actuator_hs_state[i].rpm,
actuator.actuator_ls_state[i].driver_temp,
actuator.actuator_ls_state[i].motor_temp);
}
std::cout << "actuator state age (ms): "
<< std::chrono::duration_cast<std::chrono::milliseconds>(
AgxMsgRefClock::now() - actuator.time_stamp)
.count()
<< std::endl;
}
std::cout << "-------------------------------" << std::endl;