///////////////////////////////////////////////////////////////////////////////// // // 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. // ///////////////////////////////////////////////////////////////////////////////// #pragma once #include "cvfMatrix4.h" #include #include #include class RigWellPath; class RimFracture; class RigWellPathStimplanIntersectorTester; //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- class RigWellPathStimplanIntersector { public: struct WellCellIntersection { WellCellIntersection() : hlength( 0.0 ) , vlength( 0.0 ) , endpointCount( 0 ) { } double hlength; double vlength; int endpointCount; double computeLength() const { return cvf::Math::sqrt( hlength * hlength + vlength * vlength ); } }; RigWellPathStimplanIntersector( gsl::not_null wellpathGeom, gsl::not_null rimFracture ); const std::map& intersections() const; private: friend class RigWellPathStimplanIntersectorTester; static void calculate( const cvf::Mat4d& fractureXf, const std::vector& wellPathPoints, double wellRadius, double perforationLength, const std::vector>& stpCellPolygons, std::map& stimPlanCellIdxToIntersectionInfoMap ); std::map m_stimPlanCellIdxToIntersectionInfoMap; }; //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- class RigWellPathStimplanIntersectorTester { public: static void testCalculate( const cvf::Mat4d& fractureXf, const std::vector& wellPathPoints, double wellRadius, double perforationLength, const std::vector>& stpCellPolygons, std::map& stimPlanCellIdxToIntersectionInfoMap ) { RigWellPathStimplanIntersector::calculate( fractureXf, wellPathPoints, wellRadius, perforationLength, stpCellPolygons, stimPlanCellIdxToIntersectionInfoMap ); } };