ObstaclesΒΆ
- 
struct BoxΒΆ
- A box collision object. - The Box struct represents a simple 3D rectangular collision object. It is defined by its dimensions along the x, y, and z axes, which correspond to the width, depth, and height of the box, respectively. - Public Functions - 
inline explicit Box(float x, float y, float z)ΒΆ
- Construct a box of size x, y, z along the respective axes. - Parameters:
- x β The width of the box along the x-axis. 
- y β The depth of the box along the y-axis. 
- z β The height of the box along the z-axis. 
 
 
 - 
explicit Box() = defaultΒΆ
- Default constructor. 
 - Public Members - 
float xΒΆ
- Dimensions of the box [m]. 
 
- 
inline explicit Box(float x, float y, float z)ΒΆ
- 
struct CapsuleΒΆ
- A capsule collision object. - The Capsule struct represents a simple 3D collision object shaped like a capsule (a cylinder with hemispherical ends). It is defined by its radius and length along the z-axis. Capsules are commonly used in collision detection due to their computational efficiency. 
- 
struct ConvexΒΆ
- A convex mesh collision object. - The Convex struct represents a 3D convex mesh, often used for collision detection. It supports loading from files, direct vertex and triangle specification, and provides utility functions like bounding box computation. - Public Functions - 
explicit Convex() = defaultΒΆ
- Default constructor. 
 - 
explicit Convex(const std::vector<std::array<float, 3>> &verts, const std::vector<std::array<size_t, 3>> &triangs)ΒΆ
- Construct a convex object from given vertices and triangles. - Parameters:
- verts β List of vertex positions. 
- triangs β List of triangles, each defined by three vertex indices. 
 
 
 - 
std::array<double, 3> get_bounding_box_minimum() constΒΆ
- Get the minimum bounding box corner. - Returns:
- A 3D vector representing the minimum corner of the bounding box. 
 
 - 
std::array<double, 3> get_bounding_box_maximum() constΒΆ
- Get the maximum bounding box corner. - Returns:
- A 3D vector representing the maximum corner of the bounding box. 
 
 - Public Members - 
std::vector<Vector> verticesΒΆ
- List of vertices that define the convex mesh. 
 - Public Static Functions - 
static std::vector<Convex> load_from_file(const std::filesystem::path &path, std::optional<float> scale = std::nullopt)ΒΆ
- Deprecated:
- Load convex objects from a file. 
 - Parameters:
- path β The path to the file (*.obj). 
- scale β Optional scale to apply when loading the object. 
 
- Returns:
- A vector of Convex objects loaded from the file. 
 
 - 
class TriangleΒΆ
 
- 
explicit Convex() = defaultΒΆ
- 
struct CylinderΒΆ
- A cylinder collision object. - The Cylinder struct represents a 3D cylindrical collision object. It is defined by its radius and length along the z-axis. 
- 
struct DepthMapΒΆ
- A depth map collision object. - The DepthMap struct represents a 3D collision object based on a depth map, which is essentially a grid of depth values. - Public Functions - 
inline explicit DepthMap(const Matrix &depths, float x, float y)ΒΆ
- Construct a depth map with the given data. - Parameters:
- depths β The matrix of depth values. 
- x β The size of the depth map along the x-axis. 
- y β The size of the depth map along the y-axis. 
 
 
 - 
explicit DepthMap() = defaultΒΆ
- Default constructor. 
 - Public Members - 
Matrix depthsΒΆ
- Matrix containing the depth values at evenly spaced grid points. 
 - 
float xΒΆ
- Size along the x-axis [m]. 
 - 
float yΒΆ
- Size along the y-axis [m]. 
 - 
float max_depth = {1e2}ΒΆ
- Maximum depth to check for collisions [m]. - This value sets the maximum depth that will be considered during collision checking. Any depth greater than this value will be ignored. The default value is 100 meters. 
 
- 
inline explicit DepthMap(const Matrix &depths, float x, float y)ΒΆ
- 
struct MeshFileΒΆ
- A collision object loaded from a file. - Public Functions - 
explicit MeshFile() = defaultΒΆ
- Default constructor. 
 - 
explicit MeshFile(const std::filesystem::path &path, std::optional<float> scale = std::nullopt)ΒΆ
- Load a file obstacle. - Parameters:
- path β The path to the collision file (*.obj). 
- scale β Optional scale to apply when loading the object. 
 
 
 - 
explicit MeshFile(const std::filesystem::path &visual_path, const std::filesystem::path &collision_path, std::optional<float> scale = std::nullopt)ΒΆ
- Load a file obstacle. - Parameters:
- visual_path β The path to the visual file. 
- collision_path β The path to the collision file (*.obj). 
- scale β Optional scale to apply when loading the object. 
 
 
 - Public Members - 
FileReference original_referenceΒΆ
- The reference to the original file. 
 - 
FileReference visual_referenceΒΆ
- The reference to a visual file. 
 - 
FileReference collision_referenceΒΆ
- The reference to the collision file. 
 - 
float scale = {1.0}ΒΆ
- Scale of the object. 
 - 
bool inside_project = {false}ΒΆ
- Indicates if the file is part of a Jacobi Studio project. Then, the file content is not uploaded when referencing the file in Studio live. 
 - Public Static Attributes - 
static std::filesystem::path base_pathΒΆ
- Base path for file operations. 
 
- 
explicit MeshFile() = defaultΒΆ
- 
struct PointCloudΒΆ
- A point cloud collision object. - The PointCloud struct represents a 3D collision object based on a point cloud, which is a set of [x, y, z] points. - Public Functions - 
inline explicit PointCloud(const Matrix &points, double resolution = 0.01)ΒΆ
- Construct a point cloud with the given data. - Parameters:
- points β The matrix (std::vector<std::array<float, 3>>) containing [x, y, z] points. 
- resolution β The resolution of the Octree that will be constructed from the point cloud and used for collision checking. 
 
 
 - 
explicit PointCloud() = defaultΒΆ
- Default constructor. 
 
- 
inline explicit PointCloud(const Matrix &points, double resolution = 0.01)ΒΆ
- 
struct SphereΒΆ
- A sphere collision object. - The Sphere struct represents a 3D spherical collision object, defined by its radius, which determines its size in all directions. - Public Functions - 
inline explicit Sphere(float radius)ΒΆ
- Construct a sphere with the given radius. - Initializes the sphere with the specified radius. - Parameters:
- radius β The radius of the sphere. 
 
 - 
explicit Sphere() = defaultΒΆ
- Default constructor. 
 - Public Members - 
float radiusΒΆ
- Radius of the sphere [m]. 
 
- 
inline explicit Sphere(float radius)ΒΆ
- 
class Obstacle : public jacobi::ElementΒΆ
- An environment obstacle. - The Obstacle class represents an object in an environment that can be used for both visualization and collision detection. Obstacles can have various geometric shapes and properties, and can be associated with a robot or be independent within the environment. - Public Functions - 
explicit Obstacle() = defaultΒΆ
- Default constructor. 
 - 
Obstacle with_origin(const Frame &origin) constΒΆ
- Clone the current obstacle and set the new origin. - Creates a copy of the current obstacle and updates its origin to the provided frame. This function is useful for creating modified versions of an obstacle without altering the original object. - Parameters:
- origin β The new pose (origin) for the cloned obstacle. 
- Returns:
- Obstacle A new Obstacle instance with the updated origin. 
 
 - 
Obstacle with_name(const std::string &name) constΒΆ
- Clone the current obstacle and update some parameters. - Creates a copy of the current obstacle and updates its name. This function is useful for creating modified versions of an obstacle without altering the original object. - Parameters:
- name β The new name for the cloned obstacle. 
- Returns:
- Obstacle A new Obstacle instance with the updated origin. 
 
 - Public Members - 
Color colorΒΆ
- The hex-string representation of the obstacleβs color, without the leading #. - This string defines the color of the obstacle for visualization purposes, formatted as a hex code (e.g., βFF5733β for orange). 
 - 
std::optional<FileReference> visualΒΆ
- Optional reference to the visual file. - This optional reference points to an external visual file that represents the obstacle. If provided, this file will be used for rendering the obstacleβs appearance. 
 - 
Geometry collisionΒΆ
- The object for collision checking (and/or visualization). - This variant holds the geometric representation of the obstacle. It can be any of the supported shapes, including Box, Capsule, Convex, ConvexVector, Cylinder, DepthMap, PointCloud or Sphere. 
 - 
bool for_visual = {true}ΒΆ
- Whether this obstacle is used for visualization. - If true, the obstacle will be rendered in the environmentβs visualization in Studio. By default, this is set to true. 
 - 
bool for_collision = {true}ΒΆ
- Whether this obstacle is used for collision checking. - If true, the obstacle will be considered in collision detection calculations. By default, this is set to true. 
 - 
float safety_margin = {0.0}ΒΆ
- An additional obstacle-specific safety margin for collision checking (on top of the environmentβs global safety margin). - This margin adds an extra buffer around the obstacle during collision detection. It is specific to this obstacle and is added on top of any global safety margins. 
 
- 
explicit Obstacle() = defaultΒΆ