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.

Formation_Information.f90 6.2 KiB

2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
1 year ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. SUBROUTINE FormationInformationCalculator
  2. use KickVARIABLESModule
  3. use SimulationVariables !@
  4. Use CReservoirVariables
  5. Use CFormationVariables
  6. USE Fluid_Flow_Startup_Vars
  7. USE CLog2
  8. USE CDownHoleVariables
  9. USE MudSystemVARIABLES
  10. use SimulationVariables !@@@
  11. use SimulationVariables
  12. IMPLICIT NONE
  13. INTEGER :: i
  14. REAL(8) :: WellGeoTopTVD
  15. KickGasType = 1 ! methane
  16. !====================================================
  17. ! Formation Length Calculation
  18. !====================================================
  19. WellGeoTopTVD = 0.
  20. KickFormTopMD = 0.
  21. KickFormDownMD = 0.
  22. !===> Top Measured Depth of Formation
  23. Do i = 1 , data%State%TD_WellGeneral%WellIntervalsCount
  24. if ( Reservoir%FormationTop >= data%State%TD_WellGeo(i)%VerticalDepth ) then
  25. KickFormTopMD = KickFormTopMD + data%State%TD_WellGeo(i)%IntervalLength
  26. !WRITE (*,*) ' here 11' , data%State%TD_WellGeo(i)%IntervalLength
  27. !WRITE (*,*) ' here v11' , data%State%TD_WellGeo(i)%VerticalDepth
  28. WellGeoTopTVD = data%State%TD_WellGeo(i)%VerticalDepth
  29. else if ( Reservoir%FormationTop < data%State%TD_WellGeo(i)%VerticalDepth ) then
  30. if ( data%State%TD_WellGeo(i)%HoleType == 0 ) then
  31. KickFormTopMD = KickFormTopMD + ((Reservoir%FormationTop - WellGeoTopTVD)&
  32. / cos(data%State%TD_WellGeo(i)%StartAngle))
  33. !WRITE (*,*) ' here 12' , (FormationTop - WellGeoTopTVD) / cos(data%State%TD_WellGeo(i)%StartAngle)
  34. else
  35. KickFormTopMD = KickFormTopMD + (data%State%TD_WellGeo(i)%RCurvature &
  36. * Asin((Reservoir%FormationTop - WellGeoTopTVD) / data%State%TD_WellGeo(i)%RCurvature))
  37. !WRITE (*,*) ' here 13' , data%State%TD_WellGeo(i)%RCurvature * Asin((FormationTop - WellGeoTopTVD) / data%State%TD_WellGeo(i)%RCurvature)
  38. end if
  39. exit
  40. end if
  41. End Do
  42. !!===> Down Measured Depth of Formation
  43. WellGeoTopTVD = 0.
  44. Do i = 1 , data%State%TD_WellGeneral%WellIntervalsCount
  45. if ( (Reservoir%FormationTop + data%Configuration%Formation%Formations(Reservoir%FormationNo)%Thickness)>=data%State%TD_WellGeo(i)%VerticalDepth ) then
  46. KickFormDownMD = KickFormDownMD + data%State%TD_WellGeo(i)%IntervalLength
  47. WellGeoTopTVD = data%State%TD_WellGeo(i)%VerticalDepth
  48. else if ( (Reservoir%FormationTop+data%Configuration%Formation%Formations(Reservoir%FormationNo)%Thickness)<data%State%TD_WellGeo(i)%VerticalDepth ) then
  49. if ( data%State%TD_WellGeo(i)%HoleType==0 ) then
  50. KickFormDownMD = KickFormDownMD + (((Reservoir%FormationTop+data%Configuration%Formation%Formations(Reservoir%FormationNo)%Thickness)-WellGeoTopTVD)&
  51. / cos(data%State%TD_WellGeo(i)%StartAngle))
  52. else
  53. KickFormDownMD = KickFormDownMD + (data%State%TD_WellGeo(i)%RCurvature &
  54. * Asin((Reservoir%FormationTop - WellGeoTopTVD) / data%State%TD_WellGeo(i)%RCurvature))
  55. end if
  56. exit
  57. end if
  58. End Do
  59. !!===> Determination of Formation Length for Kick Modeling
  60. if (data%State%TD_WellGeneral%WellTotalVerticalLength >= Reservoir%FormationTop .AND. data%State%TD_WellGeneral%WellTotalVerticalLength < (Reservoir%FormationTop+data%Configuration%Formation%Formations(Reservoir%FormationNo)%Thickness)) then
  61. KickFormLength = data%State%TD_WellGeneral%WellTotalLength - KickFormTopMD ![ft]
  62. else if ( data%State%TD_WellGeneral%WellTotalVerticalLength >= (Reservoir%FormationTop + data%Configuration%Formation%Formations(Reservoir%FormationNo)%Thickness) ) then
  63. KickFormLength = KickFormDownMD - KickFormTopMD ![ft]
  64. else
  65. KickFormLength = 0.
  66. end if
  67. !PermeabilityExposedHeight = KickFormLength * FormationPermeability
  68. data%Equipments%DownHole%PermeabilityExposedHeight = data%State%MudSystem%FluidFlowCounter - data%State%MudSystem%MudSys_timeCounter
  69. !====================================================
  70. ! Reservoir Data
  71. !====================================================
  72. FormPermeability = Reservoir%FormationPermeability ! [mD]
  73. FormPressure = data%State%TD_WellGeneral%WellTotalVerticalLength * data%Configuration%Formation%Formations(Reservoir%FormationNo)%PorePressureGradient ![psia]
  74. data%Equipments%DownHole%FormationPressure = INT(FormPressure)
  75. !CALL Log_2('FormPressure =' , FormPressure)
  76. !if(print_log) print*, 'Formations(FormationNo)%PorePressureGradient=', Formations(FormationNo)%PorePressureGradient
  77. !print * , 'FormationNo=' , FormationNo
  78. !print * , 'data%State%TD_WellGeneral%WellTotalVerticalLength=' , data%State%TD_WellGeneral%WellTotalVerticalLength
  79. FormTemperature = 600 ! [Ra]
  80. !WRITE (*,*) ' Formation pressure ' , FormPressure
  81. !====================================================
  82. ! Gas Properties (Methane Gas)
  83. !====================================================
  84. GasResTemperature = FormTemperature
  85. GasResPressure = FormPressure
  86. !!!! Methane , Gas type =1
  87. GasKickMolarMass = data%State%GasType(KickGasType)%MolarWt ! Methane Gas [gr/mol]
  88. GasSpecGravity = GasKickMolarMass / GasDensityRefrence
  89. KickTc = data%State%GasType(KickGasType)%CritTemp
  90. KickPc = data%State%GasType(KickGasType)%CritPress
  91. !!!!!!!! Calculating Compressibility, viscosity for influx condition (Average of reservoir and bottomhole)
  92. KickTr = GasResTemperature / KickTc
  93. KickPr = GasResPressure / KickPc
  94. K_A_Res = 3.53 * KickPr
  95. K_B_Res = 10.0**(0.9813 * KickTr)
  96. K_C_Res = 0.274 * (KickPr**2)
  97. K_D_Res = 10.0**(0.8157 * KickTr)
  98. GasResCompressibility = 0.98 !1. - (K_A_Res / K_B_Res) + (K_C_Res / K_D_Res)
  99. GasReservoirDensity = GasResPressure / (GasResCompressibility * &
  100. GasResTemperature * data%State%GasType(KickGasType)%GasConstant) / Convft3toUSgal ! [ppg]
  101. END SUBROUTINE