|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517 |
- SUBROUTINE Utube2_and_TripIn ! is called in subroutine CirculationCodeSelect annulus to string
-
- Use UTUBEVARS
- Use GeoElements_FluidModule
- USE CMudPropertiesVariables
- USE MudSystemVARIABLES
- USE Pumps_VARIABLES
- use CDrillWatchVariables
- !use CTanksVariables, TripTankVolume2 => DrillingWatch%TripTankVolume, TripTankDensity2 => TripTankDensity
- Use CShoeVariables
-
- implicit none
-
- write(*,*) 'Utube2 code'
-
- !===========================================================WELL============================================================
- !===========================================================WELL============================================================
-
- MudSystemDotUtubeMode2Activated= .true.
- write(*,*) 'QUtubeOutput=' , QUtubeOutput
- !QUTubeInput=5000.
- MudSystemDotStringFlowRate= QUtubeOutput ! (gpm)
- MudSystemDotAnnulusFlowRate= QUtubeOutput
- MudSystemDotStringFlowRateFinal= MudSystemDotStringFlowRate
- MudSystemDotAnnulusFlowRateFinal= MudSystemDotAnnulusFlowRate
- !===========================================
-
- if (MudSystemDotFirstSetUtube2==0) then
- ! call St_MudDischarged_Volume%AddToFirst (REAL(sum(F_Interval(1:F_StringIntervalCounts)%Volume))) !startup initial
- ! call St_Mud_Backhead_X%AddToFirst (Xstart_PipeSection(1))
- ! call St_Mud_Backhead_section%AddToFirst (1)
- ! call St_Mud_Forehead_X%AddToFirst (Xend_PipeSection(F_StringIntervalCounts))
- ! call St_Mud_Forehead_section%AddToFirst (F_StringIntervalCounts)
- ! call St_Density%AddToFirst (REAL(ActiveDensity)) ! initial(ppg)
- ! call St_RemainedVolume_in_LastSection%AddToFirst (0.0d0)
- ! call St_EmptyVolume_inBackheadLocation%AddToFirst (0.0d0)
- !
- ! call Ann_MudDischarged_Volume%AddToFirst (REAL(sum(F_Interval((F_StringIntervalCounts+F_BottomHoleIntervalCounts+1):F_IntervalsTotalCounts)%Volume))) !startup initial
- ! call Ann_Mud_Backhead_X%AddToFirst (Xstart_PipeSection(F_StringIntervalCounts+1))
- ! call Ann_Mud_Backhead_section%AddToFirst (F_StringIntervalCounts+1)
- ! call Ann_Mud_Forehead_X%AddToFirst (Xend_PipeSection(NoPipeSections))
- ! call Ann_Mud_Forehead_section%AddToFirst (NoPipeSections)
- ! call Ann_Density%AddToFirst (REAL(ActiveDensity)) ! initial(ppg)
- ! call Ann_RemainedVolume_in_LastSection%AddToFirst (0.0d0)
- ! call Ann_EmptyVolume_inBackheadLocation%AddToFirst (0.0d0)
- !Hz_Density%Array(:)= 0.0
- !Hz_MudOrKick%Array(:)= 104
-
- MudSystemDotHz_Density_Utube= 0.0
- MudSystemDotHz_MudOrKick_Utube= 104
-
- MudSystemDotFirstSetUtube2= 1
- endif
-
-
-
-
- !========================Horizontal PIPE ENTRANCE=================
-
- !if (SuctionDensity_Old >= (ActiveDensity+0.05) .or. SuctionDensity_Old <= (ActiveDensity-0.05)) then ! new mud is pumped
- ! !ImudCount= ImudCount+1
- ! !SuctionMud= ImudCount
- ! call Hz_Density%AddToFirst (REAL(ActiveDensity)) !ActiveDensity : badan in moteghayer bayad avaz beshe
- ! call Hz_MudDischarged_Volume%AddToFirst (0.0d0)
- ! call Hz_Mud_Forehead_X%AddToFirst (Xstart_PipeSection(1))
- ! call Hz_Mud_Forehead_section%AddToFirst (1)
- ! call Hz_Mud_Backhead_X%AddToFirst (Xstart_PipeSection(1))
- ! call Hz_Mud_Backhead_section%AddToFirst (1)
- ! call Hz_RemainedVolume_in_LastSection%AddToFirst (0.0d0)
- ! call Hz_EmptyVolume_inBackheadLocation%AddToFirst (0.0d0)
- ! call Hz_MudOrKick%AddToFirst (0)
-
- ! deltaV= 0.
- !
- ! SuctionDensity_Old= ActiveDensity
- !endif
-
- !========================Horizontal PIPE STRING=================
-
- !commented
-
- ! Hz_MudDischarged_Volume%Array(1)= Hz_MudDischarged_Volume%Array(1)+ ((StringFlowRate/60.)*DeltaT_Mudline) !(gal)
- !
- !imud=0
- ! do while (imud < Hz_Mud_Forehead_X%Length())
- ! imud = imud + 1
- !
- ! if (imud> 1) then
- ! Hz_Mud_Backhead_X%Array(imud)= Hz_Mud_Forehead_X%Array(imud-1)
- ! Hz_Mud_Backhead_section%Array(imud)= Hz_Mud_Forehead_section%Array(imud-1)
- ! endif
- !
- !
- ! DirectionCoef= (Xend_PipeSection(Hz_Mud_Backhead_section%Array(imud))-Xstart_PipeSection(Hz_Mud_Backhead_section%Array(imud))) &
- ! / ABS(Xend_PipeSection(Hz_Mud_Backhead_section%Array(imud))-Xstart_PipeSection(Hz_Mud_Backhead_section%Array(imud)))
- ! ! +1 for string , -1 for annulus
- !
- !
- ! Hz_EmptyVolume_inBackheadLocation%Array(imud)= DirectionCoef* (Xend_PipeSection(Hz_Mud_Backhead_section%Array(imud))- Hz_Mud_Backhead_X%Array(imud))* &
- ! Area_PipeSectionFt(Hz_Mud_Backhead_section%Array(imud)) !(ft^3)
- ! Hz_EmptyVolume_inBackheadLocation%Array(imud)= Hz_EmptyVolume_inBackheadLocation%Array(imud)* 7.48051948 ! ft^3 to gal
- !
- !
- ! if ( Hz_MudDischarged_Volume%Array(imud) <= Hz_EmptyVolume_inBackheadLocation%Array(imud)) then
- ! Hz_Mud_Forehead_section%Array(imud)= Hz_Mud_Backhead_section%Array(imud)
- ! Hz_Mud_Forehead_X%Array(imud)= Hz_Mud_Backhead_X%Array(imud)+ DirectionCoef*(Hz_MudDischarged_Volume%Array(imud)/7.48051948)/Area_PipeSectionFt(Hz_Mud_Backhead_section%Array(imud))
- ! ! 7.48051948 is for gal to ft^3
- ! else
- !
- ! isection= Hz_Mud_Backhead_section%Array(imud)+1
- ! Hz_RemainedVolume_in_LastSection%Array(imud)= Hz_MudDischarged_Volume%Array(imud)- Hz_EmptyVolume_inBackheadLocation%Array(imud)
- !
- ! do
- ! if (isection > 1) then ! (horizontal pipe exit)
- ! Hz_MudDischarged_Volume%Array(imud)= Hz_MudDischarged_Volume%Array(imud)- Hz_RemainedVolume_in_LastSection%Array(imud)
- ! Hz_Mud_Forehead_X%Array(imud)= Xend_PipeSection(1)
- ! Hz_Mud_Forehead_section%Array(imud)= 1
- ! if (Hz_MudDischarged_Volume%Array(imud)<= 0.0d0) then ! imud is completely exited form the string
- ! call Hz_MudDischarged_Volume%Remove (imud)
- ! call Hz_Mud_Backhead_X%Remove (imud)
- ! call Hz_Mud_Backhead_section%Remove (imud)
- ! call Hz_Mud_Forehead_X%Remove (imud)
- ! call Hz_Mud_Forehead_section%Remove (imud)
- ! call Hz_Density%Remove (imud)
- ! call Hz_RemainedVolume_in_LastSection%Remove (imud)
- ! call Hz_EmptyVolume_inBackheadLocation%Remove (imud)
- ! call Hz_MudOrKick%Remove (imud)
- ! endif
- ! exit
- ! endif
- !
- ! xx= Hz_RemainedVolume_in_LastSection%Array(imud)/ PipeSection_VolumeCapacity(isection) !(gal)
- !
- ! if (xx<= 1.0) then
- ! Hz_Mud_Forehead_section%Array(imud)= isection
- ! Hz_Mud_Forehead_X%Array(imud)= (xx * (Xend_PipeSection(isection)- Xstart_PipeSection(isection)))+ Xstart_PipeSection(isection)
- ! exit
- ! else
- ! Hz_RemainedVolume_in_LastSection%Array(imud)= Hz_RemainedVolume_in_LastSection%Array(imud)- PipeSection_VolumeCapacity(isection)
- ! isection= isection+ 1
- !
- !
- ! endif
- !
- ! enddo
- !
- ! endif
- !
- ! enddo
-
- !commented
-
- !========================Horizontal PIPE END=================
-
- !========================ANNULUS ENTRANCE====================
-
- if (ABS(AnnulusSuctionDensity_Old - MudSystemDotHz_Density_Utube) >= MudSystemDotDensityMixTol ) then ! new mud is pumped
- call Ann_Density%Add (MudSystemDotHz_Density_Utube)
- call MudSystemDotAnn_MudDischarged_Volume%Add (0.0d0)
- call Ann_Mud_Forehead_X%Add (MudSystemDotXend_PipeSection(MudSystemDotNoPipeSections))
- call Ann_Mud_Forehead_section%Add (MudSystemDotNoPipeSections)
- call Ann_Mud_Backhead_X%Add (MudSystemDotXstart_PipeSection(MudSystemDotNoPipeSections))
- call Ann_Mud_Backhead_section%Add (MudSystemDotNoPipeSections)
- call Ann_RemainedVolume_in_LastSection%Add (0.0d0)
- call Ann_EmptyVolume_inBackheadLocation%Add (0.0d0)
- call Ann_MudOrKick%Add (MudSystemDotHz_MudOrKick_Utube) ! Hz_MudOrKick%Last() = 104
- call Ann_CuttingMud%Add (0)
-
- AnnulusSuctionDensity_Old= MudSystemDotHz_Density_Utube
- endif
-
- !========================ANNULUS====================
-
- MudSystemDotAnn_MudDischarged_Volume%Array(MudSystemDotAnn_MudDischarged_Volume%Length())= MudSystemDotAnn_MudDischarged_Volume%Last()+ ((MudSystemDotAnnulusFlowRate/60.)*DeltaT_Mudline) !(gal)
-
- MudSystemDotimud= Ann_Mud_Forehead_X%Length() + 1
-
- do while (MudSystemDotimud > 1)
- MudSystemDotimud = MudSystemDotimud - 1
-
- if (MudSystemDotimud< Ann_Mud_Forehead_X%Length()) then
- Ann_Mud_Forehead_X%Array(MudSystemDotimud)= Ann_Mud_Backhead_X%Array(MudSystemDotimud+1)
- Ann_Mud_Forehead_section%Array(MudSystemDotimud)= Ann_Mud_Backhead_section%Array(MudSystemDotimud+1)
- endif
-
- ! <<< Fracture Shoe Lost
- IF ( MudSystemDotShoeLost .and. MudSystemDotLostInTripOutIsDone== .false. .and. Shoe%ShoeDepth < Ann_Mud_Backhead_X%Array(MudSystemDotimud) .and. Shoe%ShoeDepth >= Ann_Mud_Forehead_X%Array(MudSystemDotimud) ) then
- !write(*,*) 'ShoeLost imud,AnnVolume(imud), VolumeLost:' , imud,Ann_MudDischarged_Volume%Array(imud), (( Qlost/60.0d0)*DeltaT_Mudline)
- MudSystemDotAnn_MudDischarged_Volume%Array(MudSystemDotimud)= MudSystemDotAnn_MudDischarged_Volume%Array(MudSystemDotimud)-((MudSystemDotQlost/60.0d0)*DeltaT_Mudline) !(gal)
- if (MudSystemDotAnn_MudDischarged_Volume%Array(MudSystemDotimud) < 0.0) then
- !write(*,*) 'mud is removed by shoe lost, imud=' , imud
- call RemoveAnnulusMudArrays(MudSystemDotimud)
- MudSystemDotimud= MudSystemDotimud-1
- cycle
- endif
- ENDIF
- ! Fracture Shoe Lost >>>
-
-
- MudSystemDotDirectionCoef= (MudSystemDotXend_PipeSection(Ann_Mud_Forehead_section%Array(MudSystemDotimud))-MudSystemDotXstart_PipeSection(Ann_Mud_Forehead_section%Array(MudSystemDotimud))) &
- / ABS(MudSystemDotXend_PipeSection(Ann_Mud_Forehead_section%Array(MudSystemDotimud))-MudSystemDotXstart_PipeSection(Ann_Mud_Forehead_section%Array(MudSystemDotimud)))
- ! +1 for string , -1 for annulus
-
-
- Ann_EmptyVolume_inBackheadLocation%Array(MudSystemDotimud)= MudSystemDotDirectionCoef* (Ann_Mud_Forehead_X%Array(MudSystemDotimud)- MudSystemDotXstart_PipeSection(Ann_Mud_Forehead_section%Array(MudSystemDotimud)))* &
- MudSystemDotArea_PipeSectionFt(Ann_Mud_Forehead_section%Array(MudSystemDotimud)) !(ft^3)
- Ann_EmptyVolume_inBackheadLocation%Array(MudSystemDotimud)= Ann_EmptyVolume_inBackheadLocation%Array(MudSystemDotimud)* 7.48051948d0 ! ft^3 to gal
-
-
- if ( MudSystemDotAnn_MudDischarged_Volume%Array(MudSystemDotimud) <= Ann_EmptyVolume_inBackheadLocation%Array(MudSystemDotimud)) then
- Ann_Mud_Backhead_section%Array(MudSystemDotimud)= Ann_Mud_Forehead_section%Array(MudSystemDotimud)
- Ann_Mud_Backhead_X%Array(MudSystemDotimud)= Ann_Mud_Forehead_X%Array(MudSystemDotimud)- MudSystemDotDirectionCoef*(MudSystemDotAnn_MudDischarged_Volume%Array(MudSystemDotimud)/7.48051948d0)/MudSystemDotArea_PipeSectionFt(Ann_Mud_Forehead_section%Array(MudSystemDotimud))
- ! 7.48051948 is for gal to ft^3
- else
-
- MudSystemDotisection= Ann_Mud_Forehead_section%Array(MudSystemDotimud)-1
- Ann_RemainedVolume_in_LastSection%Array(MudSystemDotimud)= MudSystemDotAnn_MudDischarged_Volume%Array(MudSystemDotimud)- Ann_EmptyVolume_inBackheadLocation%Array(MudSystemDotimud)
-
- do
- if (MudSystemDotisection < F_StringIntervalCounts+1) then ! last pipe section(well exit) F_StringIntervalCounts+1 is the first section in Annulus
- MudSystemDotAnn_MudDischarged_Volume%Array(MudSystemDotimud)= MudSystemDotAnn_MudDischarged_Volume%Array(MudSystemDotimud)- Ann_RemainedVolume_in_LastSection%Array(MudSystemDotimud)
- Ann_Mud_Backhead_X%Array(MudSystemDotimud)= MudSystemDotXstart_PipeSection(F_StringIntervalCounts+1)
- Ann_Mud_Backhead_section%Array(MudSystemDotimud)= F_StringIntervalCounts+1
-
- if (MudSystemDotAnn_MudDischarged_Volume%Array(MudSystemDotimud)<= 0.0d0) then ! imud is completely exited form the well
- call RemoveAnnulusMudArrays(MudSystemDotimud)
- endif
-
- exit
- endif
-
- MudSystemDotxx= Ann_RemainedVolume_in_LastSection%Array(MudSystemDotimud)/ MudSystemDotPipeSection_VolumeCapacity(MudSystemDotisection) !(gal)
-
- if (MudSystemDotxx<= 1.0) then
- Ann_Mud_Backhead_section%Array(MudSystemDotimud)= MudSystemDotisection
- Ann_Mud_Backhead_X%Array(MudSystemDotimud)= (MudSystemDotxx * (MudSystemDotXstart_PipeSection(MudSystemDotisection)- MudSystemDotXend_PipeSection(MudSystemDotisection)))+ MudSystemDotXend_PipeSection(MudSystemDotisection)
- exit
- else
- Ann_RemainedVolume_in_LastSection%Array(MudSystemDotimud)= Ann_RemainedVolume_in_LastSection%Array(MudSystemDotimud)- MudSystemDotPipeSection_VolumeCapacity(MudSystemDotisection)
- MudSystemDotisection= MudSystemDotisection- 1
-
-
- endif
-
- enddo
-
- endif
-
- enddo
- !========================ANNULUS END=================
-
- !========================== tripping in for OP remove ===============================
-
- !if (DeltaVolumeOp>0. .and. DeltaVolumeOp< Op_MudDischarged_Volume%Last()) then
- ! Op_MudDischarged_Volume%Array(Op_MudDischarged_Volume%Length())= Op_MudDischarged_Volume%Array(Op_MudDischarged_Volume%Length()) - DeltaVolumeOp
- !else
- ! Op_MudDischarged_Volume%Array(Op_MudDischarged_Volume%Length()-1)= Op_MudDischarged_Volume%Array(Op_MudDischarged_Volume%Length()-1) - (DeltaVolumeOp-Op_MudDischarged_Volume%Last())
- !
- ! call Op_MudDischarged_Volume%Remove (Op_MudDischarged_Volume%Length())
- ! call Op_Mud_Backhead_X%Remove (Op_MudDischarged_Volume%Length())
- ! call Op_Mud_Backhead_section%Remove (Op_MudDischarged_Volume%Length())
- ! call Op_Mud_Forehead_X%Remove (Op_MudDischarged_Volume%Length())
- ! call Op_Mud_Forehead_section%Remove (Op_MudDischarged_Volume%Length())
- ! call Op_Density%Remove (Op_MudDischarged_Volume%Length())
- ! call Op_RemainedVolume_in_LastSection%Remove (Op_MudDischarged_Volume%Length())
- ! call Op_EmptyVolume_inBackheadLocation%Remove (Op_MudDischarged_Volume%Length())
- ! call Op_MudOrKick%Remove (Op_MudDischarged_Volume%Length())
- !endif
- !
-
- !============================= Bottom Hole ==============================
-
- !Op_MudDischarged_Volume%Array(1)= Op_MudDischarged_Volume%Array(1)+ ((GasKickPumpFlowRate/60.)*DeltaT_Mudline) !(gal) due to KickFlux
- MudSystemDotimud=0
- do while (MudSystemDotimud < MudSystemDotOp_Mud_Forehead_X%Length())
- MudSystemDotimud = MudSystemDotimud + 1
-
- if (MudSystemDotimud> 1) then
- MudSystemDotOp_Mud_Backhead_X%Array(MudSystemDotimud)= MudSystemDotOp_Mud_Forehead_X%Array(MudSystemDotimud-1)
- Op_Mud_Backhead_section%Array(MudSystemDotimud)= Op_Mud_Forehead_section%Array(MudSystemDotimud-1)
- endif
-
-
- MudSystemDotDirectionCoef= (MudSystemDotXend_OpSection(Op_Mud_Backhead_section%Array(MudSystemDotimud))-MudSystemDotXstart_OpSection(Op_Mud_Backhead_section%Array(MudSystemDotimud))) &
- / ABS(MudSystemDotXend_OpSection(Op_Mud_Backhead_section%Array(MudSystemDotimud))-MudSystemDotXstart_OpSection(Op_Mud_Backhead_section%Array(MudSystemDotimud)))
- ! +1 for string , -1 for annulus
-
-
-
- MudSystemDotOp_EmptyVolume_inBackheadLocation%Array(MudSystemDotimud)= MudSystemDotDirectionCoef* (MudSystemDotXend_OpSection(Op_Mud_Backhead_section%Array(MudSystemDotimud))- MudSystemDotOp_Mud_Backhead_X%Array(MudSystemDotimud))* &
- MudSystemDotArea_OpSectionFt(Op_Mud_Backhead_section%Array(MudSystemDotimud)) !(ft^3)
- MudSystemDotOp_EmptyVolume_inBackheadLocation%Array(MudSystemDotimud)= MudSystemDotOp_EmptyVolume_inBackheadLocation%Array(MudSystemDotimud)* 7.48051948d0 ! ft^3 to gal
-
-
- if ( MudSystemDotOp_MudDischarged_Volume%Array(MudSystemDotimud) <= MudSystemDotOp_EmptyVolume_inBackheadLocation%Array(MudSystemDotimud)) then
- Op_Mud_Forehead_section%Array(MudSystemDotimud)= Op_Mud_Backhead_section%Array(MudSystemDotimud)
- MudSystemDotOp_Mud_Forehead_X%Array(MudSystemDotimud)= MudSystemDotOp_Mud_Backhead_X%Array(MudSystemDotimud)+ MudSystemDotDirectionCoef*(MudSystemDotOp_MudDischarged_Volume%Array(MudSystemDotimud)/7.48051948d0)/MudSystemDotArea_OpSectionFt(Op_Mud_Backhead_section%Array(MudSystemDotimud))
- ! 7.48051948 is for gal to ft^3
-
- else
-
- MudSystemDotisection= Op_Mud_Backhead_section%Array(MudSystemDotimud)+1
- MudSystemDotOp_RemainedVolume_in_LastSection%Array(MudSystemDotimud)= MudSystemDotOp_MudDischarged_Volume%Array(MudSystemDotimud)- MudSystemDotOp_EmptyVolume_inBackheadLocation%Array(MudSystemDotimud)
-
- do
- if (MudSystemDotisection > F_BottomHoleIntervalCounts) then ! last pipe section(well exit)
- if( MudSystemDotimud==1) MudSystemDotKickDeltaVinAnnulus= MudSystemDotOp_RemainedVolume_in_LastSection%Array(MudSystemDotimud) ! Kick enters Annulus space
- MudSystemDotOp_MudDischarged_Volume%Array(MudSystemDotimud)= MudSystemDotOp_MudDischarged_Volume%Array(MudSystemDotimud)- MudSystemDotOp_RemainedVolume_in_LastSection%Array(MudSystemDotimud)
- MudSystemDotOp_Mud_Forehead_X%Array(MudSystemDotimud)= MudSystemDotXend_OpSection(F_BottomHoleIntervalCounts)
- Op_Mud_Forehead_section%Array(MudSystemDotimud)= F_BottomHoleIntervalCounts
-
- if (MudSystemDotOp_MudDischarged_Volume%Array(MudSystemDotimud)<= 0.0d0) then ! imud is completely exited form the well
- call RemoveOpMudArrays(MudSystemDotimud)
- endif
-
- exit
- endif
-
- MudSystemDotxx= MudSystemDotOp_RemainedVolume_in_LastSection%Array(MudSystemDotimud)/ MudSystemDotOpSection_VolumeCapacity(MudSystemDotisection) !(gal)
-
- if (MudSystemDotxx<= 1.0) then
- Op_Mud_Forehead_section%Array(MudSystemDotimud)= MudSystemDotisection
- MudSystemDotOp_Mud_Forehead_X%Array(MudSystemDotimud)= (MudSystemDotxx * (MudSystemDotXend_OpSection(MudSystemDotisection)- MudSystemDotXstart_OpSection(MudSystemDotisection)))+ MudSystemDotXstart_OpSection(MudSystemDotisection)
- exit
- else
- MudSystemDotOp_RemainedVolume_in_LastSection%Array(MudSystemDotimud)= MudSystemDotOp_RemainedVolume_in_LastSection%Array(MudSystemDotimud)- MudSystemDotOpSection_VolumeCapacity(MudSystemDotisection)
- MudSystemDotisection= MudSystemDotisection+ 1
-
- endif
-
- enddo
-
- endif
-
- if (MudSystemDotOp_Mud_Forehead_X%Array(MudSystemDotimud)== MudSystemDotXend_OpSection(F_BottomHoleIntervalCounts)) then
- MudSystemDottotalLength = MudSystemDotOp_MudDischarged_Volume%Length()
- do while(MudSystemDotimud < MudSystemDottotalLength)
-
- !imud = imud + 1
- call RemoveOpMudArrays(MudSystemDottotalLength)
- MudSystemDottotalLength = MudSystemDottotalLength - 1
-
-
- enddo
-
- exit !
-
- endif
-
- !WRITE(*,*) imud,'Op_MudDischarged_Volume%Array(imud)' , Op_MudDischarged_Volume%Array(imud), Op_Density%Array(imud)
-
-
-
-
-
-
- enddo
-
-
- !write(*,*) 'Op_Mud_Forehead_X%Length()' , Op_Mud_Forehead_X%Length()
- !
- ! WRITE(*,*) 'Xend_PipeSection(F_StringIntervalCounts)' , Xend_PipeSection(F_StringIntervalCounts)
- ! WRITE(*,*) 'Op_Mud_Backhead_X%Array(1)' , Op_Mud_Backhead_X%Array(1)
- ! WRITE(*,*) 'Op_Mud_Forehead_X%Array(1)' , Op_Mud_Forehead_X%Array(1)
- ! WRITE(*,*) 'Op_Mud_Backhead_X%Array(2)' , Op_Mud_Backhead_X%Array(2)
- ! WRITE(*,*) 'Op_Mud_Forehead_X%Array(2)' , Op_Mud_Forehead_X%Array(2)
- !========================Bottom Hole END=================
-
-
-
-
- ! NO KICK
-
-
-
- !========================STRING ENTRANCE=================
-
- if ((ABS(St_Density%Last() - Ann_Density%First()) >= MudSystemDotDensityMixTol) .OR. (MudSystemDotDeltaVolumeOp == 0.0 .and. St_Density%Last() /= Ann_Density%Array(1) .and. MudSystemDotStringFlowRate/=0.0d0)) then ! new mud is pumped
-
- !if ((ABS(StringDensity_Old - Ann_Density%First()) >= DensityMixTol) .OR. (DeltaVolumeOp == 0.0 .and. St_Density%Last() /= Ann_Density%Array(1) .and. StringFlowRate/=0.0d0)) then ! new mud is pumped
- call St_Density%Add (Ann_Density%First())
- call MudSystemDotSt_MudDischarged_Volume%Add (0.0d0)
- call MudSystemDotSt_Mud_Forehead_X%Add (MudSystemDotXend_PipeSection(F_StringIntervalCounts))
- call St_Mud_Forehead_section%Add (F_StringIntervalCounts)
- call MudSystemDotSt_Mud_Backhead_X%Add (MudSystemDotXstart_PipeSection(F_StringIntervalCounts))
- call St_Mud_Backhead_section%Add (F_StringIntervalCounts)
- call MudSystemDotSt_RemainedVolume_in_LastSection%Add (0.0d0)
- call MudSystemDotSt_EmptyVolume_inBackheadLocation%Add (0.0d0)
- call St_MudOrKick%Add (0)
-
- !StringDensity_Old= Ann_Density%First()
-
- MudSystemDotMudIsChanged= .true.
- endif
-
- MudSystemDotSt_MudDischarged_Volume%Array(MudSystemDotSt_MudDischarged_Volume%Length())= MudSystemDotSt_MudDischarged_Volume%Last()+ ((MudSystemDotStringFlowRate/60.0d0)*DeltaT_Mudline) !(gal)
-
- !========================Tripping In====================
-
- !write(*,*) 'DeltaVolumeOp=' , DeltaVolumeOp
- write(*,*) 'DeltaVolumeOp=' , MudSystemDotDeltaVolumeOp
- if (MudSystemDotDeltaVolumeOp > 0.0 .and. MudSystemDotMudIsChanged== .false.) then !.and. DrillingMode== .false.) then ! trip in mode(loole paeen)
-
- !write(*,*) 'Tripping In'
-
- NewDensity= (Ann_Density%First()*((MudSystemDotStringFlowRate/60.0d0)*DeltaT_Mudline)+MudSystemDotOp_Density%Last()*MudSystemDotDeltaVolumeOp)/(((MudSystemDotStringFlowRate/60.0d0)*DeltaT_Mudline)+MudSystemDotDeltaVolumeOp)
- MudSystemDotNewVolume= ((MudSystemDotStringFlowRate/60.0d0)*DeltaT_Mudline)+MudSystemDotDeltaVolumeOp
-
- !write(*,*) 'St_MudDischarged_Volume%Last()=', St_MudDischarged_Volume%Last(), 'NewVolume=', NewVolume
-
- if (abs(St_Density%Last()-NewDensity)< MudSystemDotDensityMixTol) then ! .OR. (St_MudDischarged_Volume%Last()< 42.) ) then !+ NewVolume)< 42.) then ! 1-Pockets are Merged
- St_Density%Array(St_Density%Length())= (St_Density%Last()*MudSystemDotSt_MudDischarged_Volume%Last()+NewDensity*MudSystemDotNewVolume)/(MudSystemDotSt_MudDischarged_Volume%Last()+MudSystemDotNewVolume)
- MudSystemDotSt_MudDischarged_Volume%Array(St_Density%Length())= MudSystemDotSt_MudDischarged_Volume%Last()+MudSystemDotDeltaVolumeOp
- MudSystemDotSt_Mud_Forehead_X%Array(St_Density%Length())= (MudSystemDotXend_PipeSection(F_StringIntervalCounts))
- St_Mud_Forehead_section%Array(St_Density%Length())= (F_StringIntervalCounts)
- MudSystemDotSt_Mud_Backhead_X%Array(St_Density%Length())= (MudSystemDotXstart_PipeSection(F_StringIntervalCounts))
- St_Mud_Backhead_section%Array(St_Density%Length())= (F_StringIntervalCounts)
- MudSystemDotSt_RemainedVolume_in_LastSection%Array(St_Density%Length())= (0.0d0)
- MudSystemDotSt_EmptyVolume_inBackheadLocation%Array(St_Density%Length())= (0.0d0)
- else ! 2-Merging conditions are not meeted, so new pocket
- call St_Density%Add (NewDensity)
- call MudSystemDotSt_MudDischarged_Volume%Add (MudSystemDotNewVolume)
- call MudSystemDotSt_Mud_Forehead_X%Add (MudSystemDotXend_PipeSection(F_StringIntervalCounts))
- call St_Mud_Forehead_section%Add (F_StringIntervalCounts)
- call MudSystemDotSt_Mud_Backhead_X%Add (MudSystemDotXstart_PipeSection(F_StringIntervalCounts))
- call St_Mud_Backhead_section%Add (F_StringIntervalCounts)
- call MudSystemDotSt_RemainedVolume_in_LastSection%Add (0.0d0)
- call MudSystemDotSt_EmptyVolume_inBackheadLocation%Add (0.0d0)
- call St_MudOrKick%Add (0)
- endif
-
-
- elseif (MudSystemDotDeltaVolumeOp > 0.0 .and. MudSystemDotMudIsChanged== .true.) then
- St_Density%Array(St_Density%Length())= NewDensity
- MudSystemDotSt_MudDischarged_Volume%Array(St_Density%Length())= MudSystemDotNewVolume
- MudSystemDotSt_Mud_Forehead_X%Array(St_Density%Length())= (MudSystemDotXend_PipeSection(F_StringIntervalCounts))
- St_Mud_Forehead_section%Array(St_Density%Length())= (F_StringIntervalCounts)
- MudSystemDotSt_Mud_Backhead_X%Array(St_Density%Length())= (MudSystemDotXstart_PipeSection(F_StringIntervalCounts))
- St_Mud_Backhead_section%Array(St_Density%Length())= (F_StringIntervalCounts)
- MudSystemDotSt_RemainedVolume_in_LastSection%Array(St_Density%Length())= (0.0d0)
- MudSystemDotSt_EmptyVolume_inBackheadLocation%Array(St_Density%Length())= (0.0d0)
- endif
-
-
- !========================Tripping In - End====================
-
-
- !======================== STRING ====================
-
- MudSystemDotMudIsChanged= .false.
-
- MudSystemDotimud= MudSystemDotSt_Mud_Forehead_X%Length() + 1
-
- do while (MudSystemDotimud > 1)
- MudSystemDotimud = MudSystemDotimud - 1
-
- if (MudSystemDotimud< MudSystemDotSt_Mud_Forehead_X%Length()) then
- MudSystemDotSt_Mud_Forehead_X%Array(MudSystemDotimud)= MudSystemDotSt_Mud_Backhead_X%Array(MudSystemDotimud+1)
- St_Mud_Forehead_section%Array(MudSystemDotimud)= St_Mud_Backhead_section%Array(MudSystemDotimud+1)
- endif
-
-
- MudSystemDotDirectionCoef= (MudSystemDotXend_PipeSection(St_Mud_Forehead_section%Array(MudSystemDotimud))-MudSystemDotXstart_PipeSection(St_Mud_Forehead_section%Array(MudSystemDotimud))) &
- / ABS(MudSystemDotXend_PipeSection(St_Mud_Forehead_section%Array(MudSystemDotimud))-MudSystemDotXstart_PipeSection(St_Mud_Forehead_section%Array(MudSystemDotimud)))
- ! +1 for string , -1 for annulus
-
-
- MudSystemDotSt_EmptyVolume_inBackheadLocation%Array(MudSystemDotimud)= MudSystemDotDirectionCoef* (MudSystemDotSt_Mud_Forehead_X%Array(MudSystemDotimud)- MudSystemDotXstart_PipeSection(St_Mud_Forehead_section%Array(MudSystemDotimud)))* &
- MudSystemDotArea_PipeSectionFt(St_Mud_Backhead_section%Array(MudSystemDotimud)) !(ft^3)
- MudSystemDotSt_EmptyVolume_inBackheadLocation%Array(MudSystemDotimud)= MudSystemDotSt_EmptyVolume_inBackheadLocation%Array(MudSystemDotimud)* 7.48051948d0 ! ft^3 to gal
-
-
- if ( MudSystemDotSt_MudDischarged_Volume%Array(MudSystemDotimud) <= MudSystemDotSt_EmptyVolume_inBackheadLocation%Array(MudSystemDotimud)) then
- St_Mud_Backhead_section%Array(MudSystemDotimud)= St_Mud_Forehead_section%Array(MudSystemDotimud)
- MudSystemDotSt_Mud_Backhead_X%Array(MudSystemDotimud)= MudSystemDotSt_Mud_Forehead_X%Array(MudSystemDotimud)- MudSystemDotDirectionCoef*(MudSystemDotSt_MudDischarged_Volume%Array(MudSystemDotimud)/7.48051948d0)/MudSystemDotArea_PipeSectionFt(St_Mud_Forehead_section%Array(MudSystemDotimud))
- ! 7.48051948 is for gal to ft^3
- else
-
- MudSystemDotisection= St_Mud_Backhead_section%Array(MudSystemDotimud)-1
- MudSystemDotSt_RemainedVolume_in_LastSection%Array(MudSystemDotimud)= MudSystemDotSt_MudDischarged_Volume%Array(MudSystemDotimud)- MudSystemDotSt_EmptyVolume_inBackheadLocation%Array(MudSystemDotimud)
-
- do
- if (MudSystemDotisection < 1) then ! last pipe section(string exit)
- MudSystemDotSt_MudDischarged_Volume%Array(MudSystemDotimud)= MudSystemDotSt_MudDischarged_Volume%Array(MudSystemDotimud)- MudSystemDotSt_RemainedVolume_in_LastSection%Array(MudSystemDotimud)
- MudSystemDotSt_Mud_Backhead_X%Array(MudSystemDotimud)= MudSystemDotXstart_PipeSection(2)
- St_Mud_Backhead_section%Array(MudSystemDotimud)= 2
-
- if (MudSystemDotSt_MudDischarged_Volume%Array(MudSystemDotimud)<= 0.0d0) then ! imud is completely exited form the string
- call RemoveStringMudArrays(MudSystemDotimud)
- endif
-
- exit
- endif
-
- MudSystemDotxx= MudSystemDotSt_RemainedVolume_in_LastSection%Array(MudSystemDotimud)/ MudSystemDotPipeSection_VolumeCapacity(MudSystemDotisection) !(gal)
-
- if (MudSystemDotxx<= 1.0) then
- St_Mud_Backhead_section%Array(MudSystemDotimud)= MudSystemDotisection
- MudSystemDotSt_Mud_Backhead_X%Array(MudSystemDotimud)= (MudSystemDotxx * (MudSystemDotXstart_PipeSection(MudSystemDotisection)- MudSystemDotXend_PipeSection(MudSystemDotisection)))+ MudSystemDotXend_PipeSection(MudSystemDotisection)
- exit
- else
- MudSystemDotSt_RemainedVolume_in_LastSection%Array(MudSystemDotimud)= MudSystemDotSt_RemainedVolume_in_LastSection%Array(MudSystemDotimud)- MudSystemDotPipeSection_VolumeCapacity(MudSystemDotisection)
- MudSystemDotisection= MudSystemDotisection- 1
-
- endif
-
- enddo
-
- endif
-
- enddo
- !========================STRING END=================
-
-
-
-
- end subroutine Utube2_and_TripIn
|