PSCF v1.2
rpg/fts/analyzer/ConcentrationDerivative.tpp
1#ifndef RPG_CONCENTRATION_DERIVATIVE_TPP
2#define RPG_CONCENTRATION_DERIVATIVE_TPP
3
4/*
5* PSCF - Polymer Self-Consistent Field Theory
6*
7* Copyright 2016 - 2022, The Regents of the University of Minnesota
8* Distributed under the terms of the GNU General Public License.
9*/
10
11#include "ConcentrationDerivative.h"
12
13#include <rpg/System.h>
14#include <rpg/fts/simulator/Simulator.h>
15#include <rpg/fts/perturbation/Perturbation.h>
16
17namespace Pscf {
18namespace Rpg {
19
20 using namespace Util;
21
22 /*
23 * Constructor.
24 */
25 template <int D>
27 System<D>& system)
28 : AverageAnalyzer<D>(simulator, system)
29 { setClassName("ConcentrationDerivative"); }
30
31 /*
32 * Destructor.
33 */
34 template <int D>
37
38 template <int D>
40 {
41 UTIL_CHECK(system().w().hasData());
42
43 // For AB diblock
44 const int nMonomer = system().mixture().nMonomer();
45 UTIL_CHECK(nMonomer == 2);
46
47 double vMonomer = system().mixture().vMonomer();
48 const int meshSize = system().domain().mesh().size();
49
50 // Compute hamiltonian, if necessary
51 if (!system().hasCFields()) {
52 system().compute();
53 }
54 if (!simulator().hasWc()){
55 simulator().computeWc();
56 }
57 if (!simulator().hasHamiltonian()) {
58 simulator().computeHamiltonian();
59 }
60
61 // Obtain Hamiltonian
62 double h = simulator().hamiltonian();
63
64 // Calculate derivative with respect to concentration
65 double dfdc = h * vMonomer;
66
67 // With N term
68 double Hh = double(meshSize)/2.0 * vMonomer;
69 dfdc -= Hh;
70
71 return dfdc;
72 }
73
74 template <int D>
75 void ConcentrationDerivative<D>::outputValue(int step, double value)
76 {
77 if (simulator().hasRamp() && nSamplePerOutput() == 1) {
78 double vMonomer = system().mixture().vMonomer();
79
80 UTIL_CHECK(outputFile_.is_open());
81 outputFile_ << Int(step);
82 outputFile_ << Dbl(vMonomer);
83 outputFile_ << Dbl(value);
84 outputFile_ << "\n";
85 } else {
87 }
88 }
89
90}
91}
92#endif
Analyze averages and block averages of several real variables.
virtual void outputValue(int step, double value)
Output a sampled or block average value.
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 double compute()
Compute and return the derivative of H w/ respect to concentration.
Field theoretic simulator (base class).
Definition rpg/System.h:41
Main class for calculations that represent one system.
Definition rpg/System.h:107
Wrapper for a double precision number, for formatted ostream output.
Definition Dbl.h:40
Wrapper for an int, for formatted ostream output.
Definition Int.h:37
#define UTIL_CHECK(condition)
Assertion macro suitable for serial or parallel production code.
Definition global.h:68
PSCF package top-level namespace.
Definition param_pc.dox:1
Utility classes for scientific computation.