1#ifndef RPC_PERTURBATION_DERIVATIVE_TPP
2#define RPC_PERTURBATION_DERIVATIVE_TPP
11#include "PerturbationDerivative.h"
13#include <rpc/System.h>
14#include <rpc/fts/simulator/Simulator.h>
15#include <rpc/fts/perturbation/Perturbation.h>
44 if (!system().hasCFields()) {
47 if (!simulator().hasWc()){
48 simulator().computeWc();
50 if (!simulator().hasHamiltonian()) {
51 simulator().computeHamiltonian();
54 return simulator().perturbation().df();
60 if (simulator().hasRamp() && nSamplePerOutput() == 1) {
61 double lambda = simulator().perturbation().lambda();
64 outputFile_ <<
Int(step);
65 outputFile_ <<
Dbl(lambda);
66 outputFile_ <<
Dbl(value);
Analyze averages and block averages of several real variables.
virtual void outputValue(int step, double value)
Output a sampled or block average value.
virtual ~PerturbationDerivative()
Destructor.
virtual void outputValue(int step, double value)
Output a sampled or block average value.
void setClassName(const char *className)
Set class name string.
PerturbationDerivative(Simulator< D > &simulator, System< D > &system)
Constructor.
virtual double compute()
Compute and return the derivative of H w/ respect to lambda.
Field theoretic simulator (base class).
Main class for SCFT or PS-FTS simulation of one 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.
PSCF package top-level namespace.
Utility classes for scientific computation.