plugin/sdf/README.md
These are first-party plugins that implement implicit geometries using SDFs. They can be applied to geoms and meshes (in the asset section). Sample models can be found in this folder.
Implemented in bolt.cc. Example usage in nutbolt.xml.
This plugin implements a bolt with a hexagonal head, similar to https://www.shadertoy.com/view/XtffzX.
Parameters:
radius [m]: bolt radius (default 0.26).Implemented in bowl.cc. Example usage in bowl.xml.
The plugin implements a cut hollow sphere from https://www.shadertoy.com/view/7tVXRt.
Parameters:
height [m]: location of the cut plane (default 0.4).radius [m]: radius of the sphere (default 1).thickness [m]: thickness of the bowl (default 0.02).Implemented in gear.cc. Example usage in gear.xml.
The plugin implements a 3D extrusion of the 2D gear geometry from https://www.shadertoy.com/view/3lG3WR.
Parameters:
alpha [m]: initial angle of rotation of the gear (default 0).diameter [m]: gear diameter (default 2.8).teeth []: number of teeth (default 25).Implemented in nut.cc. Example usage in nutbolt.xml.
This plugin implements a hexagonal nut identical to the bolt head from https://www.shadertoy.com/view/XtffzX.
Parameters:
radius [m]: nut radius (default 0.26).Implemented in torus.cc. Example usage in torus.xml.
This plugin implements a torus.
Parameters:
radius1 [m]: major radius (default 0.35).radius1 [m]: minor radius (default 0.15).Create your MySDF.h and MySDF.cc files in the SDF folder, where this README is located. Implement your SDF using the
following interface:
struct MySDFAttribute {
static constexpr int nattribute =
/* insert the number of attributes */;
static constexpr char const* names[nattribute] =
/* an array of attributes with the same order as the attribute array in your SDF class */;
static constexpr mjtNum defaults[nattribute] =
/* an array of default values for your attributes */;
};
class MySDF {
public:
// creates a new MySDF instance or returns null on failure.
static std::optional<MySDF> Create(const mjModel* m, mjData* d, int instance);
MySDF(MySDF&&) = default;
~MySDF() = default;
// functions that return the SDF and its gradient at a query point
mjtNum Distance(const mjtNum point[3]) const;
void Gradient(mjtNum grad[3], const mjtNum point[3]) const;
// a call to this needs to be added to register.cc
static void RegisterPlugin();
// an array of attributes with the same order as in the struct above
mjtNum attribute[MySDFAttribute::nattribute];
private:
MySDF(const mjModel* m, mjData* d, int instance);
};