Fix initialization of tracer heads, and output ordering.
This commit is contained in:
parent
59d0ae185f
commit
e8db63dfb0
@ -110,14 +110,15 @@ namespace Opm
|
|||||||
darcyflux_ = darcyflux;
|
darcyflux_ = darcyflux;
|
||||||
porevolume_ = porevolume;
|
porevolume_ = porevolume;
|
||||||
source_ = source;
|
source_ = source;
|
||||||
|
const int num_cells = grid_.number_of_cells;
|
||||||
#ifndef NDEBUG
|
#ifndef NDEBUG
|
||||||
// Sanity check for sources.
|
// Sanity check for sources.
|
||||||
const double cum_src = std::accumulate(source, source + grid_.number_of_cells, 0.0);
|
const double cum_src = std::accumulate(source, source + num_cells, 0.0);
|
||||||
if (std::fabs(cum_src) > *std::max_element(source, source + grid_.number_of_cells)*1e-2) {
|
if (std::fabs(cum_src) > *std::max_element(source, source + num_cells)*1e-2) {
|
||||||
OPM_THROW(std::runtime_error, "Sources do not sum to zero: " << cum_src);
|
OPM_THROW(std::runtime_error, "Sources do not sum to zero: " << cum_src);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
tof.resize(grid_.number_of_cells);
|
tof.resize(num_cells);
|
||||||
std::fill(tof.begin(), tof.end(), 0.0);
|
std::fill(tof.begin(), tof.end(), 0.0);
|
||||||
tof_ = &tof[0];
|
tof_ = &tof[0];
|
||||||
|
|
||||||
@ -134,28 +135,36 @@ namespace Opm
|
|||||||
|
|
||||||
// Find the tracer heads (injectors).
|
// Find the tracer heads (injectors).
|
||||||
const int num_tracers = tracerheads.size();
|
const int num_tracers = tracerheads.size();
|
||||||
tracer.resize(grid_.number_of_cells*num_tracers);
|
tracer.resize(num_cells*num_tracers);
|
||||||
std::fill(tracer.begin(), tracer.end(), 0.0);
|
std::fill(tracer.begin(), tracer.end(), 0.0);
|
||||||
if (num_tracers > 0) {
|
if (num_tracers > 0) {
|
||||||
tracerhead_by_cell_.clear();
|
tracerhead_by_cell_.clear();
|
||||||
tracerhead_by_cell_.resize(grid_.number_of_cells, NoTracerHead);
|
tracerhead_by_cell_.resize(num_cells, NoTracerHead);
|
||||||
}
|
}
|
||||||
for (int tr = 0; tr < num_tracers; ++tr) {
|
for (int tr = 0; tr < num_tracers; ++tr) {
|
||||||
for (int i = 0; i < tracerheads[tr].size(); ++i) {
|
for (int i = 0; i < tracerheads[tr].size(); ++i) {
|
||||||
const int cell = tracerheads[tr][i];
|
const int cell = tracerheads[tr][i];
|
||||||
tracer[cell*num_tracers + tr] = 1.0;
|
tracer[num_cells * tr + cell] = 1.0;
|
||||||
tracerhead_by_cell_[cell] = tr;
|
tracerhead_by_cell_[cell] = tr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Execute solve for tracers.
|
// Execute solve for tracers.
|
||||||
std::vector<double> fake_pv(grid_.number_of_cells, 0.0);
|
std::vector<double> fake_pv(num_cells, 0.0);
|
||||||
porevolume_ = fake_pv.data();
|
porevolume_ = fake_pv.data();
|
||||||
for (int tr = 0; tr < num_tracers; ++tr) {
|
for (int tr = 0; tr < num_tracers; ++tr) {
|
||||||
tof_ = tracer.data() + tr * grid_.number_of_cells;
|
tof_ = tracer.data() + tr * num_cells;
|
||||||
compute_tracer_ = true;
|
compute_tracer_ = true;
|
||||||
executeSolve();
|
executeSolve();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Write output tracer data (transposing the computed data).
|
||||||
|
std::vector<double> computed = tracer;
|
||||||
|
for (int cell = 0; cell < num_cells; ++cell) {
|
||||||
|
for (int tr = 0; tr < num_tracers; ++tr) {
|
||||||
|
tracer[num_tracers * cell + tr] = computed[num_cells * tr + cell];
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user