/* Copyright 2014 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 . */ #if HAVE_CONFIG_H #include "config.h" #endif // HAVE_CONFIG_H #include #include #include #include #include #include #include #include #include #include #include #include namespace { void warnIfUnusedParams(const Opm::parameter::ParameterGroup& param) { if (param.anyUnused()) { std::cout << "-------------------- Unused parameters: --------------------\n"; param.displayUsage(); std::cout << "----------------------------------------------------------------" << std::endl; } } void outputData(const std::string& output_dir, const std::string& name, const std::vector& data) { std::ostringstream fname; fname << output_dir << "/" << name; boost::filesystem::path fpath = fname.str(); try { create_directories(fpath); } catch (...) { OPM_THROW(std::runtime_error, "Creating directories failed: " << fpath); } fname << "/" << "initial.txt"; std::ofstream file(fname.str().c_str()); if (!file) { OPM_THROW(std::runtime_error, "Failed to open " << fname.str()); } std::copy(data.begin(), data.end(), std::ostream_iterator(file, "\n")); } } // anon namespace // ----------------- Main program ----------------- int main(int argc, char** argv) try { using namespace Opm; // Setup. parameter::ParameterGroup param(argc, argv); std::cout << "--------------- Reading parameters ---------------" << std::endl; const std::string deck_filename = param.get("deck_filename"); Opm::ParseContext parseContext; Opm::Parser parser; const Opm::Deck& deck = parser.parseFile(deck_filename , parseContext); const Opm::EclipseState eclipseState(deck, parseContext); const double grav = param.getDefault("gravity", unit::gravity); GridManager gm(eclipseState.getInputGrid()); const UnstructuredGrid& grid = *gm.c_grid(); BlackoilPropertiesFromDeck props(deck, eclipseState, grid, param); warnIfUnusedParams(param); // Initialisation. //initBlackoilSurfvolUsingRSorRV(UgGridHelpers::numCells(grid), props, state); BlackoilState state( UgGridHelpers::numCells(grid) , UgGridHelpers::numFaces(grid), 3); initStateEquil(grid, props, deck, eclipseState, grav, state); // Output. const std::string output_dir = param.getDefault("output_dir", "output"); outputData(output_dir, "pressure", state.pressure()); outputData(output_dir, "saturation", state.saturation()); outputData(output_dir, "rs", state.gasoilratio()); outputData(output_dir, "rv", state.rv()); } catch (const std::exception& e) { std::cerr << "Program threw an exception: " << e.what() << "\n"; throw; }