Interim iteration
r2383 | dcl | 2008-03-05 15:25:32 +1100 (Wed, 05 Mar 2008) | 2 lines
This commit is contained in:
@@ -1,21 +1,25 @@
|
||||
NO TE: WOMBAT - CONTROLLER 1
|
||||
NO TE:
|
||||
NO TE: $Revision: 1.7 $
|
||||
NO TE: $Date: 2007-05-03 06:52:51 $
|
||||
NO TE: Author: Dan Bartlett
|
||||
NO TE: Last revision by: $Author: dbx $
|
||||
NO TE:
|
||||
NO TE: A-MONOCHROMATOR UPPER TILT - TILT 1
|
||||
NO TE: B-MONOCHROMATOR LOWER TILT - TILT 2
|
||||
NO TE: C-MONOCHROMATOR UPPER TRANSLATION - LINEAR 1
|
||||
NO TE: D-MONOCHROMATOR LOWER TRANSLATION - LINEAR 2
|
||||
NO TE: E-MONOCHROMATOR ROTATION - ROTATE
|
||||
NO TE: F-FLIGHT TUBE ROTATE
|
||||
NO TE: G-SPARE
|
||||
NO TE: H-SPARE
|
||||
NO ----------------------------------------
|
||||
' WOMBAT - CONTROLLER 1
|
||||
'
|
||||
' $Revision: 1.8 $
|
||||
' $Date: 2008-03-05 04:25:02 $
|
||||
' Author: Dan Bartlett
|
||||
' Airpad control added by Doug Clowes
|
||||
' Last revision by: $Author: dcl $
|
||||
'
|
||||
' A-MONOCHROMATOR UPPER TILT
|
||||
' B-MONOCHROMATOR LOWER TILT
|
||||
' C-MONOCHROMATOR UPPER TRANSLATION
|
||||
' D-MONOCHROMATOR LOWER TRANSLATION
|
||||
' E-MONOCHROMATOR ROTATION
|
||||
' F-FLIGHT TUBE ROTATION
|
||||
' G-SPARE
|
||||
' H-SPARE
|
||||
'
|
||||
'
|
||||
'-----------------------------------------------------------------------
|
||||
#AUTO
|
||||
NO TE: THIS IS THE PROGRAM THAT RUNS AUTOMATICALLY ON CONTROLLER STARTUP
|
||||
' THIS IS THE PROGRAM THAT RUNS AUTOMATICALLY ON CONTROLLER STARTUP
|
||||
'
|
||||
MT-2,-2,-2,-2,-2,-2,-2,-2;'CONFIGURES ALL AXES AS STEPPER
|
||||
MO;' FIRST TIME MOTOR OFF
|
||||
CN 1;' CONFIGURES LIMIT SWITCHES TO ACCEPT NC CONTACTS
|
||||
@@ -33,14 +37,171 @@ SIE=1,25,13,0<-2>2;'HEIDENHAIN ROQ425
|
||||
SIF=1,25,25,0<-2>2;'HEIDENHAIN RCN226
|
||||
SIG=0,25,13,0<-2>2;'NOT USED
|
||||
SIH=0,25,13,0<-2>2;'NOT USED
|
||||
APDONE=0;' FIRST TIME THROUGH AIRPAD CONTROL NOT DONE
|
||||
FTUBE=0;' FLIGHT TUBE OFF
|
||||
' FIRST TIME THROUGH RESET AIRPAD CONTROL
|
||||
REQF=0
|
||||
RSPF=0
|
||||
' FIRST TIME THROUGH RESET HALT CONTROL
|
||||
HLTA=0
|
||||
HLTB=0
|
||||
HLTC=0
|
||||
HLTD=0
|
||||
HLTE=0
|
||||
HLTF=0
|
||||
' HLTG=0
|
||||
' HLTH=0
|
||||
' FIRST TIME THROUGH RESET LIMIT CONTROL
|
||||
LSAHIT=0
|
||||
LSBHIT=0
|
||||
LSCHIT=0
|
||||
LSDHIT=0
|
||||
LSEHIT=0
|
||||
LSFHIT=0
|
||||
' LSGHIT=0
|
||||
' LSHHIT=0
|
||||
JS #THREAD0
|
||||
EN
|
||||
NO ----------------------------------------
|
||||
'
|
||||
'
|
||||
'-----------------------------------------------------------------------
|
||||
#THREAD0
|
||||
NO TE: THERE MUST BE A THREAD RUNNING FOR #LIMSWI, #TCPERR AND #ININT TO WORK
|
||||
NO TE: CHECKS IF SPEEDS ARE ABOVE MAXIMUM ALLOWED
|
||||
' MAIN THREAD
|
||||
' THERE MUST BE A THREAD RUNNING FOR #LIMSWI, #TCPERR AND #ININT TO WORK
|
||||
'
|
||||
JS #CHKDCEL
|
||||
JS #AIRPAD
|
||||
JS #CHKSPD
|
||||
JP #THREAD0
|
||||
EN
|
||||
'
|
||||
'
|
||||
'-----------------------------------------------------------------------
|
||||
#CHKDCEL
|
||||
'ROUTINE TO CHECK DECELERATION AFTER A LIMIT HIT
|
||||
'
|
||||
IF (LSAHIT=1)&(_BGA=0);'WHEN MOTION STOPS AFTER A LIMIT HIT
|
||||
DCA=OLDDCA;' RESET DECEL TO OLD VALUE
|
||||
IF (HLTA=1)
|
||||
MOA
|
||||
HLTA=0
|
||||
ENDIF
|
||||
LSAHIT=0
|
||||
ENDIF
|
||||
IF (LSBHIT=1)&(_BGB=0)
|
||||
DCB=OLDDCB
|
||||
IF (HLTB=1)
|
||||
MOB
|
||||
HLTB=0
|
||||
ENDIF
|
||||
LSBHIT=0
|
||||
ENDIF
|
||||
IF (LSCHIT=1)&(_BGC=0)
|
||||
DCC=OLDDCC
|
||||
IF (HLTC=1)
|
||||
MOC
|
||||
HLTC=0
|
||||
ENDIF
|
||||
LSCHIT=0
|
||||
ENDIF
|
||||
IF (LSDHIT=1)&(_BGD=0)
|
||||
DCD=OLDDCD
|
||||
IF (HLTD=1)
|
||||
MOD
|
||||
HLTD=0
|
||||
ENDIF
|
||||
LSDHIT=0
|
||||
ENDIF
|
||||
IF (LSEHIT=1)&(_BGE=0)
|
||||
DCE=OLDDCE
|
||||
IF (HLTE=1)
|
||||
MOE
|
||||
HLTE=0
|
||||
ENDIF
|
||||
LSEHIT=0
|
||||
ENDIF
|
||||
IF (LSFHIT=1)&(_BGF=0)
|
||||
DCF=OLDDCF
|
||||
IF (HLTF=1)
|
||||
MOF
|
||||
HLTF=0
|
||||
ENDIF;'
|
||||
LSFHIT=0
|
||||
ENDIF
|
||||
' IF (LSGHIT=1)&(_BGG=0)
|
||||
' DCG=OLDDCG
|
||||
' IF (HLTG=1)
|
||||
' MOG
|
||||
' HLTG=0
|
||||
' ENDIF
|
||||
' LSGHIT=0
|
||||
' ENDIF
|
||||
' IF (LSHHIT=1)&(_BGH=0)
|
||||
' DCH=OLDDCH
|
||||
' IF (HLTH=1)
|
||||
' MOH
|
||||
' HLTH=0
|
||||
' ENDIF
|
||||
' LSHHIT=0
|
||||
' ENDIF
|
||||
JS #SETDCEL,((HLTA=1)&(LSAHIT=0))
|
||||
JS #SETDCEL,((HLTB=1)&(LSBHIT=0))
|
||||
JS #SETDCEL,((HLTC=1)&(LSCHIT=0))
|
||||
JS #SETDCEL,((HLTD=1)&(LSDHIT=0))
|
||||
JS #SETDCEL,((HLTE=1)&(LSEHIT=0))
|
||||
JS #SETDCEL,((HLTF=1)&(LSFHIT=0))
|
||||
' JS #SETDCEL,((HLTG=1)&(LSGHIT=0))
|
||||
' JS #SETDCEL,((HLTH=1)&(LSHHIT=0))
|
||||
EN
|
||||
'
|
||||
'
|
||||
'-----------------------------------------------------------------------
|
||||
#AIRPAD
|
||||
' ROUTINE TO CONTROL THE AIRPADS
|
||||
' SET REQF=1 TO MAKE FLIGHT TUBE AVAILABLE FOR MOVE
|
||||
' THE RSPF BIT IS USED SO THAT THE CODE ONLY RUNS WHEN THE
|
||||
' STATE OF FTUBE CHANGES - THE DELAYS ARENT RUNNING EVERY CYCLE
|
||||
' IN THE 2ND IF, THE OFF-SOLENOIDS ARENT HELD ENERGISED IN CASE THE
|
||||
' VALVE MANUAL OVER RIDE IS NEEDED.
|
||||
'
|
||||
' FOLLOW SHF/MOF COMMANDS ENTERED MANUALLY
|
||||
IF (_MOF=0)&(RSPF=0);'FLIGHT TUBE MOTOR IS ON BUT AIR IS OFF
|
||||
REQF=1
|
||||
ENDIF
|
||||
IF (_MOF=1)&(RSPF=1);'FLIGHT TUBE MOTOR IS OFF BUT AIR IS ON
|
||||
SHF;' FOLLOWING STEPS MUST BE RUN BEFORE MOTOR CAN BE TURNED OFF
|
||||
REQF=0
|
||||
ENDIF
|
||||
'
|
||||
IF (REQF=1)&(RSPF=0);'REQUESTING FLIGHT TUBE BE MOVABLE
|
||||
SHF;' TURN MOTOR ON
|
||||
WT500;' WAIT FOR MOTOR TO STABILISE
|
||||
SB 12;' DRIVE WHEEL UP-SOLENOID OFF
|
||||
CB 11;' DRIVE WHEEL DOWN-SOLENOID ON
|
||||
WT1000;' WAIT FOR DRIVE WHEEL TO LOWER
|
||||
SB 10;' SAMPLE STAGE AIR PAD OFF-SOLENOID OFF
|
||||
CB 9;' SAMPLE STAGE AIR PAD ON-SOLENOID ON
|
||||
WT1000;
|
||||
RSPF=1
|
||||
ENDIF
|
||||
IF (REQF=0)&(RSPF=1);'FLIGHT TUBE MOTION FINISHED
|
||||
WT1000;' WAIT FOR FLIGHT TUBE TO SETTLE
|
||||
SB 9;' SAMPLE STAGE AIR PAD ON-SOLENOID OFF
|
||||
CB 10;' SAMPLE STAGE AIR PAD OFF-SOLENOID ON
|
||||
WT500;
|
||||
SB 10;' SAMPLE STAGE AIR PAD OFF-SOLENOID OFF
|
||||
SB 11;' DRIVE WHEEL DOWN-SOLENOID OFF
|
||||
CB 12;' DRIVE WHEEL UP-SOLENOID ON
|
||||
WT500;' WAIT 1/2 SEC
|
||||
SB 12;' DRIVE WHEEL UP-SOLENOID OFF
|
||||
MOF;' TURN MOTOR OFF
|
||||
RSPF=0
|
||||
ENDIF
|
||||
EN
|
||||
'
|
||||
'
|
||||
'-----------------------------------------------------------------------
|
||||
#CHKSPD
|
||||
' ROUTINE TO CHECK IF SPEEDS ARE ABOVE MAXIMUM ALLOWED
|
||||
'
|
||||
IF (_SPA>50000)
|
||||
SPA=50000
|
||||
ENDIF
|
||||
@@ -59,105 +220,125 @@ ENDIF
|
||||
IF (_SPF>75000)
|
||||
SPF=75000
|
||||
ENDIF
|
||||
NO IF (_SPG>50000) AXES NOT USED, COMMENTED OUT
|
||||
NO SPG=50000
|
||||
NO ENDIF
|
||||
NO IF (_SPH>50000)
|
||||
NO SPH=50000
|
||||
NO ENDIF
|
||||
NO TE: CONTROLS THE AIRPAD SOLENOID VALVES
|
||||
NO TE: SET FTUBE=1 TO MAKE FLIGHT TUBE AVAILABLE FOR MOVE
|
||||
NO TE: THE APDONE BIT IS USED SO THAT THE CODE ONLY RUNS WHEN THE
|
||||
NO TE: STATE OF FTUBE CHANGES - THE DELAYS ARENT RUNNING EVERY CYCLE
|
||||
NO TE: IN THE 2ND IF, THE OFF-SOLENOIDS ARENT HELD ENERGISED IN CASE THE
|
||||
NO TE: VALVE MANUAL OVER RIDE IS NEEDED.
|
||||
IF (FTUBE=1)&(APDONE=0);'REQUESTING FLIGHT TUBE BE MOVABLE
|
||||
SHF;' TURN MOTOR ON
|
||||
WT500;' WAIT FOR MOTOR TO STABILISE
|
||||
SB 12;' DRIVE WHEEL UP-SOLENOID OFF
|
||||
CB 11;' DRIVE WHEEL DOWN-SOLENOID ON
|
||||
WT1000;' WAIT FOR DRIVE WHEEL TO LOWER
|
||||
SB 10;' SAMPLE STAGE AIR PAD OFF-SOLENOID OFF
|
||||
CB 9;' SAMPLE STAGE AIR PAD ON-SOLENOID ON
|
||||
APDONE=1
|
||||
ENDIF
|
||||
IF (FTUBE=0)&(APDONE=1);'FLIGHT TUBE MOTION FINISHED
|
||||
WT1000;' WAIT FOR FLIGHT TUBE TO SETTLE
|
||||
SB 9;' SAMPLE STAGE AIR PAD ON-SOLENOID OFF
|
||||
CB 10;' SAMPLE STAGE AIR PAD OFF-SOLENOID ON
|
||||
WT500;
|
||||
SB 10;' SAMPLE STAGE AIR PAD OFF-SOLENOID OFF
|
||||
SB 11;' DRIVE WHEEL DOWN-SOLENOID OFF
|
||||
CB 12;' DRIVE WHEEL UP-SOLENOID ON
|
||||
WT500;' WAIT 1/2 SEC
|
||||
SB 12;' DRIVE WHEEL UP-SOLENOID OFF
|
||||
MOF;' TURN MOTOR OFF
|
||||
APDONE=0
|
||||
ENDIF
|
||||
JP #THREAD0
|
||||
' IF (_SPG>50000)
|
||||
' SPG=50000
|
||||
' ENDIF
|
||||
' IF (_SPH>50000)
|
||||
' SPH=50000
|
||||
' ENDIF
|
||||
EN
|
||||
NO ----------------------------------------
|
||||
'
|
||||
'
|
||||
'-----------------------------------------------------------------------
|
||||
#TCPERR
|
||||
NO TE: EMPTY ROUTINE FOR A TCP ERROR
|
||||
' EMPTY ROUTINE FOR A TCP ERROR
|
||||
'
|
||||
RE
|
||||
NO ----------------------------------------
|
||||
'
|
||||
'
|
||||
'-----------------------------------------------------------------------
|
||||
#CMDERR
|
||||
'ROUTINE TO HANDLE COMMAND ERRORS
|
||||
'
|
||||
ZS0
|
||||
EN1
|
||||
'
|
||||
'
|
||||
'-----------------------------------------------------------------------
|
||||
#ININT
|
||||
NO TE: INTERUPT ROUTINE TO STOP ALL AXES
|
||||
NO TE: WHEN SAFETY & INTERLOCK SYSTEM REQUESTS IT
|
||||
' INTERUPT ROUTINE TO STOP ALL AXES
|
||||
' WHEN SAFETY & INTERLOCK SYSTEM REQUESTS IT
|
||||
'
|
||||
STA,B,C,D,E,F,G,H
|
||||
AM
|
||||
MO
|
||||
HLTA=1
|
||||
HLTB=1
|
||||
HLTC=1
|
||||
HLTD=1
|
||||
HLTE=1
|
||||
HLTF=1
|
||||
' HLTG=1
|
||||
' HLTH=1
|
||||
JS #SETDCEL
|
||||
RI
|
||||
NO ----------------------------------------
|
||||
'
|
||||
'
|
||||
'-----------------------------------------------------------------------
|
||||
#LIMSWI
|
||||
NO TE: LIMIT SWITCH ROUTINE WHICH SHORTENS DECEL TIME WHEN A LIMIT IS HIT
|
||||
OLDDCA=_DCA;' REMEMBERS CURRENT DECEL
|
||||
OLDDCB=_DCB
|
||||
OLDDCC=_DCC
|
||||
OLDDCD=_DCD
|
||||
OLDDCE=_DCE
|
||||
OLDDCF=_DCF
|
||||
NO OLDDCG=_DCG AXIS NOT USED
|
||||
NO OLDDCH=_DCH AXIS NOT USED
|
||||
IF (_LFA = 0) | (_LRA = 0)
|
||||
DCA=100000;' DECEL FOR LIMIT HIT OCCURENCE
|
||||
STA
|
||||
ENDIF
|
||||
IF (_LFB = 0) | (_LRB = 0)
|
||||
DCB=100000;' DECEL FOR LIMIT HIT OCCURENCE
|
||||
STB
|
||||
ENDIF
|
||||
IF (_LFC = 0) | (_LRC = 0)
|
||||
DCC=100000;' DECEL FOR LIMIT HIT OCCURENCE
|
||||
STC
|
||||
ENDIF
|
||||
IF (_LFD = 0) | (_LRD = 0)
|
||||
DCD=100000;' DECEL FOR LIMIT HIT OCCURENCE
|
||||
STD
|
||||
ENDIF
|
||||
IF (_LFE = 0) | (_LRE = 0)
|
||||
DCE=100000;' DECEL FOR LIMIT HIT OCCURENCE
|
||||
STE
|
||||
ENDIF
|
||||
IF (_LFF = 0) | (_LRF = 0)
|
||||
DCF=50000;' DECEL FOR LIMIT HIT OCCURENCE
|
||||
STF
|
||||
ENDIF
|
||||
NO IF (_LFG = 0) | (_LRG = 0) AXES NOT USED, COMMENTED OUT
|
||||
NO DCG=100000;' DECEL FOR LIMIT HIT OCCURENCE
|
||||
NO STG
|
||||
NO ENDIF
|
||||
NO IF (_LFH = 0) | (_LRH = 0)
|
||||
NO DCH=100000;' DECEL FOR LIMIT HIT OCCURENCE
|
||||
NO STH
|
||||
NO ENDIF
|
||||
AM ABCDEFGH;' AFTER ALL AXES STOPPED
|
||||
DCA=OLDDCA;' RESET DECEL TO OLD VALUE
|
||||
DCB=OLDDCB
|
||||
DCC=OLDDCC
|
||||
DCD=OLDDCD
|
||||
DCE=OLDDCE
|
||||
DCF=OLDDCF
|
||||
NO DCG=OLDDCG AXIS NOT USED
|
||||
NO DCH=OLDDCH AXIS NOT USED
|
||||
'ROUTINE TO HASTEN THE DECELERATION OF AN AXIS WHEN A LIMIT SWITCH IS HIT
|
||||
'
|
||||
JS #SETDCEL
|
||||
RE
|
||||
'
|
||||
'-----------------------------------------------------------------------
|
||||
#SETDCEL
|
||||
'ROUTINE TO HASTEN THE DECELERATION OF AN AXIS WHEN A LIMIT SWITCH IS HIT
|
||||
'
|
||||
IF (_LFA=0)|(_LRA=0)|(HLTA=1);'LIMIT HIT
|
||||
IF (LSAHIT=0)&(_BGA=1);'STILL MOVING, FIRST TIME
|
||||
OLDDCA=_DCA;'REMEMBER OLD DECEL VALUE
|
||||
STA
|
||||
DCA=100000;'INCREASE DECEL VALUE FOR RAPID STOP
|
||||
LSAHIT=1
|
||||
ENDIF
|
||||
ENDIF
|
||||
IF (_LFB=0)|(_LRB=0)|(HLTB=1)
|
||||
IF (LSBHIT=0)&(_BGB=1)
|
||||
OLDDCB=_DCB
|
||||
STB
|
||||
DCB=100000
|
||||
LSBHIT=1
|
||||
ENDIF
|
||||
ENDIF
|
||||
IF (_LFC=0)|(_LRC=0)|(HLTC=1)
|
||||
IF (LSCHIT=0)&(_BGC=1)
|
||||
OLDDCC=_DCC
|
||||
STC
|
||||
DCC=100000
|
||||
LSCHIT=1
|
||||
ENDIF
|
||||
ENDIF
|
||||
IF (_LFD=0)|(_LRD=0)|(HLTD=1)
|
||||
IF (LSDHIT=0)&(_BGD=1)
|
||||
OLDDCD=_DCD
|
||||
STD
|
||||
DCD=100000
|
||||
LSDHIT=1
|
||||
ENDIF
|
||||
ENDIF
|
||||
IF (_LFE=0)|(_LRE=0)|(HLTE=1)
|
||||
IF (LSEHIT=0)&(_BGE=1)
|
||||
OLDDCE=_DCE
|
||||
STE
|
||||
DCE=100000
|
||||
LSEHIT=1
|
||||
ENDIF
|
||||
ENDIF
|
||||
IF (_LFF=0)|(_LRF=0)|(HLTF=1)
|
||||
IF (LSFHIT=0)&(_BGF=1)
|
||||
OLDDCF=_DCF
|
||||
STF
|
||||
DCF=50000
|
||||
LSFHIT=1
|
||||
ENDIF
|
||||
ENDIF
|
||||
' IF (_LFG=0)|(_LRG=0)|(HLTG=1)
|
||||
' IF (LSGHIT=0)&(_BGG=1)
|
||||
' OLDDCG=_DCG
|
||||
' STG
|
||||
' DCG=100000
|
||||
' LSGHIT=1
|
||||
' ENDIF
|
||||
' ENDIF
|
||||
' IF (_LFH=0)|(_LRH=0)|(HLTH=1)
|
||||
' IF (LSHHIT=0)&(_BGH=1)
|
||||
' OLDDCH=_DCH
|
||||
' STH
|
||||
' DCH=100000
|
||||
' LSHHIT=1
|
||||
' ENDIF
|
||||
' ENDIF
|
||||
EN
|
||||
'
|
||||
'
|
||||
'-----------------------------------------------------------------------
|
||||
|
||||
|
||||
@@ -1,21 +1,25 @@
|
||||
NO TE: WOMBAT - CONTROLLER 2
|
||||
NO TE:
|
||||
NO TE: $Revision: 1.4 $
|
||||
NO TE: $Date: 2008-02-26 22:47:54 $
|
||||
NO TE: Author: Dan Bartlett
|
||||
NO TE: Last revision by: $Author: dcl $
|
||||
NO TE:
|
||||
NO TE: A-SAMPLE UPPER TILT
|
||||
NO TE: B-SAMPLE LOWER TILT
|
||||
NO TE: C-SAMPLE UPPER LINEAR
|
||||
NO TE: D-SAMPLE LOWER LINEAR
|
||||
NO TE: E-SAMPLE ROTATE
|
||||
NO TE: F-DETECTOR ROTATE
|
||||
NO TE: G-OSCILLATING COLLIMATOR
|
||||
NO TE: H-SPARE
|
||||
NO ----------------------------------------
|
||||
' WOMBAT - CONTROLLER 2
|
||||
'
|
||||
' $Revision: 1.5 $
|
||||
' $Date: 2008-03-05 04:25:32 $
|
||||
' Author: Dan Bartlett
|
||||
' Airpad control added by Doug Clowes
|
||||
' Last revision by: $Author: dcl $
|
||||
'
|
||||
' A-SAMPLE UPPER TILT
|
||||
' B-SAMPLE LOWER TILT
|
||||
' C-SAMPLE UPPER LINEAR
|
||||
' D-SAMPLE LOWER LINEAR
|
||||
' E-SAMPLE ROTATE
|
||||
' F-DETECTOR ROTATE
|
||||
' G-OSCILLATING COLLIMATOR
|
||||
' H-SPARE
|
||||
'
|
||||
'
|
||||
'-----------------------------------------------------------------------
|
||||
#AUTO
|
||||
NO TE: THIS IS THE PROGRAM THAT RUNS AUTOMATICALLY ON CONTROLLER STARTUP
|
||||
' THIS IS THE PROGRAM THAT RUNS AUTOMATICALLY ON CONTROLLER STARTUP
|
||||
'
|
||||
MT-2,-2,-2,-2,-2,-2,-2,-2;'CONFIGURES ALL AXES AS STEPPER
|
||||
MO;' FIRST TIME MOTOR OFF
|
||||
CN 1;' CONFIGURES LIMIT SWITCHES TO ACCEPT NC CONTACTS
|
||||
@@ -33,13 +37,164 @@ SIE=1,25,13,0<-2>2;'HEIDENHAIN ROQ425
|
||||
SIF=1,25,25,0<-2>2;'HEIDENHAIN RCN226
|
||||
SIG=1,25,13,0<-2>2;'HEIDENHAIN ROQ425
|
||||
SIH=0,25,13,0<-2>2;'NOT USED
|
||||
APDONE=0;' FIRST TIME THROUGH AIRPAD CONTROL NOT DONE
|
||||
' FIRST TIME THROUGH RESET AIRPAD CONTROL
|
||||
REQF=0
|
||||
RSPF=0
|
||||
' FIRST TIME THROUGH RESET HALT CONTROL
|
||||
HLTA=0
|
||||
HLTB=0
|
||||
HLTC=0
|
||||
HLTD=0
|
||||
HLTE=0
|
||||
HLTF=0
|
||||
HLTG=0
|
||||
' HLTH=0
|
||||
' FIRST TIME THROUGH RESET LIMIT CONTROL
|
||||
LSAHIT=0
|
||||
LSBHIT=0
|
||||
LSCHIT=0
|
||||
LSDHIT=0
|
||||
LSEHIT=0
|
||||
LSFHIT=0
|
||||
LSGHIT=0
|
||||
' LSHHIT=0
|
||||
JS #THREAD0
|
||||
EN
|
||||
NO ----------------------------------------
|
||||
'
|
||||
'
|
||||
'-----------------------------------------------------------------------
|
||||
#THREAD0
|
||||
NO TE: THERE MUST BE A THREAD RUNNING FOR #LIMSWI, #TCPERR AND #ININT TO WORK
|
||||
NO TE: CHECKS IF SPEEDS ARE ABOVE MAXIMUM ALLOWED
|
||||
' MAIN THREAD
|
||||
' THERE MUST BE A THREAD RUNNING FOR #LIMSWI, #TCPERR AND #ININT TO WORK
|
||||
'
|
||||
JS #CHKDCEL
|
||||
JS #AIRPAD
|
||||
JS #CHKSPD
|
||||
JP #THREAD0
|
||||
EN
|
||||
'
|
||||
'
|
||||
'-----------------------------------------------------------------------
|
||||
#CHKDCEL
|
||||
'ROUTINE TO CHECK DECELERATION AFTER A LIMIT HIT
|
||||
'
|
||||
IF (LSAHIT=1)&(_BGA=0);'WHEN MOTION STOPS AFTER A LIMIT HIT
|
||||
DCA=OLDDCA;' RESET DECEL TO OLD VALUE
|
||||
IF (HLTA=1)
|
||||
MOA
|
||||
HLTA=0
|
||||
ENDIF
|
||||
LSAHIT=0
|
||||
ENDIF
|
||||
IF (LSBHIT=1)&(_BGB=0)
|
||||
DCB=OLDDCB
|
||||
IF (HLTB=1)
|
||||
MOB
|
||||
HLTB=0
|
||||
ENDIF
|
||||
LSBHIT=0
|
||||
ENDIF
|
||||
IF (LSCHIT=1)&(_BGC=0)
|
||||
DCC=OLDDCC
|
||||
IF (HLTC=1)
|
||||
MOC
|
||||
HLTC=0
|
||||
ENDIF
|
||||
LSCHIT=0
|
||||
ENDIF
|
||||
IF (LSDHIT=1)&(_BGD=0)
|
||||
DCD=OLDDCD
|
||||
IF (HLTD=1)
|
||||
MOD
|
||||
HLTD=0
|
||||
ENDIF
|
||||
LSDHIT=0
|
||||
ENDIF
|
||||
IF (LSEHIT=1)&(_BGE=0)
|
||||
DCE=OLDDCE
|
||||
IF (HLTE=1)
|
||||
MOE
|
||||
HLTE=0
|
||||
ENDIF
|
||||
LSEHIT=0
|
||||
ENDIF
|
||||
IF (LSFHIT=1)&(_BGF=0)
|
||||
DCF=OLDDCF
|
||||
IF (HLTF=1)
|
||||
MOF
|
||||
HLTF=0
|
||||
ENDIF;'
|
||||
LSFHIT=0
|
||||
ENDIF
|
||||
IF (LSGHIT=1)&(_BGG=0)
|
||||
DCG=OLDDCG
|
||||
IF (HLTG=1)
|
||||
MOG
|
||||
HLTG=0
|
||||
ENDIF
|
||||
LSGHIT=0
|
||||
ENDIF
|
||||
' IF (LSHHIT=1)&(_BGH=0)
|
||||
' DCH=OLDDCH
|
||||
' IF (HLTH=1)
|
||||
' MOH
|
||||
' HLTH=0
|
||||
' ENDIF
|
||||
' LSHHIT=0
|
||||
' ENDIF
|
||||
JS #SETDCEL,((HLTA=1)&(LSAHIT=0))
|
||||
JS #SETDCEL,((HLTB=1)&(LSBHIT=0))
|
||||
JS #SETDCEL,((HLTC=1)&(LSCHIT=0))
|
||||
JS #SETDCEL,((HLTD=1)&(LSDHIT=0))
|
||||
JS #SETDCEL,((HLTE=1)&(LSEHIT=0))
|
||||
JS #SETDCEL,((HLTF=1)&(LSFHIT=0))
|
||||
JS #SETDCEL,((HLTG=1)&(LSGHIT=0))
|
||||
' JS #SETDCEL,((HLTH=1)&(LSHHIT=0))
|
||||
EN
|
||||
'
|
||||
'
|
||||
'-----------------------------------------------------------------------
|
||||
#AIRPAD
|
||||
' ROUTINE TO CONTROL THE AIRPADS
|
||||
' SET REQF=1 TO MAKE FLIGHT TUBE AVAILABLE FOR MOVE
|
||||
' THE RSPF BIT IS USED SO THAT THE CODE ONLY RUNS WHEN THE
|
||||
' STATE OF FTUBE CHANGES - THE DELAYS ARENT RUNNING EVERY CYCLE
|
||||
' IN THE 2ND IF, THE OFF-SOLENOIDS ARENT HELD ENERGISED IN CASE THE
|
||||
' VALVE MANUAL OVER RIDE IS NEEDED.
|
||||
'
|
||||
' FOLLOW SHF/MOF COMMANDS ENTERED MANUALLY
|
||||
IF (_MOF=0)&(RSPF=0);'FLIGHT TUBE MOTOR IS ON BUT AIR IS OFF
|
||||
REQF=1
|
||||
ENDIF
|
||||
IF (_MOF=1)&(RSPF=1);'FLIGHT TUBE MOTOR IS OFF BUT AIR IS ON
|
||||
SHF;' FOLLOWING STEPS MUST BE RUN BEFORE MOTOR CAN BE TURNED OFF
|
||||
REQF=0
|
||||
ENDIF
|
||||
'
|
||||
IF (REQF=1)&(RSPF=0);'REQUESTING FLIGHT TUBE BE MOVABLE
|
||||
SHF;' TURN MOTOR ON
|
||||
WT500;' WAIT FOR MOTOR TO STABILISE
|
||||
SB 10;' DETECTOR AIR PAD OFF-SOLENOID OFF
|
||||
CB 9;' DETECTOR AIR PAD ON-SOLENOID ON
|
||||
WT1000;
|
||||
RSPF=1
|
||||
ENDIF
|
||||
IF (REQF=0)&(RSPF=1);'FLIGHT TUBE MOTION FINISHED
|
||||
WT1000;' WAIT FOR FLIGHT TUBE TO SETTLE
|
||||
SB 9;' DETECTOR AIR PAD ON-SOLENOID OFF
|
||||
CB 10;' DETECTOR AIR PAD OFF-SOLENOID ON
|
||||
WT500;
|
||||
SB 10;' DETECTOR AIR PAD OFF-SOLENOID OFF
|
||||
MOF;' TURN MOTOR OFF
|
||||
RSPF=0
|
||||
ENDIF
|
||||
EN
|
||||
'
|
||||
'
|
||||
'-----------------------------------------------------------------------
|
||||
#CHKSPD
|
||||
' ROUTINE TO CHECK IF SPEEDS ARE ABOVE MAXIMUM ALLOWED
|
||||
'
|
||||
IF (_SPA>50000)
|
||||
SPA=50000
|
||||
ENDIF
|
||||
@@ -61,95 +216,129 @@ ENDIF
|
||||
IF (_SPG>500000)
|
||||
SPG=500000
|
||||
ENDIF
|
||||
NO IF (_SPH>50000) AXIS NOT USED, COMMENTED OUT
|
||||
NO SPH=50000
|
||||
NO ENDIF
|
||||
NO TE: CONTROLS THE AIRPAD SOLENOID VALVES
|
||||
IF (_MOF=0);'DETECTOR MOTOR IS ON
|
||||
SB 10;'DETECTOR AIR PAD OFF-SOLENOID OFF
|
||||
CB 9;'DETECTOR AIR PAD ON-SOLENOID ON
|
||||
APDONE=0
|
||||
ENDIF
|
||||
IF (_MOF=1)&(APDONE=0);'FLIGHT TUBE MOTOR IS OFF
|
||||
SB 9;'DETECTOR AIR PAD ON-SOLENOID OFF
|
||||
CB 10;'DETECTOR AIR PAD OFF-SOLENOID ON
|
||||
WT500;'WAIT 1/2 SEC
|
||||
SB 10;'DETECTOR AIR PAD OFF-SOLENOID OFF
|
||||
APDONE=1
|
||||
ENDIF
|
||||
JP #THREAD0
|
||||
' IF (_SPH>50000)
|
||||
' SPH=50000
|
||||
' ENDIF
|
||||
EN
|
||||
NO ----------------------------------------
|
||||
'
|
||||
'
|
||||
'-----------------------------------------------------------------------
|
||||
#TCPERR
|
||||
NO TE: EMPTY ROUTINE FOR A TCP ERROR
|
||||
' EMPTY ROUTINE FOR A TCP ERROR
|
||||
'
|
||||
RE
|
||||
NO ----------------------------------------
|
||||
'
|
||||
'
|
||||
'-----------------------------------------------------------------------
|
||||
#CMDERR
|
||||
'ROUTINE TO HANDLE COMMAND ERRORS
|
||||
'
|
||||
ZS0
|
||||
EN1
|
||||
'
|
||||
'
|
||||
'-----------------------------------------------------------------------
|
||||
#ININT
|
||||
NO TE: INTERUPT ROUTINE TO STOP ALL AXES
|
||||
NO TE: WHEN SAFETY & INTERLOCK SYSTEM REQUESTS IT
|
||||
' INTERUPT ROUTINE TO STOP ALL AXES
|
||||
' WHEN SAFETY & INTERLOCK SYSTEM REQUESTS IT
|
||||
'
|
||||
STA,B,C,D,E,F,G,H
|
||||
AM
|
||||
MO
|
||||
HLTA=1
|
||||
HLTB=1
|
||||
HLTC=1
|
||||
HLTD=1
|
||||
HLTE=1
|
||||
HLTF=1
|
||||
HLTG=1
|
||||
' HLTH=1
|
||||
JS #SETDCEL
|
||||
RI
|
||||
NO ----------------------------------------
|
||||
'
|
||||
'
|
||||
'-----------------------------------------------------------------------
|
||||
#LIMSWI
|
||||
NO TE: LIMIT SWITCH ROUTINE WHICH SHORTENS DECEL TIME WHEN A LIMIT IS HIT
|
||||
OLDDCA=_DCA;' REMEMBERS CURRENT DECEL
|
||||
OLDDCB=_DCB
|
||||
OLDDCC=_DCC
|
||||
OLDDCD=_DCD
|
||||
OLDDCE=_DCE
|
||||
OLDDCF=_DCF
|
||||
OLDDCG=_DCG
|
||||
NO OLDDCH=_DCH AXIS NOT USED
|
||||
IF (_LFA = 0) | (_LRA = 0)
|
||||
DCA=100000;' DECEL FOR LIMIT HIT OCCURENCE
|
||||
STA
|
||||
ENDIF
|
||||
IF (_LFB = 0) | (_LRB = 0)
|
||||
DCB=100000;' DECEL FOR LIMIT HIT OCCURENCE
|
||||
STB
|
||||
ENDIF
|
||||
IF (_LFC = 0) | (_LRC = 0)
|
||||
DCC=100000;' DECEL FOR LIMIT HIT OCCURENCE
|
||||
STC
|
||||
ENDIF
|
||||
IF (_LFD = 0) | (_LRD = 0)
|
||||
DCD=100000;' DECEL FOR LIMIT HIT OCCURENCE
|
||||
STD
|
||||
ENDIF
|
||||
IF (_LFE = 0) | (_LRE = 0)
|
||||
DCE=100000;' DECEL FOR LIMIT HIT OCCURENCE
|
||||
STE
|
||||
ENDIF
|
||||
IF (_LFF = 0) | (_LRF = 0)
|
||||
DCF=50000;' DECEL FOR LIMIT HIT OCCURENCE
|
||||
STF
|
||||
ENDIF
|
||||
IF (_LFG = 0) | (_LRG = 0)
|
||||
DCG=100000;' DECEL FOR LIMIT HIT OCCURENCE
|
||||
STG
|
||||
ENDIF
|
||||
NO IF (_LFH = 0) | (_LRH = 0)
|
||||
NO DCH=100000;' DECEL FOR LIMIT HIT OCCURENCE
|
||||
NO STH
|
||||
NO ENDIF
|
||||
AM ABCDEFGH;' AFTER ALL AXES STOPPED
|
||||
DCA=OLDDCA;' RESET DECEL TO OLD VALUE
|
||||
DCB=OLDDCB
|
||||
DCC=OLDDCC
|
||||
DCD=OLDDCD
|
||||
DCE=OLDDCE
|
||||
DCF=OLDDCF
|
||||
DCG=OLDDCG
|
||||
NO DCH=OLDDCH AXIS NOT USED
|
||||
'ROUTINE TO HASTEN THE DECELERATION OF AN AXIS WHEN A LIMIT SWITCH IS HIT
|
||||
'
|
||||
JS #SETDCEL
|
||||
RE
|
||||
NO ----------------------------------------
|
||||
'
|
||||
'-----------------------------------------------------------------------
|
||||
#SETDCEL
|
||||
'ROUTINE TO HASTEN THE DECELERATION OF AN AXIS WHEN A LIMIT SWITCH IS HIT
|
||||
'
|
||||
IF (_LFA=0)|(_LRA=0)|(HLTA=1);'LIMIT HIT
|
||||
IF (LSAHIT=0)&(_BGA=1);'STILL MOVING, FIRST TIME
|
||||
OLDDCA=_DCA;'REMEMBER OLD DECEL VALUE
|
||||
STA
|
||||
DCA=100000;'INCREASE DECEL VALUE FOR RAPID STOP
|
||||
LSAHIT=1
|
||||
ENDIF
|
||||
ENDIF
|
||||
IF (_LFB=0)|(_LRB=0)|(HLTB=1)
|
||||
IF (LSBHIT=0)&(_BGB=1)
|
||||
OLDDCB=_DCB
|
||||
STB
|
||||
DCB=100000
|
||||
LSBHIT=1
|
||||
ENDIF
|
||||
ENDIF
|
||||
IF (_LFC=0)|(_LRC=0)|(HLTC=1)
|
||||
IF (LSCHIT=0)&(_BGC=1)
|
||||
OLDDCC=_DCC
|
||||
STC
|
||||
DCC=100000
|
||||
LSCHIT=1
|
||||
ENDIF
|
||||
ENDIF
|
||||
IF (_LFD=0)|(_LRD=0)|(HLTD=1)
|
||||
IF (LSDHIT=0)&(_BGD=1)
|
||||
OLDDCD=_DCD
|
||||
STD
|
||||
DCD=100000
|
||||
LSDHIT=1
|
||||
ENDIF
|
||||
ENDIF
|
||||
IF (_LFE=0)|(_LRE=0)|(HLTE=1)
|
||||
IF (LSEHIT=0)&(_BGE=1)
|
||||
OLDDCE=_DCE
|
||||
STE
|
||||
DCE=100000
|
||||
LSEHIT=1
|
||||
ENDIF
|
||||
ENDIF
|
||||
IF (_LFF=0)|(_LRF=0)|(HLTF=1)
|
||||
IF (LSFHIT=0)&(_BGF=1)
|
||||
OLDDCF=_DCF
|
||||
STF
|
||||
DCF=50000
|
||||
LSFHIT=1
|
||||
ENDIF
|
||||
ENDIF
|
||||
IF (_LFG=0)|(_LRG=0)|(HLTG=1)
|
||||
IF (LSGHIT=0)&(_BGG=1)
|
||||
OLDDCG=_DCG
|
||||
STG
|
||||
DCG=100000
|
||||
LSGHIT=1
|
||||
ENDIF
|
||||
ENDIF
|
||||
' IF (_LFH=0)|(_LRH=0)|(HLTH=1)
|
||||
' IF (LSHHIT=0)&(_BGH=1)
|
||||
' OLDDCH=_DCH
|
||||
' STH
|
||||
' DCH=100000
|
||||
' LSHHIT=1
|
||||
' ENDIF
|
||||
' ENDIF
|
||||
EN
|
||||
'
|
||||
'
|
||||
'-----------------------------------------------------------------------
|
||||
#OSC
|
||||
NO TE: THIS PROGRAM OSCILATES THE COLLIMATOR
|
||||
NO TE: IT MUST BE RUN IN THREAD 1
|
||||
' THIS PROGRAM OSCILATES THE COLLIMATOR
|
||||
' IT MUST BE RUN IN THREAD 1
|
||||
XQ #ACCVETO,2
|
||||
NO TE: STARTS THE VETO PROGRAM IN THREAD 2
|
||||
' STARTS THE VETO PROGRAM IN THREAD 2
|
||||
#STRT
|
||||
STRTPOS=7744139;' STARTING ENCODER POSITION
|
||||
SHG
|
||||
@@ -160,7 +349,7 @@ PRG=(_TPG - STRTPOS)/204.8*25000
|
||||
BGG
|
||||
AMG
|
||||
JP #STRT,(_TPG<>STRTPOS)
|
||||
NO TE: JUMP TO #STRT UNTIL TABLE IS IN POSITION
|
||||
' JUMP TO #STRT UNTIL TABLE IS IN POSITION
|
||||
SPG=500000
|
||||
ACG=750000
|
||||
DCG=750000
|
||||
@@ -173,17 +362,16 @@ BGG
|
||||
AMG
|
||||
JP #LOOP
|
||||
EN
|
||||
NO ----------------------------------------
|
||||
' ----------------------------------------
|
||||
#ACCVETO
|
||||
NO TE: THIS PROGRAM MONITORS THE VELOCITY OF THE OSCILATING COLLIMATOR
|
||||
NO TE: AND SENDS A VETO SIGNAL TO THE DAE WHEN VELOCITY IS CONSTANT
|
||||
NO TE: IT IS CALLED BY #OSC AND IS RUN IN THREAD 2
|
||||
' THIS PROGRAM MONITORS THE VELOCITY OF THE OSCILATING COLLIMATOR
|
||||
' AND SENDS A VETO SIGNAL TO THE DAE WHEN VELOCITY IS CONSTANT
|
||||
' IT IS CALLED BY #OSC AND IS RUN IN THREAD 2
|
||||
IF (_TVG=_SPG)
|
||||
SB1
|
||||
ELSE
|
||||
CB1
|
||||
ENDIF
|
||||
JP #ACCVETO,(_XQ1<>-1)
|
||||
NO TE: JUMP BACK TO START UNLESS #OSC IS NOT RUNNING
|
||||
' JUMP BACK TO START UNLESS #OSC IS NOT RUNNING
|
||||
EN
|
||||
NO ----------------------------------------
|
||||
|
||||
Reference in New Issue
Block a user