47using RSI.RapidCode.dotNET;
51using System.Threading;
61public class PathMotion : SampleAppTestBase
70 public void Teardown()
78 jointsMultiAxis?.
Abort();
85 var actualUnits = model.UnitsGet();
86 Assert.That(actualUnits, Is.EqualTo(expectedUnits), $
"Expected model units to be '{expectedUnits}' but was '{actualUnits}' instead!");
87 var actualName = model.NameGet();
88 Assert.That(actualName, Is.EqualTo(expectedName), $
"Expected model name to be '{expectedName}' but was '{actualName}' instead!");
92 public void GantryPrimeAxis()
98 const string xLabel =
"X-Axis";
99 const string yLabel =
"Y-Axis";
100 const string primeLabel =
"Y-Prime";
111 Axis[] axes =
new Axis[] { x_axis, y_axis, prime_axis };
112 jointsMultiAxis.
AxesAdd(axes, axes.Length);
115 const string modelName =
"RSI_XY_Yp";
116 const double scaling = 1.0, offset = 0.0;
124 const int motionFrameBufferSize = 50;
125 robot =
Robot.
RobotCreate(controller, jointsMultiAxis, builder, motionFrameBufferSize);
129 VerifyModel(robot.
ModelGet(), units, modelName);
132 [Test, Timeout(Constants.MAX_TEST_TIME)]
133 public void SimplePathMotion()
137 const string xLabel =
"X-Axis";
138 const string yLabel =
"Y-Axis";
139 const string zLabel =
"Z-Axis";
140 const string aLabel =
"A-Axis";
141 const string bLabel =
"B-Axis";
142 const string cLabel =
"C-Axis";
159 Axis[] axes =
new Axis[] { x_axis, y_axis, z_axis, a_axis, b_axis, c_axis };
160 jointsMultiAxis.
AxesAdd(axes, axes.Length);
164 const string modelName =
"RSI_XYZABC_Meters";
165 const double scaling = 1.0, offset = 0.0;
193 VerifyModel(robot.
ModelGet(), units, modelName);
197 public void ChangingUnits()
201 const string xLabel =
"X-Axis";
202 const string yLabel =
"Y-Axis";
203 const string zLabel =
"Z-Axis";
204 const string aLabel =
"A-Axis";
205 const string bLabel =
"B-Axis";
206 const string cLabel =
"C-Axis";
223 Axis[] axes =
new Axis[] { x_axis, y_axis, z_axis, a_axis, b_axis, c_axis };
224 jointsMultiAxis.
AxesAdd(axes, axes.Length);
227 const string modelName =
"RSI_XYZABC_Millimeters";
228 const double scaling = 1.0, offset = 0.0;
259 VerifyModel(robot.
ModelGet(), units, modelName);
262 public void PathPoint()
265 const ulong frameCount = 500;
266 ulong totalFrames = frameCount;
267 ulong startFrame = 0;
269 while (totalFrames == frameCount)
272 totalFrames = positions.Size();
278 double xCoord = spatial.
X, yCoord = spatial.
Y, zCoord = spatial.
Z;
288 startFrame += totalFrames;
static void CheckErrors(RapidCodeObject rsiObject)
Check if the RapidCodeObject has any errors.
Helper Functions for checking logged creation errors, starting the network, etc.
void UserLabelSet(const char *const userLabel)
Set the axis User defined Label.
Represents a single axis of motion control. This class provides an interface for commanding motion,...
void UnitsSet(LinearUnits units)
Set the units the built model will use.
Describes the mathematical kinematic model of a robot.
The Builder for a linear kinematic model. Constructs a single Linear Kinematic Model to use when crea...
void JointAdd(const LinearJointMapping &joint)
adds a joint to the model using the configuration specified within the LinearJoint structure.
Vector3d Position
The position component of the Pose.
Quaternion Orientation
The orientation component of the Pose.
Quaternion for representing rotations.
uint64_t MotionDoneWait()=0
Waits for a move to complete.
RapidVector< RobotPosition > PathPlannedPositionsGet(uint64_t startFrame, uint64_t frameCount)=0
Get Positions (see RobotPosition) representing the planned motion in cartesian space that will happen...
void PathVelocitySet(double unitsPerSecond)=0
Sets the target linear cartesian velocity for each move (UserUnits/second).
bool IsRunning()=0
Returns whether or not the robot is in motion (from executor or other source). Can be used to determi...
double PathLinearScalingGet() const =0
Gets scaling between input to path motion and output of path motion to the kinematic model.
static Robot * RobotCreate(MotionController *controller, MultiAxis *multiAxis, KinematicModelBuilder *builder, uint32_t motionFrameBufferSize)
Create a Robot object to use G-Code, path motion, etc.
void PathAccelerationSet(double unitsPerSecondSquared)=0
Sets the target acceleration for the machine (UserUnits/second^2). Should be set appropriately based ...
LinearUnits PathUnitsGet() const =0
Gets the units of path motion.
void PathArc(const Pose &target, double radius, RotationDirection direction)=0
Appends an arc on to the current on the PathPlaneGet() plane XY by default.
void PathUnitsSet(LinearUnits units)=0
Defines the units Cartesian Path Motion is in.
void PathLine(const Pose &target)=0
void EStop()=0
Commands a joint EStop and clears the loaded moves.
void PathProgrammingModeSet(PathMode mode)=0
Sets the programming mode (Relative/Absolute).
void Run()=0
Run the loaded path lines/arcs. The behavior is non-blocking. Use Robot.MotionDoneWait() to block.
Represents a collection of joints in Cartesian space with forward and inverse kinematics....
void ClearFaults()=0
Clears the MultiAxis fault then the Robot's error bit.
const KinematicModel & ModelGet()=0
Get the model this robot was created with.
static void RobotDelete(MotionController *controller, Robot *robot)
Delete a Robot.
A representation of the robot containing the Pose and the positions of the free axes.
Pose Pose
The Robot's Pose.
Vector3d is used for three-dimensional points and vectors.
double Z
The Z coordinate.
double X
The X coordinate.
double Y
The Y coordinate.
static constexpr int32_t AxisFrameBufferSizeDefault
The default value of the AxisFrameBufferSize, also the minimum allowable value.
Represents the RMP soft motion controller. This class provides an interface to general controller con...
void AxisRemoveAll()
Remove all axes from a MultiAxis group.s.
void AxesAdd(Axis **axes, int32_t axisCount)
void ClearFaults()
Clear all faults for an Axis or MultiAxis.
void AmpEnableSet(bool enable)
Enable all amplifiers.
void Abort()
Abort an axis.
PathMode
Motion types. For G-code use and Cartesian path motion.
CartesianAxis
This enum specifies which Cartesian axis a LinearJointMapping maps a robot joint to.
RotationDirection
Rotational directions about an axis.
LinearUnits
Unit types. For Cartesian Robot/G-Code use.