Schaublin 125-CNC retrofit.

More
12 Dec 2022 20:30 - 12 Dec 2022 20:36 #259265 by smc.collins
take a picture of the v-out analog out voltage trace.

let's see what the output looks like. that will tell what needs to be changed in the drive settings.

think of it as follows.


vout is throttle
p is idle controller
ff1 is idle sprak/fuel adjustment


to put it into engine terms.


if your relationship between throttle request and engine rpm is wrong, all your doing is bandaids the problem with ff1 and p

first step is, what's the maximum velocity of the drive 0-10v

is that the same as you maximum velocity in linux cnc ??

this is throttle or gain in the drive. linuxcnc is the driver with the throttle, the drive is the engine.

there needs to be gross agreement between the commanded velocity and the actual velocity. now that you have following errors, you should be able to work on adjusting the relationship between the motion control command and the drive. 


post your drive manual, I'll read it through tonight 
 
Last edit: 12 Dec 2022 20:36 by smc.collins.
The following user(s) said Thank You: RotarySMP

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

More
12 Dec 2022 20:33 #259266 by RotarySMP
I'll get to that tomorrow evening. Thanks a lot for your advice. I need it :)

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

More
12 Dec 2022 20:38 #259267 by tommylight


Starting with X axis:
Drive automatic rigidity = 18 (Scale 0-31)



"turn the P setting to zero , set ff1 to 1 make sure the other ff settings are zero"
Done.
Tiny move and following error.


 

First is probably what other manufacturers call "damping".
Second, that is open loop so LinuxCNC has no control over it except outputing whatever is requested from software on the analog output, and since the encoders are wired, after a 1mm move it cuts off with joint error.
-
-leave rigidity at 18
-have a run through this:
forum.linuxcnc.org/10-advanced-configura...ning-detailed-how-to

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

More
13 Dec 2022 20:54 #259363 by RotarySMP
I didn't get to the basement this even due a long work day and then visitors. Tomorrow looks better as I will work from home.
This is the JMC Servo driver manual. Thanks a lot for your support on this.
www.jmc-motor.com/file/1806080392.pdf
Cheers,
Mark

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

More
13 Dec 2022 21:03 - 13 Dec 2022 23:06 #259365 by smc.collins
happy to help, I've spent 20+ yrs as a engine controls calibration specialist and master technician. it's just a different type of motor.

warning tongue in cheek humor below, becuase my cat died today and I need to laugh. 

quick assumptions

you are using input pin 42 for velocity mode ?
you are using the output phase pins for the encoder feedback to the mesa 7i77 ? or other IO card I assume 21-25

Can you get a scope capture of the drive encoder feedback velocity ? 

the should be say 
z-axis-postion-feedback-velocity-encoder etc
then 
z-axis-position-velocity- commanded

and z-axis-analog-out-volts

do you have a voltage signal generator ? that you can send a input voltage into the velocity command pin of terminal 42 ? 

www.amazon.com/Generator-DROK-Adjustable...lation/dp/B071NLGP6L

or you can use linux cnc to do this. but what you need to know first, is , what voltage into the drive creates x velocity at the encoder.  I think and I am still reading the manual, that you can 

so analog-V-in-to-drive = velocity in ipm "freedom units" or mm/sec "socialist utopia units"  etc. How fast does this load move with X voltage on the input. .

once you know what this scale is, you can then jump into the hal file or pnconf, and then set your min/max voltage and your min/max velocity scalling. once you do that, you'll be half way there, living on a prayer, whoa , living on a prayer. 

anyhow. so step one is to get agreement between the commanded velocity in total and the actual velocity in total..

1v out in linuxcnc is a commanded velocity of 1ipm and the drive gives, 1ipm. 2v = 10ipm etc etc etc. This absolutely must be step 1. I don't care how much makeup gain etc you allow, if the drive can't do it, it'll never happen. 

next up, you'll probably have stopped a good chunk of your following error, immediately. That is where the pid tuning gets involved. I am reading the manual and it appears to have a lot of functionality in it regarding compensation, holding TQ etc, velocity curves. My hot take, it's probably easier to massage the drive " and more reliable " than it is to try and tune the control system software with kludges. That said, IF you want Lcnc to control motor stiffness, acceleration rates etc, then you need to go into the drive controls and dampen down those controls. But trying to have 2 competing control loops each fighting one another for the motor output, is going to lead to a very unstable unreliable drive system. You should pick A control loop to run the show in regards to finite position control etc. 

to go any further, I need to see some analog out voltage traces to see how the motor responds and how Lcnc is responding. generally if you see a big spike on the left with oscillation on the hold voltage, that's to much compensation and to little velocity from the drive, relative to the command velocity. the spike is lack of drive velocity, the oscillation is to much compensation OR insufficient Motor current for the load. 

what are your settings on these parameters ?


6.2.2 velocity mode settings page 27

p01-01  = 1 velocity mode ?
p04-00 ??? source of rotation speed ? 
p04-06 max motor speed forward
p04-07 max motor speed reverse

I just grabbed the software, can you post the drive config in a zip. I just spent 3 weeks going to school on siemens simetic and simoreg drives, this looks relatively similar and if I can see the file and use the same software, it's easier to help. 








 
Last edit: 13 Dec 2022 23:06 by smc.collins.

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

More
13 Dec 2022 22:58 #259374 by tommylight
Section 6.2.1 < wiring for analog velocity control
Section 6.2.2 < check those

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

More
14 Dec 2022 14:17 - 14 Dec 2022 14:26 #259466 by smc.collins
lead screw pitch to, need those. rpm x pitch = velocty. 

for example

10v drive input = 2000rpm / 4.5 tpi = 444ipm

so now you know max velocity if you 

444ipm /60seconds = 7.4 ips, which is what lcnc wants as a format,

typically your acceleration rate is roughly 25% of total velocity as a starting point. depends on motor torque. That gets into, I'd tune the drive to match the expected behavior from Lcnc and then use the pid loop in lcmc to fine tune position and give it some adaptation. but in velocity mode the drive is going to handle the cutting torque and match velocity request, so you'll need to configure the motor current ramping profiles in the drive so that it meets Lcnc expectations.

 
Last edit: 14 Dec 2022 14:26 by smc.collins.

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

More
14 Dec 2022 19:52 #259491 by RotarySMP
I have been through Tommy's excellent tuning tutorial before, which, along with the assistance of Wout got me to the level the machine has been running at in recent videos.

However Tommys method with P and FF only tunes  the LinuxCNC position loop right? The velocity/torque loop of driver to motor needs tuning for the reflected inertia of the load first. That is the 6kHz internal  loop of drive and need setting first.

 

Attachment not found




The JMC servos don't really auto tune, they just have a look up table of settings which are selected through the autotune setting of 1-31 to get you close.
You can input the calculated Inertia ratio load/motor, but only in integer values, and I have calculated about 1.4  on X and 1.7 on Z. So I have set this to 1 for the X axis.
Beyond that you can tune a dozens of  manual settings, where it seems to break down the P.I.D and FF values into low and high speed settings.
Using the auto tune settings I managed to reliable motion on each axis, but you can still hear some ringing and other acoustic signals for poor tuning. That is what I have been unable to tune out with the LinuxCNC Osci, as I suspect they are associated with the drivers 6kHz velocity loop.

Here is a look at the current sort of working settings. I actually had things a bit better than this, but didn't back up before starting today.



With P0 FF1, I get nothing useful on the JMC Osci.
 

Attachment not found



Cheers,
Mark

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

More
14 Dec 2022 20:16 #259493 by RotarySMP
Here is a zoomed in version of the plot at a change in directions...

Attachments:
The following user(s) said Thank You: tommylight

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

More
14 Dec 2022 22:52 #259514 by tommylight
First thing to check the page 04 with speed parameters, those must be correct before anything else.
Type P00-07 and line numbers P00-10 for the encoder, P04-02 should be set at 10, and maximum motor speed P04-06 and P04-07.
The following user(s) said Thank You: RotarySMP, smc.collins

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

Moderators: piasdom
Time to create page: 0.306 seconds
Powered by Kunena Forum