Limiting keyboard jog accelerations after 2.7.15->2.9.3 Upgrade

More
03 Jan 2025 12:46 #317922 by Peto
Hello,
I upgraded my router from 2.7.15 to 2.9.3 and found out that jogging acceleration limits from XHC-HB04 config are no longer applied to keyboard jogs. MPG jogs are limited by new pins jog-accel-fraction for joints and for axes, tho. I have read a comment to a commit that introduces this change and it confirms, that keyboard jog accelerations are no longer limited. The thing is, that my machine's max accelerations are too scary to be used in manual jogging moves, and I would like to limit them as it was in 2.7.15. 
I did not found any other way to limit the keyboard jogging accelerations other than bringing back the old deprecated mpg-accel script functionality, that muxed the accel values to ini component during jog.
Any thoughts if this could be achieved in other way?
Thank for all feedback.

My setup: (Axis screen, simple servo with stepper outputs to servo drivers from 5i25/7i76 combo)










 

Please Log in or Create an account to join the conversation.

More
12 Jan 2025 17:00 #318796 by andypugh
accel-fraction is intended to be used for external_offsets. If you are not using those then I don't think you should set a value to that.

The Axis GUI has a jog-speed slider. You should be able to limit jog speed there? (But I think that rapid shift-jog probably still goes at full speed)

It looks like you should be able to set a MAX_LINEAR_VELOCITY in the [DISPLAY] section that will limit max jog speed.

github.com/LinuxCNC/linuxcnc/blob/master...cripts/axis.py#L3443

(This should not affect the overall machine max speed which is [TRAJ]MAX_LINEAR_VELOCITY

Please Log in or Create an account to join the conversation.

More
12 Jan 2025 17:21 #318802 by Peto
Hi Andy,

accel-fraction is intended to be used for external_offsets

Does it? Isn't the eoffset movement acceleration controlled by ini setting for each respective axis with OFFSET_AV_RATIO?
I thought that accel-fraction is used for limiting jog acceleration only. 

axis.L.jog-accel-fraction IN FLOATSets acceleration for wheel jogging to a fraction of the INI max_acceleration for the axis. Values greater than 1 or less than zero are ignored.

I don't want to limit velocity but acceleration. My servo motors are powerful and go to max velocity instantly because acceleration is not limited. Limiting the acceleration during keyboard jogs will limit jerk and rapid grow of jog movement speed. 
I think there should be a user friendly way of limiting acceleration for keyboard jogs.
 

Please Log in or Create an account to join the conversation.

More
12 Jan 2025 18:09 #318808 by andypugh
Sorry, yes, you are right.
Though it is mainly intended for MPGs so that the machine doesn't shake to bits responding to each MPG pulse individually

What was limiting the accel previously? I am not sure what has changed to affect this. Is the behaviour the same for both joint and axis jogging (ie, before and after homing)

Please Log in or Create an account to join the conversation.

More
12 Jan 2025 19:02 #318812 by Peto
Previously both, the MPG jogs and the keyboard jogs were limited by multiplexing lower acceleration values to ini.*.max_acceleration parameters during these jogs. Here is the commit message:

xhc-hb04.tcl use *.jog-accel-fraction pins
instead of mulitplexing reduced accels to ini.*.max_acceleration. Notes: 1) the prior multiplexing to ini.*.max_acceleration pins required a helper script (scripts/xhc-hb04-accels) since the ini pins are not available until task started. 2) the fractional accel settings apply only to wheel jogging (not other forms of jogging using nml commands)


The xhc-hb04-accels script is marked as obsolete and not used since 2.8~pre. The new suggested solution, to use *.jog-accel-fraction pins does not cover the keyboard jogs. Only MPG jogs.

Link to xhc-hb04-accels script from v2.7.15

Please Log in or Create an account to join the conversation.

More
20 Jan 2025 19:30 #319483 by cakeslob
Ive was playing with this recently, I think it is this in [TRAJ], and the default one says its specific to jog,


DEFAULT_LINEAR_ACCELERATION = 2.0 - In machines with nontrivial kinematics, the acceleration used for "teleop" (Cartesian space) jogs, in machine units per second per second.
 

Please Log in or Create an account to join the conversation.

Time to create page: 0.058 seconds
Powered by Kunena Forum