/* Copyright 2010 SINTEF ICT, Applied Mathematics. This file is part of the Open Porous Media project (OPM). OPM 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. OPM 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 for more details. You should have received a copy of the GNU General Public License along with OPM. If not, see . */ #ifndef OPM_WELL_HEADER_INCLUDED #define OPM_WELL_HEADER_INCLUDED /** * \file * Deprecated (and obsolescent) well definition. Still in use by * the hybridized pressure solvers. */ #ifdef __cplusplus extern "C" { #endif /** * Well taxonomy. */ enum well_type { INJECTOR, PRODUCER }; /** * Control types recognised in system. */ enum well_control { BHP , RATE }; /** * Compositions recognised in injection wells. */ enum surface_component { WATER = 0, OIL = 1, GAS = 2 }; /** * Basic representation of well topology. */ struct WellCompletions { int number_of_wells; /**< Number of wells. */ int *well_connpos; /**< Well topology start pointers. */ int *well_cells; /**< Well connections */ }; /** * Basic representation of well controls. */ struct WellControls { enum well_type *type; /**< Individual well taxonomy */ enum well_control *ctrl; /**< Individual well controls */ double *target; /**< Control target */ double *zfrac; /**< Surface injection composition */ }; /** * Dynamic discretisation data relating well to flow in reservoir. */ struct completion_data { double *WI; /**< Well indices */ double *gpot; /**< Gravity potential */ double *A; /**< \f$RB^{-1}\f$ for compressible flows. */ double *phasemob; /**< Phase mobility, per connection. */ }; /** * Convenience type alias to preserve backwards compatibility in * well topology definitions used by hybridised pressure solver. */ typedef struct WellCompletions well_t; /** * Convenience type alias to preserve backwards compatiblity in * well control definitions used by hybridised pressure solver. */ typedef struct WellControls well_control_t; /** * Allocate cell-to-well mapping (as a sparse array). * * @param[in] nc Total number of cells. * @param[in] W Well topology (well-to-cell mapping). * @param[out] cwpos Indirection array. Points to array of size * nc + 1 if successful. * @param[out] cwells Cell-to-well mapping. Points to array * of size W->well_connpos[ * W->number_of_wells] if successful. * @return Positive number (size of *cwells) * if successful. Zero in case of allocation failure. */ int allocate_cell_wells(int nc, well_t *W, int **cwpos, int **cwells); /** * Dispose of memory resources allocated using function * allocate_cell_wells(). * * Following a call to deallocate_cell_wells(), the input pointers * are no longer valid. * * @param[in,out] cvpos Cell-to-well start pointers. * @param[in,out] cwells Cell-to-well mapping. */ void deallocate_cell_wells(int *cvpos, int *cwells); /** * Construct cell-to-well mapping (i.e., transpose the * well-to-cell mapping represented by W->well_cells). * * @param[in] nc Total number of cells. * @param[in] W Well topology (well-to-cell mapping). * @param[out] cwpos Cell-to-well start pointers. * @param[out] cwells Cell-to-well mapping. */ void derive_cell_wells(int nc, well_t *W, int *cwpos, int *cwells); #ifdef __cplusplus } #endif #endif /* OPM_WELL_HEADER_INCLUDED */