///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2017 Statoil ASA // // ResInsight is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // ResInsight is distributed in the hope that it will be useful, but WITHOUT ANY // WARRANTY; without even the implied warranty of MERCHANTABILITY or // FITNESS FOR A PARTICULAR PURPOSE. // // See the GNU General Public License at // for more details. // ///////////////////////////////////////////////////////////////////////////////// #include "RimFishbonesPipeProperties.h" #include "RimWellPath.h" #include CAF_PDM_SOURCE_INIT(RimFishbonesPipeProperties, "FishbonesPipeProperties"); //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RimFishbonesPipeProperties::RimFishbonesPipeProperties() { CAF_PDM_InitObject("FishbonesPipeProperties", "", "", ""); CAF_PDM_InitField(&m_lateralHoleDiameter, "LateralHoleDiameter", 12.5, "Hole Diameter [mm]", "", "", ""); CAF_PDM_InitField(&m_skinFactor, "SkinFactor", 0.0, "Skin Factor [0..1]", "", "", ""); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RimFishbonesPipeProperties::~RimFishbonesPipeProperties() { } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- double RimFishbonesPipeProperties::holeDiameter(RiaEclipseUnitTools::UnitSystem unitSystem) const { RimWellPath* wellPath; firstAncestorOrThisOfTypeAsserted(wellPath); if (unitSystem == RiaEclipseUnitTools::UNITS_METRIC) { if (wellPath->unitSystem() == RiaEclipseUnitTools::UNITS_FIELD) { return RiaEclipseUnitTools::inchToMeter(m_lateralHoleDiameter()); } else { return m_lateralHoleDiameter() / 1000; } } else if (unitSystem == RiaEclipseUnitTools::UNITS_FIELD) { if (wellPath->unitSystem() == RiaEclipseUnitTools::UNITS_METRIC) { return RiaEclipseUnitTools::meterToFeet(m_lateralHoleDiameter() / 1000); } else { return RiaEclipseUnitTools::inchToFeet(m_lateralHoleDiameter()); } } CVF_ASSERT(false); return 0.0; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimFishbonesPipeProperties::setUnitSystemSpecificDefaults() { RimWellPath* wellPath; firstAncestorOrThisOfType(wellPath); if (wellPath) { if (wellPath->unitSystem() == RiaEclipseUnitTools::UNITS_METRIC) { m_lateralHoleDiameter = 12.5; } else if (wellPath->unitSystem() == RiaEclipseUnitTools::UNITS_FIELD) { m_lateralHoleDiameter = 0.5; } } } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimFishbonesPipeProperties::defineUiOrdering(QString uiConfigName, caf::PdmUiOrdering & uiOrdering) { { RimWellPath* wellPath; firstAncestorOrThisOfType(wellPath); if (wellPath) { if (wellPath->unitSystem() == RiaEclipseUnitTools::UNITS_METRIC) { m_lateralHoleDiameter.uiCapability()->setUiName("Hole Diameter [mm]"); } else if (wellPath->unitSystem() == RiaEclipseUnitTools::UNITS_FIELD) { m_lateralHoleDiameter.uiCapability()->setUiName("Hole Diameter [in]"); } } } uiOrdering.add(&m_lateralHoleDiameter); uiOrdering.add(&m_skinFactor); }