Difference between revisions of "Gantry Issues"

From SoftMC-Wiki
Jump to: navigation, search
(Slave-Disable.)
(AXY: new links)
 
(50 intermediate revisions by 6 users not shown)
Line 1: Line 1:
In several MANZ's applications, gantry systems (pair of parallel axes) are implemented as master slave pairs. Where master is a part of a bigger (XYZ) group and each of the group's axis can be a master to a different slave axis. The whole issue can be exteneded to any group of geared axes that are moving together one physical object.
+
{{Languages|Gantry_Issues}}
 
+
In some applications, gantry systems (pair of parallel axes) are implemented as master slave pairs. Where master is a part of a bigger (XYZ) group and each of the group's axis can be a master to a different slave axis. The whole issue can be extended to any group of geared axes that are moving together one physical object.
 
 
=Problems:=
 
  
 +
=Problems=
  
 
Problems occur when due to asymmetrical engagement of the system either by different stopping starting or mechanical non-symmetries.
 
Problems occur when due to asymmetrical engagement of the system either by different stopping starting or mechanical non-symmetries.
 
  
 
1.) Motors are directly working against mechanic and possible mechanical breakage/damage can occur.
 
1.) Motors are directly working against mechanic and possible mechanical breakage/damage can occur.
Line 14: Line 12:
 
3.) Load is distributed not equally, therefore dynamic behavior of one axis differs from the other.
 
3.) Load is distributed not equally, therefore dynamic behavior of one axis differs from the other.
  
 +
=Prevention Features =
  
=Prevention features:=
+
# Slave deviation: difference in position between master's and slave's feedback is monitored if it exceeds certain threshold an error is generated and the system stopped. MC-Basic: '''<nowiki><slave>.SlaveDeviation</nowiki>'''.
 
+
# Slave disconnect: when slave is disabled either due to explicit user command or as a result of an error its master is automatically disabled. MC-Basic: '''<nowiki><slave>.SlaveDisconnect </nowiki>'''.
 
+
# The master is "aware" of its slaves. Keeping slave in enabled state when master is disabled can introduce a feedback loop (mechanical linkage between slave and master) resulting is a system that is not always stable i.e. we have a runaway. This can be prevented using SlaveDisable flag, each time a master is disabled due to whatever reason all its slaves will be disabled too.''' '''MC-Basic: '''<nowiki><master>.SlaveDisable </nowiki>'''.
# Slave deviation: difference in position between master's and slave's feedback is monitored if it exceeds certain threshold an error is generated and the system stopped. MC-BASIC: '''<nowiki><slave>.SlaveDeviation </nowiki>'''.
 
# Slave disconnect: when slave is disabled either due to explicit user command or as a result of an error it's master is automatically disabled. MC-BASIC: '''<nowiki><slave>.SlaveDisconnect </nowiki>'''.
 
# The master is "aware" of its slaves. Keeping slave in enabled state when master is disabled can introduce a feedback loop (mechanical linkage between slave and master) resulting in a system that is not always stable i.e. we have a runaway. This can be prevented using SlaveDisable flag, each time a master is disabled due to whatever reason all its slaves will be disabled too.''' '''MC-BASIC: '''<nowiki><master>.SlaveDisable </nowiki>'''.
 
 
# In order to keep the delay between master and slave minimal it is imporrtant to take care about the order of calling of axis RTK. Connecting slave to a master automaticaly re-orders their RTK by changing their priorities.
 
# In order to keep the delay between master and slave minimal it is imporrtant to take care about the order of calling of axis RTK. Connecting slave to a master automaticaly re-orders their RTK by changing their priorities.
  
=Table of Actions=
+
= Table of Actions=
'''''General Axis Deviation''''' (GAD) is defined as one of the follwing:
+
General axis deviation GAD is defined as one of the following events:
 
 
* position follwing error ('''''Pe > PeMax''''')
 
* velocity overspeed (Vfb > Vospd)
 
* slave deviation (SlaveDeviation > SlaveMaxDeviation)<br/>
 
  
 +
* Position following error ('''[[MC-Basic:element.POSITIONERROR|Pe]] > [[MC-Basic:element.POSITIONERRORMAX|PeMax]]''')
 +
* Velocity overspeed (Vfb > Vospd)
 +
* Excessive acceleration (over [[MC-Basic:SYSTEM.MOTIONMARGIN|Sys.MotionMargin]]*[[Category talk:MC-Basic:axis.ACCELERATIONMAX|Amax]])
 +
* Excessive torque (over [[MC-Basic:axis.TorqueMax|Tmax]])
 +
* Slave deviation (SlaveDeviation > SlaveMaxDeviation)<br/>
  
  
 
{| border = 1  
 
{| border = 1  
||Action:
+
|'''Action'''
|| <center><nowiki><slave>.SlaveDisconnect </nowiki> 1 (default)<br> (''or master is PEXT'')</center>
+
|| <nowiki><slave>.SlaveDisconnect </nowiki> 1 (default)<br/> (''or master is PEXT'')
|| <center><nowiki><slave>.SlaveDisconnect</nowiki> 0</center>
+
|| <nowiki><slave>.SlaveDisconnect</nowiki> 0
|| <center><nowiki><master>.SlaveDisable</nowiki> 0 (default)</center>
+
|| <nowiki><master>.SlaveDisable</nowiki> 0 (default)
|| <center><nowiki><master>.SlaveDisable</nowiki> 1</center>
+
|| <nowiki><master>.SlaveDisable</nowiki> 1
 
|-
 
|-
  
||Slave '''''GAD'''''
+
||Slave '''GAD'''
||<center>'''''Disconnecting''''': sax.slave=0<br>'''''Stopping''''' master axis<br>'''''Stopping''''' slave axis</center>
+
||'''Disconnecting''': sax.slave=0<br/>'''Stopping''''master axis<br/>'''Stopping''' slave axis
||<center>'''''Stopping''''' the ''first'' master if it is moving,<br>else '''''disabling''''' the master</center>
+
||'''Stopping''' the ''first'' master if it is moving,<br/>else '''disabling''' the master
| colspan="2" | <center>Nothing affected</center>
+
| colspan="2" | Nothing affected
 
|-
 
|-
  
||Slave '''''GAD'''''<br>
+
||Slave '''GAD'''<br/>
 
(when slave is stopped)
 
(when slave is stopped)
| colspan="4" | <center> can not occur as slaved axis is considered always in a moving state (ismoving ≠ 0)</center>
+
| colspan="4" | Cannot occur as slaved axis is considered always in a moving state (ismoving ≠ 0)
 
|-
 
|-
  
||Slave '''''GAD'''''<br>
+
||Slave '''GAD'''<br/>
 
(when master is stopped)
 
(when master is stopped)
| colspan="4" | <center>'''Disabling''' master.<br>'''Disabling''' slave</center>
+
| colspan="4" | '''Disabling''' master.<br/>'''Disabling''' slave
 
|-
 
|-
  
||Master '''''GAD'''''
+
||Master '''GAD'''
| colspan="4" | <center>'''''Stopping''''' master axis</center>
+
| colspan="4" | <'''Stopping''' master axis
  
 
|-
 
|-
||Master '''''GAD'''''<br>
+
||Master '''GAD'''<br/>
(wnen master is stopped)
+
(when master is stopped)
| colspan="3" | <center>'''Disabling''' master axis</center>
+
| colspan="3" | '''Disabling''' master axis
|| <center>'''Disabling''' slave axis</center>
+
|| '''Disabling''' slave axis
  
 
|-
 
|-
 
||Error on slave axis
 
||Error on slave axis
|| <center>'''''Disconnecting''''': <nowiki>sax.slave=0</nowiki><br> '''''Stopping''''' slave axis</center>
+
|| '''Disconnecting''': <nowiki>sax.slave=0</nowiki><br/> '''Stopping''' slave axis
|| <center>'''''Stopping''''' slave axis</center>
+
|| '''Stopping''' slave axis
|colspan=2| <center>Nothing affected</center>
+
|colspan=2| Nothing affected
  
 
|-
 
|-
 
||Error on master axis
 
||Error on master axis
| colspan=4  | <center>'''''Stopping''''' master axis</center>
+
| colspan=4  |'''Stopping''' master axis
  
 
|-
 
|-
||Disabling master: <br>(max.en: 1→0)
+
||Disabling master: <br/>(max.en: 1→0)
| colspan=3  | <center>Nothing affected</center>
+
| colspan=3  |Nothing affected
|| <center>'''''Disabling '''''all slave axes that are directly or indirectly connected.</center>
+
|| '''Disabling''' all slave axes that are directly or indirectly connected.
 
|-
 
|-
  
|| Disabling slave: <br>(sax.en: 1→0)
+
|| Disabling slave: <br/>(sax.en: 1→0)
|| <center>'''''Msync''''' is reset<br>No disconnection.</center>
+
|| '''Msyn''' is reset<br/>No disconnection.
|| <center>'''''Msync''''' is reset<br>'''Disable''' all master axes connected directly or indirectly.</center>
+
|| '''Msyn''' is reset<br/>'''Disable''' all master axes connected directly or indirectly.
| colspan="2" | <center>Nothing affected</center>
+
| colspan="2" |Nothing affected
  
 
|}
 
|}
  
 +
 +
<!--  @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 
= Re-ordering the master-slave sequence.  =
 
= Re-ordering the master-slave sequence.  =
In AMCS the sequence of calling different RTK's is assured by giving them different priorities (starting from 20), by default the first axis (the one with lowest ID) has the starting priority (20) , the next has 21 and so on. IF the group's RTK is activated, it gets the priority number of it's first axis. In this way we assure that no RTK interrupts execution of the other one.
+
In softMC the sequence of calling different RTKs is assured by giving them different priorities (starting from 20). By default the first axis (the one with lowest ID) has the starting priority (20), the next has 21, and so on. IF the group's RTK is activated, it gets the priority number of its first axis. In this way we assure that no RTK interrupts execution of the other one.
  
  
 
Once the new master slave pair is given, the system should check the priorities of their RTK tasks, if prio(RTK_Slave) > prio(RTK_Master) then everything is OK, if not they should be exchanged but before that we must check if the specified master is a slave to another axis, if yes then this pair should be checked also.  
 
Once the new master slave pair is given, the system should check the priorities of their RTK tasks, if prio(RTK_Slave) > prio(RTK_Master) then everything is OK, if not they should be exchanged but before that we must check if the specified master is a slave to another axis, if yes then this pair should be checked also.  
  
= Slave-Disable. =
+
= Slave-Disable =
  
 
* Name: <nowiki><axis>.SlaveDisable</nowiki>
 
* Name: <nowiki><axis>.SlaveDisable</nowiki>
Line 103: Line 102:
 
* Context: Task or Terminal
 
* Context: Task or Terminal
  
See Also: [[Axystems:MC-Basic:axis.SLAVEDISABLE |SlaveDisable]]
+
See Also: [[MC-Basic:axis.SLAVEDISABLE |SlaveDisable]]
  
Once the '''''<nowiki><master>.SlaveDisable</nowiki>''''' is on, each time the axis is disabled (due to an error, or by direct assignment i.e., ”en=0”) all of it's slave axes will be disabled:
+
Once the '''<nowiki><master>.SlaveDisable</nowiki>''' is on, each time the axis is disabled (due to an error, or by direct assignment i.e., ”en=0”) all of its slave axes will be disabled:
  
 
If the user directly enters:
 
If the user directly enters:
Line 112: Line 111:
  
 
* If the default error handler disables the axis
 
* If the default error handler disables the axis
* It the axis is disabled by an automatic disable due to a position error on a stopped axis  
+
* If the axis is disabled by an automatic disable due to a position error on a stopped axis  
 
* If the torque threshold is exceeded on a stopped axis.
 
* If the torque threshold is exceeded on a stopped axis.
 
* If the VOSPD is exceeded on a stopped axis
 
* If the VOSPD is exceeded on a stopped axis
 
* If the master is disabled because it is a part of the group that is being disabled (or some axes of it are).
 
* If the master is disabled because it is a part of the group that is being disabled (or some axes of it are).
* If the master is disabled because being master of another axis having '''''<nowiki><axis>.SlaveDisconnect</nowiki>''''' flag set to 0(This is when this feature is on).
+
* If the master is disabled because being master of another axis having '''<nowiki><axis>.SlaveDisconnect</nowiki>''' flag set to 0(This is when this feature is on).
 +
 
 +
= Slave - disconnect =
 +
* Name: <nowiki><axis>.SlaveDisconnect </nowiki>
 +
* Type: long
 +
* Values: 0 or 1
 +
* Default: 1
 +
* Limitations: Modal-Only, Read/Write
 +
* Context: Task or Terminal
 +
Flag for protection against unwonted disconnection between master and slave pairs during camming/gearing. If this flag is off, the master/slave pair will be disconnected from each other only by explicit issuing: “<slaveaxis>.slave= 0” or “STOP <slaveaxis>”.
 +
 
 +
See Also: [[MC-Basic:axis.SLAVEDISCONNECT |SlaveDisconnect]]
  
{{Note|Special care must be taken to avoid loops i.e. if the master disables the slave and the slave disables the master there must be a way that explicit enabling of master-slave pair succeeds.}}
+
{{Note|Take care to avoid loops; i.e., if the master disables the slave and the slave disables the master, there must be a way that explicit enabling of master-slave pair succeeds.}}
  
 
= Manz's Bugs related to this issue: =
 
= Manz's Bugs related to this issue: =
Line 129: Line 139:
  
 
{{Bugzilla|1003}} B/F: Master-Slave order affects PCMD synchronization
 
{{Bugzilla|1003}} B/F: Master-Slave order affects PCMD synchronization
 +
-->

Latest revision as of 11:53, 13 September 2017

Language: English  • 中文(简体)‎

In some applications, gantry systems (pair of parallel axes) are implemented as master slave pairs. Where master is a part of a bigger (XYZ) group and each of the group's axis can be a master to a different slave axis. The whole issue can be extended to any group of geared axes that are moving together one physical object.

Problems

Problems occur when due to asymmetrical engagement of the system either by different stopping starting or mechanical non-symmetries.

1.) Motors are directly working against mechanic and possible mechanical breakage/damage can occur.

2.) The systems forms a mechanical feedback loop and instability in form of axis runway can occur.

3.) Load is distributed not equally, therefore dynamic behavior of one axis differs from the other.

Prevention Features

  1. Slave deviation: difference in position between master's and slave's feedback is monitored if it exceeds certain threshold an error is generated and the system stopped. MC-Basic: <slave>.SlaveDeviation.
  2. Slave disconnect: when slave is disabled either due to explicit user command or as a result of an error its master is automatically disabled. MC-Basic: <slave>.SlaveDisconnect .
  3. The master is "aware" of its slaves. Keeping slave in enabled state when master is disabled can introduce a feedback loop (mechanical linkage between slave and master) resulting is a system that is not always stable i.e. we have a runaway. This can be prevented using SlaveDisable flag, each time a master is disabled due to whatever reason all its slaves will be disabled too. MC-Basic: <master>.SlaveDisable .
  4. In order to keep the delay between master and slave minimal it is imporrtant to take care about the order of calling of axis RTK. Connecting slave to a master automaticaly re-orders their RTK by changing their priorities.

Table of Actions

General axis deviation GAD is defined as one of the following events:

  • Position following error (Pe > PeMax)
  • Velocity overspeed (Vfb > Vospd)
  • Excessive acceleration (over Sys.MotionMargin*Amax)
  • Excessive torque (over Tmax)
  • Slave deviation (SlaveDeviation > SlaveMaxDeviation)


Action <slave>.SlaveDisconnect 1 (default)
(or master is PEXT)
<slave>.SlaveDisconnect 0 <master>.SlaveDisable 0 (default) <master>.SlaveDisable 1
Slave GAD Disconnecting: sax.slave=0
Stopping'master axis
Stopping slave axis
Stopping the first master if it is moving,
else disabling the master
Nothing affected
Slave GAD

(when slave is stopped)

Cannot occur as slaved axis is considered always in a moving state (ismoving ≠ 0)
Slave GAD

(when master is stopped)

Disabling master.
Disabling slave
Master GAD <Stopping master axis
Master GAD

(when master is stopped)

Disabling master axis Disabling slave axis
Error on slave axis Disconnecting: sax.slave=0
Stopping slave axis
Stopping slave axis Nothing affected
Error on master axis Stopping master axis
Disabling master:
(max.en: 1→0)
Nothing affected Disabling all slave axes that are directly or indirectly connected.
Disabling slave:
(sax.en: 1→0)
Msyn is reset
No disconnection.
Msyn is reset
Disable all master axes connected directly or indirectly.
Nothing affected