source:
src/solver/solver.cpp@
d24c2f
| Last change on this file since d24c2f was dfed1c, checked in by , 14 years ago | |
|---|---|
|
|
| File size: 977 bytes | |
| Rev | Line | |
|---|---|---|
| [48b662] | 1 | /** |
| 2 | * @file solver.cpp | |
| 3 | * @author Julian Iseringhausen <isering@ins.uni-bonn.de> | |
| 4 | * @date Mon Apr 18 13:10:55 2011 | |
| 5 | * | |
| 6 | * @brief VMG::Solver | |
| 7 | * | |
| 8 | */ | |
| 9 | ||
| 10 | #ifdef HAVE_CONFIG_H | |
| 11 | #include <config.h> | |
| 12 | #endif | |
| 13 | ||
| 14 | #include "solver/solver.hpp" | |
| 15 | ||
| 16 | using namespace VMG; | |
| 17 | ||
| [dfed1c] | 18 | void Solver::Run(Grid& sol, Grid& rhs) |
| [48b662] | 19 | { |
| [dfed1c] | 20 | #ifdef DEBUG_MATRIX_CHECKS |
| 21 | sol.IsConsistent(); | |
| 22 | rhs.IsConsistent(); | |
| 23 | #endif | |
| 24 | ||
| 25 | #ifdef DEBUG | |
| 26 | sol.IsCompatible(rhs); | |
| 27 | #endif | |
| 28 | ||
| 29 | Comm* comm = MG::GetComm(); | |
| [48b662] | 30 | |
| [dfed1c] | 31 | Grid& rhsGlobal = comm->GetGlobalCoarseGrid(*rhs.Father()); |
| [48b662] | 32 | |
| [dfed1c] | 33 | this->Realloc(rhsGlobal); |
| 34 | this->AssembleMatrix(rhsGlobal); | |
| 35 | this->Compute(); | |
| 36 | this->ExportSol(sol, rhs); | |
| 37 | } | |
| 38 | ||
| 39 | void Solver::Realloc(int n) | |
| 40 | { | |
| 41 | //Reallocate memory if necessary | |
| 42 | this->size = n; | |
| [48b662] | 43 | |
| [dfed1c] | 44 | if (static_cast<int>(A.size()) < n*n) |
| 45 | A.resize(n*n); | |
| [48b662] | 46 | |
| [dfed1c] | 47 | if (static_cast<int>(b.size()) < n) |
| 48 | b.resize(n); | |
| [48b662] | 49 | |
| [dfed1c] | 50 | if (static_cast<int>(x.size()) < n) |
| 51 | x.resize(n); | |
| [48b662] | 52 | } |
| 53 | ||
| 54 | void Solver::Realloc(Grid& sol) | |
| 55 | { | |
| [dfed1c] | 56 | this->Realloc(sol.Global().SizeGlobal().Product()); |
| [48b662] | 57 | } |
Note:
See TracBrowser
for help on using the repository browser.
