# 1 "/home/admin/SimulationCore2/Equipments/RotaryTable/RTable_Inputs.f90" subroutine RTable_INPUTS use CDrillingConsoleVariables use SimulationVariables use UnitySignalsModule use CHoistingVariables use TD_DrillStemComponents use UnityModule use CWarnings use UnitySignalVariables IMPLICIT NONE integer :: i data%State%RTable%AssignmentSwitch = data%Equipments%DrillingConsole%AssignmentSwitch data%State%RTable%Switch = data%Equipments%DrillingConsole%RTSwitch !data%State%RTable%GearsAbuse = RotaryGearsAbuse data%State%RTable%Throttle = data%Equipments%DrillingConsole%RTThrottle ![RPM] 0 [lb.in] ????????? !data%State%RTable%RpmGaugeMalf !:dar module haye C meghdardehi mishe data%State%RTable%N_new = data%State%RTable%Throttle if ( data%State%RTable%MotorFaileMalf==1 ) then data%State%RTable%N_new = 0.d0 end if data%State%RTable%String_Torque = 0.112984d0*data%State%RTable%String_Torque ![N.m] !===> String_JCoef Calculation if ( data%Configuration%Hoisting%DriveType==0 ) then if ( Get_TdsConnectionModes()==TDS_CONNECTION_NOTHING .and. Get_TdsElevatorModes()==TDS_ELEVATOR_CONNECTION_NOTHING ) then data%State%RTable%RotaryMode = 1 data%State%RTable%String_JCoef = 0.d0 Do i = 1,data%State%TD_String%StringConfigurationCount data%State%RTable%String_JCoef = data%State%RTable%String_JCoef+( (data%State%TD_DrillStem(i)%TotalWeight*((data%State%TD_DrillStem(i)%Id**2.d0)+(data%State%TD_DrillStem(i)%Od**2.d0)))/8.d0 ) ![lb.ft^2] , Jz=(1/2)*m*(r1^2+r2^2) End Do data%State%RTable%String_JCoef = data%State%RTable%String_JCoef*0.0421401d0 ![kg.m^2] else if ( Get_Slips() /= SLIPS_SET_END ) then data%State%RTable%RotaryMode = 2 data%State%RTable%String_JCoef = 0.d0 data%State%RTable%String_Torque = 0.d0 else data%State%RTable%RotaryMode = 3 data%State%RTable%String_JCoef = 0.d0 data%State%RTable%String_Torque = 0.d0 end if else if ( data%Configuration%Hoisting%DriveType==1 ) then if ( Get_IsKellyBushingSetInTable() .or. Get_Slips() == SLIPS_SET_END ) then !if rotary connected to string data%State%RTable%RotaryMode = 4 data%State%RTable%String_JCoef = 0.d0 Do i = 1,data%State%TD_String%StringConfigurationCount data%State%RTable%String_JCoef = data%State%RTable%String_JCoef+( (data%State%TD_DrillStem(i)%TotalWeight*((data%State%TD_DrillStem(i)%Id**2.d0)+(data%State%TD_DrillStem(i)%Od**2.d0)))/8.d0 ) ![lb.ft^2] , Jz=(1/2)*m*(r1^2+r2^2) End Do data%State%RTable%String_JCoef = data%State%RTable%String_JCoef*0.0421401e0 ![kg.m^2] else data%State%RTable%RotaryMode = 5 data%State%RTable%String_JCoef = 0.d0 data%State%RTable%String_Torque = 0.d0 end if end if end subroutine RTable_INPUTS