|
- module CSwingLedNotification
- use OperationScenariosModule
- implicit none
- contains
-
- subroutine Evaluate_SwingLed()
- implicit none
-
-
-
-
-
- if (data%State%Hoisting%DriveType == TopDrive_DriveType) then
- #ifdef OST
- print*, 'Evaluate_SwingLed=TopDrive'
- #endif
-
-
-
- endif
-
-
-
-
-
-
-
-
-
- if (data%State%Hoisting%DriveType == Kelly_DriveType) then
- #ifdef OST
- print*, 'Evaluate_SwingLed=Kelly'
- #endif
-
-
- !OPERATION-CODE=22
- if (Get_OperationCondition() == OPERATION_TRIP .and.&
- Get_HookHeight() >= (data%State%OperationScenario%HL + Get_NearFloorConnection()) .and. Get_HookHeight() <= (data%State%OperationScenario%HL + Get_NearFloorConnection() + data%State%OperationScenario%LG) .and.&
- Get_ElevatorConnection() == ELEVATOR_CONNECTION_NOTHING .and.&
- Get_JointConnectionPossible() == .false. .and.&
- (Get_Swing() /= SWING_WELL_BEGIN .and.&
- Get_Swing() /= SWING_MOUSE_HOLE_BEGIN .and.&
- Get_Swing() /= SWING_RAT_HOLE_BEGIN) .and.&
- Get_Slips() == SLIPS_SET_END) then
-
- call Set_SwingLed(.true.)
- return
- end if
-
-
- !OPERATION-CODE=23
- if (Get_OperationCondition() == OPERATION_TRIP .and.&
- Get_HookHeight() >= (data%State%OperationScenario%HL + Get_NearFloorConnection() + data%State%OperationScenario%PL) .and. Get_HookHeight() <= (data%State%OperationScenario%HL + Get_NearFloorConnection() + data%State%OperationScenario%LG + data%State%OperationScenario%PL) .and.&
- Get_ElevatorConnection() == ELEVATOR_CONNECTION_SINGLE .and.&
- Get_JointConnectionPossible() == .false. .and.&
- (Get_Swing() /= SWING_WELL_BEGIN .and.&
- Get_Swing() /= SWING_MOUSE_HOLE_BEGIN .and.&
- Get_Swing() /= SWING_RAT_HOLE_BEGIN) .and.&
- Get_Slips() == SLIPS_SET_END) then
-
- call Set_SwingLed(.true.)
- return
- end if
-
-
- !OPERATION-CODE=24
- if (Get_OperationCondition() == OPERATION_DRILL .and.&
- Get_HookHeight() >= (data%State%OperationScenario%HKL + Get_NearFloorConnection()) .and. Get_HookHeight() <= (data%State%OperationScenario%HKL + Get_NearFloorConnection() + data%State%OperationScenario%LG) .and.&
- Get_JointConnectionPossible() == .false. .and.&
- Get_KellyConnection() == KELLY_CONNECTION_NOTHING .and.&
- (Get_Swing() /= SWING_WELL_BEGIN .and.&
- Get_Swing() /= SWING_MOUSE_HOLE_BEGIN .and.&
- Get_Swing() /= SWING_RAT_HOLE_BEGIN) .and.&
- Get_Slips() == SLIPS_SET_END) then
-
- call Set_SwingLed(.true.)
- return
- end if
-
- !OPERATION-CODE=25
- if (Get_OperationCondition() == OPERATION_DRILL .and.&
- Get_HookHeight() >= (data%State%OperationScenario%HKL + Get_NearFloorConnection() + data%State%OperationScenario%PL) .and. Get_HookHeight() <= (data%State%OperationScenario%HKL + Get_NearFloorConnection() + data%State%OperationScenario%LG + data%State%OperationScenario%PL) .and.&
- Get_KellyConnection() == KELLY_CONNECTION_SINGLE .and.&
- Get_JointConnectionPossible() == .false. .and.&
- (Get_Swing() /= SWING_WELL_BEGIN .and.&
- Get_Swing() /= SWING_MOUSE_HOLE_BEGIN .and.&
- Get_Swing() /= SWING_RAT_HOLE_BEGIN) .and.&
- Get_Slips() == SLIPS_SET_END) then
-
- call Set_SwingLed(.true.)
- return
- end if
-
-
- call Set_SwingLed(.false.)
-
-
- endif
-
-
-
-
-
-
-
-
- end subroutine
-
- ! subroutine Subscribe_SwingLed()
- ! implicit none
-
- ! call OnOperationConditionChange%Add(Evaluate_SwingLed)
- ! call OnHookHeightChange%Add(Evaluate_SwingLed)
- ! call OnElevatorConnectionChange%Add(Evaluate_SwingLed)
- ! call OnKellyConnectionChange%Add(Evaluate_SwingLed)
- ! call OnSwingChange%Add(Evaluate_SwingLed)
- ! call OnSlipsChange%Add(Evaluate_SwingLed)
- ! call OnFillMouseHoleLedChange%Add(Evaluate_SwingLed)
-
- ! end subroutine
-
- end module CSwingLedNotification
|