1#ifndef RPG_CONCENTRATION_DERIVATIVE_TPP
2#define RPG_CONCENTRATION_DERIVATIVE_TPP
11#include "ConcentrationDerivative.h"
13#include <rpg/system/System.h>
14#include <rpg/fts/simulator/Simulator.h>
15#include <rpg/fts/perturbation/Perturbation.h>
44 const int nMonomer =
system().mixture().nMonomer();
47 double vMonomer =
system().mixture().vMonomer();
48 const int meshSize =
system().domain().mesh().size();
51 if (!
system().c().hasData()) {
65 double dfdc = h * vMonomer;
68 double Hh = double(meshSize)/2.0 * vMonomer;
78 double vMonomer =
system().mixture().vMonomer();
81 outputFile_ <<
Int(step);
82 outputFile_ <<
Dbl(vMonomer);
83 outputFile_ <<
Dbl(value);
AverageAnalyzer(Simulator< D > &simulator, System< D > &system)
Constructor.
virtual void outputValue(int step, double value)
Output a sampled or block average value.
int nSamplePerOutput() const
Get value of nSamplePerOutput.
Simulator< D > & simulator()
Return reference to parent simulator.
System< D > & system()
Return reference to parent system.
void setClassName(const char *className)
Set class name string.
ConcentrationDerivative(Simulator< D > &simulator, System< D > &system)
Constructor.
virtual void outputValue(int step, double value)
Output a sampled or block average value.
virtual ~ConcentrationDerivative()
Destructor.
virtual double compute()
Compute and return the derivative of H w/ respect to concentration.
Field theoretic simulator (base class).
Main class, representing one complete system.
Wrapper for a double precision number, for formatted ostream output.
Wrapper for an int, for formatted ostream output.
#define UTIL_CHECK(condition)
Assertion macro suitable for serial or parallel production code.
SCFT and PS-FTS with real periodic fields (GPU)
PSCF package top-level namespace.