- Configuring LinuxCNC
- Basic Configuration
- Suggestions on Spindle control options? (Analog, Step/Dir, ModBus)
Suggestions on Spindle control options? (Analog, Step/Dir, ModBus)
26 Sep 2020 18:06 #183862
by jhandel
My Spindle is a 3.5kw 10000 RPM servo with an Encoder.. I can command it multiple ways, and for my usecase I am not sure which way to go..
Option 1: Modbus - easy to configure, I have already proofed out control in a python script, but I really want to keep my ability to rigid tap and most folks suggest avoiding userspace components in regards to things that need to be near realtime (at least servo loop responsive)
Option 2: Step and Direction - Tested and Works, accurate, however when the spindle is in that mode it really tries to act like a Servo, so a square form stop (IE the steps pulses just stop) shakes the heck out of things as it tries to stop instantly, and that can't be good for the ATC spindle, the Belt drive, or well the machine. And I haven't figured out how to get Linux CNC to play nice and ease down or up the pulses rather than just jumping to the desired pulse count. <-- will PID solve for that because spindle declaration settings doesn't and poking at PID settings with a stick didn't seem to... Also not sure how that hard stop with no pulsed based deceleration would get handled by a G33.1 command.
Option 3: Analog 0-10v with PID tuning (many, many threads on here around the pain of that approach).
Everything is driven off either a direct USB to ModBus connection or a 7i76e mesa card
My gut is pointing to option 2 with tuning of the PID or as-of-yet not found settings to get rid of the square form behavior and the spindle actually being eased down from a speed (so something in linuxcnc controlling the pulses/second in some form of scaling function rather than flooding them or turning them all off instantly..
Anyways, I am open to advice here given the many, many ways I "could" control this spindle and none of them jumping out as the "one best way"
Thanks
Option 1: Modbus - easy to configure, I have already proofed out control in a python script, but I really want to keep my ability to rigid tap and most folks suggest avoiding userspace components in regards to things that need to be near realtime (at least servo loop responsive)
Option 2: Step and Direction - Tested and Works, accurate, however when the spindle is in that mode it really tries to act like a Servo, so a square form stop (IE the steps pulses just stop) shakes the heck out of things as it tries to stop instantly, and that can't be good for the ATC spindle, the Belt drive, or well the machine. And I haven't figured out how to get Linux CNC to play nice and ease down or up the pulses rather than just jumping to the desired pulse count. <-- will PID solve for that because spindle declaration settings doesn't and poking at PID settings with a stick didn't seem to... Also not sure how that hard stop with no pulsed based deceleration would get handled by a G33.1 command.
Option 3: Analog 0-10v with PID tuning (many, many threads on here around the pain of that approach).
Everything is driven off either a direct USB to ModBus connection or a 7i76e mesa card
My gut is pointing to option 2 with tuning of the PID or as-of-yet not found settings to get rid of the square form behavior and the spindle actually being eased down from a speed (so something in linuxcnc controlling the pulses/second in some form of scaling function rather than flooding them or turning them all off instantly..
Anyways, I am open to advice here given the many, many ways I "could" control this spindle and none of them jumping out as the "one best way"
Thanks
Please Log in or Create an account to join the conversation.
26 Sep 2020 19:55 - 26 Sep 2020 19:56 #183875
by PCW
Replied by PCW on topic Suggestions on Spindle control options? (Analog, Step/Dir, ModBus)
I would probably suggest analog or Step/Dir
Note that you do not need PID to run a analog spindle and
in fact its not normally needed if the VFD is set up correctly.
For analog, you can use either VFD settings or LinuxCNCs
limit2 component to limit the spindle acceleration
If you choose Step/Dir, can use the stepgenerator
settings to limit acceleration if required.
Note that you do not need PID to run a analog spindle and
in fact its not normally needed if the VFD is set up correctly.
For analog, you can use either VFD settings or LinuxCNCs
limit2 component to limit the spindle acceleration
If you choose Step/Dir, can use the stepgenerator
settings to limit acceleration if required.
Last edit: 26 Sep 2020 19:56 by PCW.
Please Log in or Create an account to join the conversation.
05 Oct 2020 00:52 - 05 Oct 2020 00:53 #184894
by jhandel
Replied by jhandel on topic Suggestions on Spindle control options? (Analog, Step/Dir, ModBus)
I finally got to a point where I can spin up and spin down my spindle via M03 M05 commands... I went with Step/Dir as I want the control for rigid tapping..
That being said, I ran into a bit of an issue... Is there a way to make M05 honor the MAX_ACCELORATION? When I do an M05 the spindle tries to break instantly (because the pulses are stoping instantly I imagine) and throws an over volt error (E Brake resister can not stop things instantly).
Or is this something I am going to have to put in my post processor to always go S0, G4P10, M05 or something?
That being said, I ran into a bit of an issue... Is there a way to make M05 honor the MAX_ACCELORATION? When I do an M05 the spindle tries to break instantly (because the pulses are stoping instantly I imagine) and throws an over volt error (E Brake resister can not stop things instantly).
Or is this something I am going to have to put in my post processor to always go S0, G4P10, M05 or something?
Last edit: 05 Oct 2020 00:53 by jhandel.
Please Log in or Create an account to join the conversation.
05 Oct 2020 01:20 #184900
by PCW
Replied by PCW on topic Suggestions on Spindle control options? (Analog, Step/Dir, ModBus)
Did you try setting the stepgen acceleration parameter?
Please Log in or Create an account to join the conversation.
05 Oct 2020 01:43 #184906
by jhandel
Replied by jhandel on topic Suggestions on Spindle control options? (Analog, Step/Dir, ModBus)
Both are set, StepGen gets ignored if Max_Acceleration isn't also set in the INI
Should StepGen acceloration be applied to an M05.. if so I'll dig back in there to figure out if I missed something..
Should StepGen acceloration be applied to an M05.. if so I'll dig back in there to figure out if I missed something..
Please Log in or Create an account to join the conversation.
05 Oct 2020 01:55 #184909
by jhandel
Replied by jhandel on topic Suggestions on Spindle control options? (Analog, Step/Dir, ModBus)
I see how these are wired up on the spindle (wired as in, between the configs)
These are the spindle settings from the INI file:
here is the relivent part of the HAL file
this was configured by pnconfig so its wired to ignore stepgen_acceloration and use Max_Acceloration.. (which is great and does give me a nice soft start... I just need it to give me a nice soft stop with M05 too)
These are the spindle settings from the INI file:
MAX_ACCELERATION = 50.0
# The values below should be 25% larger than MAX_VELOCITY and MAX_ACCELERATION
# If using BACKLASH compensation STEPGEN_MAXACCEL should be 100% larger.
STEPGEN_MAXVEL = 187.50
STEPGEN_MAXACCEL = 100.00
here is the relivent part of the HAL file
setp hm2_7i76e.0.stepgen.05.dirsetup [SPINDLE_0]DIRSETUP
setp hm2_7i76e.0.stepgen.05.dirhold [SPINDLE_0]DIRHOLD
setp hm2_7i76e.0.stepgen.05.steplen [SPINDLE_0]STEPLEN
setp hm2_7i76e.0.stepgen.05.stepspace [SPINDLE_0]STEPSPACE
setp hm2_7i76e.0.stepgen.05.position-scale [SPINDLE_0]STEP_SCALE
setp hm2_7i76e.0.stepgen.05.step_type 0
setp hm2_7i76e.0.stepgen.05.control-type 1
setp hm2_7i76e.0.stepgen.05.maxaccel [SPINDLE_0]MAX_ACCELERATION
setp hm2_7i76e.0.stepgen.05.maxvel [SPINDLE_0]MAX_VELOCITY
this was configured by pnconfig so its wired to ignore stepgen_acceloration and use Max_Acceloration.. (which is great and does give me a nice soft start... I just need it to give me a nice soft stop with M05 too)
Please Log in or Create an account to join the conversation.
05 Oct 2020 21:03 #185007
by jhandel
Replied by jhandel on topic Suggestions on Spindle control options? (Analog, Step/Dir, ModBus)
I just found the power of remap.. So I might try to remap M5 to a custom ngc file that way I can do an S0, wait for that and then turn off the spindle... though I guess that means I have to figure out the right signals to turn off the spindle... maybe I can find those in a UI and I can steal them from there..
Please Log in or Create an account to join the conversation.
05 Oct 2020 23:19 - 05 Oct 2020 23:19 #185018
by PCW
Replied by PCW on topic Suggestions on Spindle control options? (Analog, Step/Dir, ModBus)
This should be possible entirely in hal, you just need to not disable the spindle
until the actual speed is 0 or close to 0. You could use the stepgen velocity feedback
pin or actual encoder velocity if you have a spindle encoder.
until the actual speed is 0 or close to 0. You could use the stepgen velocity feedback
pin or actual encoder velocity if you have a spindle encoder.
Last edit: 05 Oct 2020 23:19 by PCW.
Please Log in or Create an account to join the conversation.
06 Oct 2020 01:37 - 06 Oct 2020 01:37 #185024
by jhandel
Replied by jhandel on topic Suggestions on Spindle control options? (Analog, Step/Dir, ModBus)
yah just learned that M5 isn't one I can override with remap..
So you are thinking the spindle off signal would be some kind of Anding logic with both the signal and the spindle speed being zero...
I haven't really gotten into HAL programming, but I guess I'll start poking around in that direction.. I saw someone on here doing a soft stop based on a time delay so maybe I can start from there..
So you are thinking the spindle off signal would be some kind of Anding logic with both the signal and the spindle speed being zero...
I haven't really gotten into HAL programming, but I guess I'll start poking around in that direction.. I saw someone on here doing a soft stop based on a time delay so maybe I can start from there..
Last edit: 06 Oct 2020 01:37 by jhandel.
Please Log in or Create an account to join the conversation.
06 Oct 2020 02:03 #185025
by PCW
Replied by PCW on topic Suggestions on Spindle control options? (Analog, Step/Dir, ModBus)
I would consider using the near component to check the actual vs commanded
spindle speed and then some simple logic to keep the spindle on
if they are not equal, but make sure the spindle is off when LinuxCNC is not in
the machine-on state.
Note that there are some tricky safety issues if you leave the spindle enabled
for ramp down that need to be analyzed
spindle speed and then some simple logic to keep the spindle on
if they are not equal, but make sure the spindle is off when LinuxCNC is not in
the machine-on state.
Note that there are some tricky safety issues if you leave the spindle enabled
for ramp down that need to be analyzed
Please Log in or Create an account to join the conversation.
- Configuring LinuxCNC
- Basic Configuration
- Suggestions on Spindle control options? (Analog, Step/Dir, ModBus)
Time to create page: 0.114 seconds