Skip to content

Commit

Permalink
CLANG FORMAT IS CRACCCCCCKKKKKKED bro :))))))))))))
Browse files Browse the repository at this point in the history
  • Loading branch information
jbrhm committed Sep 15, 2024
1 parent ba98358 commit 7cb4218
Show file tree
Hide file tree
Showing 5 changed files with 431 additions and 435 deletions.
18 changes: 8 additions & 10 deletions perception/zed_wrapper/pch.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -4,16 +4,14 @@
#include <tf2_ros/transform_listener.h>

// Messages
#include <sensor_msgs/msg/imu.hpp>
#include <sensor_msgs/msg/magnetic_field.hpp>
#include <sensor_msgs/distortion_models.hpp>
#include <sensor_msgs/image_encodings.hpp>
#include <sensor_msgs/msg/image.hpp>
#include <sensor_msgs/msg/camera_info.hpp>
#include <sensor_msgs/distortion_models.hpp>
#include <sensor_msgs/msg/image.hpp>
#include <sensor_msgs/msg/imu.hpp>
#include <sensor_msgs/msg/magnetic_field.hpp>
#include <sensor_msgs/msg/point_cloud2.hpp>
#include <sensor_msgs/point_cloud2_iterator.hpp>
#include "sensor_msgs/msg/image.hpp"
#include "sensor_msgs/image_encodings.hpp"

// ZED
#include <sl/Camera.hpp>
Expand All @@ -22,12 +20,12 @@
#include <thrust/device_vector.h>

// STD
#include <vector>
#include <string>
#include <format>
#include <string>
#include <vector>

// Utils
#include "parameter.hpp"
#include "lie.hpp"
#include "point.hpp"
#include "loop_profiler.hpp"
#include "parameter.hpp"
#include "point.hpp"
208 changes: 104 additions & 104 deletions perception/zed_wrapper/zed_wrapper.bridge.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2,115 +2,115 @@

namespace mrover {

constexpr static float DEG_TO_RAD = std::numbers::pi_v<float> / 180.0f;
constexpr static std::uint64_t NS_PER_S = 1000000000;
constexpr static float DEG_TO_RAD = std::numbers::pi_v<float> / 180.0f;
constexpr static std::uint64_t NS_PER_S = 1000000000;

auto slTime2Ros(sl::Timestamp t) -> rclcpp::Time {
return {static_cast<int32_t>(t.getNanoseconds() / NS_PER_S),
static_cast<uint32_t>(t.getNanoseconds() % NS_PER_S)};
}
auto slTime2Ros(sl::Timestamp t) -> rclcpp::Time {
return {static_cast<int32_t>(t.getNanoseconds() / NS_PER_S),
static_cast<uint32_t>(t.getNanoseconds() % NS_PER_S)};
}

auto fillImuMessage(rclcpp::Node* node, sl::SensorsData::IMUData& imuData, sensor_msgs::msg::Imu& msg) -> void {
msg.header.stamp = node->now();
msg.orientation.x = imuData.pose.getOrientation().x;
msg.orientation.y = imuData.pose.getOrientation().y;
msg.orientation.z = imuData.pose.getOrientation().z;
msg.orientation.w = imuData.pose.getOrientation().w;
for (int i = 0; i < 3; ++i)
for (int j = 0; j < 3; ++j)
msg.orientation_covariance[i * 3 + j] = imuData.pose_covariance(i, j) * DEG_TO_RAD * DEG_TO_RAD;
msg.angular_velocity.x = imuData.angular_velocity.x * DEG_TO_RAD;
msg.angular_velocity.y = imuData.angular_velocity.y * DEG_TO_RAD;
msg.angular_velocity.z = imuData.angular_velocity.z * DEG_TO_RAD;
for (int i = 0; i < 3; ++i)
for (int j = 0; j < 3; ++j)
msg.angular_velocity_covariance[i * 3 + j] = imuData.angular_velocity_covariance(i, j) * DEG_TO_RAD * DEG_TO_RAD;
msg.linear_acceleration.x = imuData.linear_acceleration.x;
msg.linear_acceleration.y = imuData.linear_acceleration.y;
msg.linear_acceleration.z = imuData.linear_acceleration.z;
for (int i = 0; i < 3; ++i)
for (int j = 0; j < 3; ++j)
msg.linear_acceleration_covariance[i * 3 + j] = imuData.linear_acceleration_covariance(i, j);
}
auto fillImuMessage(rclcpp::Node* node, sl::SensorsData::IMUData& imuData, sensor_msgs::msg::Imu& msg) -> void {
msg.header.stamp = node->now();
msg.orientation.x = imuData.pose.getOrientation().x;
msg.orientation.y = imuData.pose.getOrientation().y;
msg.orientation.z = imuData.pose.getOrientation().z;
msg.orientation.w = imuData.pose.getOrientation().w;
for (int i = 0; i < 3; ++i)
for (int j = 0; j < 3; ++j)
msg.orientation_covariance[i * 3 + j] = imuData.pose_covariance(i, j) * DEG_TO_RAD * DEG_TO_RAD;
msg.angular_velocity.x = imuData.angular_velocity.x * DEG_TO_RAD;
msg.angular_velocity.y = imuData.angular_velocity.y * DEG_TO_RAD;
msg.angular_velocity.z = imuData.angular_velocity.z * DEG_TO_RAD;
for (int i = 0; i < 3; ++i)
for (int j = 0; j < 3; ++j)
msg.angular_velocity_covariance[i * 3 + j] = imuData.angular_velocity_covariance(i, j) * DEG_TO_RAD * DEG_TO_RAD;
msg.linear_acceleration.x = imuData.linear_acceleration.x;
msg.linear_acceleration.y = imuData.linear_acceleration.y;
msg.linear_acceleration.z = imuData.linear_acceleration.z;
for (int i = 0; i < 3; ++i)
for (int j = 0; j < 3; ++j)
msg.linear_acceleration_covariance[i * 3 + j] = imuData.linear_acceleration_covariance(i, j);
}

auto fillMagMessage(sl::SensorsData::MagnetometerData const& magData, sensor_msgs::msg::MagneticField& msg) -> void {
msg.magnetic_field.x = magData.magnetic_field_calibrated.x;
msg.magnetic_field.y = magData.magnetic_field_calibrated.y;
msg.magnetic_field.z = magData.magnetic_field_calibrated.z;

msg.magnetic_field_covariance.fill(0.0f);
msg.magnetic_field_covariance[0] = 0.039e-6;
msg.magnetic_field_covariance[4] = 0.037e-6;
msg.magnetic_field_covariance[8] = 0.047e-6;
}
auto fillMagMessage(sl::SensorsData::MagnetometerData const& magData, sensor_msgs::msg::MagneticField& msg) -> void {
msg.magnetic_field.x = magData.magnetic_field_calibrated.x;
msg.magnetic_field.y = magData.magnetic_field_calibrated.y;
msg.magnetic_field.z = magData.magnetic_field_calibrated.z;

auto fillImageMessage(sl::Mat const& bgra, sensor_msgs::msg::Image::UniquePtr const& msg) -> void {
assert(bgra.getChannels() == 4);
assert(msg);

msg->height = bgra.getHeight();
msg->width = bgra.getWidth();
msg->encoding = sensor_msgs::image_encodings::BGRA8;
msg->step = bgra.getStepBytes();
msg->is_bigendian = __BYTE_ORDER__ == __ORDER_BIG_ENDIAN__;
auto* bgrGpuPtr = bgra.getPtr<sl::uchar1>(sl::MEM::GPU);
size_t size = msg->step * msg->height;
msg->data.resize(size);
checkCudaError(cudaMemcpy(msg->data.data(), bgrGpuPtr, size, cudaMemcpyDeviceToHost));
}
msg.magnetic_field_covariance.fill(0.0f);
msg.magnetic_field_covariance[0] = 0.039e-6;
msg.magnetic_field_covariance[4] = 0.037e-6;
msg.magnetic_field_covariance[8] = 0.047e-6;
}

auto fillCameraInfoMessages(sl::CalibrationParameters& calibration, sl::Resolution const& resolution,
auto fillImageMessage(sl::Mat const& bgra, sensor_msgs::msg::Image::UniquePtr const& msg) -> void {
assert(bgra.getChannels() == 4);
assert(msg);

msg->height = bgra.getHeight();
msg->width = bgra.getWidth();
msg->encoding = sensor_msgs::image_encodings::BGRA8;
msg->step = bgra.getStepBytes();
msg->is_bigendian = __BYTE_ORDER__ == __ORDER_BIG_ENDIAN__;
auto* bgrGpuPtr = bgra.getPtr<sl::uchar1>(sl::MEM::GPU);
size_t size = msg->step * msg->height;
msg->data.resize(size);
checkCudaError(cudaMemcpy(msg->data.data(), bgrGpuPtr, size, cudaMemcpyDeviceToHost));
}

auto fillCameraInfoMessages(sl::CalibrationParameters& calibration, sl::Resolution const& resolution,
sensor_msgs::msg::CameraInfo& leftInfoMsg, sensor_msgs::msg::CameraInfo& rightInfoMsg) -> void {


leftInfoMsg.width = resolution.width;
leftInfoMsg.height = resolution.height;
rightInfoMsg.width = resolution.width;
rightInfoMsg.height = resolution.height;
leftInfoMsg.distortion_model = sensor_msgs::distortion_models::PLUMB_BOB;
rightInfoMsg.distortion_model = sensor_msgs::distortion_models::PLUMB_BOB;
leftInfoMsg.d.resize(5);
rightInfoMsg.d.resize(5);
leftInfoMsg.d[0] = calibration.left_cam.disto[0];
leftInfoMsg.d[1] = calibration.left_cam.disto[1];
leftInfoMsg.d[2] = calibration.left_cam.disto[4];
leftInfoMsg.d[3] = calibration.left_cam.disto[2];
leftInfoMsg.d[4] = calibration.left_cam.disto[3];
rightInfoMsg.d[0] = calibration.right_cam.disto[0];
rightInfoMsg.d[1] = calibration.right_cam.disto[1];
rightInfoMsg.d[2] = calibration.right_cam.disto[4];
rightInfoMsg.d[3] = calibration.right_cam.disto[2];
rightInfoMsg.d[4] = calibration.right_cam.disto[3];
leftInfoMsg.k.fill(0.0);
rightInfoMsg.k.fill(0.0);
leftInfoMsg.k[0] = calibration.left_cam.fx;
leftInfoMsg.k[2] = calibration.left_cam.cx;
leftInfoMsg.k[4] = calibration.left_cam.fy;
leftInfoMsg.k[5] = calibration.left_cam.cy;
leftInfoMsg.k[8] = 1.0;
rightInfoMsg.k[0] = calibration.right_cam.fx;
rightInfoMsg.k[2] = calibration.right_cam.cx;
rightInfoMsg.k[4] = calibration.right_cam.fy;
rightInfoMsg.k[5] = calibration.right_cam.cy;
rightInfoMsg.k[8] = 1;
leftInfoMsg.r.fill(0.0);
rightInfoMsg.r.fill(0.0);
for (size_t i = 0; i < 3; ++i) {
leftInfoMsg.r[i * 3 + i] = 1.0;
rightInfoMsg.r[i * 3 + i] = 1.0;
}
leftInfoMsg.p.fill(0.0);
rightInfoMsg.p.fill(0.0);
leftInfoMsg.p[0] = calibration.left_cam.fx;
leftInfoMsg.p[2] = calibration.left_cam.cx;
leftInfoMsg.p[5] = calibration.left_cam.fy;
leftInfoMsg.p[6] = calibration.left_cam.cy;
leftInfoMsg.p[10] = 1.0;
rightInfoMsg.p[3] = -1.0 * calibration.left_cam.fx * calibration.getCameraBaseline();
rightInfoMsg.p[0] = calibration.right_cam.fx;
rightInfoMsg.p[2] = calibration.right_cam.cx;
rightInfoMsg.p[5] = calibration.right_cam.fy;
rightInfoMsg.p[6] = calibration.right_cam.cy;
rightInfoMsg.p[10] = 1.0;
}
};
leftInfoMsg.width = resolution.width;
leftInfoMsg.height = resolution.height;
rightInfoMsg.width = resolution.width;
rightInfoMsg.height = resolution.height;
leftInfoMsg.distortion_model = sensor_msgs::distortion_models::PLUMB_BOB;
rightInfoMsg.distortion_model = sensor_msgs::distortion_models::PLUMB_BOB;
leftInfoMsg.d.resize(5);
rightInfoMsg.d.resize(5);
leftInfoMsg.d[0] = calibration.left_cam.disto[0];
leftInfoMsg.d[1] = calibration.left_cam.disto[1];
leftInfoMsg.d[2] = calibration.left_cam.disto[4];
leftInfoMsg.d[3] = calibration.left_cam.disto[2];
leftInfoMsg.d[4] = calibration.left_cam.disto[3];
rightInfoMsg.d[0] = calibration.right_cam.disto[0];
rightInfoMsg.d[1] = calibration.right_cam.disto[1];
rightInfoMsg.d[2] = calibration.right_cam.disto[4];
rightInfoMsg.d[3] = calibration.right_cam.disto[2];
rightInfoMsg.d[4] = calibration.right_cam.disto[3];
leftInfoMsg.k.fill(0.0);
rightInfoMsg.k.fill(0.0);
leftInfoMsg.k[0] = calibration.left_cam.fx;
leftInfoMsg.k[2] = calibration.left_cam.cx;
leftInfoMsg.k[4] = calibration.left_cam.fy;
leftInfoMsg.k[5] = calibration.left_cam.cy;
leftInfoMsg.k[8] = 1.0;
rightInfoMsg.k[0] = calibration.right_cam.fx;
rightInfoMsg.k[2] = calibration.right_cam.cx;
rightInfoMsg.k[4] = calibration.right_cam.fy;
rightInfoMsg.k[5] = calibration.right_cam.cy;
rightInfoMsg.k[8] = 1;
leftInfoMsg.r.fill(0.0);
rightInfoMsg.r.fill(0.0);
for (size_t i = 0; i < 3; ++i) {
leftInfoMsg.r[i * 3 + i] = 1.0;
rightInfoMsg.r[i * 3 + i] = 1.0;
}
leftInfoMsg.p.fill(0.0);
rightInfoMsg.p.fill(0.0);
leftInfoMsg.p[0] = calibration.left_cam.fx;
leftInfoMsg.p[2] = calibration.left_cam.cx;
leftInfoMsg.p[5] = calibration.left_cam.fy;
leftInfoMsg.p[6] = calibration.left_cam.cy;
leftInfoMsg.p[10] = 1.0;
rightInfoMsg.p[3] = -1.0 * calibration.left_cam.fx * calibration.getCameraBaseline();
rightInfoMsg.p[0] = calibration.right_cam.fx;
rightInfoMsg.p[2] = calibration.right_cam.cx;
rightInfoMsg.p[5] = calibration.right_cam.fy;
rightInfoMsg.p[6] = calibration.right_cam.cy;
rightInfoMsg.p[10] = 1.0;
}
}; // namespace mrover
2 changes: 1 addition & 1 deletion perception/zed_wrapper/zed_wrapper.bridge.cu
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@

namespace mrover {

using PointCloudGpu = thrust::device_vector<Point>;
using PointCloudGpu = thrust::device_vector<Point>;

// Optimal for the Jetson Xavier NX - this is max threads per block and each block has a max of 2048 threads
constexpr uint BLOCK_SIZE = 1024;
Expand Down
Loading

0 comments on commit 7cb4218

Please sign in to comment.