Simulation Core
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

CDrillingConsole.f90 13 KiB

1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  1. module CDrillingConsole
  2. use CDrillingConsoleVariables
  3. use SimulationVariables
  4. ! use CSimulationVariables
  5. use CLog4
  6. use CLog3
  7. implicit none
  8. public
  9. contains
  10. subroutine DrillingConsoleFromJson(jsonfile)
  11. type(json_value),pointer :: parent
  12. type(json_core) :: json
  13. type(json_value),pointer :: p,pval
  14. type(json_file)::jsonfile
  15. logical::found
  16. integer :: i
  17. ! call jsonfile%get('Equipments.Drilling.AssignmentSwitch',data%Equipments%DrillingConsole%AssignmentSwitch,found)
  18. ! if ( .not. found ) call logg(4,"Not found: AssignmentSwitch")
  19. ! call jsonfile%get('Equipments.Drilling.EmergencySwitch',data%Equipments%DrillingConsole%EmergencySwitch,found)
  20. ! if ( .not. found ) call logg(4,"Not found: EmergencySwitch")
  21. ! call jsonfile%get('Equipments.Drilling.RTTorqueLimitKnob',data%Equipments%DrillingConsole%RTTorqueLimitKnob,found)
  22. ! if ( .not. found ) call logg(4,"Not found: RTTorqueLimitKnob")
  23. call jsonfile%get('Equipments.Drilling.MP1CPSwitch',data%Equipments%DrillingConsole%MP1CPSwitch,found)
  24. if ( .not. found ) call logg(4,"Not found: MP1CPSwitch")
  25. ! call jsonfile%get('Equipments.Drilling.MP1ThrottleUpdate',data%Equipments%DrillingConsole%MP1ThrottleUpdate,found)
  26. ! if ( .not. found ) call logg(4,"Not found: MP1ThrottleUpdate")
  27. call jsonfile%get('Equipments.Drilling.MP1Throttle',data%Equipments%DrillingConsole%MP1Throttle,found)
  28. if ( .not. found ) call logg(4,"Not found: MP1Throttle")
  29. call jsonfile%get('Equipments.Drilling.MP2Switch',data%Equipments%DrillingConsole%MP2Switch,found)
  30. if ( .not. found ) call logg(4,"Not found: MP2Switch")
  31. ! call jsonfile%get('Equipments.Drilling.MP2ThrottleUpdate',data%Equipments%DrillingConsole%MP2ThrottleUpdate,found)
  32. ! if ( .not. found ) call logg(4,"Not found: MP2ThrottleUpdate")
  33. call jsonfile%get('Equipments.Drilling.MP2Throttle',data%Equipments%DrillingConsole%MP2Throttle,found)
  34. if ( .not. found ) call logg(4,"Not found: MP2Throttle")
  35. call jsonfile%get('Equipments.Drilling.DWSwitch',data%Equipments%DrillingConsole%DWSwitch,found)
  36. if ( .not. found ) call logg(4,"Not found: DWSwitch")
  37. call jsonfile%get('Equipments.Drilling.DWThrottle',data%Equipments%DrillingConsole%DWThrottle,found)
  38. if ( .not. found ) call logg(4,"Not found: DWThrottle")
  39. ! if (print_log .and. abs(data%Equipments%DrillingConsole%DWThrottle)>0) print *,"data%Equipments%DrillingConsole%DWThrottle = ",data%Equipments%DrillingConsole%DWThrottle
  40. call jsonfile%get('Equipments.Drilling.RTSwitch',data%Equipments%DrillingConsole%RTSwitch,found)
  41. if ( .not. found ) call logg(4,"Not found: RTSwitch")
  42. call jsonfile%get('Equipments.Drilling.RTThrottle',i,found)
  43. data%Equipments%DrillingConsole%RTThrottle = real(i)
  44. if ( .not. found ) call logg(4,"Not found: RTThrottle")
  45. ! call jsonfile%get('Equipments.Drilling.DWBreak',data%Equipments%DrillingConsole%DWBreak,found)
  46. ! if ( .not. found ) call logg(4,"Not found: DWBreak")
  47. ! call jsonfile%get('Equipments.Drilling.PreviousDWBreak',data%Equipments%DrillingConsole%PreviousDWBreak,found)
  48. ! if ( .not. found ) call logg(4,"Not found: PreviousDWBreak")
  49. ! call jsonfile%get('Equipments.Drilling.ForceBreak',data%Equipments%DrillingConsole%ForceBreak,found)
  50. ! if ( .not. found ) call logg(4,"Not found: ForceBreak")
  51. ! call jsonfile%get('Equipments.Drilling.DWAcceleretor',data%Equipments%DrillingConsole%DWAcceleretor,found)
  52. ! if ( .not. found ) call logg(4,"Not found: DWAcceleretor")
  53. ! call jsonfile%get('Equipments.Drilling.DWTransmisionLever',data%Equipments%DrillingConsole%DWTransmisionLever,found)
  54. ! if ( .not. found ) call logg(4,"Not found: DWTransmisionLever")
  55. ! call jsonfile%get('Equipments.Drilling.DWPowerLever',data%Equipments%DrillingConsole%DWPowerLever,found)
  56. ! if ( .not. found ) call logg(4,"Not found: DWPowerLever")
  57. ! call jsonfile%get('Equipments.Drilling.TongLever',data%Equipments%DrillingConsole%TongLever,found)
  58. ! if ( .not. found ) call logg(4,"Not found: TongLever")
  59. ! call jsonfile%get('Equipments.Drilling.RTTransmissionLever',data%Equipments%DrillingConsole%RTTransmissionLever,found)
  60. ! if ( .not. found ) call logg(4,"Not found: RTTransmissionLever")
  61. ! call jsonfile%get('Equipments.Drilling.DWClutchLever',data%Equipments%DrillingConsole%DWClutchLever,found)
  62. ! if ( .not. found ) call logg(4,"Not found: DWClutchLever")
  63. ! call jsonfile%get('Equipments.Drilling.EddyBreakLever',data%Equipments%DrillingConsole%EddyBreakLever,found)
  64. ! if ( .not. found ) call logg(4,"Not found: EddyBreakLever")
  65. ! call jsonfile%get('Equipments.Drilling.AutoDW',data%Equipments%DrillingConsole%AutoDW,found)
  66. ! if ( .not. found ) call logg(4,"Not found: AutoDW")
  67. ! call jsonfile%get('Equipments.Drilling.GEN1',data%Equipments%DrillingConsole%GEN1,found)
  68. ! if ( .not. found ) call logg(4,"Not found: GEN1")
  69. ! call jsonfile%get('Equipments.Drilling.GEN2',data%Equipments%DrillingConsole%GEN2,found)
  70. ! if ( .not. found ) call logg(4,"Not found: GEN2")
  71. ! call jsonfile%get('Equipments.Drilling.GEN3',data%Equipments%DrillingConsole%GEN3,found)
  72. ! if ( .not. found ) call logg(4,"Not found: GEN3")
  73. ! call jsonfile%get('Equipments.Drilling.GEN4',data%Equipments%DrillingConsole%GEN4,found)
  74. ! if ( .not. found ) call logg(4,"Not found: GEN4")
  75. ! call jsonfile%get('Equipments.Drilling.Permission_OpenKellyCock',data%Equipments%DrillingConsole%Permission_OpenKellyCock,found)
  76. ! if ( .not. found ) call logg(4,"Not found: Permission_OpenKellyCock")
  77. ! call jsonfile%get('Equipments.Drilling.OpenKellyCock',data%Equipments%DrillingConsole%OpenKellyCock,found)
  78. ! if ( .not. found ) call logg(4,"Not found: OpenKellyCock")
  79. ! call jsonfile%get('Equipments.Drilling.Permission_CloseKellyCock',data%Equipments%DrillingConsole%Permission_CloseKellyCock,found)
  80. ! if ( .not. found ) call logg(4,"Not found: Permission_CloseKellyCock")
  81. ! call jsonfile%get('Equipments.Drilling.CloseKellyCock',data%Equipments%DrillingConsole%CloseKellyCock,found)
  82. ! if ( .not. found ) call logg(4,"Not found: CloseKellyCock")
  83. ! call jsonfile%get('Equipments.Drilling.Permission_OpenSafetyValve',data%Equipments%DrillingConsole%Permission_OpenSafetyValve,found)
  84. ! if ( .not. found ) call logg(4,"Not found: Permission_OpenSafetyValve")
  85. ! call jsonfile%get('Equipments.Drilling.OpenSafetyValve',data%Equipments%DrillingConsole%OpenSafetyValve,found)
  86. ! if ( .not. found ) call logg(4,"Not found: OpenSafetyValve")
  87. ! call jsonfile%get('Equipments.Drilling.Permission_CloseSafetyValve',data%Equipments%DrillingConsole%Permission_CloseSafetyValve,found)
  88. ! if ( .not. found ) call logg(4,"Not found: Permission_CloseSafetyValve")
  89. ! call jsonfile%get('Equipments.Drilling.CloseSafetyValve',data%Equipments%DrillingConsole%CloseSafetyValve,found)
  90. ! if ( .not. found ) call logg(4,"Not found: CloseSafetyValve")
  91. ! call jsonfile%get('Equipments.Drilling.Permission_IRSafetyValve',data%Equipments%DrillingConsole%Permission_IRSafetyValve,found)
  92. ! if ( .not. found ) call logg(4,"Not found: Permission_IRSafetyValve")
  93. ! call jsonfile%get('Equipments.Drilling.IRSafetyValve',data%Equipments%DrillingConsole%IRSafetyValve,found)
  94. ! if ( .not. found ) call logg(4,"Not found: IRSafetyValve")
  95. ! call jsonfile%get('Equipments.Drilling.Permission_IRIBop',data%Equipments%DrillingConsole%Permission_IRIBop,found)
  96. ! if ( .not. found ) call logg(4,"Not found: Permission_IRIBop")
  97. ! call jsonfile%get('Equipments.Drilling.IRIBop',data%Equipments%DrillingConsole%IRIBop,found)
  98. ! if ( .not. found ) call logg(4,"Not found: IRIBop")
  99. ! call jsonfile%get('Equipments.Drilling.LatchPipe',data%Equipments%DrillingConsole%LatchPipe,found)
  100. ! if ( .not. found ) call logg(4,"Not found: LatchPipe")
  101. ! call jsonfile%get('Equipments.Drilling.UnlatchPipe',data%Equipments%DrillingConsole%UnlatchPipe,found)
  102. ! if ( .not. found ) call logg(4,"Not found: UnlatchPipe")
  103. ! call jsonfile%get('Equipments.Drilling.Swing',data%Equipments%DrillingConsole%Swing,found)
  104. ! if ( .not. found ) call logg(4,"Not found: Swing")
  105. ! call jsonfile%get('Equipments.Drilling.FillMouseHole',data%Equipments%DrillingConsole%FillMouseHole,found)
  106. ! if ( .not. found ) call logg(4,"Not found: FillMouseHole")
  107. ! call jsonfile%get('Equipments.Drilling.Slips',data%Equipments%DrillingConsole%Slips,found)
  108. ! if ( .not. found ) call logg(4,"Not found: Slips")
  109. ! call jsonfile%get('Equipments.Drilling.BrakeLeverCoefficient',data%Equipments%DrillingConsole%BrakeLeverCoefficient,found)
  110. ! if ( .not. found ) call logg(4,"Not found: BrakeLeverCoefficient")
  111. ! call jsonfile%get('Equipments.Drilling.HideDrillingBrake',data%Equipments%DrillingConsole%HideDrillingBrake,found)
  112. ! if ( .not. found ) call logg(4,"Not found: HideDrillingBrake")
  113. ! call jsonfile%get('Equipments.Drilling.ParkingBrakeBtn',data%Equipments%DrillingConsole%ParkingBrakeBtn,found)
  114. ! if ( .not. found ) call logg(4,"Not found: ParkingBrakeBtn")
  115. ! call jsonfile%destroy()
  116. ! data%Equipments%DrillingConsole%DWSwitch = -1
  117. data%Equipments%DrillingConsole%AssignmentSwitch = 1
  118. ! data%Equipments%DrillingConsole%MP1CPSwitch = -1
  119. ! data%Equipments%DrillingConsole%MP2Switch = -1
  120. ! data%Equipments%DrillingConsole%RTSwitch = -1
  121. end subroutine
  122. subroutine DrillingConsoleToJson(parent)
  123. type(json_value),pointer :: parent
  124. type(json_core) :: json
  125. type(json_value),pointer :: p
  126. ! 1. create new node
  127. call json%create_object(p,'Drilling')
  128. call json%add(p,"ParkingBrakeLed",data%Equipments%DrillingConsole%ParkingBrakeLed)
  129. call json%add(p,"GEN1LED",data%Equipments%DrillingConsole%GEN1LED)
  130. call json%add(p,"GEN2LED",data%Equipments%DrillingConsole%GEN2LED)
  131. call json%add(p,"GEN3LED",data%Equipments%DrillingConsole%GEN3LED)
  132. call json%add(p,"GEN4LED",data%Equipments%DrillingConsole%GEN4LED)
  133. call json%add(p,"SCR1LED",data%Equipments%DrillingConsole%SCR1LED)
  134. call json%add(p,"SCR2LED",data%Equipments%DrillingConsole%SCR2LED)
  135. call json%add(p,"SCR3LED",data%Equipments%DrillingConsole%SCR3LED)
  136. call json%add(p,"SCR4LED",data%Equipments%DrillingConsole%SCR4LED)
  137. call json%add(p,"MP1BLWR",data%Equipments%DrillingConsole%MP1BLWR)
  138. call json%add(p,"MP2BLWR",data%Equipments%DrillingConsole%MP2BLWR)
  139. call json%add(p,"DWBLWR",data%Equipments%DrillingConsole%DWBLWR)
  140. call json%add(p,"RTBLWR",data%Equipments%DrillingConsole%RTBLWR)
  141. call json%add(p,"PWRLIM",data%Equipments%DrillingConsole%PWRLIM)
  142. call json%add(p,"PWRLIMMTR",data%Equipments%DrillingConsole%PWRLIMMTR)
  143. call json%add(p,"RTTorqueLimitGauge",data%Equipments%DrillingConsole%RTTorqueLimitGauge)
  144. call json%add(p,"AutoDWLED",data%Equipments%DrillingConsole%AutoDWLED)
  145. call json%add(p,"GEN1BTNLED",data%Equipments%DrillingConsole%GEN1BTNLED)
  146. call json%add(p,"GEN2BTNLED",data%Equipments%DrillingConsole%GEN2BTNLED)
  147. call json%add(p,"GEN3BTNLED",data%Equipments%DrillingConsole%GEN3BTNLED)
  148. call json%add(p,"GEN4BTNLED",data%Equipments%DrillingConsole%GEN4BTNLED)
  149. call json%add(p,"OpenKellyCockLed",data%Equipments%DrillingConsole%OpenKellyCockLed)
  150. call json%add(p,"CloseKellyCockLed",data%Equipments%DrillingConsole%CloseKellyCockLed)
  151. call json%add(p,"OpenSafetyValveLed",data%Equipments%DrillingConsole%OpenSafetyValveLed)
  152. call json%add(p,"CloseSafetyValveLed",data%Equipments%DrillingConsole%CloseSafetyValveLed)
  153. call json%add(p,"IRSafetyValveLed",data%Equipments%DrillingConsole%IRSafetyValveLed)
  154. call json%add(p,"IRIBopLed",data%Equipments%DrillingConsole%IRIBopLed)
  155. call json%add(p,"LatchPipeLED",data%Equipments%DrillingConsole%LatchPipeLED)
  156. call json%add(p,"UnlatchPipeLED",data%Equipments%DrillingConsole%UnlatchPipeLED)
  157. call json%add(p,"SwingLed",data%Equipments%DrillingConsole%SwingLed)
  158. call json%add(p,"FillMouseHoleLed",data%Equipments%DrillingConsole%FillMouseHoleLed)
  159. call json%add(p,"MP1CPSwitch",data%Equipments%DrillingConsole%MP1CPSwitch)
  160. call json%add(p,"MP2Switch",data%Equipments%DrillingConsole%MP2Switch)
  161. call json%add(p,"DWSwitch",data%Equipments%DrillingConsole%DWSwitch)
  162. call json%add(p,"RTSwitch",data%Equipments%DrillingConsole%RTSwitch)
  163. call json%add(p,"RTSwitch",data%Equipments%DrillingConsole%RTSwitch)
  164. ! Trottle -------------
  165. call json%add(p,"MP1Throttle",data%Equipments%DrillingConsole%MP1Throttle)
  166. call json%add(p,"MP2Throttle",data%Equipments%DrillingConsole%MP2Throttle)
  167. call json%add(p,"RTThrottle",data%Equipments%DrillingConsole%RTThrottle)
  168. call json%add(p,"DWThrottle",data%Equipments%DrillingConsole%DWThrottle)
  169. call json%add(parent,p)
  170. end subroutine
  171. subroutine SetTongLever(v) bind(C,name="setTongLever")
  172. use CTongEnum
  173. use ISO_C_BINDING, only:c_int
  174. integer(c_int), intent(in) :: v
  175. if(v == 1) then
  176. call ButtonPress_Breakout_TongNotification()
  177. if(print_log) print*, 'BreakoutLeverPress'
  178. endif
  179. if(v == -1) then
  180. call ButtonPress_Makeup_TongNotification()
  181. if(print_log) print*, 'MakeupLeverPress'
  182. endif
  183. if(print_log) print*, 'TongLever=', v
  184. end subroutine
  185. end module CDrillingConsole