|
- subroutine Rtable_MainSolver
-
- use CDataDisplayConsoleVariables
- use CDrillingConsoleVariables
- use CSimulationVariables
- use RTable_VARIABLES
- use CDrillWatchVariables
- use CWarningsVariables
- use CSounds
-
- IMPLICIT NONE
-
-
- if (IsPortable) then
- RTable%AssignmentSwitch = 1
- else
- RTable%AssignmentSwitch = DrillingConsole%AssignmentSwitch
- end if
-
- if (DrillingConsole%RTThrottle<=0.e0) then
- RTable%K_throttle = 1
- end if
-
- if ( (any(RTable%AssignmentSwitch==(/1,2,3,4,5,8,9,10,11/))) .and. (DrillingConsole%RTSwitch == -1) .and. (IsStopped == .false.) ) then
-
- RTable%SoundBlower = .true.
- Call SetSoundBlowerRT(RTable%SoundBlower)
- DrillingConsole%RTBLWR = 1
-
-
- IF ( DrillingConsole%RTTransmissionLever /=0 .and. RotaryGearsAbuse==0 ) THEN !be in clutch mode ??????
- RTable%N_new = DrillingConsole%RTThrottle
-
- !===> Rotary Table Malfunction ----> Drive Motor Failure
- call RTMalfunction_MotorFailure
-
- if (((RTable%N_new-RTable%N_old)/RTable%time_step)>193.) then
- RTable%N_ref = (193.*RTable%time_step)+RTable%N_old
- else if (((RTable%N_old-RTable%N_new)/RTable%time_step)>193.) then
- RTable%N_ref = (-193.*RTable%time_step)+RTable%N_old
- else
- RTable%N_ref = RTable%N_new
- end if
- CALL RTable_INPUTS
- CALL RTable_Solver
- RT_RPMUnityOutput = DataDisplayConsole%RotaryRPMGauge
- RTable%N_old = RTable%N_ref
- Else IF ( DrillingConsole%RTTransmissionLever==0) THEN !be in brake mode ??????
- Call RTable_OffMode
- RT_RPMUnityOutput = DataDisplayConsole%RotaryRPMGauge
- End IF
- RT_OldTransMode = DrillingConsole%RTTransmissionLever
-
-
- else if ( (any(RTable%AssignmentSwitch==(/1,2,3,4,5,8,9,10,11/))) .and. (DrillingConsole%RTSwitch == 1) .and. (RTable%K_throttle==1) .and. (IsStopped == .false.) ) then
-
- RTable%SoundBlower = .true.
- Call SetSoundBlowerRT(RTable%SoundBlower)
- DrillingConsole%RTBLWR = 1
-
-
- IF ( DrillingConsole%RTTransmissionLever /=0 .and. RotaryGearsAbuse==0 ) THEN !be in clutch mode ??????
- RTable%N_new = DrillingConsole%RTThrottle
-
- !===> Rotary Table Malfunction ----> Drive Motor Failure
- call RTMalfunction_MotorFailure
-
- if (((RTable%N_new-RTable%N_old)/RTable%time_step)>193.) then
- RTable%N_ref = (193.*RTable%time_step)+RTable%N_old
- else if (((RTable%N_old-RTable%N_new)/RTable%time_step)>193.) then
- RTable%N_ref = (-193.*RTable%time_step)+RTable%N_old
- else
- RTable%N_ref = RTable%N_new
- end if
- CALL RTable_INPUTS
- CALL RTable_Solver
- RT_RPMUnityOutput = -DataDisplayConsole%RotaryRPMGauge
- RTable%N_old = RTable%N_ref
- Else IF ( DrillingConsole%RTTransmissionLever==0) THEN !be in brake mode ??????
- Call RTable_OffMode
- RT_RPMUnityOutput = -DataDisplayConsole%RotaryRPMGauge
- End IF
- RT_OldTransMode = DrillingConsole%RTTransmissionLever
-
-
- else
-
-
- if((any(RTable%AssignmentSwitch==(/1,2,3,4,5,8,9,10,11/))) .and. (DrillingConsole%RTSwitch /= 0) .and. (IsStopped == .false.) ) then
- RTable%SoundBlower = .true.
- Call SetSoundBlowerRT(RTable%SoundBlower)
- DrillingConsole%RTBLWR = 1
- else
- RTable%SoundBlower = .false.
- Call SetSoundBlowerRT(RTable%SoundBlower)
- DrillingConsole%RTBLWR = 0
- end if
-
- Call RTable_OffMode
- RT_RPMUnityOutput = DataDisplayConsole%RotaryRPMGauge
- RT_OldTransMode = DrillingConsole%RTTransmissionLever
- RTable%K_throttle = 0
-
-
- end if
-
- END subroutine Rtable_MainSolver
|