-
Notifications
You must be signed in to change notification settings - Fork 541
Adding New Kinematics
The supported kinematics are defined in files in folder src/Movement/Kinematics. It is organised as a class hierarchy. Each supported kinematics has its own class definition. For example, class CartesianKinematics supports standard Cartesian motion kinematics. The class declaration is in file CartesianKinematics.h and the implementation is in class CartesianKinematics.cpp.
To add new kinematics:
-
Tell me the name of your kinematics and ask me (dc42) to allocate a kinematics type number for it, via the Duet3d forum. The kinematics type number will be the K parameter in the M669 command.
-
Create .h and .cpp files to declare and implement the class for your kinematics. This should inherit one of the following base classes:
- If your machine has a conventional Z axis with one or more motors that only affect the Z coordinate, and you want to support bed levelling using multiple independent leadscrews, or the facility to assist users in determining corrections to make to manual bed levelling screws, then you should derive your kinematics class from class ZLeadscrewKinematics.
- Otherwise, if the bed of the printer is round, derive it from RoundBedKinematics.
- Otherwise derive it directly from class Kinematics.
-
In your kinematics class, override virtual functions as needed. See the comments in file Kinematics.h for a description of those functions.
-
Modify file Kinematics.cpp by adding a #include directive to include the .h file that declares your new kinematics. Also modify function Create by adding a new case to create an instance of your new kinematics class when the appropriate kinematics type number is passed.
DC updated 2022-05-22.