n2p2 - A neural network potential package
nnp::SymGrpCompAngwWeighted Class Reference

Weighted wide angular symmetry function with compact support (type 25) More...

#include <SymGrpCompAngwWeighted.h>

Inheritance diagram for nnp::SymGrpCompAngwWeighted:
Collaboration diagram for nnp::SymGrpCompAngwWeighted:

Public Member Functions

 SymGrpCompAngwWeighted (ElementMap const &elementMap)
 Constructor, sets type = 25. More...
 
virtual bool operator== (SymGrp const &rhs) const
 Overload == operator. More...
 
virtual bool operator< (SymGrp const &rhs) const
 Overload < operator. More...
 
virtual bool addMember (SymFnc const *const symmetryFunction)
 Potentially add a member to group. More...
 
virtual void sortMembers ()
 Sort member symmetry functions. More...
 
virtual void calculate (Atom &atom, bool const derivatives) const
 Calculate all symmetry functions of this group for one atom. More...
 
- Public Member Functions inherited from nnp::SymGrpBaseCompAngWeighted
virtual void setScalingFactors ()
 Fill scalingFactors with values from member symmetry functions. More...
 
virtual std::vector< std::string > parameterLines () const
 Give symmetry function group parameters on multiple lines. More...
 
- Public Member Functions inherited from nnp::SymGrpBaseComp
double getRmin () const
 Getter for rmin. More...
 
double getRmax () const
 Getter for rmax. More...
 
- Public Member Functions inherited from nnp::SymGrp
virtual ~SymGrp ()
 Virtual destructor. More...
 
virtual bool operator== (SymGrp const &rhs) const =0
 Overload == operator. More...
 
virtual bool operator< (SymGrp const &rhs) const =0
 Overload < operator. More...
 
bool operator!= (SymGrp const &rhs) const
 Overload != operator. More...
 
bool operator> (SymGrp const &rhs) const
 Overload > operator. More...
 
bool operator<= (SymGrp const &rhs) const
 Overload <= operator. More...
 
bool operator>= (SymGrp const &rhs) const
 Overload >= operator. More...
 
virtual bool addMember (SymFnc const *const symmetryFunction)=0
 Potentially add a member to group. More...
 
virtual void sortMembers ()=0
 Sort member symmetry functions. More...
 
virtual void setScalingFactors ()=0
 Fill scalingFactors with values from member symmetry functions. More...
 
virtual void calculate (Atom &atom, bool const derivatives) const =0
 Calculate all symmetry functions of this group for one atom. More...
 
virtual std::vector< std::string > parameterLines () const =0
 Give symmetry function group parameters on multiple lines. More...
 
void setIndex (std::size_t index)
 Set private index member variable. More...
 
std::size_t getIndex () const
 Get private index member variable. More...
 
std::size_t getType () const
 Get private type member variable. More...
 
std::size_t getEc () const
 Get private ec member variable. More...
 

Private Member Functions

virtual std::vector< SymFncBaseCompAngWeighted const * > getMembers () const
 Get symmetry function members. More...
 

Private Attributes

std::vector< SymFncCompAngwWeighted const * > members
 Vector of all group member pointers. More...
 

Additional Inherited Members

- Protected Types inherited from nnp::SymGrp
typedef std::map< std::string, std::pair< std::string, std::string > > PrintFormat
 
typedef std::vector< std::string > PrintOrder
 
- Protected Member Functions inherited from nnp::SymGrpBaseCompAngWeighted
 SymGrpBaseCompAngWeighted (std::size_t type, ElementMap const &elementMap)
 Constructor, sets type. More...
 
virtual std::vector< SymFncBaseCompAngWeighted const * > getMembers () const =0
 Get symmetry function members. More...
 
- Protected Member Functions inherited from nnp::SymGrpBaseComp
 SymGrpBaseComp (std::size_t type, ElementMap const &elementMap)
 Constructor, sets type. More...
 
- Protected Member Functions inherited from nnp::SymGrp
 SymGrp (std::size_t type, ElementMap const &elementMap)
 Constructor, sets type. More...
 
std::string getPrintFormatCommon () const
 Get common parameter line format string. More...
 
std::string getPrintFormatMember () const
 Get member parameter line format string. More...
 
- Static Protected Member Functions inherited from nnp::SymGrp
static PrintFormat const initializePrintFormat ()
 Initialize static print format map for all possible parameters. More...
 
static PrintOrder const initializePrintOrder ()
 Initialize static print order vector for all possible parameters. More...
 
- Protected Attributes inherited from nnp::SymGrpBaseCompAngWeighted
std::vector< bool > calculateComp
 Vector indicating whether compact function needs to be recalculated. More...
 
std::vector< double > mrl
 Member rl. More...
 
std::vector< double > mrc
 Member rc. More...
 
std::vector< double > mal
 Member angleLeft. More...
 
std::vector< double > mar
 Member angleRight. More...
 
std::vector< std::vector< std::vector< std::size_t > > > mci
 Member cache indices for actual neighbor element. More...
 
- Protected Attributes inherited from nnp::SymGrpBaseComp
double rmin
 Minimum radius within group. More...
 
double rmax
 Maximum radius within group. More...
 
- Protected Attributes inherited from nnp::SymGrp
std::size_t type
 Symmetry function type. More...
 
ElementMap elementMap
 Copy of element map. More...
 
std::size_t index
 Symmetry function group index. More...
 
std::size_t ec
 Element index of center atom (common feature). More...
 
double convLength
 Data set normalization length conversion factor. More...
 
std::vector< size_t > memberIndex
 Vector containing indices of all member symmetry functions. More...
 
std::vector< double > scalingFactors
 Scaling factors of all member symmetry functions. More...
 
std::set< std::string > parametersCommon
 Set of common parameters IDs. More...
 
std::set< std::string > parametersMember
 Set of common parameters IDs. More...
 
std::vector< std::vector< std::size_t > > memberIndexPerElement
 Vector containing per-element indices of all member symmetry functions. More...
 
- Static Protected Attributes inherited from nnp::SymGrp
static PrintFormat const printFormat = initializePrintFormat()
 Map of parameter format strings and empty strings. More...
 
static PrintOrder const printOrder = initializePrintOrder()
 Vector of parameters in order of printing. More...
 

Detailed Description

Weighted wide angular symmetry function with compact support (type 25)

\[ G^{25}_i = \sum_{\substack{j,k\neq i \\ j < k}} Z_j Z_k C(r_{ij}, r_l, r_c) C(r_{ik}, r_l, r_c) C(\theta_{ijk}, \theta_l, \theta_r), \]

where \(C(x, x_\text{low}, x_\text{high})\) is a function with compact support \(\left[x_\text{low}, x_\text{high}\right]\). \(Z_j\) is defined as the atomic number of the neighbor atom \(j\).

Common features:

  • element of central atom

Definition at line 50 of file SymGrpCompAngwWeighted.h.

Constructor & Destructor Documentation

◆ SymGrpCompAngwWeighted()

SymGrpCompAngwWeighted::SymGrpCompAngwWeighted ( ElementMap const &  elementMap)

Constructor, sets type = 25.

Definition at line 30 of file SymGrpCompAngwWeighted.cpp.

31 :
33{
34}
SymGrpBaseCompAngWeighted(std::size_t type, ElementMap const &elementMap)
Constructor, sets type.
ElementMap elementMap
Copy of element map.
Definition: SymGrp.h:108

Member Function Documentation

◆ operator==()

bool SymGrpCompAngwWeighted::operator== ( SymGrp const &  rhs) const
virtual

Overload == operator.

Implements nnp::SymGrp.

Definition at line 36 of file SymGrpCompAngwWeighted.cpp.

37{
38 if (ec != rhs.getEc() ) return false;
39 if (type != rhs.getType()) return false;
40 return true;
41}
std::size_t type
Symmetry function type.
Definition: SymGrp.h:106
std::size_t ec
Element index of center atom (common feature).
Definition: SymGrp.h:112

References nnp::SymGrp::ec, nnp::SymGrp::getEc(), nnp::SymGrp::getType(), and nnp::SymGrp::type.

Here is the call graph for this function:

◆ operator<()

bool SymGrpCompAngwWeighted::operator< ( SymGrp const &  rhs) const
virtual

Overload < operator.

Implements nnp::SymGrp.

Definition at line 43 of file SymGrpCompAngwWeighted.cpp.

44{
45 if (ec < rhs.getEc() ) return true;
46 else if (ec > rhs.getEc() ) return false;
47 if (type < rhs.getType()) return true;
48 else if (type > rhs.getType()) return false;
49 return false;
50}

References nnp::SymGrp::ec, nnp::SymGrp::getEc(), nnp::SymGrp::getType(), and nnp::SymGrp::type.

Here is the call graph for this function:

◆ addMember()

bool SymGrpCompAngwWeighted::addMember ( SymFnc const *const  symmetryFunction)
virtual

Potentially add a member to group.

Parameters
[in]symmetryFunctionCandidate symmetry function.
Returns
If addition was successful.

If symmetry function is compatible with common feature list its pointer will be added to members.

Implements nnp::SymGrp.

Definition at line 52 of file SymGrpCompAngwWeighted.cpp.

53{
54 if (symmetryFunction->getType() != type) return false;
55
56 SymFncCompAngwWeighted const* sf =
57 dynamic_cast<SymFncCompAngwWeighted const*>(symmetryFunction);
58
59 if (members.empty())
60 {
61 ec = sf->getEc();
63 }
64
65 if (sf->getEc() != ec ) return false;
66 if (sf->getConvLength() != convLength )
67 {
68 throw runtime_error("ERROR: Unable to add symmetry function members "
69 "with different conversion factors.\n");
70 }
71
72 if (sf->getRl() <= 0.0) rmin = 0.0;
73 else rmin = min( rmin, sf->getRl() );
74 rmax = max( rmax, sf->getRc() );
75
76 members.push_back(sf);
77
78 return true;
79}
double getRl() const
Get private rl member variable.
Weighted wide angular symmetry function with compact support (type 25)
double getConvLength() const
Get private convLength member variable.
Definition: SymFnc.h:364
double getRc() const
Get private rc member variable.
Definition: SymFnc.h:360
std::size_t getEc() const
Get private ec member variable.
Definition: SymFnc.h:356
double rmin
Minimum radius within group.
double rmax
Maximum radius within group.
std::vector< SymFncCompAngwWeighted const * > members
Vector of all group member pointers.
double convLength
Data set normalization length conversion factor.
Definition: SymGrp.h:114

References nnp::SymGrp::convLength, nnp::SymGrp::ec, nnp::SymFnc::getConvLength(), nnp::SymFnc::getEc(), nnp::SymFnc::getRc(), nnp::SymFncBaseComp::getRl(), nnp::SymFnc::getType(), members, nnp::SymGrpBaseComp::rmax, nnp::SymGrpBaseComp::rmin, and nnp::SymGrp::type.

Here is the call graph for this function:

◆ sortMembers()

void SymGrpCompAngwWeighted::sortMembers ( )
virtual

Sort member symmetry functions.

Also allocate and precalculate additional stuff.

Implements nnp::SymGrp.

Definition at line 81 of file SymGrpCompAngwWeighted.cpp.

82{
83 sort(members.begin(),
84 members.end(),
85 comparePointerTargets<SymFncCompAngwWeighted const>);
86
87 mrl.resize(members.size(), 0.0);
88 mrc.resize(members.size(), 0.0);
89 mal.resize(members.size(), 0.0);
90 mar.resize(members.size(), 0.0);
91 for (size_t i = 0; i < members.size(); i++)
92 {
93 mrl.at(i) = members[i]->getRl();
94 mrc.at(i) = members[i]->getRc();
95 mal.at(i) = members[i]->getAngleLeft() * M_PI / 180.0;
96 mar.at(i) = members[i]->getAngleRight() * M_PI / 180.0;
97 memberIndex.push_back(members[i]->getIndex());
98 memberIndexPerElement.push_back(members[i]->getIndexPerElement());
99 calculateComp.push_back(true);
100 }
101
102#ifndef N2P2_NO_SF_CACHE
103 mci.resize(members.size());
104 for (size_t k = 0; k < members.size(); ++k)
105 {
106 mci.at(k) = members.at(k)->getCacheIndices();
107 }
108#endif
109
110 return;
111}
std::vector< double > mal
Member angleLeft.
std::vector< double > mrc
Member rc.
std::vector< bool > calculateComp
Vector indicating whether compact function needs to be recalculated.
std::vector< double > mrl
Member rl.
std::vector< std::vector< std::vector< std::size_t > > > mci
Member cache indices for actual neighbor element.
std::vector< double > mar
Member angleRight.
std::vector< size_t > memberIndex
Vector containing indices of all member symmetry functions.
Definition: SymGrp.h:116
std::vector< std::vector< std::size_t > > memberIndexPerElement
Vector containing per-element indices of all member symmetry functions.
Definition: SymGrp.h:124
std::size_t getIndex() const
Get private index member variable.
Definition: SymGrp.h:184

References nnp::SymGrpBaseCompAngWeighted::calculateComp, nnp::SymGrp::getIndex(), nnp::SymGrpBaseCompAngWeighted::mal, nnp::SymGrpBaseCompAngWeighted::mar, nnp::SymGrpBaseCompAngWeighted::mci, nnp::SymGrp::memberIndex, nnp::SymGrp::memberIndexPerElement, members, nnp::SymGrpBaseCompAngWeighted::mrc, and nnp::SymGrpBaseCompAngWeighted::mrl.

Here is the call graph for this function:

◆ calculate()

void SymGrpCompAngwWeighted::calculate ( Atom atom,
bool const  derivatives 
) const
virtual

Calculate all symmetry functions of this group for one atom.

Parameters
[in,out]atomAtom for which symmetry functions are caluclated.
[in]derivativesIf also symmetry function derivatives will be calculated and saved.

Implements nnp::SymGrp.

Definition at line 119 of file SymGrpCompAngwWeighted.cpp.

121{
122 double* result = new double[members.size()];
123 double* radij = new double[members.size()];
124 double* dradij = new double[members.size()];
125 for (size_t l = 0; l < members.size(); ++l)
126 {
127 result[l] = 0.0;
128 radij[l] = 0.0;
129 dradij[l] = 0.0;
130 }
131
132 size_t numNeighbors = atom.numNeighbors;
133 // Prevent problematic condition in loop test below (j < numNeighbors - 1).
134 if (numNeighbors == 0) numNeighbors = 1;
135
136 for (size_t j = 0; j < numNeighbors - 1; j++)
137 {
138 Atom::Neighbor& nj = atom.neighbors[j];
139 size_t const nej = nj.element;
140 double const rij = nj.d;
141
142 if (rij < rmax && rij > rmin)
143 {
144 // Precalculate the radial part for ij
145 // Supposedly saves quite a number of operations
146 for (size_t l = 0; l < members.size(); ++l)
147 {
148 if (rij > mrl[l] && rij < mrc[l])
149 {
150 SymFncCompAngwWeighted const& sf = *(members[l]);
151#ifndef N2P2_NO_SF_CACHE
152 if (mci[l][nej].size() == 0)
153 {
154 sf.getCompactRadial(rij, radij[l], dradij[l]);
155 }
156 else
157 {
158 double& crad = nj.cache[mci[l][nej][0]];
159 double& cdrad = nj.cache[mci[l][nej][1]];
160 if (crad < 0) sf.getCompactRadial(rij, crad, cdrad);
161 radij[l] = crad;
162 dradij[l] = cdrad;
163 }
164#else
165 sf.getCompactRadial(rij, radij[l], dradij[l]);
166#endif
167 }
168 else radij[l] = 0.0;
169 }
170
171 // SIMPLE EXPRESSIONS:
172 //Vec3D drij(atom.neighbors[j].dr);
173 double const* const dr1 = nj.dr.r;
174
175 for (size_t k = j + 1; k < numNeighbors; k++)
176 {
177 Atom::Neighbor& nk = atom.neighbors[k];
178 size_t const nek = nk.element;
179 double const rik = nk.d;
180 if (rik < rmax && rik > rmin)
181 {
182 // SIMPLE EXPRESSIONS:
183 //Vec3D drik(atom.neighbors[k].dr);
184 //Vec3D drjk = drik - drij;
185 double const* const dr2 = nk.dr.r;
186 double const dr30 = dr2[0] - dr1[0];
187 double const dr31 = dr2[1] - dr1[1];
188 double const dr32 = dr2[2] - dr1[2];
189
190 // Energy calculation.
191 double const rinvijik = 1.0 / (rij * rik);
192 double const costijk = (dr1[0] * dr2[0] +
193 dr1[1] * dr2[1] +
194 dr1[2] * dr2[2]) * rinvijik;
195
196 // By definition, our polynomial is zero at 0 and 180 deg.
197 // Therefore, skip the whole rest which might yield some NaN
198 if (costijk <= -1.0 || costijk >= 1.0) continue;
199
200 double const acostijk = acos(costijk);
201
202 double const rinvij = rinvijik * rik;
203 double const rinvik = rinvijik * rij;
204 double const phiijik0 = rinvij
205 * (rinvik - rinvij * costijk);
206 double const phiikij0 = rinvik
207 * (rinvij - rinvik * costijk);
208 double dacostijk = 0.0;
209 if (derivatives)
210 {
211 dacostijk = -1.0 / sqrt(1.0 - costijk * costijk);
212 }
213
214 double ang;
215 double dang;
216 double radik;
217 double dradik;
218
219 for (size_t l = 0; l < members.size(); ++l)
220 {
221 // Break conditions.
222 if (radij[l] == 0.0 ||
223 rik <= mrl[l] || rik >= mrc[l] ||
224 acostijk <= mal[l] || acostijk >= mar[l])
225 {
226 continue;
227 }
228
229 SymFncCompAngwWeighted const& sf = *(members[l]);
230#ifndef N2P2_NO_SF_CACHE
231 if (mci[l][nek].size() == 0)
232 {
233 sf.getCompactRadial(rik, radik, dradik);
234 }
235 else
236 {
237 double& crad = nk.cache[mci[l][nek][0]];
238 double& cdrad = nk.cache[mci[l][nek][1]];
239 if (crad < 0) sf.getCompactRadial(rik, crad, cdrad);
240 radik = crad;
241 dradik = cdrad;
242 }
243#else
244 sf.getCompactRadial(rik, radik, dradik);
245#endif
246 sf.getCompactAngle(acostijk, ang, dang);
247
248 double const z = elementMap.atomicNumber(nej)
250 ang *= z;
251 double rad = radij[l] * radik;
252 result[l] += rad * ang;
253
254 // Force calculation.
255 if (!derivatives) continue;
256
257 dang *= dacostijk;
258 double const phiijik = phiijik0 * dang;
259 double const phiikij = phiikij0 * dang;
260 double const psiijik = rinvijik * dang;
261
262 double const chiij = rinvij * dradij[l] * radik;
263 double const chiik = rinvik * radij[l] * dradik;
264
265 double p1;
266 double p2;
267 double p3;
268
269 if (dang != 0.0 && rad != 0.0)
270 {
271 rad *= scalingFactors[l] * z;
272 ang *= scalingFactors[l];
273 p1 = rad * phiijik + ang * chiij;
274 p2 = rad * phiikij + ang * chiik;
275 p3 = rad * psiijik;
276 }
277 else if (ang != 0.0)
278 {
279 ang *= scalingFactors[l];
280
281 p1 = ang * chiij;
282 p2 = ang * chiik;
283 p3 = 0.0;
284 }
285 else continue;
286
287 // SIMPLE EXPRESSIONS:
288 // Save force contributions in Atom storage.
289 //atom.dGdr[memberIndex[l]] += p1 * drij
290 // + p2 * drik;
291 //atom.neighbors[j].
292 // dGdr[memberIndex[l]] -= p1 * drij
293 // + p3 * drjk;
294 //atom.neighbors[k].
295 // dGdr[memberIndex[l]] -= p2 * drik
296 // - p3 * drjk;
297
298 double const p1drijx = p1 * dr1[0];
299 double const p1drijy = p1 * dr1[1];
300 double const p1drijz = p1 * dr1[2];
301
302 double const p2drikx = p2 * dr2[0];
303 double const p2driky = p2 * dr2[1];
304 double const p2drikz = p2 * dr2[2];
305
306 double const p3drjkx = p3 * dr30;
307 double const p3drjky = p3 * dr31;
308 double const p3drjkz = p3 * dr32;
309
310#ifndef N2P2_FULL_SFD_MEMORY
311 size_t li = memberIndex[l];
312#else
313 size_t const li = memberIndex[l];
314#endif
315 double* dGdr = atom.dGdr[li].r;
316 dGdr[0] += p1drijx + p2drikx;
317 dGdr[1] += p1drijy + p2driky;
318 dGdr[2] += p1drijz + p2drikz;
319
320#ifndef N2P2_FULL_SFD_MEMORY
321 li = memberIndexPerElement[l][nej];
322#endif
323 dGdr = nj.dGdr[li].r;
324 dGdr[0] -= p1drijx + p3drjkx;
325 dGdr[1] -= p1drijy + p3drjky;
326 dGdr[2] -= p1drijz + p3drjkz;
327
328#ifndef N2P2_FULL_SFD_MEMORY
329 li = memberIndexPerElement[l][nek];
330#endif
331 dGdr = nk.dGdr[li].r;
332 dGdr[0] -= p2drikx - p3drjkx;
333 dGdr[1] -= p2driky - p3drjky;
334 dGdr[2] -= p2drikz - p3drjkz;
335 } // l
336 } // rik <= rc
337 } // k
338 } // rij <= rc
339 } // j
340
341 for (size_t l = 0; l < members.size(); ++l)
342 {
343 atom.G[memberIndex[l]] = members[l]->scale(result[l]);
344 }
345
346 delete[] result;
347 delete[] radij;
348 delete[] dradij;
349
350 return;
351}
std::size_t atomicNumber(std::size_t index) const
Get atomic number from element index.
Definition: ElementMap.h:145
void getCompactRadial(double const x, double &fx, double &dfx) const
void getCompactAngle(double const x, double &fx, double &dfx) const
std::vector< double > scalingFactors
Scaling factors of all member symmetry functions.
Definition: SymGrp.h:118
Struct to store information on neighbor atoms.
Definition: Atom.h:35
std::vector< double > cache
Symmetry function cache (e.g. for cutoffs, compact functions).
Definition: Atom.h:48
std::size_t element
Element index of neighbor atom.
Definition: Atom.h:41
double d
Distance to neighbor atom.
Definition: Atom.h:43
Vec3D dr
Distance vector to neighbor atom.
Definition: Atom.h:45
std::vector< Vec3D > dGdr
Derivatives of symmetry functions with respect to neighbor coordinates.
Definition: Atom.h:59
std::vector< Neighbor > neighbors
Neighbor array (maximum number defined in macros.h.
Definition: Atom.h:148
std::vector< Vec3D > dGdr
Derivative of symmetry functions with respect to this atom's coordinates.
Definition: Atom.h:146
std::vector< double > G
Symmetry function values.
Definition: Atom.h:134
std::size_t numNeighbors
Total number of neighbors.
Definition: Atom.h:106
double r[3]
cartesian coordinates.
Definition: Vec3D.h:31

References nnp::ElementMap::atomicNumber(), nnp::Atom::Neighbor::cache, nnp::Atom::Neighbor::d, nnp::Atom::Neighbor::dGdr, nnp::Atom::dGdr, nnp::Atom::Neighbor::dr, nnp::Atom::Neighbor::element, nnp::SymGrp::elementMap, nnp::Atom::G, nnp::SymFncBaseCompAngWeighted::getCompactAngle(), nnp::SymFncBaseCompAngWeighted::getCompactRadial(), nnp::SymGrpBaseCompAngWeighted::mal, nnp::SymGrpBaseCompAngWeighted::mar, nnp::SymGrpBaseCompAngWeighted::mci, nnp::SymGrp::memberIndex, nnp::SymGrp::memberIndexPerElement, members, nnp::SymGrpBaseCompAngWeighted::mrc, nnp::SymGrpBaseCompAngWeighted::mrl, nnp::Atom::neighbors, nnp::Atom::numNeighbors, nnp::Vec3D::r, nnp::SymGrpBaseComp::rmin, and nnp::SymGrp::scalingFactors.

Here is the call graph for this function:

◆ getMembers()

std::vector< SymFncBaseCompAngWeighted const * > nnp::SymGrpCompAngwWeighted::getMembers ( ) const
inlineprivatevirtual

Get symmetry function members.

Returns
Vector of pointers casted to base class.

Implements nnp::SymGrpBaseCompAngWeighted.

Definition at line 96 of file SymGrpCompAngwWeighted.h.

97{
98 std::vector<SymFncBaseCompAngWeighted const*> cast;
99
100 for (auto p : members)
101 {
102 cast.push_back(dynamic_cast<SymFncBaseCompAngWeighted const*>(p));
103 }
104
105 return cast;
106}
size_t p
Definition: nnp-cutoff.cpp:33

References members, and p.

Member Data Documentation

◆ members

std::vector<SymFncCompAngwWeighted const*> nnp::SymGrpCompAngwWeighted::members
private

Vector of all group member pointers.

Definition at line 92 of file SymGrpCompAngwWeighted.h.

Referenced by addMember(), calculate(), getMembers(), and sortMembers().


The documentation for this class was generated from the following files: