Merge pull request #7060 from bgort/i2cpefix
I2C Position Encoders Example Configs
This commit is contained in:
		| @@ -1263,7 +1263,7 @@ | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
| //=========================================================================== | //=========================================================================== | ||||||
| //============================ I2C Encoder Settings ========================= | //====================== I2C Position Encoder Settings ====================== | ||||||
| //=========================================================================== | //=========================================================================== | ||||||
| /** | /** | ||||||
|  *  I2C position encoders for closed loop control. |  *  I2C position encoders for closed loop control. | ||||||
| @@ -1343,6 +1343,6 @@ | |||||||
|   // Use a rolling average to identify persistant errors that indicate skips, as opposed to vibration and noise. |   // Use a rolling average to identify persistant errors that indicate skips, as opposed to vibration and noise. | ||||||
|   #define I2CPE_ERR_ROLLING_AVERAGE |   #define I2CPE_ERR_ROLLING_AVERAGE | ||||||
|  |  | ||||||
| #endif | #endif // I2C_POSITION_ENCODERS | ||||||
|  |  | ||||||
| #endif // CONFIGURATION_ADV_H | #endif // CONFIGURATION_ADV_H | ||||||
|   | |||||||
| @@ -1255,4 +1255,87 @@ | |||||||
|   #define USER_GCODE_5 "G28\nM503" |   #define USER_GCODE_5 "G28\nM503" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | //=========================================================================== | ||||||
|  | //====================== I2C Position Encoder Settings ====================== | ||||||
|  | //=========================================================================== | ||||||
|  | /** | ||||||
|  |  *  I2C position encoders for closed loop control. | ||||||
|  |  *  Developed by Chris Barr at Aus3D. | ||||||
|  |  * | ||||||
|  |  *  Wiki: http://wiki.aus3d.com.au/Magnetic_Encoder | ||||||
|  |  *  Github: https://github.com/Aus3D/MagneticEncoder | ||||||
|  |  * | ||||||
|  |  *  Supplier: http://aus3d.com.au/magnetic-encoder-module | ||||||
|  |  *  Alternative Supplier: http://reliabuild3d.com/ | ||||||
|  |  * | ||||||
|  |  *  Reilabuild encoders have been modified to improve reliability. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | //#define I2C_POSITION_ENCODERS | ||||||
|  | #if ENABLED(I2C_POSITION_ENCODERS) | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENCODER_CNT         1                       // The number of encoders installed; max of 5 | ||||||
|  |                                                             // encoders supported currently. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_1_ADDR          I2CPE_PRESET_ADDR_X     // I2C address of the encoder. 30-200. | ||||||
|  |   #define I2CPE_ENC_1_AXIS          X_AXIS                  // Axis the encoder module is installed on.  <X|Y|Z|E>_AXIS. | ||||||
|  |   #define I2CPE_ENC_1_TYPE          I2CPE_ENC_TYPE_LINEAR   // Type of encoder:  I2CPE_ENC_TYPE_LINEAR -or- | ||||||
|  |                                                             // I2CPE_ENC_TYPE_ROTARY. | ||||||
|  |   #define I2CPE_ENC_1_TICKS_UNIT    2048                    // 1024 for magnetic strips with 2mm poles; 2048 for | ||||||
|  |                                                             // 1mm poles. For linear encoders this is ticks / mm, | ||||||
|  |                                                             // for rotary encoders this is ticks / revolution. | ||||||
|  |   //#define I2CPE_ENC_1_TICKS_REV     (16 * 200)            // Only needed for rotary encoders; number of stepper | ||||||
|  |                                                             // steps per full revolution (motor steps/rev * microstepping) | ||||||
|  |   //#define I2CPE_ENC_1_INVERT                              // Invert the direction of axis travel. | ||||||
|  |   #define I2CPE_ENC_1_EC_METHOD     I2CPE_ECM_NONE          // Type of error error correction. | ||||||
|  |   #define I2CPE_ENC_1_EC_THRESH     0.10                    // Threshold size for error (in mm) above which the | ||||||
|  |                                                             // printer will attempt to correct the error; errors | ||||||
|  |                                                             // smaller than this are ignored to minimize effects of | ||||||
|  |                                                             // measurement noise / latency (filter). | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_2_ADDR          I2CPE_PRESET_ADDR_Y     // Same as above, but for encoder 2. | ||||||
|  |   #define I2CPE_ENC_2_AXIS          Y_AXIS | ||||||
|  |   #define I2CPE_ENC_2_TYPE          I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_ENC_2_TICKS_UNIT    2048 | ||||||
|  |   //#define I2CPE_ENC_2_TICKS_REV   (16 * 200) | ||||||
|  |   //#define I2CPE_ENC_2_INVERT | ||||||
|  |   #define I2CPE_ENC_2_EC_METHOD     I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_ENC_2_EC_THRESH     0.10 | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_3_ADDR          I2CPE_PRESET_ADDR_Z     // Encoder 3.  Add additional configuration options | ||||||
|  |   #define I2CPE_ENC_3_AXIS          Z_AXIS                  // as above, or use defaults below. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_4_ADDR          I2CPE_PRESET_ADDR_E     // Encoder 4. | ||||||
|  |   #define I2CPE_ENC_4_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_5_ADDR          34                      // Encoder 5. | ||||||
|  |   #define I2CPE_ENC_5_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   // Default settings for encoders which are enabled, but without settings configured above. | ||||||
|  |   #define I2CPE_DEF_TYPE            I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_DEF_ENC_TICKS_UNIT  2048 | ||||||
|  |   #define I2CPE_DEF_TICKS_REV       (16 * 200) | ||||||
|  |   #define I2CPE_DEF_EC_METHOD       I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_DEF_EC_THRESH       0.1 | ||||||
|  |  | ||||||
|  |   //#define I2CPE_ERR_THRESH_ABORT  100.0                   // Threshold size for error (in mm) error on any given | ||||||
|  |                                                             // axis after which the printer will abort. Comment out to | ||||||
|  |                                                             // disable abort behaviour. | ||||||
|  |  | ||||||
|  |   #define I2CPE_TIME_TRUSTED        10000                   // After an encoder fault, there must be no further fault | ||||||
|  |                                                             // for this amount of time (in ms) before the encoder | ||||||
|  |                                                             // is trusted again. | ||||||
|  |  | ||||||
|  |   /** | ||||||
|  |    * Position is checked every time a new command is executed from the buffer but during long moves, | ||||||
|  |    * this setting determines the minimum update time between checks. A value of 100 works well with | ||||||
|  |    * error rolling average when attempting to correct only for skips and not for vibration. | ||||||
|  |    */ | ||||||
|  |   #define I2CPE_MIN_UPD_TIME_MS     100                     // Minimum time in miliseconds between encoder checks. | ||||||
|  |  | ||||||
|  |   // Use a rolling average to identify persistant errors that indicate skips, as opposed to vibration and noise. | ||||||
|  |   #define I2CPE_ERR_ROLLING_AVERAGE | ||||||
|  |  | ||||||
|  | #endif // I2C_POSITION_ENCODERS | ||||||
|  |  | ||||||
| #endif // CONFIGURATION_ADV_H | #endif // CONFIGURATION_ADV_H | ||||||
|   | |||||||
| @@ -1255,4 +1255,87 @@ | |||||||
|   //#define USER_GCODE_5 "G28\nM503" |   //#define USER_GCODE_5 "G28\nM503" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | //=========================================================================== | ||||||
|  | //====================== I2C Position Encoder Settings ====================== | ||||||
|  | //=========================================================================== | ||||||
|  | /** | ||||||
|  |  *  I2C position encoders for closed loop control. | ||||||
|  |  *  Developed by Chris Barr at Aus3D. | ||||||
|  |  * | ||||||
|  |  *  Wiki: http://wiki.aus3d.com.au/Magnetic_Encoder | ||||||
|  |  *  Github: https://github.com/Aus3D/MagneticEncoder | ||||||
|  |  * | ||||||
|  |  *  Supplier: http://aus3d.com.au/magnetic-encoder-module | ||||||
|  |  *  Alternative Supplier: http://reliabuild3d.com/ | ||||||
|  |  * | ||||||
|  |  *  Reilabuild encoders have been modified to improve reliability. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | //#define I2C_POSITION_ENCODERS | ||||||
|  | #if ENABLED(I2C_POSITION_ENCODERS) | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENCODER_CNT         1                       // The number of encoders installed; max of 5 | ||||||
|  |                                                             // encoders supported currently. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_1_ADDR          I2CPE_PRESET_ADDR_X     // I2C address of the encoder. 30-200. | ||||||
|  |   #define I2CPE_ENC_1_AXIS          X_AXIS                  // Axis the encoder module is installed on.  <X|Y|Z|E>_AXIS. | ||||||
|  |   #define I2CPE_ENC_1_TYPE          I2CPE_ENC_TYPE_LINEAR   // Type of encoder:  I2CPE_ENC_TYPE_LINEAR -or- | ||||||
|  |                                                             // I2CPE_ENC_TYPE_ROTARY. | ||||||
|  |   #define I2CPE_ENC_1_TICKS_UNIT    2048                    // 1024 for magnetic strips with 2mm poles; 2048 for | ||||||
|  |                                                             // 1mm poles. For linear encoders this is ticks / mm, | ||||||
|  |                                                             // for rotary encoders this is ticks / revolution. | ||||||
|  |   //#define I2CPE_ENC_1_TICKS_REV     (16 * 200)            // Only needed for rotary encoders; number of stepper | ||||||
|  |                                                             // steps per full revolution (motor steps/rev * microstepping) | ||||||
|  |   //#define I2CPE_ENC_1_INVERT                              // Invert the direction of axis travel. | ||||||
|  |   #define I2CPE_ENC_1_EC_METHOD     I2CPE_ECM_NONE          // Type of error error correction. | ||||||
|  |   #define I2CPE_ENC_1_EC_THRESH     0.10                    // Threshold size for error (in mm) above which the | ||||||
|  |                                                             // printer will attempt to correct the error; errors | ||||||
|  |                                                             // smaller than this are ignored to minimize effects of | ||||||
|  |                                                             // measurement noise / latency (filter). | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_2_ADDR          I2CPE_PRESET_ADDR_Y     // Same as above, but for encoder 2. | ||||||
|  |   #define I2CPE_ENC_2_AXIS          Y_AXIS | ||||||
|  |   #define I2CPE_ENC_2_TYPE          I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_ENC_2_TICKS_UNIT    2048 | ||||||
|  |   //#define I2CPE_ENC_2_TICKS_REV   (16 * 200) | ||||||
|  |   //#define I2CPE_ENC_2_INVERT | ||||||
|  |   #define I2CPE_ENC_2_EC_METHOD     I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_ENC_2_EC_THRESH     0.10 | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_3_ADDR          I2CPE_PRESET_ADDR_Z     // Encoder 3.  Add additional configuration options | ||||||
|  |   #define I2CPE_ENC_3_AXIS          Z_AXIS                  // as above, or use defaults below. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_4_ADDR          I2CPE_PRESET_ADDR_E     // Encoder 4. | ||||||
|  |   #define I2CPE_ENC_4_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_5_ADDR          34                      // Encoder 5. | ||||||
|  |   #define I2CPE_ENC_5_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   // Default settings for encoders which are enabled, but without settings configured above. | ||||||
|  |   #define I2CPE_DEF_TYPE            I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_DEF_ENC_TICKS_UNIT  2048 | ||||||
|  |   #define I2CPE_DEF_TICKS_REV       (16 * 200) | ||||||
|  |   #define I2CPE_DEF_EC_METHOD       I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_DEF_EC_THRESH       0.1 | ||||||
|  |  | ||||||
|  |   //#define I2CPE_ERR_THRESH_ABORT  100.0                   // Threshold size for error (in mm) error on any given | ||||||
|  |                                                             // axis after which the printer will abort. Comment out to | ||||||
|  |                                                             // disable abort behaviour. | ||||||
|  |  | ||||||
|  |   #define I2CPE_TIME_TRUSTED        10000                   // After an encoder fault, there must be no further fault | ||||||
|  |                                                             // for this amount of time (in ms) before the encoder | ||||||
|  |                                                             // is trusted again. | ||||||
|  |  | ||||||
|  |   /** | ||||||
|  |    * Position is checked every time a new command is executed from the buffer but during long moves, | ||||||
|  |    * this setting determines the minimum update time between checks. A value of 100 works well with | ||||||
|  |    * error rolling average when attempting to correct only for skips and not for vibration. | ||||||
|  |    */ | ||||||
|  |   #define I2CPE_MIN_UPD_TIME_MS     100                     // Minimum time in miliseconds between encoder checks. | ||||||
|  |  | ||||||
|  |   // Use a rolling average to identify persistant errors that indicate skips, as opposed to vibration and noise. | ||||||
|  |   #define I2CPE_ERR_ROLLING_AVERAGE | ||||||
|  |  | ||||||
|  | #endif // I2C_POSITION_ENCODERS | ||||||
|  |  | ||||||
| #endif // CONFIGURATION_ADV_H | #endif // CONFIGURATION_ADV_H | ||||||
|   | |||||||
| @@ -1268,4 +1268,87 @@ | |||||||
|   //#define USER_GCODE_5 "G28\nM503" |   //#define USER_GCODE_5 "G28\nM503" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | //=========================================================================== | ||||||
|  | //====================== I2C Position Encoder Settings ====================== | ||||||
|  | //=========================================================================== | ||||||
|  | /** | ||||||
|  |  *  I2C position encoders for closed loop control. | ||||||
|  |  *  Developed by Chris Barr at Aus3D. | ||||||
|  |  * | ||||||
|  |  *  Wiki: http://wiki.aus3d.com.au/Magnetic_Encoder | ||||||
|  |  *  Github: https://github.com/Aus3D/MagneticEncoder | ||||||
|  |  * | ||||||
|  |  *  Supplier: http://aus3d.com.au/magnetic-encoder-module | ||||||
|  |  *  Alternative Supplier: http://reliabuild3d.com/ | ||||||
|  |  * | ||||||
|  |  *  Reilabuild encoders have been modified to improve reliability. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | //#define I2C_POSITION_ENCODERS | ||||||
|  | #if ENABLED(I2C_POSITION_ENCODERS) | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENCODER_CNT         1                       // The number of encoders installed; max of 5 | ||||||
|  |                                                             // encoders supported currently. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_1_ADDR          I2CPE_PRESET_ADDR_X     // I2C address of the encoder. 30-200. | ||||||
|  |   #define I2CPE_ENC_1_AXIS          X_AXIS                  // Axis the encoder module is installed on.  <X|Y|Z|E>_AXIS. | ||||||
|  |   #define I2CPE_ENC_1_TYPE          I2CPE_ENC_TYPE_LINEAR   // Type of encoder:  I2CPE_ENC_TYPE_LINEAR -or- | ||||||
|  |                                                             // I2CPE_ENC_TYPE_ROTARY. | ||||||
|  |   #define I2CPE_ENC_1_TICKS_UNIT    2048                    // 1024 for magnetic strips with 2mm poles; 2048 for | ||||||
|  |                                                             // 1mm poles. For linear encoders this is ticks / mm, | ||||||
|  |                                                             // for rotary encoders this is ticks / revolution. | ||||||
|  |   //#define I2CPE_ENC_1_TICKS_REV     (16 * 200)            // Only needed for rotary encoders; number of stepper | ||||||
|  |                                                             // steps per full revolution (motor steps/rev * microstepping) | ||||||
|  |   //#define I2CPE_ENC_1_INVERT                              // Invert the direction of axis travel. | ||||||
|  |   #define I2CPE_ENC_1_EC_METHOD     I2CPE_ECM_NONE          // Type of error error correction. | ||||||
|  |   #define I2CPE_ENC_1_EC_THRESH     0.10                    // Threshold size for error (in mm) above which the | ||||||
|  |                                                             // printer will attempt to correct the error; errors | ||||||
|  |                                                             // smaller than this are ignored to minimize effects of | ||||||
|  |                                                             // measurement noise / latency (filter). | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_2_ADDR          I2CPE_PRESET_ADDR_Y     // Same as above, but for encoder 2. | ||||||
|  |   #define I2CPE_ENC_2_AXIS          Y_AXIS | ||||||
|  |   #define I2CPE_ENC_2_TYPE          I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_ENC_2_TICKS_UNIT    2048 | ||||||
|  |   //#define I2CPE_ENC_2_TICKS_REV   (16 * 200) | ||||||
|  |   //#define I2CPE_ENC_2_INVERT | ||||||
|  |   #define I2CPE_ENC_2_EC_METHOD     I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_ENC_2_EC_THRESH     0.10 | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_3_ADDR          I2CPE_PRESET_ADDR_Z     // Encoder 3.  Add additional configuration options | ||||||
|  |   #define I2CPE_ENC_3_AXIS          Z_AXIS                  // as above, or use defaults below. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_4_ADDR          I2CPE_PRESET_ADDR_E     // Encoder 4. | ||||||
|  |   #define I2CPE_ENC_4_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_5_ADDR          34                      // Encoder 5. | ||||||
|  |   #define I2CPE_ENC_5_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   // Default settings for encoders which are enabled, but without settings configured above. | ||||||
|  |   #define I2CPE_DEF_TYPE            I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_DEF_ENC_TICKS_UNIT  2048 | ||||||
|  |   #define I2CPE_DEF_TICKS_REV       (16 * 200) | ||||||
|  |   #define I2CPE_DEF_EC_METHOD       I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_DEF_EC_THRESH       0.1 | ||||||
|  |  | ||||||
|  |   //#define I2CPE_ERR_THRESH_ABORT  100.0                   // Threshold size for error (in mm) error on any given | ||||||
|  |                                                             // axis after which the printer will abort. Comment out to | ||||||
|  |                                                             // disable abort behaviour. | ||||||
|  |  | ||||||
|  |   #define I2CPE_TIME_TRUSTED        10000                   // After an encoder fault, there must be no further fault | ||||||
|  |                                                             // for this amount of time (in ms) before the encoder | ||||||
|  |                                                             // is trusted again. | ||||||
|  |  | ||||||
|  |   /** | ||||||
|  |    * Position is checked every time a new command is executed from the buffer but during long moves, | ||||||
|  |    * this setting determines the minimum update time between checks. A value of 100 works well with | ||||||
|  |    * error rolling average when attempting to correct only for skips and not for vibration. | ||||||
|  |    */ | ||||||
|  |   #define I2CPE_MIN_UPD_TIME_MS     100                     // Minimum time in miliseconds between encoder checks. | ||||||
|  |  | ||||||
|  |   // Use a rolling average to identify persistant errors that indicate skips, as opposed to vibration and noise. | ||||||
|  |   #define I2CPE_ERR_ROLLING_AVERAGE | ||||||
|  |  | ||||||
|  | #endif // I2C_POSITION_ENCODERS | ||||||
|  |  | ||||||
| #endif // CONFIGURATION_ADV_H | #endif // CONFIGURATION_ADV_H | ||||||
|   | |||||||
| @@ -1255,4 +1255,87 @@ | |||||||
|   //#define USER_GCODE_5 "G28\nM503" |   //#define USER_GCODE_5 "G28\nM503" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | //=========================================================================== | ||||||
|  | //====================== I2C Position Encoder Settings ====================== | ||||||
|  | //=========================================================================== | ||||||
|  | /** | ||||||
|  |  *  I2C position encoders for closed loop control. | ||||||
|  |  *  Developed by Chris Barr at Aus3D. | ||||||
|  |  * | ||||||
|  |  *  Wiki: http://wiki.aus3d.com.au/Magnetic_Encoder | ||||||
|  |  *  Github: https://github.com/Aus3D/MagneticEncoder | ||||||
|  |  * | ||||||
|  |  *  Supplier: http://aus3d.com.au/magnetic-encoder-module | ||||||
|  |  *  Alternative Supplier: http://reliabuild3d.com/ | ||||||
|  |  * | ||||||
|  |  *  Reilabuild encoders have been modified to improve reliability. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | //#define I2C_POSITION_ENCODERS | ||||||
|  | #if ENABLED(I2C_POSITION_ENCODERS) | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENCODER_CNT         1                       // The number of encoders installed; max of 5 | ||||||
|  |                                                             // encoders supported currently. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_1_ADDR          I2CPE_PRESET_ADDR_X     // I2C address of the encoder. 30-200. | ||||||
|  |   #define I2CPE_ENC_1_AXIS          X_AXIS                  // Axis the encoder module is installed on.  <X|Y|Z|E>_AXIS. | ||||||
|  |   #define I2CPE_ENC_1_TYPE          I2CPE_ENC_TYPE_LINEAR   // Type of encoder:  I2CPE_ENC_TYPE_LINEAR -or- | ||||||
|  |                                                             // I2CPE_ENC_TYPE_ROTARY. | ||||||
|  |   #define I2CPE_ENC_1_TICKS_UNIT    2048                    // 1024 for magnetic strips with 2mm poles; 2048 for | ||||||
|  |                                                             // 1mm poles. For linear encoders this is ticks / mm, | ||||||
|  |                                                             // for rotary encoders this is ticks / revolution. | ||||||
|  |   //#define I2CPE_ENC_1_TICKS_REV     (16 * 200)            // Only needed for rotary encoders; number of stepper | ||||||
|  |                                                             // steps per full revolution (motor steps/rev * microstepping) | ||||||
|  |   //#define I2CPE_ENC_1_INVERT                              // Invert the direction of axis travel. | ||||||
|  |   #define I2CPE_ENC_1_EC_METHOD     I2CPE_ECM_NONE          // Type of error error correction. | ||||||
|  |   #define I2CPE_ENC_1_EC_THRESH     0.10                    // Threshold size for error (in mm) above which the | ||||||
|  |                                                             // printer will attempt to correct the error; errors | ||||||
|  |                                                             // smaller than this are ignored to minimize effects of | ||||||
|  |                                                             // measurement noise / latency (filter). | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_2_ADDR          I2CPE_PRESET_ADDR_Y     // Same as above, but for encoder 2. | ||||||
|  |   #define I2CPE_ENC_2_AXIS          Y_AXIS | ||||||
|  |   #define I2CPE_ENC_2_TYPE          I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_ENC_2_TICKS_UNIT    2048 | ||||||
|  |   //#define I2CPE_ENC_2_TICKS_REV   (16 * 200) | ||||||
|  |   //#define I2CPE_ENC_2_INVERT | ||||||
|  |   #define I2CPE_ENC_2_EC_METHOD     I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_ENC_2_EC_THRESH     0.10 | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_3_ADDR          I2CPE_PRESET_ADDR_Z     // Encoder 3.  Add additional configuration options | ||||||
|  |   #define I2CPE_ENC_3_AXIS          Z_AXIS                  // as above, or use defaults below. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_4_ADDR          I2CPE_PRESET_ADDR_E     // Encoder 4. | ||||||
|  |   #define I2CPE_ENC_4_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_5_ADDR          34                      // Encoder 5. | ||||||
|  |   #define I2CPE_ENC_5_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   // Default settings for encoders which are enabled, but without settings configured above. | ||||||
|  |   #define I2CPE_DEF_TYPE            I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_DEF_ENC_TICKS_UNIT  2048 | ||||||
|  |   #define I2CPE_DEF_TICKS_REV       (16 * 200) | ||||||
|  |   #define I2CPE_DEF_EC_METHOD       I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_DEF_EC_THRESH       0.1 | ||||||
|  |  | ||||||
|  |   //#define I2CPE_ERR_THRESH_ABORT  100.0                   // Threshold size for error (in mm) error on any given | ||||||
|  |                                                             // axis after which the printer will abort. Comment out to | ||||||
|  |                                                             // disable abort behaviour. | ||||||
|  |  | ||||||
|  |   #define I2CPE_TIME_TRUSTED        10000                   // After an encoder fault, there must be no further fault | ||||||
|  |                                                             // for this amount of time (in ms) before the encoder | ||||||
|  |                                                             // is trusted again. | ||||||
|  |  | ||||||
|  |   /** | ||||||
|  |    * Position is checked every time a new command is executed from the buffer but during long moves, | ||||||
|  |    * this setting determines the minimum update time between checks. A value of 100 works well with | ||||||
|  |    * error rolling average when attempting to correct only for skips and not for vibration. | ||||||
|  |    */ | ||||||
|  |   #define I2CPE_MIN_UPD_TIME_MS     100                     // Minimum time in miliseconds between encoder checks. | ||||||
|  |  | ||||||
|  |   // Use a rolling average to identify persistant errors that indicate skips, as opposed to vibration and noise. | ||||||
|  |   #define I2CPE_ERR_ROLLING_AVERAGE | ||||||
|  |  | ||||||
|  | #endif // I2C_POSITION_ENCODERS | ||||||
|  |  | ||||||
| #endif // CONFIGURATION_ADV_H | #endif // CONFIGURATION_ADV_H | ||||||
|   | |||||||
| @@ -1238,4 +1238,87 @@ | |||||||
|   //#define USER_GCODE_5 "G28\nM503" |   //#define USER_GCODE_5 "G28\nM503" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | //=========================================================================== | ||||||
|  | //====================== I2C Position Encoder Settings ====================== | ||||||
|  | //=========================================================================== | ||||||
|  | /** | ||||||
|  |  *  I2C position encoders for closed loop control. | ||||||
|  |  *  Developed by Chris Barr at Aus3D. | ||||||
|  |  * | ||||||
|  |  *  Wiki: http://wiki.aus3d.com.au/Magnetic_Encoder | ||||||
|  |  *  Github: https://github.com/Aus3D/MagneticEncoder | ||||||
|  |  * | ||||||
|  |  *  Supplier: http://aus3d.com.au/magnetic-encoder-module | ||||||
|  |  *  Alternative Supplier: http://reliabuild3d.com/ | ||||||
|  |  * | ||||||
|  |  *  Reilabuild encoders have been modified to improve reliability. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | //#define I2C_POSITION_ENCODERS | ||||||
|  | #if ENABLED(I2C_POSITION_ENCODERS) | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENCODER_CNT         1                       // The number of encoders installed; max of 5 | ||||||
|  |                                                             // encoders supported currently. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_1_ADDR          I2CPE_PRESET_ADDR_X     // I2C address of the encoder. 30-200. | ||||||
|  |   #define I2CPE_ENC_1_AXIS          X_AXIS                  // Axis the encoder module is installed on.  <X|Y|Z|E>_AXIS. | ||||||
|  |   #define I2CPE_ENC_1_TYPE          I2CPE_ENC_TYPE_LINEAR   // Type of encoder:  I2CPE_ENC_TYPE_LINEAR -or- | ||||||
|  |                                                             // I2CPE_ENC_TYPE_ROTARY. | ||||||
|  |   #define I2CPE_ENC_1_TICKS_UNIT    2048                    // 1024 for magnetic strips with 2mm poles; 2048 for | ||||||
|  |                                                             // 1mm poles. For linear encoders this is ticks / mm, | ||||||
|  |                                                             // for rotary encoders this is ticks / revolution. | ||||||
|  |   //#define I2CPE_ENC_1_TICKS_REV     (16 * 200)            // Only needed for rotary encoders; number of stepper | ||||||
|  |                                                             // steps per full revolution (motor steps/rev * microstepping) | ||||||
|  |   //#define I2CPE_ENC_1_INVERT                              // Invert the direction of axis travel. | ||||||
|  |   #define I2CPE_ENC_1_EC_METHOD     I2CPE_ECM_NONE          // Type of error error correction. | ||||||
|  |   #define I2CPE_ENC_1_EC_THRESH     0.10                    // Threshold size for error (in mm) above which the | ||||||
|  |                                                             // printer will attempt to correct the error; errors | ||||||
|  |                                                             // smaller than this are ignored to minimize effects of | ||||||
|  |                                                             // measurement noise / latency (filter). | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_2_ADDR          I2CPE_PRESET_ADDR_Y     // Same as above, but for encoder 2. | ||||||
|  |   #define I2CPE_ENC_2_AXIS          Y_AXIS | ||||||
|  |   #define I2CPE_ENC_2_TYPE          I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_ENC_2_TICKS_UNIT    2048 | ||||||
|  |   //#define I2CPE_ENC_2_TICKS_REV   (16 * 200) | ||||||
|  |   //#define I2CPE_ENC_2_INVERT | ||||||
|  |   #define I2CPE_ENC_2_EC_METHOD     I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_ENC_2_EC_THRESH     0.10 | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_3_ADDR          I2CPE_PRESET_ADDR_Z     // Encoder 3.  Add additional configuration options | ||||||
|  |   #define I2CPE_ENC_3_AXIS          Z_AXIS                  // as above, or use defaults below. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_4_ADDR          I2CPE_PRESET_ADDR_E     // Encoder 4. | ||||||
|  |   #define I2CPE_ENC_4_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_5_ADDR          34                      // Encoder 5. | ||||||
|  |   #define I2CPE_ENC_5_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   // Default settings for encoders which are enabled, but without settings configured above. | ||||||
|  |   #define I2CPE_DEF_TYPE            I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_DEF_ENC_TICKS_UNIT  2048 | ||||||
|  |   #define I2CPE_DEF_TICKS_REV       (16 * 200) | ||||||
|  |   #define I2CPE_DEF_EC_METHOD       I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_DEF_EC_THRESH       0.1 | ||||||
|  |  | ||||||
|  |   //#define I2CPE_ERR_THRESH_ABORT  100.0                   // Threshold size for error (in mm) error on any given | ||||||
|  |                                                             // axis after which the printer will abort. Comment out to | ||||||
|  |                                                             // disable abort behaviour. | ||||||
|  |  | ||||||
|  |   #define I2CPE_TIME_TRUSTED        10000                   // After an encoder fault, there must be no further fault | ||||||
|  |                                                             // for this amount of time (in ms) before the encoder | ||||||
|  |                                                             // is trusted again. | ||||||
|  |  | ||||||
|  |   /** | ||||||
|  |    * Position is checked every time a new command is executed from the buffer but during long moves, | ||||||
|  |    * this setting determines the minimum update time between checks. A value of 100 works well with | ||||||
|  |    * error rolling average when attempting to correct only for skips and not for vibration. | ||||||
|  |    */ | ||||||
|  |   #define I2CPE_MIN_UPD_TIME_MS     100                     // Minimum time in miliseconds between encoder checks. | ||||||
|  |  | ||||||
|  |   // Use a rolling average to identify persistant errors that indicate skips, as opposed to vibration and noise. | ||||||
|  |   #define I2CPE_ERR_ROLLING_AVERAGE | ||||||
|  |  | ||||||
|  | #endif // I2C_POSITION_ENCODERS | ||||||
|  |  | ||||||
| #endif // CONFIGURATION_ADV_H | #endif // CONFIGURATION_ADV_H | ||||||
|   | |||||||
| @@ -1268,4 +1268,87 @@ | |||||||
|   //#define USER_GCODE_5 "G28\nM503" |   //#define USER_GCODE_5 "G28\nM503" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | //=========================================================================== | ||||||
|  | //====================== I2C Position Encoder Settings ====================== | ||||||
|  | //=========================================================================== | ||||||
|  | /** | ||||||
|  |  *  I2C position encoders for closed loop control. | ||||||
|  |  *  Developed by Chris Barr at Aus3D. | ||||||
|  |  * | ||||||
|  |  *  Wiki: http://wiki.aus3d.com.au/Magnetic_Encoder | ||||||
|  |  *  Github: https://github.com/Aus3D/MagneticEncoder | ||||||
|  |  * | ||||||
|  |  *  Supplier: http://aus3d.com.au/magnetic-encoder-module | ||||||
|  |  *  Alternative Supplier: http://reliabuild3d.com/ | ||||||
|  |  * | ||||||
|  |  *  Reilabuild encoders have been modified to improve reliability. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | //#define I2C_POSITION_ENCODERS | ||||||
|  | #if ENABLED(I2C_POSITION_ENCODERS) | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENCODER_CNT         1                       // The number of encoders installed; max of 5 | ||||||
|  |                                                             // encoders supported currently. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_1_ADDR          I2CPE_PRESET_ADDR_X     // I2C address of the encoder. 30-200. | ||||||
|  |   #define I2CPE_ENC_1_AXIS          X_AXIS                  // Axis the encoder module is installed on.  <X|Y|Z|E>_AXIS. | ||||||
|  |   #define I2CPE_ENC_1_TYPE          I2CPE_ENC_TYPE_LINEAR   // Type of encoder:  I2CPE_ENC_TYPE_LINEAR -or- | ||||||
|  |                                                             // I2CPE_ENC_TYPE_ROTARY. | ||||||
|  |   #define I2CPE_ENC_1_TICKS_UNIT    2048                    // 1024 for magnetic strips with 2mm poles; 2048 for | ||||||
|  |                                                             // 1mm poles. For linear encoders this is ticks / mm, | ||||||
|  |                                                             // for rotary encoders this is ticks / revolution. | ||||||
|  |   //#define I2CPE_ENC_1_TICKS_REV     (16 * 200)            // Only needed for rotary encoders; number of stepper | ||||||
|  |                                                             // steps per full revolution (motor steps/rev * microstepping) | ||||||
|  |   //#define I2CPE_ENC_1_INVERT                              // Invert the direction of axis travel. | ||||||
|  |   #define I2CPE_ENC_1_EC_METHOD     I2CPE_ECM_NONE          // Type of error error correction. | ||||||
|  |   #define I2CPE_ENC_1_EC_THRESH     0.10                    // Threshold size for error (in mm) above which the | ||||||
|  |                                                             // printer will attempt to correct the error; errors | ||||||
|  |                                                             // smaller than this are ignored to minimize effects of | ||||||
|  |                                                             // measurement noise / latency (filter). | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_2_ADDR          I2CPE_PRESET_ADDR_Y     // Same as above, but for encoder 2. | ||||||
|  |   #define I2CPE_ENC_2_AXIS          Y_AXIS | ||||||
|  |   #define I2CPE_ENC_2_TYPE          I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_ENC_2_TICKS_UNIT    2048 | ||||||
|  |   //#define I2CPE_ENC_2_TICKS_REV   (16 * 200) | ||||||
|  |   //#define I2CPE_ENC_2_INVERT | ||||||
|  |   #define I2CPE_ENC_2_EC_METHOD     I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_ENC_2_EC_THRESH     0.10 | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_3_ADDR          I2CPE_PRESET_ADDR_Z     // Encoder 3.  Add additional configuration options | ||||||
|  |   #define I2CPE_ENC_3_AXIS          Z_AXIS                  // as above, or use defaults below. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_4_ADDR          I2CPE_PRESET_ADDR_E     // Encoder 4. | ||||||
|  |   #define I2CPE_ENC_4_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_5_ADDR          34                      // Encoder 5. | ||||||
|  |   #define I2CPE_ENC_5_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   // Default settings for encoders which are enabled, but without settings configured above. | ||||||
|  |   #define I2CPE_DEF_TYPE            I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_DEF_ENC_TICKS_UNIT  2048 | ||||||
|  |   #define I2CPE_DEF_TICKS_REV       (16 * 200) | ||||||
|  |   #define I2CPE_DEF_EC_METHOD       I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_DEF_EC_THRESH       0.1 | ||||||
|  |  | ||||||
|  |   //#define I2CPE_ERR_THRESH_ABORT  100.0                   // Threshold size for error (in mm) error on any given | ||||||
|  |                                                             // axis after which the printer will abort. Comment out to | ||||||
|  |                                                             // disable abort behaviour. | ||||||
|  |  | ||||||
|  |   #define I2CPE_TIME_TRUSTED        10000                   // After an encoder fault, there must be no further fault | ||||||
|  |                                                             // for this amount of time (in ms) before the encoder | ||||||
|  |                                                             // is trusted again. | ||||||
|  |  | ||||||
|  |   /** | ||||||
|  |    * Position is checked every time a new command is executed from the buffer but during long moves, | ||||||
|  |    * this setting determines the minimum update time between checks. A value of 100 works well with | ||||||
|  |    * error rolling average when attempting to correct only for skips and not for vibration. | ||||||
|  |    */ | ||||||
|  |   #define I2CPE_MIN_UPD_TIME_MS     100                     // Minimum time in miliseconds between encoder checks. | ||||||
|  |  | ||||||
|  |   // Use a rolling average to identify persistant errors that indicate skips, as opposed to vibration and noise. | ||||||
|  |   #define I2CPE_ERR_ROLLING_AVERAGE | ||||||
|  |  | ||||||
|  | #endif // I2C_POSITION_ENCODERS | ||||||
|  |  | ||||||
| #endif // CONFIGURATION_ADV_H | #endif // CONFIGURATION_ADV_H | ||||||
|   | |||||||
| @@ -1255,4 +1255,87 @@ | |||||||
|   //#define USER_GCODE_5 "G28\nM503" |   //#define USER_GCODE_5 "G28\nM503" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | //=========================================================================== | ||||||
|  | //====================== I2C Position Encoder Settings ====================== | ||||||
|  | //=========================================================================== | ||||||
|  | /** | ||||||
|  |  *  I2C position encoders for closed loop control. | ||||||
|  |  *  Developed by Chris Barr at Aus3D. | ||||||
|  |  * | ||||||
|  |  *  Wiki: http://wiki.aus3d.com.au/Magnetic_Encoder | ||||||
|  |  *  Github: https://github.com/Aus3D/MagneticEncoder | ||||||
|  |  * | ||||||
|  |  *  Supplier: http://aus3d.com.au/magnetic-encoder-module | ||||||
|  |  *  Alternative Supplier: http://reliabuild3d.com/ | ||||||
|  |  * | ||||||
|  |  *  Reilabuild encoders have been modified to improve reliability. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | //#define I2C_POSITION_ENCODERS | ||||||
|  | #if ENABLED(I2C_POSITION_ENCODERS) | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENCODER_CNT         1                       // The number of encoders installed; max of 5 | ||||||
|  |                                                             // encoders supported currently. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_1_ADDR          I2CPE_PRESET_ADDR_X     // I2C address of the encoder. 30-200. | ||||||
|  |   #define I2CPE_ENC_1_AXIS          X_AXIS                  // Axis the encoder module is installed on.  <X|Y|Z|E>_AXIS. | ||||||
|  |   #define I2CPE_ENC_1_TYPE          I2CPE_ENC_TYPE_LINEAR   // Type of encoder:  I2CPE_ENC_TYPE_LINEAR -or- | ||||||
|  |                                                             // I2CPE_ENC_TYPE_ROTARY. | ||||||
|  |   #define I2CPE_ENC_1_TICKS_UNIT    2048                    // 1024 for magnetic strips with 2mm poles; 2048 for | ||||||
|  |                                                             // 1mm poles. For linear encoders this is ticks / mm, | ||||||
|  |                                                             // for rotary encoders this is ticks / revolution. | ||||||
|  |   //#define I2CPE_ENC_1_TICKS_REV     (16 * 200)            // Only needed for rotary encoders; number of stepper | ||||||
|  |                                                             // steps per full revolution (motor steps/rev * microstepping) | ||||||
|  |   //#define I2CPE_ENC_1_INVERT                              // Invert the direction of axis travel. | ||||||
|  |   #define I2CPE_ENC_1_EC_METHOD     I2CPE_ECM_NONE          // Type of error error correction. | ||||||
|  |   #define I2CPE_ENC_1_EC_THRESH     0.10                    // Threshold size for error (in mm) above which the | ||||||
|  |                                                             // printer will attempt to correct the error; errors | ||||||
|  |                                                             // smaller than this are ignored to minimize effects of | ||||||
|  |                                                             // measurement noise / latency (filter). | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_2_ADDR          I2CPE_PRESET_ADDR_Y     // Same as above, but for encoder 2. | ||||||
|  |   #define I2CPE_ENC_2_AXIS          Y_AXIS | ||||||
|  |   #define I2CPE_ENC_2_TYPE          I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_ENC_2_TICKS_UNIT    2048 | ||||||
|  |   //#define I2CPE_ENC_2_TICKS_REV   (16 * 200) | ||||||
|  |   //#define I2CPE_ENC_2_INVERT | ||||||
|  |   #define I2CPE_ENC_2_EC_METHOD     I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_ENC_2_EC_THRESH     0.10 | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_3_ADDR          I2CPE_PRESET_ADDR_Z     // Encoder 3.  Add additional configuration options | ||||||
|  |   #define I2CPE_ENC_3_AXIS          Z_AXIS                  // as above, or use defaults below. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_4_ADDR          I2CPE_PRESET_ADDR_E     // Encoder 4. | ||||||
|  |   #define I2CPE_ENC_4_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_5_ADDR          34                      // Encoder 5. | ||||||
|  |   #define I2CPE_ENC_5_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   // Default settings for encoders which are enabled, but without settings configured above. | ||||||
|  |   #define I2CPE_DEF_TYPE            I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_DEF_ENC_TICKS_UNIT  2048 | ||||||
|  |   #define I2CPE_DEF_TICKS_REV       (16 * 200) | ||||||
|  |   #define I2CPE_DEF_EC_METHOD       I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_DEF_EC_THRESH       0.1 | ||||||
|  |  | ||||||
|  |   //#define I2CPE_ERR_THRESH_ABORT  100.0                   // Threshold size for error (in mm) error on any given | ||||||
|  |                                                             // axis after which the printer will abort. Comment out to | ||||||
|  |                                                             // disable abort behaviour. | ||||||
|  |  | ||||||
|  |   #define I2CPE_TIME_TRUSTED        10000                   // After an encoder fault, there must be no further fault | ||||||
|  |                                                             // for this amount of time (in ms) before the encoder | ||||||
|  |                                                             // is trusted again. | ||||||
|  |  | ||||||
|  |   /** | ||||||
|  |    * Position is checked every time a new command is executed from the buffer but during long moves, | ||||||
|  |    * this setting determines the minimum update time between checks. A value of 100 works well with | ||||||
|  |    * error rolling average when attempting to correct only for skips and not for vibration. | ||||||
|  |    */ | ||||||
|  |   #define I2CPE_MIN_UPD_TIME_MS     100                     // Minimum time in miliseconds between encoder checks. | ||||||
|  |  | ||||||
|  |   // Use a rolling average to identify persistant errors that indicate skips, as opposed to vibration and noise. | ||||||
|  |   #define I2CPE_ERR_ROLLING_AVERAGE | ||||||
|  |  | ||||||
|  | #endif // I2C_POSITION_ENCODERS | ||||||
|  |  | ||||||
| #endif // CONFIGURATION_ADV_H | #endif // CONFIGURATION_ADV_H | ||||||
|   | |||||||
| @@ -1262,4 +1262,87 @@ | |||||||
|   #define USER_GCODE_5 "G28\nM503" |   #define USER_GCODE_5 "G28\nM503" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | //=========================================================================== | ||||||
|  | //====================== I2C Position Encoder Settings ====================== | ||||||
|  | //=========================================================================== | ||||||
|  | /** | ||||||
|  |  *  I2C position encoders for closed loop control. | ||||||
|  |  *  Developed by Chris Barr at Aus3D. | ||||||
|  |  * | ||||||
|  |  *  Wiki: http://wiki.aus3d.com.au/Magnetic_Encoder | ||||||
|  |  *  Github: https://github.com/Aus3D/MagneticEncoder | ||||||
|  |  * | ||||||
|  |  *  Supplier: http://aus3d.com.au/magnetic-encoder-module | ||||||
|  |  *  Alternative Supplier: http://reliabuild3d.com/ | ||||||
|  |  * | ||||||
|  |  *  Reilabuild encoders have been modified to improve reliability. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | //#define I2C_POSITION_ENCODERS | ||||||
|  | #if ENABLED(I2C_POSITION_ENCODERS) | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENCODER_CNT         1                       // The number of encoders installed; max of 5 | ||||||
|  |                                                             // encoders supported currently. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_1_ADDR          I2CPE_PRESET_ADDR_X     // I2C address of the encoder. 30-200. | ||||||
|  |   #define I2CPE_ENC_1_AXIS          X_AXIS                  // Axis the encoder module is installed on.  <X|Y|Z|E>_AXIS. | ||||||
|  |   #define I2CPE_ENC_1_TYPE          I2CPE_ENC_TYPE_LINEAR   // Type of encoder:  I2CPE_ENC_TYPE_LINEAR -or- | ||||||
|  |                                                             // I2CPE_ENC_TYPE_ROTARY. | ||||||
|  |   #define I2CPE_ENC_1_TICKS_UNIT    2048                    // 1024 for magnetic strips with 2mm poles; 2048 for | ||||||
|  |                                                             // 1mm poles. For linear encoders this is ticks / mm, | ||||||
|  |                                                             // for rotary encoders this is ticks / revolution. | ||||||
|  |   //#define I2CPE_ENC_1_TICKS_REV     (16 * 200)            // Only needed for rotary encoders; number of stepper | ||||||
|  |                                                             // steps per full revolution (motor steps/rev * microstepping) | ||||||
|  |   //#define I2CPE_ENC_1_INVERT                              // Invert the direction of axis travel. | ||||||
|  |   #define I2CPE_ENC_1_EC_METHOD     I2CPE_ECM_NONE          // Type of error error correction. | ||||||
|  |   #define I2CPE_ENC_1_EC_THRESH     0.10                    // Threshold size for error (in mm) above which the | ||||||
|  |                                                             // printer will attempt to correct the error; errors | ||||||
|  |                                                             // smaller than this are ignored to minimize effects of | ||||||
|  |                                                             // measurement noise / latency (filter). | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_2_ADDR          I2CPE_PRESET_ADDR_Y     // Same as above, but for encoder 2. | ||||||
|  |   #define I2CPE_ENC_2_AXIS          Y_AXIS | ||||||
|  |   #define I2CPE_ENC_2_TYPE          I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_ENC_2_TICKS_UNIT    2048 | ||||||
|  |   //#define I2CPE_ENC_2_TICKS_REV   (16 * 200) | ||||||
|  |   //#define I2CPE_ENC_2_INVERT | ||||||
|  |   #define I2CPE_ENC_2_EC_METHOD     I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_ENC_2_EC_THRESH     0.10 | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_3_ADDR          I2CPE_PRESET_ADDR_Z     // Encoder 3.  Add additional configuration options | ||||||
|  |   #define I2CPE_ENC_3_AXIS          Z_AXIS                  // as above, or use defaults below. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_4_ADDR          I2CPE_PRESET_ADDR_E     // Encoder 4. | ||||||
|  |   #define I2CPE_ENC_4_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_5_ADDR          34                      // Encoder 5. | ||||||
|  |   #define I2CPE_ENC_5_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   // Default settings for encoders which are enabled, but without settings configured above. | ||||||
|  |   #define I2CPE_DEF_TYPE            I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_DEF_ENC_TICKS_UNIT  2048 | ||||||
|  |   #define I2CPE_DEF_TICKS_REV       (16 * 200) | ||||||
|  |   #define I2CPE_DEF_EC_METHOD       I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_DEF_EC_THRESH       0.1 | ||||||
|  |  | ||||||
|  |   //#define I2CPE_ERR_THRESH_ABORT  100.0                   // Threshold size for error (in mm) error on any given | ||||||
|  |                                                             // axis after which the printer will abort. Comment out to | ||||||
|  |                                                             // disable abort behaviour. | ||||||
|  |  | ||||||
|  |   #define I2CPE_TIME_TRUSTED        10000                   // After an encoder fault, there must be no further fault | ||||||
|  |                                                             // for this amount of time (in ms) before the encoder | ||||||
|  |                                                             // is trusted again. | ||||||
|  |  | ||||||
|  |   /** | ||||||
|  |    * Position is checked every time a new command is executed from the buffer but during long moves, | ||||||
|  |    * this setting determines the minimum update time between checks. A value of 100 works well with | ||||||
|  |    * error rolling average when attempting to correct only for skips and not for vibration. | ||||||
|  |    */ | ||||||
|  |   #define I2CPE_MIN_UPD_TIME_MS     100                     // Minimum time in miliseconds between encoder checks. | ||||||
|  |  | ||||||
|  |   // Use a rolling average to identify persistant errors that indicate skips, as opposed to vibration and noise. | ||||||
|  |   #define I2CPE_ERR_ROLLING_AVERAGE | ||||||
|  |  | ||||||
|  | #endif // I2C_POSITION_ENCODERS | ||||||
|  |  | ||||||
| #endif // CONFIGURATION_ADV_H | #endif // CONFIGURATION_ADV_H | ||||||
|   | |||||||
| @@ -1255,4 +1255,87 @@ | |||||||
|   //#define USER_GCODE_5 "G28\nM503" |   //#define USER_GCODE_5 "G28\nM503" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | //=========================================================================== | ||||||
|  | //====================== I2C Position Encoder Settings ====================== | ||||||
|  | //=========================================================================== | ||||||
|  | /** | ||||||
|  |  *  I2C position encoders for closed loop control. | ||||||
|  |  *  Developed by Chris Barr at Aus3D. | ||||||
|  |  * | ||||||
|  |  *  Wiki: http://wiki.aus3d.com.au/Magnetic_Encoder | ||||||
|  |  *  Github: https://github.com/Aus3D/MagneticEncoder | ||||||
|  |  * | ||||||
|  |  *  Supplier: http://aus3d.com.au/magnetic-encoder-module | ||||||
|  |  *  Alternative Supplier: http://reliabuild3d.com/ | ||||||
|  |  * | ||||||
|  |  *  Reilabuild encoders have been modified to improve reliability. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | //#define I2C_POSITION_ENCODERS | ||||||
|  | #if ENABLED(I2C_POSITION_ENCODERS) | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENCODER_CNT         1                       // The number of encoders installed; max of 5 | ||||||
|  |                                                             // encoders supported currently. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_1_ADDR          I2CPE_PRESET_ADDR_X     // I2C address of the encoder. 30-200. | ||||||
|  |   #define I2CPE_ENC_1_AXIS          X_AXIS                  // Axis the encoder module is installed on.  <X|Y|Z|E>_AXIS. | ||||||
|  |   #define I2CPE_ENC_1_TYPE          I2CPE_ENC_TYPE_LINEAR   // Type of encoder:  I2CPE_ENC_TYPE_LINEAR -or- | ||||||
|  |                                                             // I2CPE_ENC_TYPE_ROTARY. | ||||||
|  |   #define I2CPE_ENC_1_TICKS_UNIT    2048                    // 1024 for magnetic strips with 2mm poles; 2048 for | ||||||
|  |                                                             // 1mm poles. For linear encoders this is ticks / mm, | ||||||
|  |                                                             // for rotary encoders this is ticks / revolution. | ||||||
|  |   //#define I2CPE_ENC_1_TICKS_REV     (16 * 200)            // Only needed for rotary encoders; number of stepper | ||||||
|  |                                                             // steps per full revolution (motor steps/rev * microstepping) | ||||||
|  |   //#define I2CPE_ENC_1_INVERT                              // Invert the direction of axis travel. | ||||||
|  |   #define I2CPE_ENC_1_EC_METHOD     I2CPE_ECM_NONE          // Type of error error correction. | ||||||
|  |   #define I2CPE_ENC_1_EC_THRESH     0.10                    // Threshold size for error (in mm) above which the | ||||||
|  |                                                             // printer will attempt to correct the error; errors | ||||||
|  |                                                             // smaller than this are ignored to minimize effects of | ||||||
|  |                                                             // measurement noise / latency (filter). | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_2_ADDR          I2CPE_PRESET_ADDR_Y     // Same as above, but for encoder 2. | ||||||
|  |   #define I2CPE_ENC_2_AXIS          Y_AXIS | ||||||
|  |   #define I2CPE_ENC_2_TYPE          I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_ENC_2_TICKS_UNIT    2048 | ||||||
|  |   //#define I2CPE_ENC_2_TICKS_REV   (16 * 200) | ||||||
|  |   //#define I2CPE_ENC_2_INVERT | ||||||
|  |   #define I2CPE_ENC_2_EC_METHOD     I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_ENC_2_EC_THRESH     0.10 | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_3_ADDR          I2CPE_PRESET_ADDR_Z     // Encoder 3.  Add additional configuration options | ||||||
|  |   #define I2CPE_ENC_3_AXIS          Z_AXIS                  // as above, or use defaults below. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_4_ADDR          I2CPE_PRESET_ADDR_E     // Encoder 4. | ||||||
|  |   #define I2CPE_ENC_4_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_5_ADDR          34                      // Encoder 5. | ||||||
|  |   #define I2CPE_ENC_5_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   // Default settings for encoders which are enabled, but without settings configured above. | ||||||
|  |   #define I2CPE_DEF_TYPE            I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_DEF_ENC_TICKS_UNIT  2048 | ||||||
|  |   #define I2CPE_DEF_TICKS_REV       (16 * 200) | ||||||
|  |   #define I2CPE_DEF_EC_METHOD       I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_DEF_EC_THRESH       0.1 | ||||||
|  |  | ||||||
|  |   //#define I2CPE_ERR_THRESH_ABORT  100.0                   // Threshold size for error (in mm) error on any given | ||||||
|  |                                                             // axis after which the printer will abort. Comment out to | ||||||
|  |                                                             // disable abort behaviour. | ||||||
|  |  | ||||||
|  |   #define I2CPE_TIME_TRUSTED        10000                   // After an encoder fault, there must be no further fault | ||||||
|  |                                                             // for this amount of time (in ms) before the encoder | ||||||
|  |                                                             // is trusted again. | ||||||
|  |  | ||||||
|  |   /** | ||||||
|  |    * Position is checked every time a new command is executed from the buffer but during long moves, | ||||||
|  |    * this setting determines the minimum update time between checks. A value of 100 works well with | ||||||
|  |    * error rolling average when attempting to correct only for skips and not for vibration. | ||||||
|  |    */ | ||||||
|  |   #define I2CPE_MIN_UPD_TIME_MS     100                     // Minimum time in miliseconds between encoder checks. | ||||||
|  |  | ||||||
|  |   // Use a rolling average to identify persistant errors that indicate skips, as opposed to vibration and noise. | ||||||
|  |   #define I2CPE_ERR_ROLLING_AVERAGE | ||||||
|  |  | ||||||
|  | #endif // I2C_POSITION_ENCODERS | ||||||
|  |  | ||||||
| #endif // CONFIGURATION_ADV_H | #endif // CONFIGURATION_ADV_H | ||||||
|   | |||||||
| @@ -1255,4 +1255,87 @@ | |||||||
|   //#define USER_GCODE_5 "G28\nM503" |   //#define USER_GCODE_5 "G28\nM503" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | //=========================================================================== | ||||||
|  | //====================== I2C Position Encoder Settings ====================== | ||||||
|  | //=========================================================================== | ||||||
|  | /** | ||||||
|  |  *  I2C position encoders for closed loop control. | ||||||
|  |  *  Developed by Chris Barr at Aus3D. | ||||||
|  |  * | ||||||
|  |  *  Wiki: http://wiki.aus3d.com.au/Magnetic_Encoder | ||||||
|  |  *  Github: https://github.com/Aus3D/MagneticEncoder | ||||||
|  |  * | ||||||
|  |  *  Supplier: http://aus3d.com.au/magnetic-encoder-module | ||||||
|  |  *  Alternative Supplier: http://reliabuild3d.com/ | ||||||
|  |  * | ||||||
|  |  *  Reilabuild encoders have been modified to improve reliability. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | //#define I2C_POSITION_ENCODERS | ||||||
|  | #if ENABLED(I2C_POSITION_ENCODERS) | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENCODER_CNT         1                       // The number of encoders installed; max of 5 | ||||||
|  |                                                             // encoders supported currently. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_1_ADDR          I2CPE_PRESET_ADDR_X     // I2C address of the encoder. 30-200. | ||||||
|  |   #define I2CPE_ENC_1_AXIS          X_AXIS                  // Axis the encoder module is installed on.  <X|Y|Z|E>_AXIS. | ||||||
|  |   #define I2CPE_ENC_1_TYPE          I2CPE_ENC_TYPE_LINEAR   // Type of encoder:  I2CPE_ENC_TYPE_LINEAR -or- | ||||||
|  |                                                             // I2CPE_ENC_TYPE_ROTARY. | ||||||
|  |   #define I2CPE_ENC_1_TICKS_UNIT    2048                    // 1024 for magnetic strips with 2mm poles; 2048 for | ||||||
|  |                                                             // 1mm poles. For linear encoders this is ticks / mm, | ||||||
|  |                                                             // for rotary encoders this is ticks / revolution. | ||||||
|  |   //#define I2CPE_ENC_1_TICKS_REV     (16 * 200)            // Only needed for rotary encoders; number of stepper | ||||||
|  |                                                             // steps per full revolution (motor steps/rev * microstepping) | ||||||
|  |   //#define I2CPE_ENC_1_INVERT                              // Invert the direction of axis travel. | ||||||
|  |   #define I2CPE_ENC_1_EC_METHOD     I2CPE_ECM_NONE          // Type of error error correction. | ||||||
|  |   #define I2CPE_ENC_1_EC_THRESH     0.10                    // Threshold size for error (in mm) above which the | ||||||
|  |                                                             // printer will attempt to correct the error; errors | ||||||
|  |                                                             // smaller than this are ignored to minimize effects of | ||||||
|  |                                                             // measurement noise / latency (filter). | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_2_ADDR          I2CPE_PRESET_ADDR_Y     // Same as above, but for encoder 2. | ||||||
|  |   #define I2CPE_ENC_2_AXIS          Y_AXIS | ||||||
|  |   #define I2CPE_ENC_2_TYPE          I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_ENC_2_TICKS_UNIT    2048 | ||||||
|  |   //#define I2CPE_ENC_2_TICKS_REV   (16 * 200) | ||||||
|  |   //#define I2CPE_ENC_2_INVERT | ||||||
|  |   #define I2CPE_ENC_2_EC_METHOD     I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_ENC_2_EC_THRESH     0.10 | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_3_ADDR          I2CPE_PRESET_ADDR_Z     // Encoder 3.  Add additional configuration options | ||||||
|  |   #define I2CPE_ENC_3_AXIS          Z_AXIS                  // as above, or use defaults below. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_4_ADDR          I2CPE_PRESET_ADDR_E     // Encoder 4. | ||||||
|  |   #define I2CPE_ENC_4_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_5_ADDR          34                      // Encoder 5. | ||||||
|  |   #define I2CPE_ENC_5_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   // Default settings for encoders which are enabled, but without settings configured above. | ||||||
|  |   #define I2CPE_DEF_TYPE            I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_DEF_ENC_TICKS_UNIT  2048 | ||||||
|  |   #define I2CPE_DEF_TICKS_REV       (16 * 200) | ||||||
|  |   #define I2CPE_DEF_EC_METHOD       I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_DEF_EC_THRESH       0.1 | ||||||
|  |  | ||||||
|  |   //#define I2CPE_ERR_THRESH_ABORT  100.0                   // Threshold size for error (in mm) error on any given | ||||||
|  |                                                             // axis after which the printer will abort. Comment out to | ||||||
|  |                                                             // disable abort behaviour. | ||||||
|  |  | ||||||
|  |   #define I2CPE_TIME_TRUSTED        10000                   // After an encoder fault, there must be no further fault | ||||||
|  |                                                             // for this amount of time (in ms) before the encoder | ||||||
|  |                                                             // is trusted again. | ||||||
|  |  | ||||||
|  |   /** | ||||||
|  |    * Position is checked every time a new command is executed from the buffer but during long moves, | ||||||
|  |    * this setting determines the minimum update time between checks. A value of 100 works well with | ||||||
|  |    * error rolling average when attempting to correct only for skips and not for vibration. | ||||||
|  |    */ | ||||||
|  |   #define I2CPE_MIN_UPD_TIME_MS     100                     // Minimum time in miliseconds between encoder checks. | ||||||
|  |  | ||||||
|  |   // Use a rolling average to identify persistant errors that indicate skips, as opposed to vibration and noise. | ||||||
|  |   #define I2CPE_ERR_ROLLING_AVERAGE | ||||||
|  |  | ||||||
|  | #endif // I2C_POSITION_ENCODERS | ||||||
|  |  | ||||||
| #endif // CONFIGURATION_ADV_H | #endif // CONFIGURATION_ADV_H | ||||||
|   | |||||||
| @@ -1255,4 +1255,87 @@ | |||||||
|   //#define USER_GCODE_5 "G28\nM503" |   //#define USER_GCODE_5 "G28\nM503" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | //=========================================================================== | ||||||
|  | //====================== I2C Position Encoder Settings ====================== | ||||||
|  | //=========================================================================== | ||||||
|  | /** | ||||||
|  |  *  I2C position encoders for closed loop control. | ||||||
|  |  *  Developed by Chris Barr at Aus3D. | ||||||
|  |  * | ||||||
|  |  *  Wiki: http://wiki.aus3d.com.au/Magnetic_Encoder | ||||||
|  |  *  Github: https://github.com/Aus3D/MagneticEncoder | ||||||
|  |  * | ||||||
|  |  *  Supplier: http://aus3d.com.au/magnetic-encoder-module | ||||||
|  |  *  Alternative Supplier: http://reliabuild3d.com/ | ||||||
|  |  * | ||||||
|  |  *  Reilabuild encoders have been modified to improve reliability. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | //#define I2C_POSITION_ENCODERS | ||||||
|  | #if ENABLED(I2C_POSITION_ENCODERS) | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENCODER_CNT         1                       // The number of encoders installed; max of 5 | ||||||
|  |                                                             // encoders supported currently. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_1_ADDR          I2CPE_PRESET_ADDR_X     // I2C address of the encoder. 30-200. | ||||||
|  |   #define I2CPE_ENC_1_AXIS          X_AXIS                  // Axis the encoder module is installed on.  <X|Y|Z|E>_AXIS. | ||||||
|  |   #define I2CPE_ENC_1_TYPE          I2CPE_ENC_TYPE_LINEAR   // Type of encoder:  I2CPE_ENC_TYPE_LINEAR -or- | ||||||
|  |                                                             // I2CPE_ENC_TYPE_ROTARY. | ||||||
|  |   #define I2CPE_ENC_1_TICKS_UNIT    2048                    // 1024 for magnetic strips with 2mm poles; 2048 for | ||||||
|  |                                                             // 1mm poles. For linear encoders this is ticks / mm, | ||||||
|  |                                                             // for rotary encoders this is ticks / revolution. | ||||||
|  |   //#define I2CPE_ENC_1_TICKS_REV     (16 * 200)            // Only needed for rotary encoders; number of stepper | ||||||
|  |                                                             // steps per full revolution (motor steps/rev * microstepping) | ||||||
|  |   //#define I2CPE_ENC_1_INVERT                              // Invert the direction of axis travel. | ||||||
|  |   #define I2CPE_ENC_1_EC_METHOD     I2CPE_ECM_NONE          // Type of error error correction. | ||||||
|  |   #define I2CPE_ENC_1_EC_THRESH     0.10                    // Threshold size for error (in mm) above which the | ||||||
|  |                                                             // printer will attempt to correct the error; errors | ||||||
|  |                                                             // smaller than this are ignored to minimize effects of | ||||||
|  |                                                             // measurement noise / latency (filter). | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_2_ADDR          I2CPE_PRESET_ADDR_Y     // Same as above, but for encoder 2. | ||||||
|  |   #define I2CPE_ENC_2_AXIS          Y_AXIS | ||||||
|  |   #define I2CPE_ENC_2_TYPE          I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_ENC_2_TICKS_UNIT    2048 | ||||||
|  |   //#define I2CPE_ENC_2_TICKS_REV   (16 * 200) | ||||||
|  |   //#define I2CPE_ENC_2_INVERT | ||||||
|  |   #define I2CPE_ENC_2_EC_METHOD     I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_ENC_2_EC_THRESH     0.10 | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_3_ADDR          I2CPE_PRESET_ADDR_Z     // Encoder 3.  Add additional configuration options | ||||||
|  |   #define I2CPE_ENC_3_AXIS          Z_AXIS                  // as above, or use defaults below. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_4_ADDR          I2CPE_PRESET_ADDR_E     // Encoder 4. | ||||||
|  |   #define I2CPE_ENC_4_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_5_ADDR          34                      // Encoder 5. | ||||||
|  |   #define I2CPE_ENC_5_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   // Default settings for encoders which are enabled, but without settings configured above. | ||||||
|  |   #define I2CPE_DEF_TYPE            I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_DEF_ENC_TICKS_UNIT  2048 | ||||||
|  |   #define I2CPE_DEF_TICKS_REV       (16 * 200) | ||||||
|  |   #define I2CPE_DEF_EC_METHOD       I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_DEF_EC_THRESH       0.1 | ||||||
|  |  | ||||||
|  |   //#define I2CPE_ERR_THRESH_ABORT  100.0                   // Threshold size for error (in mm) error on any given | ||||||
|  |                                                             // axis after which the printer will abort. Comment out to | ||||||
|  |                                                             // disable abort behaviour. | ||||||
|  |  | ||||||
|  |   #define I2CPE_TIME_TRUSTED        10000                   // After an encoder fault, there must be no further fault | ||||||
|  |                                                             // for this amount of time (in ms) before the encoder | ||||||
|  |                                                             // is trusted again. | ||||||
|  |  | ||||||
|  |   /** | ||||||
|  |    * Position is checked every time a new command is executed from the buffer but during long moves, | ||||||
|  |    * this setting determines the minimum update time between checks. A value of 100 works well with | ||||||
|  |    * error rolling average when attempting to correct only for skips and not for vibration. | ||||||
|  |    */ | ||||||
|  |   #define I2CPE_MIN_UPD_TIME_MS     100                     // Minimum time in miliseconds between encoder checks. | ||||||
|  |  | ||||||
|  |   // Use a rolling average to identify persistant errors that indicate skips, as opposed to vibration and noise. | ||||||
|  |   #define I2CPE_ERR_ROLLING_AVERAGE | ||||||
|  |  | ||||||
|  | #endif // I2C_POSITION_ENCODERS | ||||||
|  |  | ||||||
| #endif // CONFIGURATION_ADV_H | #endif // CONFIGURATION_ADV_H | ||||||
|   | |||||||
| @@ -1258,4 +1258,87 @@ | |||||||
|   //#define USER_GCODE_5 "G28\nM503" |   //#define USER_GCODE_5 "G28\nM503" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | //=========================================================================== | ||||||
|  | //====================== I2C Position Encoder Settings ====================== | ||||||
|  | //=========================================================================== | ||||||
|  | /** | ||||||
|  |  *  I2C position encoders for closed loop control. | ||||||
|  |  *  Developed by Chris Barr at Aus3D. | ||||||
|  |  * | ||||||
|  |  *  Wiki: http://wiki.aus3d.com.au/Magnetic_Encoder | ||||||
|  |  *  Github: https://github.com/Aus3D/MagneticEncoder | ||||||
|  |  * | ||||||
|  |  *  Supplier: http://aus3d.com.au/magnetic-encoder-module | ||||||
|  |  *  Alternative Supplier: http://reliabuild3d.com/ | ||||||
|  |  * | ||||||
|  |  *  Reilabuild encoders have been modified to improve reliability. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | //#define I2C_POSITION_ENCODERS | ||||||
|  | #if ENABLED(I2C_POSITION_ENCODERS) | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENCODER_CNT         1                       // The number of encoders installed; max of 5 | ||||||
|  |                                                             // encoders supported currently. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_1_ADDR          I2CPE_PRESET_ADDR_X     // I2C address of the encoder. 30-200. | ||||||
|  |   #define I2CPE_ENC_1_AXIS          X_AXIS                  // Axis the encoder module is installed on.  <X|Y|Z|E>_AXIS. | ||||||
|  |   #define I2CPE_ENC_1_TYPE          I2CPE_ENC_TYPE_LINEAR   // Type of encoder:  I2CPE_ENC_TYPE_LINEAR -or- | ||||||
|  |                                                             // I2CPE_ENC_TYPE_ROTARY. | ||||||
|  |   #define I2CPE_ENC_1_TICKS_UNIT    2048                    // 1024 for magnetic strips with 2mm poles; 2048 for | ||||||
|  |                                                             // 1mm poles. For linear encoders this is ticks / mm, | ||||||
|  |                                                             // for rotary encoders this is ticks / revolution. | ||||||
|  |   //#define I2CPE_ENC_1_TICKS_REV     (16 * 200)            // Only needed for rotary encoders; number of stepper | ||||||
|  |                                                             // steps per full revolution (motor steps/rev * microstepping) | ||||||
|  |   //#define I2CPE_ENC_1_INVERT                              // Invert the direction of axis travel. | ||||||
|  |   #define I2CPE_ENC_1_EC_METHOD     I2CPE_ECM_NONE          // Type of error error correction. | ||||||
|  |   #define I2CPE_ENC_1_EC_THRESH     0.10                    // Threshold size for error (in mm) above which the | ||||||
|  |                                                             // printer will attempt to correct the error; errors | ||||||
|  |                                                             // smaller than this are ignored to minimize effects of | ||||||
|  |                                                             // measurement noise / latency (filter). | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_2_ADDR          I2CPE_PRESET_ADDR_Y     // Same as above, but for encoder 2. | ||||||
|  |   #define I2CPE_ENC_2_AXIS          Y_AXIS | ||||||
|  |   #define I2CPE_ENC_2_TYPE          I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_ENC_2_TICKS_UNIT    2048 | ||||||
|  |   //#define I2CPE_ENC_2_TICKS_REV   (16 * 200) | ||||||
|  |   //#define I2CPE_ENC_2_INVERT | ||||||
|  |   #define I2CPE_ENC_2_EC_METHOD     I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_ENC_2_EC_THRESH     0.10 | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_3_ADDR          I2CPE_PRESET_ADDR_Z     // Encoder 3.  Add additional configuration options | ||||||
|  |   #define I2CPE_ENC_3_AXIS          Z_AXIS                  // as above, or use defaults below. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_4_ADDR          I2CPE_PRESET_ADDR_E     // Encoder 4. | ||||||
|  |   #define I2CPE_ENC_4_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_5_ADDR          34                      // Encoder 5. | ||||||
|  |   #define I2CPE_ENC_5_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   // Default settings for encoders which are enabled, but without settings configured above. | ||||||
|  |   #define I2CPE_DEF_TYPE            I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_DEF_ENC_TICKS_UNIT  2048 | ||||||
|  |   #define I2CPE_DEF_TICKS_REV       (16 * 200) | ||||||
|  |   #define I2CPE_DEF_EC_METHOD       I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_DEF_EC_THRESH       0.1 | ||||||
|  |  | ||||||
|  |   //#define I2CPE_ERR_THRESH_ABORT  100.0                   // Threshold size for error (in mm) error on any given | ||||||
|  |                                                             // axis after which the printer will abort. Comment out to | ||||||
|  |                                                             // disable abort behaviour. | ||||||
|  |  | ||||||
|  |   #define I2CPE_TIME_TRUSTED        10000                   // After an encoder fault, there must be no further fault | ||||||
|  |                                                             // for this amount of time (in ms) before the encoder | ||||||
|  |                                                             // is trusted again. | ||||||
|  |  | ||||||
|  |   /** | ||||||
|  |    * Position is checked every time a new command is executed from the buffer but during long moves, | ||||||
|  |    * this setting determines the minimum update time between checks. A value of 100 works well with | ||||||
|  |    * error rolling average when attempting to correct only for skips and not for vibration. | ||||||
|  |    */ | ||||||
|  |   #define I2CPE_MIN_UPD_TIME_MS     100                     // Minimum time in miliseconds between encoder checks. | ||||||
|  |  | ||||||
|  |   // Use a rolling average to identify persistant errors that indicate skips, as opposed to vibration and noise. | ||||||
|  |   #define I2CPE_ERR_ROLLING_AVERAGE | ||||||
|  |  | ||||||
|  | #endif // I2C_POSITION_ENCODERS | ||||||
|  |  | ||||||
| #endif // CONFIGURATION_ADV_H | #endif // CONFIGURATION_ADV_H | ||||||
|   | |||||||
| @@ -1255,4 +1255,87 @@ | |||||||
|   //#define USER_GCODE_5 "G28\nM503" |   //#define USER_GCODE_5 "G28\nM503" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | //=========================================================================== | ||||||
|  | //====================== I2C Position Encoder Settings ====================== | ||||||
|  | //=========================================================================== | ||||||
|  | /** | ||||||
|  |  *  I2C position encoders for closed loop control. | ||||||
|  |  *  Developed by Chris Barr at Aus3D. | ||||||
|  |  * | ||||||
|  |  *  Wiki: http://wiki.aus3d.com.au/Magnetic_Encoder | ||||||
|  |  *  Github: https://github.com/Aus3D/MagneticEncoder | ||||||
|  |  * | ||||||
|  |  *  Supplier: http://aus3d.com.au/magnetic-encoder-module | ||||||
|  |  *  Alternative Supplier: http://reliabuild3d.com/ | ||||||
|  |  * | ||||||
|  |  *  Reilabuild encoders have been modified to improve reliability. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | //#define I2C_POSITION_ENCODERS | ||||||
|  | #if ENABLED(I2C_POSITION_ENCODERS) | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENCODER_CNT         1                       // The number of encoders installed; max of 5 | ||||||
|  |                                                             // encoders supported currently. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_1_ADDR          I2CPE_PRESET_ADDR_X     // I2C address of the encoder. 30-200. | ||||||
|  |   #define I2CPE_ENC_1_AXIS          X_AXIS                  // Axis the encoder module is installed on.  <X|Y|Z|E>_AXIS. | ||||||
|  |   #define I2CPE_ENC_1_TYPE          I2CPE_ENC_TYPE_LINEAR   // Type of encoder:  I2CPE_ENC_TYPE_LINEAR -or- | ||||||
|  |                                                             // I2CPE_ENC_TYPE_ROTARY. | ||||||
|  |   #define I2CPE_ENC_1_TICKS_UNIT    2048                    // 1024 for magnetic strips with 2mm poles; 2048 for | ||||||
|  |                                                             // 1mm poles. For linear encoders this is ticks / mm, | ||||||
|  |                                                             // for rotary encoders this is ticks / revolution. | ||||||
|  |   //#define I2CPE_ENC_1_TICKS_REV     (16 * 200)            // Only needed for rotary encoders; number of stepper | ||||||
|  |                                                             // steps per full revolution (motor steps/rev * microstepping) | ||||||
|  |   //#define I2CPE_ENC_1_INVERT                              // Invert the direction of axis travel. | ||||||
|  |   #define I2CPE_ENC_1_EC_METHOD     I2CPE_ECM_NONE          // Type of error error correction. | ||||||
|  |   #define I2CPE_ENC_1_EC_THRESH     0.10                    // Threshold size for error (in mm) above which the | ||||||
|  |                                                             // printer will attempt to correct the error; errors | ||||||
|  |                                                             // smaller than this are ignored to minimize effects of | ||||||
|  |                                                             // measurement noise / latency (filter). | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_2_ADDR          I2CPE_PRESET_ADDR_Y     // Same as above, but for encoder 2. | ||||||
|  |   #define I2CPE_ENC_2_AXIS          Y_AXIS | ||||||
|  |   #define I2CPE_ENC_2_TYPE          I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_ENC_2_TICKS_UNIT    2048 | ||||||
|  |   //#define I2CPE_ENC_2_TICKS_REV   (16 * 200) | ||||||
|  |   //#define I2CPE_ENC_2_INVERT | ||||||
|  |   #define I2CPE_ENC_2_EC_METHOD     I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_ENC_2_EC_THRESH     0.10 | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_3_ADDR          I2CPE_PRESET_ADDR_Z     // Encoder 3.  Add additional configuration options | ||||||
|  |   #define I2CPE_ENC_3_AXIS          Z_AXIS                  // as above, or use defaults below. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_4_ADDR          I2CPE_PRESET_ADDR_E     // Encoder 4. | ||||||
|  |   #define I2CPE_ENC_4_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_5_ADDR          34                      // Encoder 5. | ||||||
|  |   #define I2CPE_ENC_5_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   // Default settings for encoders which are enabled, but without settings configured above. | ||||||
|  |   #define I2CPE_DEF_TYPE            I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_DEF_ENC_TICKS_UNIT  2048 | ||||||
|  |   #define I2CPE_DEF_TICKS_REV       (16 * 200) | ||||||
|  |   #define I2CPE_DEF_EC_METHOD       I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_DEF_EC_THRESH       0.1 | ||||||
|  |  | ||||||
|  |   //#define I2CPE_ERR_THRESH_ABORT  100.0                   // Threshold size for error (in mm) error on any given | ||||||
|  |                                                             // axis after which the printer will abort. Comment out to | ||||||
|  |                                                             // disable abort behaviour. | ||||||
|  |  | ||||||
|  |   #define I2CPE_TIME_TRUSTED        10000                   // After an encoder fault, there must be no further fault | ||||||
|  |                                                             // for this amount of time (in ms) before the encoder | ||||||
|  |                                                             // is trusted again. | ||||||
|  |  | ||||||
|  |   /** | ||||||
|  |    * Position is checked every time a new command is executed from the buffer but during long moves, | ||||||
|  |    * this setting determines the minimum update time between checks. A value of 100 works well with | ||||||
|  |    * error rolling average when attempting to correct only for skips and not for vibration. | ||||||
|  |    */ | ||||||
|  |   #define I2CPE_MIN_UPD_TIME_MS     100                     // Minimum time in miliseconds between encoder checks. | ||||||
|  |  | ||||||
|  |   // Use a rolling average to identify persistant errors that indicate skips, as opposed to vibration and noise. | ||||||
|  |   #define I2CPE_ERR_ROLLING_AVERAGE | ||||||
|  |  | ||||||
|  | #endif // I2C_POSITION_ENCODERS | ||||||
|  |  | ||||||
| #endif // CONFIGURATION_ADV_H | #endif // CONFIGURATION_ADV_H | ||||||
|   | |||||||
| @@ -1260,4 +1260,87 @@ | |||||||
|   #define USER_GCODE_5 "G28\nM503" |   #define USER_GCODE_5 "G28\nM503" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | //=========================================================================== | ||||||
|  | //====================== I2C Position Encoder Settings ====================== | ||||||
|  | //=========================================================================== | ||||||
|  | /** | ||||||
|  |  *  I2C position encoders for closed loop control. | ||||||
|  |  *  Developed by Chris Barr at Aus3D. | ||||||
|  |  * | ||||||
|  |  *  Wiki: http://wiki.aus3d.com.au/Magnetic_Encoder | ||||||
|  |  *  Github: https://github.com/Aus3D/MagneticEncoder | ||||||
|  |  * | ||||||
|  |  *  Supplier: http://aus3d.com.au/magnetic-encoder-module | ||||||
|  |  *  Alternative Supplier: http://reliabuild3d.com/ | ||||||
|  |  * | ||||||
|  |  *  Reilabuild encoders have been modified to improve reliability. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | //#define I2C_POSITION_ENCODERS | ||||||
|  | #if ENABLED(I2C_POSITION_ENCODERS) | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENCODER_CNT         1                       // The number of encoders installed; max of 5 | ||||||
|  |                                                             // encoders supported currently. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_1_ADDR          I2CPE_PRESET_ADDR_X     // I2C address of the encoder. 30-200. | ||||||
|  |   #define I2CPE_ENC_1_AXIS          X_AXIS                  // Axis the encoder module is installed on.  <X|Y|Z|E>_AXIS. | ||||||
|  |   #define I2CPE_ENC_1_TYPE          I2CPE_ENC_TYPE_LINEAR   // Type of encoder:  I2CPE_ENC_TYPE_LINEAR -or- | ||||||
|  |                                                             // I2CPE_ENC_TYPE_ROTARY. | ||||||
|  |   #define I2CPE_ENC_1_TICKS_UNIT    2048                    // 1024 for magnetic strips with 2mm poles; 2048 for | ||||||
|  |                                                             // 1mm poles. For linear encoders this is ticks / mm, | ||||||
|  |                                                             // for rotary encoders this is ticks / revolution. | ||||||
|  |   //#define I2CPE_ENC_1_TICKS_REV     (16 * 200)            // Only needed for rotary encoders; number of stepper | ||||||
|  |                                                             // steps per full revolution (motor steps/rev * microstepping) | ||||||
|  |   //#define I2CPE_ENC_1_INVERT                              // Invert the direction of axis travel. | ||||||
|  |   #define I2CPE_ENC_1_EC_METHOD     I2CPE_ECM_NONE          // Type of error error correction. | ||||||
|  |   #define I2CPE_ENC_1_EC_THRESH     0.10                    // Threshold size for error (in mm) above which the | ||||||
|  |                                                             // printer will attempt to correct the error; errors | ||||||
|  |                                                             // smaller than this are ignored to minimize effects of | ||||||
|  |                                                             // measurement noise / latency (filter). | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_2_ADDR          I2CPE_PRESET_ADDR_Y     // Same as above, but for encoder 2. | ||||||
|  |   #define I2CPE_ENC_2_AXIS          Y_AXIS | ||||||
|  |   #define I2CPE_ENC_2_TYPE          I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_ENC_2_TICKS_UNIT    2048 | ||||||
|  |   //#define I2CPE_ENC_2_TICKS_REV   (16 * 200) | ||||||
|  |   //#define I2CPE_ENC_2_INVERT | ||||||
|  |   #define I2CPE_ENC_2_EC_METHOD     I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_ENC_2_EC_THRESH     0.10 | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_3_ADDR          I2CPE_PRESET_ADDR_Z     // Encoder 3.  Add additional configuration options | ||||||
|  |   #define I2CPE_ENC_3_AXIS          Z_AXIS                  // as above, or use defaults below. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_4_ADDR          I2CPE_PRESET_ADDR_E     // Encoder 4. | ||||||
|  |   #define I2CPE_ENC_4_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_5_ADDR          34                      // Encoder 5. | ||||||
|  |   #define I2CPE_ENC_5_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   // Default settings for encoders which are enabled, but without settings configured above. | ||||||
|  |   #define I2CPE_DEF_TYPE            I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_DEF_ENC_TICKS_UNIT  2048 | ||||||
|  |   #define I2CPE_DEF_TICKS_REV       (16 * 200) | ||||||
|  |   #define I2CPE_DEF_EC_METHOD       I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_DEF_EC_THRESH       0.1 | ||||||
|  |  | ||||||
|  |   //#define I2CPE_ERR_THRESH_ABORT  100.0                   // Threshold size for error (in mm) error on any given | ||||||
|  |                                                             // axis after which the printer will abort. Comment out to | ||||||
|  |                                                             // disable abort behaviour. | ||||||
|  |  | ||||||
|  |   #define I2CPE_TIME_TRUSTED        10000                   // After an encoder fault, there must be no further fault | ||||||
|  |                                                             // for this amount of time (in ms) before the encoder | ||||||
|  |                                                             // is trusted again. | ||||||
|  |  | ||||||
|  |   /** | ||||||
|  |    * Position is checked every time a new command is executed from the buffer but during long moves, | ||||||
|  |    * this setting determines the minimum update time between checks. A value of 100 works well with | ||||||
|  |    * error rolling average when attempting to correct only for skips and not for vibration. | ||||||
|  |    */ | ||||||
|  |   #define I2CPE_MIN_UPD_TIME_MS     100                     // Minimum time in miliseconds between encoder checks. | ||||||
|  |  | ||||||
|  |   // Use a rolling average to identify persistant errors that indicate skips, as opposed to vibration and noise. | ||||||
|  |   #define I2CPE_ERR_ROLLING_AVERAGE | ||||||
|  |  | ||||||
|  | #endif // I2C_POSITION_ENCODERS | ||||||
|  |  | ||||||
| #endif // CONFIGURATION_ADV_H | #endif // CONFIGURATION_ADV_H | ||||||
|   | |||||||
| @@ -1259,4 +1259,87 @@ | |||||||
|   #define USER_GCODE_5 "G28\nM503" |   #define USER_GCODE_5 "G28\nM503" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | //=========================================================================== | ||||||
|  | //====================== I2C Position Encoder Settings ====================== | ||||||
|  | //=========================================================================== | ||||||
|  | /** | ||||||
|  |  *  I2C position encoders for closed loop control. | ||||||
|  |  *  Developed by Chris Barr at Aus3D. | ||||||
|  |  * | ||||||
|  |  *  Wiki: http://wiki.aus3d.com.au/Magnetic_Encoder | ||||||
|  |  *  Github: https://github.com/Aus3D/MagneticEncoder | ||||||
|  |  * | ||||||
|  |  *  Supplier: http://aus3d.com.au/magnetic-encoder-module | ||||||
|  |  *  Alternative Supplier: http://reliabuild3d.com/ | ||||||
|  |  * | ||||||
|  |  *  Reilabuild encoders have been modified to improve reliability. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | //#define I2C_POSITION_ENCODERS | ||||||
|  | #if ENABLED(I2C_POSITION_ENCODERS) | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENCODER_CNT         1                       // The number of encoders installed; max of 5 | ||||||
|  |                                                             // encoders supported currently. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_1_ADDR          I2CPE_PRESET_ADDR_X     // I2C address of the encoder. 30-200. | ||||||
|  |   #define I2CPE_ENC_1_AXIS          X_AXIS                  // Axis the encoder module is installed on.  <X|Y|Z|E>_AXIS. | ||||||
|  |   #define I2CPE_ENC_1_TYPE          I2CPE_ENC_TYPE_LINEAR   // Type of encoder:  I2CPE_ENC_TYPE_LINEAR -or- | ||||||
|  |                                                             // I2CPE_ENC_TYPE_ROTARY. | ||||||
|  |   #define I2CPE_ENC_1_TICKS_UNIT    2048                    // 1024 for magnetic strips with 2mm poles; 2048 for | ||||||
|  |                                                             // 1mm poles. For linear encoders this is ticks / mm, | ||||||
|  |                                                             // for rotary encoders this is ticks / revolution. | ||||||
|  |   //#define I2CPE_ENC_1_TICKS_REV     (16 * 200)            // Only needed for rotary encoders; number of stepper | ||||||
|  |                                                             // steps per full revolution (motor steps/rev * microstepping) | ||||||
|  |   //#define I2CPE_ENC_1_INVERT                              // Invert the direction of axis travel. | ||||||
|  |   #define I2CPE_ENC_1_EC_METHOD     I2CPE_ECM_NONE          // Type of error error correction. | ||||||
|  |   #define I2CPE_ENC_1_EC_THRESH     0.10                    // Threshold size for error (in mm) above which the | ||||||
|  |                                                             // printer will attempt to correct the error; errors | ||||||
|  |                                                             // smaller than this are ignored to minimize effects of | ||||||
|  |                                                             // measurement noise / latency (filter). | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_2_ADDR          I2CPE_PRESET_ADDR_Y     // Same as above, but for encoder 2. | ||||||
|  |   #define I2CPE_ENC_2_AXIS          Y_AXIS | ||||||
|  |   #define I2CPE_ENC_2_TYPE          I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_ENC_2_TICKS_UNIT    2048 | ||||||
|  |   //#define I2CPE_ENC_2_TICKS_REV   (16 * 200) | ||||||
|  |   //#define I2CPE_ENC_2_INVERT | ||||||
|  |   #define I2CPE_ENC_2_EC_METHOD     I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_ENC_2_EC_THRESH     0.10 | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_3_ADDR          I2CPE_PRESET_ADDR_Z     // Encoder 3.  Add additional configuration options | ||||||
|  |   #define I2CPE_ENC_3_AXIS          Z_AXIS                  // as above, or use defaults below. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_4_ADDR          I2CPE_PRESET_ADDR_E     // Encoder 4. | ||||||
|  |   #define I2CPE_ENC_4_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_5_ADDR          34                      // Encoder 5. | ||||||
|  |   #define I2CPE_ENC_5_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   // Default settings for encoders which are enabled, but without settings configured above. | ||||||
|  |   #define I2CPE_DEF_TYPE            I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_DEF_ENC_TICKS_UNIT  2048 | ||||||
|  |   #define I2CPE_DEF_TICKS_REV       (16 * 200) | ||||||
|  |   #define I2CPE_DEF_EC_METHOD       I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_DEF_EC_THRESH       0.1 | ||||||
|  |  | ||||||
|  |   //#define I2CPE_ERR_THRESH_ABORT  100.0                   // Threshold size for error (in mm) error on any given | ||||||
|  |                                                             // axis after which the printer will abort. Comment out to | ||||||
|  |                                                             // disable abort behaviour. | ||||||
|  |  | ||||||
|  |   #define I2CPE_TIME_TRUSTED        10000                   // After an encoder fault, there must be no further fault | ||||||
|  |                                                             // for this amount of time (in ms) before the encoder | ||||||
|  |                                                             // is trusted again. | ||||||
|  |  | ||||||
|  |   /** | ||||||
|  |    * Position is checked every time a new command is executed from the buffer but during long moves, | ||||||
|  |    * this setting determines the minimum update time between checks. A value of 100 works well with | ||||||
|  |    * error rolling average when attempting to correct only for skips and not for vibration. | ||||||
|  |    */ | ||||||
|  |   #define I2CPE_MIN_UPD_TIME_MS     100                     // Minimum time in miliseconds between encoder checks. | ||||||
|  |  | ||||||
|  |   // Use a rolling average to identify persistant errors that indicate skips, as opposed to vibration and noise. | ||||||
|  |   #define I2CPE_ERR_ROLLING_AVERAGE | ||||||
|  |  | ||||||
|  | #endif // I2C_POSITION_ENCODERS | ||||||
|  |  | ||||||
| #endif // CONFIGURATION_ADV_H | #endif // CONFIGURATION_ADV_H | ||||||
|   | |||||||
| @@ -1257,4 +1257,87 @@ | |||||||
|   #define USER_GCODE_5 "G28\nM503" |   #define USER_GCODE_5 "G28\nM503" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | //=========================================================================== | ||||||
|  | //====================== I2C Position Encoder Settings ====================== | ||||||
|  | //=========================================================================== | ||||||
|  | /** | ||||||
|  |  *  I2C position encoders for closed loop control. | ||||||
|  |  *  Developed by Chris Barr at Aus3D. | ||||||
|  |  * | ||||||
|  |  *  Wiki: http://wiki.aus3d.com.au/Magnetic_Encoder | ||||||
|  |  *  Github: https://github.com/Aus3D/MagneticEncoder | ||||||
|  |  * | ||||||
|  |  *  Supplier: http://aus3d.com.au/magnetic-encoder-module | ||||||
|  |  *  Alternative Supplier: http://reliabuild3d.com/ | ||||||
|  |  * | ||||||
|  |  *  Reilabuild encoders have been modified to improve reliability. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | //#define I2C_POSITION_ENCODERS | ||||||
|  | #if ENABLED(I2C_POSITION_ENCODERS) | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENCODER_CNT         1                       // The number of encoders installed; max of 5 | ||||||
|  |                                                             // encoders supported currently. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_1_ADDR          I2CPE_PRESET_ADDR_X     // I2C address of the encoder. 30-200. | ||||||
|  |   #define I2CPE_ENC_1_AXIS          X_AXIS                  // Axis the encoder module is installed on.  <X|Y|Z|E>_AXIS. | ||||||
|  |   #define I2CPE_ENC_1_TYPE          I2CPE_ENC_TYPE_LINEAR   // Type of encoder:  I2CPE_ENC_TYPE_LINEAR -or- | ||||||
|  |                                                             // I2CPE_ENC_TYPE_ROTARY. | ||||||
|  |   #define I2CPE_ENC_1_TICKS_UNIT    2048                    // 1024 for magnetic strips with 2mm poles; 2048 for | ||||||
|  |                                                             // 1mm poles. For linear encoders this is ticks / mm, | ||||||
|  |                                                             // for rotary encoders this is ticks / revolution. | ||||||
|  |   //#define I2CPE_ENC_1_TICKS_REV     (16 * 200)            // Only needed for rotary encoders; number of stepper | ||||||
|  |                                                             // steps per full revolution (motor steps/rev * microstepping) | ||||||
|  |   //#define I2CPE_ENC_1_INVERT                              // Invert the direction of axis travel. | ||||||
|  |   #define I2CPE_ENC_1_EC_METHOD     I2CPE_ECM_NONE          // Type of error error correction. | ||||||
|  |   #define I2CPE_ENC_1_EC_THRESH     0.10                    // Threshold size for error (in mm) above which the | ||||||
|  |                                                             // printer will attempt to correct the error; errors | ||||||
|  |                                                             // smaller than this are ignored to minimize effects of | ||||||
|  |                                                             // measurement noise / latency (filter). | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_2_ADDR          I2CPE_PRESET_ADDR_Y     // Same as above, but for encoder 2. | ||||||
|  |   #define I2CPE_ENC_2_AXIS          Y_AXIS | ||||||
|  |   #define I2CPE_ENC_2_TYPE          I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_ENC_2_TICKS_UNIT    2048 | ||||||
|  |   //#define I2CPE_ENC_2_TICKS_REV   (16 * 200) | ||||||
|  |   //#define I2CPE_ENC_2_INVERT | ||||||
|  |   #define I2CPE_ENC_2_EC_METHOD     I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_ENC_2_EC_THRESH     0.10 | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_3_ADDR          I2CPE_PRESET_ADDR_Z     // Encoder 3.  Add additional configuration options | ||||||
|  |   #define I2CPE_ENC_3_AXIS          Z_AXIS                  // as above, or use defaults below. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_4_ADDR          I2CPE_PRESET_ADDR_E     // Encoder 4. | ||||||
|  |   #define I2CPE_ENC_4_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_5_ADDR          34                      // Encoder 5. | ||||||
|  |   #define I2CPE_ENC_5_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   // Default settings for encoders which are enabled, but without settings configured above. | ||||||
|  |   #define I2CPE_DEF_TYPE            I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_DEF_ENC_TICKS_UNIT  2048 | ||||||
|  |   #define I2CPE_DEF_TICKS_REV       (16 * 200) | ||||||
|  |   #define I2CPE_DEF_EC_METHOD       I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_DEF_EC_THRESH       0.1 | ||||||
|  |  | ||||||
|  |   //#define I2CPE_ERR_THRESH_ABORT  100.0                   // Threshold size for error (in mm) error on any given | ||||||
|  |                                                             // axis after which the printer will abort. Comment out to | ||||||
|  |                                                             // disable abort behaviour. | ||||||
|  |  | ||||||
|  |   #define I2CPE_TIME_TRUSTED        10000                   // After an encoder fault, there must be no further fault | ||||||
|  |                                                             // for this amount of time (in ms) before the encoder | ||||||
|  |                                                             // is trusted again. | ||||||
|  |  | ||||||
|  |   /** | ||||||
|  |    * Position is checked every time a new command is executed from the buffer but during long moves, | ||||||
|  |    * this setting determines the minimum update time between checks. A value of 100 works well with | ||||||
|  |    * error rolling average when attempting to correct only for skips and not for vibration. | ||||||
|  |    */ | ||||||
|  |   #define I2CPE_MIN_UPD_TIME_MS     100                     // Minimum time in miliseconds between encoder checks. | ||||||
|  |  | ||||||
|  |   // Use a rolling average to identify persistant errors that indicate skips, as opposed to vibration and noise. | ||||||
|  |   #define I2CPE_ERR_ROLLING_AVERAGE | ||||||
|  |  | ||||||
|  | #endif // I2C_POSITION_ENCODERS | ||||||
|  |  | ||||||
| #endif // CONFIGURATION_ADV_H | #endif // CONFIGURATION_ADV_H | ||||||
|   | |||||||
| @@ -1257,4 +1257,87 @@ | |||||||
|   #define USER_GCODE_5 "G28\nM503" |   #define USER_GCODE_5 "G28\nM503" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | //=========================================================================== | ||||||
|  | //====================== I2C Position Encoder Settings ====================== | ||||||
|  | //=========================================================================== | ||||||
|  | /** | ||||||
|  |  *  I2C position encoders for closed loop control. | ||||||
|  |  *  Developed by Chris Barr at Aus3D. | ||||||
|  |  * | ||||||
|  |  *  Wiki: http://wiki.aus3d.com.au/Magnetic_Encoder | ||||||
|  |  *  Github: https://github.com/Aus3D/MagneticEncoder | ||||||
|  |  * | ||||||
|  |  *  Supplier: http://aus3d.com.au/magnetic-encoder-module | ||||||
|  |  *  Alternative Supplier: http://reliabuild3d.com/ | ||||||
|  |  * | ||||||
|  |  *  Reilabuild encoders have been modified to improve reliability. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | //#define I2C_POSITION_ENCODERS | ||||||
|  | #if ENABLED(I2C_POSITION_ENCODERS) | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENCODER_CNT         1                       // The number of encoders installed; max of 5 | ||||||
|  |                                                             // encoders supported currently. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_1_ADDR          I2CPE_PRESET_ADDR_X     // I2C address of the encoder. 30-200. | ||||||
|  |   #define I2CPE_ENC_1_AXIS          X_AXIS                  // Axis the encoder module is installed on.  <X|Y|Z|E>_AXIS. | ||||||
|  |   #define I2CPE_ENC_1_TYPE          I2CPE_ENC_TYPE_LINEAR   // Type of encoder:  I2CPE_ENC_TYPE_LINEAR -or- | ||||||
|  |                                                             // I2CPE_ENC_TYPE_ROTARY. | ||||||
|  |   #define I2CPE_ENC_1_TICKS_UNIT    2048                    // 1024 for magnetic strips with 2mm poles; 2048 for | ||||||
|  |                                                             // 1mm poles. For linear encoders this is ticks / mm, | ||||||
|  |                                                             // for rotary encoders this is ticks / revolution. | ||||||
|  |   //#define I2CPE_ENC_1_TICKS_REV     (16 * 200)            // Only needed for rotary encoders; number of stepper | ||||||
|  |                                                             // steps per full revolution (motor steps/rev * microstepping) | ||||||
|  |   //#define I2CPE_ENC_1_INVERT                              // Invert the direction of axis travel. | ||||||
|  |   #define I2CPE_ENC_1_EC_METHOD     I2CPE_ECM_NONE          // Type of error error correction. | ||||||
|  |   #define I2CPE_ENC_1_EC_THRESH     0.10                    // Threshold size for error (in mm) above which the | ||||||
|  |                                                             // printer will attempt to correct the error; errors | ||||||
|  |                                                             // smaller than this are ignored to minimize effects of | ||||||
|  |                                                             // measurement noise / latency (filter). | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_2_ADDR          I2CPE_PRESET_ADDR_Y     // Same as above, but for encoder 2. | ||||||
|  |   #define I2CPE_ENC_2_AXIS          Y_AXIS | ||||||
|  |   #define I2CPE_ENC_2_TYPE          I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_ENC_2_TICKS_UNIT    2048 | ||||||
|  |   //#define I2CPE_ENC_2_TICKS_REV   (16 * 200) | ||||||
|  |   //#define I2CPE_ENC_2_INVERT | ||||||
|  |   #define I2CPE_ENC_2_EC_METHOD     I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_ENC_2_EC_THRESH     0.10 | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_3_ADDR          I2CPE_PRESET_ADDR_Z     // Encoder 3.  Add additional configuration options | ||||||
|  |   #define I2CPE_ENC_3_AXIS          Z_AXIS                  // as above, or use defaults below. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_4_ADDR          I2CPE_PRESET_ADDR_E     // Encoder 4. | ||||||
|  |   #define I2CPE_ENC_4_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_5_ADDR          34                      // Encoder 5. | ||||||
|  |   #define I2CPE_ENC_5_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   // Default settings for encoders which are enabled, but without settings configured above. | ||||||
|  |   #define I2CPE_DEF_TYPE            I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_DEF_ENC_TICKS_UNIT  2048 | ||||||
|  |   #define I2CPE_DEF_TICKS_REV       (16 * 200) | ||||||
|  |   #define I2CPE_DEF_EC_METHOD       I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_DEF_EC_THRESH       0.1 | ||||||
|  |  | ||||||
|  |   //#define I2CPE_ERR_THRESH_ABORT  100.0                   // Threshold size for error (in mm) error on any given | ||||||
|  |                                                             // axis after which the printer will abort. Comment out to | ||||||
|  |                                                             // disable abort behaviour. | ||||||
|  |  | ||||||
|  |   #define I2CPE_TIME_TRUSTED        10000                   // After an encoder fault, there must be no further fault | ||||||
|  |                                                             // for this amount of time (in ms) before the encoder | ||||||
|  |                                                             // is trusted again. | ||||||
|  |  | ||||||
|  |   /** | ||||||
|  |    * Position is checked every time a new command is executed from the buffer but during long moves, | ||||||
|  |    * this setting determines the minimum update time between checks. A value of 100 works well with | ||||||
|  |    * error rolling average when attempting to correct only for skips and not for vibration. | ||||||
|  |    */ | ||||||
|  |   #define I2CPE_MIN_UPD_TIME_MS     100                     // Minimum time in miliseconds between encoder checks. | ||||||
|  |  | ||||||
|  |   // Use a rolling average to identify persistant errors that indicate skips, as opposed to vibration and noise. | ||||||
|  |   #define I2CPE_ERR_ROLLING_AVERAGE | ||||||
|  |  | ||||||
|  | #endif // I2C_POSITION_ENCODERS | ||||||
|  |  | ||||||
| #endif // CONFIGURATION_ADV_H | #endif // CONFIGURATION_ADV_H | ||||||
|   | |||||||
| @@ -1262,4 +1262,87 @@ | |||||||
|   #define USER_GCODE_5 "G28\nM503" |   #define USER_GCODE_5 "G28\nM503" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | //=========================================================================== | ||||||
|  | //====================== I2C Position Encoder Settings ====================== | ||||||
|  | //=========================================================================== | ||||||
|  | /** | ||||||
|  |  *  I2C position encoders for closed loop control. | ||||||
|  |  *  Developed by Chris Barr at Aus3D. | ||||||
|  |  * | ||||||
|  |  *  Wiki: http://wiki.aus3d.com.au/Magnetic_Encoder | ||||||
|  |  *  Github: https://github.com/Aus3D/MagneticEncoder | ||||||
|  |  * | ||||||
|  |  *  Supplier: http://aus3d.com.au/magnetic-encoder-module | ||||||
|  |  *  Alternative Supplier: http://reliabuild3d.com/ | ||||||
|  |  * | ||||||
|  |  *  Reilabuild encoders have been modified to improve reliability. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | //#define I2C_POSITION_ENCODERS | ||||||
|  | #if ENABLED(I2C_POSITION_ENCODERS) | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENCODER_CNT         1                       // The number of encoders installed; max of 5 | ||||||
|  |                                                             // encoders supported currently. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_1_ADDR          I2CPE_PRESET_ADDR_X     // I2C address of the encoder. 30-200. | ||||||
|  |   #define I2CPE_ENC_1_AXIS          X_AXIS                  // Axis the encoder module is installed on.  <X|Y|Z|E>_AXIS. | ||||||
|  |   #define I2CPE_ENC_1_TYPE          I2CPE_ENC_TYPE_LINEAR   // Type of encoder:  I2CPE_ENC_TYPE_LINEAR -or- | ||||||
|  |                                                             // I2CPE_ENC_TYPE_ROTARY. | ||||||
|  |   #define I2CPE_ENC_1_TICKS_UNIT    2048                    // 1024 for magnetic strips with 2mm poles; 2048 for | ||||||
|  |                                                             // 1mm poles. For linear encoders this is ticks / mm, | ||||||
|  |                                                             // for rotary encoders this is ticks / revolution. | ||||||
|  |   //#define I2CPE_ENC_1_TICKS_REV     (16 * 200)            // Only needed for rotary encoders; number of stepper | ||||||
|  |                                                             // steps per full revolution (motor steps/rev * microstepping) | ||||||
|  |   //#define I2CPE_ENC_1_INVERT                              // Invert the direction of axis travel. | ||||||
|  |   #define I2CPE_ENC_1_EC_METHOD     I2CPE_ECM_NONE          // Type of error error correction. | ||||||
|  |   #define I2CPE_ENC_1_EC_THRESH     0.10                    // Threshold size for error (in mm) above which the | ||||||
|  |                                                             // printer will attempt to correct the error; errors | ||||||
|  |                                                             // smaller than this are ignored to minimize effects of | ||||||
|  |                                                             // measurement noise / latency (filter). | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_2_ADDR          I2CPE_PRESET_ADDR_Y     // Same as above, but for encoder 2. | ||||||
|  |   #define I2CPE_ENC_2_AXIS          Y_AXIS | ||||||
|  |   #define I2CPE_ENC_2_TYPE          I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_ENC_2_TICKS_UNIT    2048 | ||||||
|  |   //#define I2CPE_ENC_2_TICKS_REV   (16 * 200) | ||||||
|  |   //#define I2CPE_ENC_2_INVERT | ||||||
|  |   #define I2CPE_ENC_2_EC_METHOD     I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_ENC_2_EC_THRESH     0.10 | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_3_ADDR          I2CPE_PRESET_ADDR_Z     // Encoder 3.  Add additional configuration options | ||||||
|  |   #define I2CPE_ENC_3_AXIS          Z_AXIS                  // as above, or use defaults below. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_4_ADDR          I2CPE_PRESET_ADDR_E     // Encoder 4. | ||||||
|  |   #define I2CPE_ENC_4_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_5_ADDR          34                      // Encoder 5. | ||||||
|  |   #define I2CPE_ENC_5_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   // Default settings for encoders which are enabled, but without settings configured above. | ||||||
|  |   #define I2CPE_DEF_TYPE            I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_DEF_ENC_TICKS_UNIT  2048 | ||||||
|  |   #define I2CPE_DEF_TICKS_REV       (16 * 200) | ||||||
|  |   #define I2CPE_DEF_EC_METHOD       I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_DEF_EC_THRESH       0.1 | ||||||
|  |  | ||||||
|  |   //#define I2CPE_ERR_THRESH_ABORT  100.0                   // Threshold size for error (in mm) error on any given | ||||||
|  |                                                             // axis after which the printer will abort. Comment out to | ||||||
|  |                                                             // disable abort behaviour. | ||||||
|  |  | ||||||
|  |   #define I2CPE_TIME_TRUSTED        10000                   // After an encoder fault, there must be no further fault | ||||||
|  |                                                             // for this amount of time (in ms) before the encoder | ||||||
|  |                                                             // is trusted again. | ||||||
|  |  | ||||||
|  |   /** | ||||||
|  |    * Position is checked every time a new command is executed from the buffer but during long moves, | ||||||
|  |    * this setting determines the minimum update time between checks. A value of 100 works well with | ||||||
|  |    * error rolling average when attempting to correct only for skips and not for vibration. | ||||||
|  |    */ | ||||||
|  |   #define I2CPE_MIN_UPD_TIME_MS     100                     // Minimum time in miliseconds between encoder checks. | ||||||
|  |  | ||||||
|  |   // Use a rolling average to identify persistant errors that indicate skips, as opposed to vibration and noise. | ||||||
|  |   #define I2CPE_ERR_ROLLING_AVERAGE | ||||||
|  |  | ||||||
|  | #endif // I2C_POSITION_ENCODERS | ||||||
|  |  | ||||||
| #endif // CONFIGURATION_ADV_H | #endif // CONFIGURATION_ADV_H | ||||||
|   | |||||||
| @@ -1257,4 +1257,87 @@ | |||||||
|   //#define USER_GCODE_5 "G28\nM503" |   //#define USER_GCODE_5 "G28\nM503" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | //=========================================================================== | ||||||
|  | //====================== I2C Position Encoder Settings ====================== | ||||||
|  | //=========================================================================== | ||||||
|  | /** | ||||||
|  |  *  I2C position encoders for closed loop control. | ||||||
|  |  *  Developed by Chris Barr at Aus3D. | ||||||
|  |  * | ||||||
|  |  *  Wiki: http://wiki.aus3d.com.au/Magnetic_Encoder | ||||||
|  |  *  Github: https://github.com/Aus3D/MagneticEncoder | ||||||
|  |  * | ||||||
|  |  *  Supplier: http://aus3d.com.au/magnetic-encoder-module | ||||||
|  |  *  Alternative Supplier: http://reliabuild3d.com/ | ||||||
|  |  * | ||||||
|  |  *  Reilabuild encoders have been modified to improve reliability. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | //#define I2C_POSITION_ENCODERS | ||||||
|  | #if ENABLED(I2C_POSITION_ENCODERS) | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENCODER_CNT         1                       // The number of encoders installed; max of 5 | ||||||
|  |                                                             // encoders supported currently. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_1_ADDR          I2CPE_PRESET_ADDR_X     // I2C address of the encoder. 30-200. | ||||||
|  |   #define I2CPE_ENC_1_AXIS          X_AXIS                  // Axis the encoder module is installed on.  <X|Y|Z|E>_AXIS. | ||||||
|  |   #define I2CPE_ENC_1_TYPE          I2CPE_ENC_TYPE_LINEAR   // Type of encoder:  I2CPE_ENC_TYPE_LINEAR -or- | ||||||
|  |                                                             // I2CPE_ENC_TYPE_ROTARY. | ||||||
|  |   #define I2CPE_ENC_1_TICKS_UNIT    2048                    // 1024 for magnetic strips with 2mm poles; 2048 for | ||||||
|  |                                                             // 1mm poles. For linear encoders this is ticks / mm, | ||||||
|  |                                                             // for rotary encoders this is ticks / revolution. | ||||||
|  |   //#define I2CPE_ENC_1_TICKS_REV     (16 * 200)            // Only needed for rotary encoders; number of stepper | ||||||
|  |                                                             // steps per full revolution (motor steps/rev * microstepping) | ||||||
|  |   //#define I2CPE_ENC_1_INVERT                              // Invert the direction of axis travel. | ||||||
|  |   #define I2CPE_ENC_1_EC_METHOD     I2CPE_ECM_NONE          // Type of error error correction. | ||||||
|  |   #define I2CPE_ENC_1_EC_THRESH     0.10                    // Threshold size for error (in mm) above which the | ||||||
|  |                                                             // printer will attempt to correct the error; errors | ||||||
|  |                                                             // smaller than this are ignored to minimize effects of | ||||||
|  |                                                             // measurement noise / latency (filter). | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_2_ADDR          I2CPE_PRESET_ADDR_Y     // Same as above, but for encoder 2. | ||||||
|  |   #define I2CPE_ENC_2_AXIS          Y_AXIS | ||||||
|  |   #define I2CPE_ENC_2_TYPE          I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_ENC_2_TICKS_UNIT    2048 | ||||||
|  |   //#define I2CPE_ENC_2_TICKS_REV   (16 * 200) | ||||||
|  |   //#define I2CPE_ENC_2_INVERT | ||||||
|  |   #define I2CPE_ENC_2_EC_METHOD     I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_ENC_2_EC_THRESH     0.10 | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_3_ADDR          I2CPE_PRESET_ADDR_Z     // Encoder 3.  Add additional configuration options | ||||||
|  |   #define I2CPE_ENC_3_AXIS          Z_AXIS                  // as above, or use defaults below. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_4_ADDR          I2CPE_PRESET_ADDR_E     // Encoder 4. | ||||||
|  |   #define I2CPE_ENC_4_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_5_ADDR          34                      // Encoder 5. | ||||||
|  |   #define I2CPE_ENC_5_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   // Default settings for encoders which are enabled, but without settings configured above. | ||||||
|  |   #define I2CPE_DEF_TYPE            I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_DEF_ENC_TICKS_UNIT  2048 | ||||||
|  |   #define I2CPE_DEF_TICKS_REV       (16 * 200) | ||||||
|  |   #define I2CPE_DEF_EC_METHOD       I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_DEF_EC_THRESH       0.1 | ||||||
|  |  | ||||||
|  |   //#define I2CPE_ERR_THRESH_ABORT  100.0                   // Threshold size for error (in mm) error on any given | ||||||
|  |                                                             // axis after which the printer will abort. Comment out to | ||||||
|  |                                                             // disable abort behaviour. | ||||||
|  |  | ||||||
|  |   #define I2CPE_TIME_TRUSTED        10000                   // After an encoder fault, there must be no further fault | ||||||
|  |                                                             // for this amount of time (in ms) before the encoder | ||||||
|  |                                                             // is trusted again. | ||||||
|  |  | ||||||
|  |   /** | ||||||
|  |    * Position is checked every time a new command is executed from the buffer but during long moves, | ||||||
|  |    * this setting determines the minimum update time between checks. A value of 100 works well with | ||||||
|  |    * error rolling average when attempting to correct only for skips and not for vibration. | ||||||
|  |    */ | ||||||
|  |   #define I2CPE_MIN_UPD_TIME_MS     100                     // Minimum time in miliseconds between encoder checks. | ||||||
|  |  | ||||||
|  |   // Use a rolling average to identify persistant errors that indicate skips, as opposed to vibration and noise. | ||||||
|  |   #define I2CPE_ERR_ROLLING_AVERAGE | ||||||
|  |  | ||||||
|  | #endif // I2C_POSITION_ENCODERS | ||||||
|  |  | ||||||
| #endif // CONFIGURATION_ADV_H | #endif // CONFIGURATION_ADV_H | ||||||
|   | |||||||
| @@ -1264,4 +1264,87 @@ | |||||||
|   //#define USER_GCODE_5 "G28\nM503" |   //#define USER_GCODE_5 "G28\nM503" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | //=========================================================================== | ||||||
|  | //====================== I2C Position Encoder Settings ====================== | ||||||
|  | //=========================================================================== | ||||||
|  | /** | ||||||
|  |  *  I2C position encoders for closed loop control. | ||||||
|  |  *  Developed by Chris Barr at Aus3D. | ||||||
|  |  * | ||||||
|  |  *  Wiki: http://wiki.aus3d.com.au/Magnetic_Encoder | ||||||
|  |  *  Github: https://github.com/Aus3D/MagneticEncoder | ||||||
|  |  * | ||||||
|  |  *  Supplier: http://aus3d.com.au/magnetic-encoder-module | ||||||
|  |  *  Alternative Supplier: http://reliabuild3d.com/ | ||||||
|  |  * | ||||||
|  |  *  Reilabuild encoders have been modified to improve reliability. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | //#define I2C_POSITION_ENCODERS | ||||||
|  | #if ENABLED(I2C_POSITION_ENCODERS) | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENCODER_CNT         1                       // The number of encoders installed; max of 5 | ||||||
|  |                                                             // encoders supported currently. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_1_ADDR          I2CPE_PRESET_ADDR_X     // I2C address of the encoder. 30-200. | ||||||
|  |   #define I2CPE_ENC_1_AXIS          X_AXIS                  // Axis the encoder module is installed on.  <X|Y|Z|E>_AXIS. | ||||||
|  |   #define I2CPE_ENC_1_TYPE          I2CPE_ENC_TYPE_LINEAR   // Type of encoder:  I2CPE_ENC_TYPE_LINEAR -or- | ||||||
|  |                                                             // I2CPE_ENC_TYPE_ROTARY. | ||||||
|  |   #define I2CPE_ENC_1_TICKS_UNIT    2048                    // 1024 for magnetic strips with 2mm poles; 2048 for | ||||||
|  |                                                             // 1mm poles. For linear encoders this is ticks / mm, | ||||||
|  |                                                             // for rotary encoders this is ticks / revolution. | ||||||
|  |   //#define I2CPE_ENC_1_TICKS_REV     (16 * 200)            // Only needed for rotary encoders; number of stepper | ||||||
|  |                                                             // steps per full revolution (motor steps/rev * microstepping) | ||||||
|  |   //#define I2CPE_ENC_1_INVERT                              // Invert the direction of axis travel. | ||||||
|  |   #define I2CPE_ENC_1_EC_METHOD     I2CPE_ECM_NONE          // Type of error error correction. | ||||||
|  |   #define I2CPE_ENC_1_EC_THRESH     0.10                    // Threshold size for error (in mm) above which the | ||||||
|  |                                                             // printer will attempt to correct the error; errors | ||||||
|  |                                                             // smaller than this are ignored to minimize effects of | ||||||
|  |                                                             // measurement noise / latency (filter). | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_2_ADDR          I2CPE_PRESET_ADDR_Y     // Same as above, but for encoder 2. | ||||||
|  |   #define I2CPE_ENC_2_AXIS          Y_AXIS | ||||||
|  |   #define I2CPE_ENC_2_TYPE          I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_ENC_2_TICKS_UNIT    2048 | ||||||
|  |   //#define I2CPE_ENC_2_TICKS_REV   (16 * 200) | ||||||
|  |   //#define I2CPE_ENC_2_INVERT | ||||||
|  |   #define I2CPE_ENC_2_EC_METHOD     I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_ENC_2_EC_THRESH     0.10 | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_3_ADDR          I2CPE_PRESET_ADDR_Z     // Encoder 3.  Add additional configuration options | ||||||
|  |   #define I2CPE_ENC_3_AXIS          Z_AXIS                  // as above, or use defaults below. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_4_ADDR          I2CPE_PRESET_ADDR_E     // Encoder 4. | ||||||
|  |   #define I2CPE_ENC_4_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_5_ADDR          34                      // Encoder 5. | ||||||
|  |   #define I2CPE_ENC_5_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   // Default settings for encoders which are enabled, but without settings configured above. | ||||||
|  |   #define I2CPE_DEF_TYPE            I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_DEF_ENC_TICKS_UNIT  2048 | ||||||
|  |   #define I2CPE_DEF_TICKS_REV       (16 * 200) | ||||||
|  |   #define I2CPE_DEF_EC_METHOD       I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_DEF_EC_THRESH       0.1 | ||||||
|  |  | ||||||
|  |   //#define I2CPE_ERR_THRESH_ABORT  100.0                   // Threshold size for error (in mm) error on any given | ||||||
|  |                                                             // axis after which the printer will abort. Comment out to | ||||||
|  |                                                             // disable abort behaviour. | ||||||
|  |  | ||||||
|  |   #define I2CPE_TIME_TRUSTED        10000                   // After an encoder fault, there must be no further fault | ||||||
|  |                                                             // for this amount of time (in ms) before the encoder | ||||||
|  |                                                             // is trusted again. | ||||||
|  |  | ||||||
|  |   /** | ||||||
|  |    * Position is checked every time a new command is executed from the buffer but during long moves, | ||||||
|  |    * this setting determines the minimum update time between checks. A value of 100 works well with | ||||||
|  |    * error rolling average when attempting to correct only for skips and not for vibration. | ||||||
|  |    */ | ||||||
|  |   #define I2CPE_MIN_UPD_TIME_MS     100                     // Minimum time in miliseconds between encoder checks. | ||||||
|  |  | ||||||
|  |   // Use a rolling average to identify persistant errors that indicate skips, as opposed to vibration and noise. | ||||||
|  |   #define I2CPE_ERR_ROLLING_AVERAGE | ||||||
|  |  | ||||||
|  | #endif // I2C_POSITION_ENCODERS | ||||||
|  |  | ||||||
| #endif // CONFIGURATION_ADV_H | #endif // CONFIGURATION_ADV_H | ||||||
|   | |||||||
| @@ -1255,4 +1255,87 @@ | |||||||
|   //#define USER_GCODE_5 "G28\nM503" |   //#define USER_GCODE_5 "G28\nM503" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | //=========================================================================== | ||||||
|  | //====================== I2C Position Encoder Settings ====================== | ||||||
|  | //=========================================================================== | ||||||
|  | /** | ||||||
|  |  *  I2C position encoders for closed loop control. | ||||||
|  |  *  Developed by Chris Barr at Aus3D. | ||||||
|  |  * | ||||||
|  |  *  Wiki: http://wiki.aus3d.com.au/Magnetic_Encoder | ||||||
|  |  *  Github: https://github.com/Aus3D/MagneticEncoder | ||||||
|  |  * | ||||||
|  |  *  Supplier: http://aus3d.com.au/magnetic-encoder-module | ||||||
|  |  *  Alternative Supplier: http://reliabuild3d.com/ | ||||||
|  |  * | ||||||
|  |  *  Reilabuild encoders have been modified to improve reliability. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | //#define I2C_POSITION_ENCODERS | ||||||
|  | #if ENABLED(I2C_POSITION_ENCODERS) | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENCODER_CNT         1                       // The number of encoders installed; max of 5 | ||||||
|  |                                                             // encoders supported currently. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_1_ADDR          I2CPE_PRESET_ADDR_X     // I2C address of the encoder. 30-200. | ||||||
|  |   #define I2CPE_ENC_1_AXIS          X_AXIS                  // Axis the encoder module is installed on.  <X|Y|Z|E>_AXIS. | ||||||
|  |   #define I2CPE_ENC_1_TYPE          I2CPE_ENC_TYPE_LINEAR   // Type of encoder:  I2CPE_ENC_TYPE_LINEAR -or- | ||||||
|  |                                                             // I2CPE_ENC_TYPE_ROTARY. | ||||||
|  |   #define I2CPE_ENC_1_TICKS_UNIT    2048                    // 1024 for magnetic strips with 2mm poles; 2048 for | ||||||
|  |                                                             // 1mm poles. For linear encoders this is ticks / mm, | ||||||
|  |                                                             // for rotary encoders this is ticks / revolution. | ||||||
|  |   //#define I2CPE_ENC_1_TICKS_REV     (16 * 200)            // Only needed for rotary encoders; number of stepper | ||||||
|  |                                                             // steps per full revolution (motor steps/rev * microstepping) | ||||||
|  |   //#define I2CPE_ENC_1_INVERT                              // Invert the direction of axis travel. | ||||||
|  |   #define I2CPE_ENC_1_EC_METHOD     I2CPE_ECM_NONE          // Type of error error correction. | ||||||
|  |   #define I2CPE_ENC_1_EC_THRESH     0.10                    // Threshold size for error (in mm) above which the | ||||||
|  |                                                             // printer will attempt to correct the error; errors | ||||||
|  |                                                             // smaller than this are ignored to minimize effects of | ||||||
|  |                                                             // measurement noise / latency (filter). | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_2_ADDR          I2CPE_PRESET_ADDR_Y     // Same as above, but for encoder 2. | ||||||
|  |   #define I2CPE_ENC_2_AXIS          Y_AXIS | ||||||
|  |   #define I2CPE_ENC_2_TYPE          I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_ENC_2_TICKS_UNIT    2048 | ||||||
|  |   //#define I2CPE_ENC_2_TICKS_REV   (16 * 200) | ||||||
|  |   //#define I2CPE_ENC_2_INVERT | ||||||
|  |   #define I2CPE_ENC_2_EC_METHOD     I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_ENC_2_EC_THRESH     0.10 | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_3_ADDR          I2CPE_PRESET_ADDR_Z     // Encoder 3.  Add additional configuration options | ||||||
|  |   #define I2CPE_ENC_3_AXIS          Z_AXIS                  // as above, or use defaults below. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_4_ADDR          I2CPE_PRESET_ADDR_E     // Encoder 4. | ||||||
|  |   #define I2CPE_ENC_4_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_5_ADDR          34                      // Encoder 5. | ||||||
|  |   #define I2CPE_ENC_5_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   // Default settings for encoders which are enabled, but without settings configured above. | ||||||
|  |   #define I2CPE_DEF_TYPE            I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_DEF_ENC_TICKS_UNIT  2048 | ||||||
|  |   #define I2CPE_DEF_TICKS_REV       (16 * 200) | ||||||
|  |   #define I2CPE_DEF_EC_METHOD       I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_DEF_EC_THRESH       0.1 | ||||||
|  |  | ||||||
|  |   //#define I2CPE_ERR_THRESH_ABORT  100.0                   // Threshold size for error (in mm) error on any given | ||||||
|  |                                                             // axis after which the printer will abort. Comment out to | ||||||
|  |                                                             // disable abort behaviour. | ||||||
|  |  | ||||||
|  |   #define I2CPE_TIME_TRUSTED        10000                   // After an encoder fault, there must be no further fault | ||||||
|  |                                                             // for this amount of time (in ms) before the encoder | ||||||
|  |                                                             // is trusted again. | ||||||
|  |  | ||||||
|  |   /** | ||||||
|  |    * Position is checked every time a new command is executed from the buffer but during long moves, | ||||||
|  |    * this setting determines the minimum update time between checks. A value of 100 works well with | ||||||
|  |    * error rolling average when attempting to correct only for skips and not for vibration. | ||||||
|  |    */ | ||||||
|  |   #define I2CPE_MIN_UPD_TIME_MS     100                     // Minimum time in miliseconds between encoder checks. | ||||||
|  |  | ||||||
|  |   // Use a rolling average to identify persistant errors that indicate skips, as opposed to vibration and noise. | ||||||
|  |   #define I2CPE_ERR_ROLLING_AVERAGE | ||||||
|  |  | ||||||
|  | #endif // I2C_POSITION_ENCODERS | ||||||
|  |  | ||||||
| #endif // CONFIGURATION_ADV_H | #endif // CONFIGURATION_ADV_H | ||||||
|   | |||||||
| @@ -1255,4 +1255,87 @@ | |||||||
|   //#define USER_GCODE_5 "G28\nM503" |   //#define USER_GCODE_5 "G28\nM503" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | //=========================================================================== | ||||||
|  | //====================== I2C Position Encoder Settings ====================== | ||||||
|  | //=========================================================================== | ||||||
|  | /** | ||||||
|  |  *  I2C position encoders for closed loop control. | ||||||
|  |  *  Developed by Chris Barr at Aus3D. | ||||||
|  |  * | ||||||
|  |  *  Wiki: http://wiki.aus3d.com.au/Magnetic_Encoder | ||||||
|  |  *  Github: https://github.com/Aus3D/MagneticEncoder | ||||||
|  |  * | ||||||
|  |  *  Supplier: http://aus3d.com.au/magnetic-encoder-module | ||||||
|  |  *  Alternative Supplier: http://reliabuild3d.com/ | ||||||
|  |  * | ||||||
|  |  *  Reilabuild encoders have been modified to improve reliability. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | //#define I2C_POSITION_ENCODERS | ||||||
|  | #if ENABLED(I2C_POSITION_ENCODERS) | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENCODER_CNT         1                       // The number of encoders installed; max of 5 | ||||||
|  |                                                             // encoders supported currently. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_1_ADDR          I2CPE_PRESET_ADDR_X     // I2C address of the encoder. 30-200. | ||||||
|  |   #define I2CPE_ENC_1_AXIS          X_AXIS                  // Axis the encoder module is installed on.  <X|Y|Z|E>_AXIS. | ||||||
|  |   #define I2CPE_ENC_1_TYPE          I2CPE_ENC_TYPE_LINEAR   // Type of encoder:  I2CPE_ENC_TYPE_LINEAR -or- | ||||||
|  |                                                             // I2CPE_ENC_TYPE_ROTARY. | ||||||
|  |   #define I2CPE_ENC_1_TICKS_UNIT    2048                    // 1024 for magnetic strips with 2mm poles; 2048 for | ||||||
|  |                                                             // 1mm poles. For linear encoders this is ticks / mm, | ||||||
|  |                                                             // for rotary encoders this is ticks / revolution. | ||||||
|  |   //#define I2CPE_ENC_1_TICKS_REV     (16 * 200)            // Only needed for rotary encoders; number of stepper | ||||||
|  |                                                             // steps per full revolution (motor steps/rev * microstepping) | ||||||
|  |   //#define I2CPE_ENC_1_INVERT                              // Invert the direction of axis travel. | ||||||
|  |   #define I2CPE_ENC_1_EC_METHOD     I2CPE_ECM_NONE          // Type of error error correction. | ||||||
|  |   #define I2CPE_ENC_1_EC_THRESH     0.10                    // Threshold size for error (in mm) above which the | ||||||
|  |                                                             // printer will attempt to correct the error; errors | ||||||
|  |                                                             // smaller than this are ignored to minimize effects of | ||||||
|  |                                                             // measurement noise / latency (filter). | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_2_ADDR          I2CPE_PRESET_ADDR_Y     // Same as above, but for encoder 2. | ||||||
|  |   #define I2CPE_ENC_2_AXIS          Y_AXIS | ||||||
|  |   #define I2CPE_ENC_2_TYPE          I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_ENC_2_TICKS_UNIT    2048 | ||||||
|  |   //#define I2CPE_ENC_2_TICKS_REV   (16 * 200) | ||||||
|  |   //#define I2CPE_ENC_2_INVERT | ||||||
|  |   #define I2CPE_ENC_2_EC_METHOD     I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_ENC_2_EC_THRESH     0.10 | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_3_ADDR          I2CPE_PRESET_ADDR_Z     // Encoder 3.  Add additional configuration options | ||||||
|  |   #define I2CPE_ENC_3_AXIS          Z_AXIS                  // as above, or use defaults below. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_4_ADDR          I2CPE_PRESET_ADDR_E     // Encoder 4. | ||||||
|  |   #define I2CPE_ENC_4_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_5_ADDR          34                      // Encoder 5. | ||||||
|  |   #define I2CPE_ENC_5_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   // Default settings for encoders which are enabled, but without settings configured above. | ||||||
|  |   #define I2CPE_DEF_TYPE            I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_DEF_ENC_TICKS_UNIT  2048 | ||||||
|  |   #define I2CPE_DEF_TICKS_REV       (16 * 200) | ||||||
|  |   #define I2CPE_DEF_EC_METHOD       I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_DEF_EC_THRESH       0.1 | ||||||
|  |  | ||||||
|  |   //#define I2CPE_ERR_THRESH_ABORT  100.0                   // Threshold size for error (in mm) error on any given | ||||||
|  |                                                             // axis after which the printer will abort. Comment out to | ||||||
|  |                                                             // disable abort behaviour. | ||||||
|  |  | ||||||
|  |   #define I2CPE_TIME_TRUSTED        10000                   // After an encoder fault, there must be no further fault | ||||||
|  |                                                             // for this amount of time (in ms) before the encoder | ||||||
|  |                                                             // is trusted again. | ||||||
|  |  | ||||||
|  |   /** | ||||||
|  |    * Position is checked every time a new command is executed from the buffer but during long moves, | ||||||
|  |    * this setting determines the minimum update time between checks. A value of 100 works well with | ||||||
|  |    * error rolling average when attempting to correct only for skips and not for vibration. | ||||||
|  |    */ | ||||||
|  |   #define I2CPE_MIN_UPD_TIME_MS     100                     // Minimum time in miliseconds between encoder checks. | ||||||
|  |  | ||||||
|  |   // Use a rolling average to identify persistant errors that indicate skips, as opposed to vibration and noise. | ||||||
|  |   #define I2CPE_ERR_ROLLING_AVERAGE | ||||||
|  |  | ||||||
|  | #endif // I2C_POSITION_ENCODERS | ||||||
|  |  | ||||||
| #endif // CONFIGURATION_ADV_H | #endif // CONFIGURATION_ADV_H | ||||||
|   | |||||||
| @@ -1258,4 +1258,87 @@ | |||||||
|   //#define USER_GCODE_5 "G28\nM503" |   //#define USER_GCODE_5 "G28\nM503" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | //=========================================================================== | ||||||
|  | //====================== I2C Position Encoder Settings ====================== | ||||||
|  | //=========================================================================== | ||||||
|  | /** | ||||||
|  |  *  I2C position encoders for closed loop control. | ||||||
|  |  *  Developed by Chris Barr at Aus3D. | ||||||
|  |  * | ||||||
|  |  *  Wiki: http://wiki.aus3d.com.au/Magnetic_Encoder | ||||||
|  |  *  Github: https://github.com/Aus3D/MagneticEncoder | ||||||
|  |  * | ||||||
|  |  *  Supplier: http://aus3d.com.au/magnetic-encoder-module | ||||||
|  |  *  Alternative Supplier: http://reliabuild3d.com/ | ||||||
|  |  * | ||||||
|  |  *  Reilabuild encoders have been modified to improve reliability. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | //#define I2C_POSITION_ENCODERS | ||||||
|  | #if ENABLED(I2C_POSITION_ENCODERS) | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENCODER_CNT         1                       // The number of encoders installed; max of 5 | ||||||
|  |                                                             // encoders supported currently. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_1_ADDR          I2CPE_PRESET_ADDR_X     // I2C address of the encoder. 30-200. | ||||||
|  |   #define I2CPE_ENC_1_AXIS          X_AXIS                  // Axis the encoder module is installed on.  <X|Y|Z|E>_AXIS. | ||||||
|  |   #define I2CPE_ENC_1_TYPE          I2CPE_ENC_TYPE_LINEAR   // Type of encoder:  I2CPE_ENC_TYPE_LINEAR -or- | ||||||
|  |                                                             // I2CPE_ENC_TYPE_ROTARY. | ||||||
|  |   #define I2CPE_ENC_1_TICKS_UNIT    2048                    // 1024 for magnetic strips with 2mm poles; 2048 for | ||||||
|  |                                                             // 1mm poles. For linear encoders this is ticks / mm, | ||||||
|  |                                                             // for rotary encoders this is ticks / revolution. | ||||||
|  |   //#define I2CPE_ENC_1_TICKS_REV     (16 * 200)            // Only needed for rotary encoders; number of stepper | ||||||
|  |                                                             // steps per full revolution (motor steps/rev * microstepping) | ||||||
|  |   //#define I2CPE_ENC_1_INVERT                              // Invert the direction of axis travel. | ||||||
|  |   #define I2CPE_ENC_1_EC_METHOD     I2CPE_ECM_NONE          // Type of error error correction. | ||||||
|  |   #define I2CPE_ENC_1_EC_THRESH     0.10                    // Threshold size for error (in mm) above which the | ||||||
|  |                                                             // printer will attempt to correct the error; errors | ||||||
|  |                                                             // smaller than this are ignored to minimize effects of | ||||||
|  |                                                             // measurement noise / latency (filter). | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_2_ADDR          I2CPE_PRESET_ADDR_Y     // Same as above, but for encoder 2. | ||||||
|  |   #define I2CPE_ENC_2_AXIS          Y_AXIS | ||||||
|  |   #define I2CPE_ENC_2_TYPE          I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_ENC_2_TICKS_UNIT    2048 | ||||||
|  |   //#define I2CPE_ENC_2_TICKS_REV   (16 * 200) | ||||||
|  |   //#define I2CPE_ENC_2_INVERT | ||||||
|  |   #define I2CPE_ENC_2_EC_METHOD     I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_ENC_2_EC_THRESH     0.10 | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_3_ADDR          I2CPE_PRESET_ADDR_Z     // Encoder 3.  Add additional configuration options | ||||||
|  |   #define I2CPE_ENC_3_AXIS          Z_AXIS                  // as above, or use defaults below. | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_4_ADDR          I2CPE_PRESET_ADDR_E     // Encoder 4. | ||||||
|  |   #define I2CPE_ENC_4_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   #define I2CPE_ENC_5_ADDR          34                      // Encoder 5. | ||||||
|  |   #define I2CPE_ENC_5_AXIS          E_AXIS | ||||||
|  |  | ||||||
|  |   // Default settings for encoders which are enabled, but without settings configured above. | ||||||
|  |   #define I2CPE_DEF_TYPE            I2CPE_ENC_TYPE_LINEAR | ||||||
|  |   #define I2CPE_DEF_ENC_TICKS_UNIT  2048 | ||||||
|  |   #define I2CPE_DEF_TICKS_REV       (16 * 200) | ||||||
|  |   #define I2CPE_DEF_EC_METHOD       I2CPE_ECM_NONE | ||||||
|  |   #define I2CPE_DEF_EC_THRESH       0.1 | ||||||
|  |  | ||||||
|  |   //#define I2CPE_ERR_THRESH_ABORT  100.0                   // Threshold size for error (in mm) error on any given | ||||||
|  |                                                             // axis after which the printer will abort. Comment out to | ||||||
|  |                                                             // disable abort behaviour. | ||||||
|  |  | ||||||
|  |   #define I2CPE_TIME_TRUSTED        10000                   // After an encoder fault, there must be no further fault | ||||||
|  |                                                             // for this amount of time (in ms) before the encoder | ||||||
|  |                                                             // is trusted again. | ||||||
|  |  | ||||||
|  |   /** | ||||||
|  |    * Position is checked every time a new command is executed from the buffer but during long moves, | ||||||
|  |    * this setting determines the minimum update time between checks. A value of 100 works well with | ||||||
|  |    * error rolling average when attempting to correct only for skips and not for vibration. | ||||||
|  |    */ | ||||||
|  |   #define I2CPE_MIN_UPD_TIME_MS     100                     // Minimum time in miliseconds between encoder checks. | ||||||
|  |  | ||||||
|  |   // Use a rolling average to identify persistant errors that indicate skips, as opposed to vibration and noise. | ||||||
|  |   #define I2CPE_ERR_ROLLING_AVERAGE | ||||||
|  |  | ||||||
|  | #endif // I2C_POSITION_ENCODERS | ||||||
|  |  | ||||||
| #endif // CONFIGURATION_ADV_H | #endif // CONFIGURATION_ADV_H | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user