345 lines
6.5 KiB
Plaintext
345 lines
6.5 KiB
Plaintext
' 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
|
|
' 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
|
|
II 8,,,0;' CONFIGURES THE 8TH INPUT TO ACTIVATE THE #ININT ROUTINE
|
|
OP 65280;' SETS OUTPUTS 9-16 ON = RELAYS OFF
|
|
IA 137,157,201,67;' CONFIGURES IP ADDRESS
|
|
AC 25000,25000,25000,25000,50000,10000,25000,25000;' SET ACELERATION
|
|
DC 25000,25000,25000,25000,50000,10000,25000,25000;' SET DECELERATION
|
|
SP 25000,25000,25000,25000,25000,75000,25000,25000;' SET SPEED
|
|
SIA=1,25,13,0<-2>2;'HEIDENHAIN ROQ425
|
|
SIB=1,25,13,0<-2>2;'HEIDENHAIN ROQ425
|
|
SIC=1,25,13,0<-2>2;'HEIDENHAIN ROQ425
|
|
SID=1,25,13,0<-2>2;'HEIDENHAIN ROQ425
|
|
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
|
|
' 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
|
|
'
|
|
'
|
|
'-----------------------------------------------------------------------
|
|
#THREAD0
|
|
' 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
|
|
IF (_SPB>50000)
|
|
SPB=50000
|
|
ENDIF
|
|
IF (_SPC>50000)
|
|
SPC=50000
|
|
ENDIF
|
|
IF (_SPD>50000)
|
|
SPD=50000
|
|
ENDIF
|
|
IF (_SPE>50000)
|
|
SPE=50000
|
|
ENDIF
|
|
IF (_SPF>75000)
|
|
SPF=75000
|
|
ENDIF
|
|
' IF (_SPG>50000)
|
|
' SPG=50000
|
|
' ENDIF
|
|
' IF (_SPH>50000)
|
|
' SPH=50000
|
|
' ENDIF
|
|
EN
|
|
'
|
|
'
|
|
'-----------------------------------------------------------------------
|
|
#TCPERR
|
|
' EMPTY ROUTINE FOR A TCP ERROR
|
|
'
|
|
RE
|
|
'
|
|
'
|
|
'-----------------------------------------------------------------------
|
|
#CMDERR
|
|
'ROUTINE TO HANDLE COMMAND ERRORS
|
|
'
|
|
ZS0
|
|
EN1
|
|
'
|
|
'
|
|
'-----------------------------------------------------------------------
|
|
#ININT
|
|
' INTERUPT ROUTINE TO STOP ALL AXES
|
|
' WHEN SAFETY & INTERLOCK SYSTEM REQUESTS IT
|
|
'
|
|
STA,B,C,D,E,F,G,H
|
|
HLTA=1
|
|
HLTB=1
|
|
HLTC=1
|
|
HLTD=1
|
|
HLTE=1
|
|
HLTF=1
|
|
' HLTG=1
|
|
' HLTH=1
|
|
JS #SETDCEL
|
|
RI
|
|
'
|
|
'
|
|
'-----------------------------------------------------------------------
|
|
#LIMSWI
|
|
'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
|
|
'
|
|
'
|
|
'-----------------------------------------------------------------------
|
|
|