mirror of
https://github.com/OPM/opm-simulators.git
synced 2025-02-25 18:55:30 -06:00
move assignment of sol tracer concentration into TracerContainer
This commit is contained in:
parent
00fe560720
commit
dcc4aa30dd
@ -649,17 +649,10 @@ public:
|
||||
[globalDofIdx, &tracerModel](const unsigned tracerIdx)
|
||||
{ return tracerModel.freeTracerConcentration(tracerIdx,
|
||||
globalDofIdx); });
|
||||
|
||||
if (! this->tracerC_.solConcentrations_.empty()) {
|
||||
for (int tracerIdx = 0; tracerIdx < tracerModel.numTracers(); ++tracerIdx) {
|
||||
if (this->tracerC_.solConcentrations_[tracerIdx].empty()) {
|
||||
continue;
|
||||
}
|
||||
this->tracerC_.solConcentrations_[tracerIdx][globalDofIdx] =
|
||||
tracerModel.solTracerConcentration(tracerIdx, globalDofIdx);
|
||||
|
||||
}
|
||||
}
|
||||
this->tracerC_.assignSolConcentrations(globalDofIdx,
|
||||
[globalDofIdx, &tracerModel](const unsigned tracerIdx)
|
||||
{ return tracerModel.solTracerConcentration(tracerIdx,
|
||||
globalDofIdx); });
|
||||
|
||||
// output residual
|
||||
for ( int phaseIdx = 0; phaseIdx < numPhases; ++phaseIdx )
|
||||
|
@ -76,6 +76,21 @@ assignFreeConcentrations(const unsigned globalDofIdx,
|
||||
});
|
||||
}
|
||||
|
||||
template<class FluidSystem>
|
||||
void TracerContainer<FluidSystem>::
|
||||
assignSolConcentrations(const unsigned globalDofIdx,
|
||||
const AssignFunction& concentration)
|
||||
{
|
||||
std::for_each(solConcentrations_.begin(), solConcentrations_.end(),
|
||||
[globalDofIdx, idx = 0, &concentration](auto& tracer) mutable
|
||||
{
|
||||
if (!tracer.empty()) {
|
||||
tracer[globalDofIdx] = concentration(idx);
|
||||
}
|
||||
++idx;
|
||||
});
|
||||
}
|
||||
|
||||
template<class FluidSystem>
|
||||
void TracerContainer<FluidSystem>::
|
||||
outputRestart(data::Solution& sol)
|
||||
|
@ -52,6 +52,9 @@ public:
|
||||
void assignFreeConcentrations(const unsigned globalDofIdx,
|
||||
const AssignFunction& concentration);
|
||||
|
||||
void assignSolConcentrations(const unsigned globalDofIdx,
|
||||
const AssignFunction& concentration);
|
||||
|
||||
void outputRestart(data::Solution& sol);
|
||||
|
||||
const EclipseState& eclState_;
|
||||
|
Loading…
Reference in New Issue
Block a user