Open Qmin  0.8.0
GPU-accelerated Q-tensor-based liquid crystal simulations
Public Member Functions | Public Attributes | Protected Member Functions | Protected Attributes | List of all members
energyMinimizerNesterovAG Class Reference

#include <energyMinimizerNesterovAG.h>

Inheritance diagram for energyMinimizerNesterovAG:
Inheritance graph
[legend]
Collaboration diagram for energyMinimizerNesterovAG:
Collaboration graph
[legend]

Public Member Functions

 energyMinimizerNesterovAG ()
 The basic constructor. More...
 
 energyMinimizerNesterovAG (shared_ptr< simpleModel > system)
 The basic constructor that feeds in a target system to minimize. More...
 
virtual void initializeParameters ()
 Sets a bunch of default parameters that do not depend on the number of degrees of freedom. More...
 
virtual void initializeFromModel ()
 by default, set Ndof More...
 
void minimize ()
 Minimize to either the force tolerance or the maximum number of iterations. More...
 
virtual void performUpdate ()
 The "intergate equatios of motion just calls minimize. More...
 
void setNesterovAGParameters (scalar _dt=0.0001, scalar _mu=0.01, scalar fc=1e-12)
 
scalar getMaxForce ()
 Return the maximum force. More...
 
void setForceCutoff (scalar fc)
 Set the force cutoff. More...
 
virtual void integrateEquationOfMotion ()
 
virtual void integrateEOMGPU ()
 
virtual void integrateEOMCPU ()
 
virtual scalar getClassSize ()
 
virtual void Update (int timestep)
 The fundamental function that a controlling Simulation can call. More...
 
void setSimulation (shared_ptr< basicSimulation > _sim)
 set the simulation More...
 
virtual void setModel (shared_ptr< simpleModel > _model)
 virtual function to allow the model to be a derived class More...
 
void setPeriod (int _p)
 set the period More...
 
void setPhase (int _p)
 set the phase More...
 
virtual void spatialSorting ()
 allow for spatial sorting to be called if necessary... More...
 
virtual void setReproducible (bool rep)
 Allow for a reproducibility call to be made. More...
 
virtual void setGPU (bool _useGPU=true)
 Enforce GPU operation. More...
 
int getNdof ()
 Get the number of degrees of freedom of the equation of motion. More...
 
void setNdof (int _n)
 Set the number of degrees of freedom of the equation of motion. More...
 
virtual void setDeltaT (scalar dt)
 allow all updaters to potentially implement an internal time scale More...
 
virtual void setNThreads (int n)
 allow for setting multiple threads More...
 
void setMaximumIterations (int maxIt)
 Set the maximum number of iterations before terminating (or set to -1 to ignore) More...
 
int getCurrentIterations ()
 
int getMaxIterations ()
 
void setCurrentIterations (int newIterations)
 
int getNTotal ()
 communicate the number of non-object sites across ranks More...
 

Public Attributes

bool scheduledMomentum
 
GPUArray< dVec > displacement
 an array of displacements More...
 
shared_ptr< basicSimulationsim
 A pointer to the governing simulation. More...
 
shared_ptr< simpleModelmodel
 A pointer to a simpleModel that the updater acts on. More...
 
vector< scalarupdaterData
 
int iterations
 The number of iterations performed. More...
 

Protected Member Functions

void nesterovStepCPU ()
 
void nesterovStepGPU ()
 

Protected Attributes

scalar mu
 
scalar forceMax
 
scalar forceCutoff
 The cutoff value of the maximum force. More...
 
scalar lambda
 
scalar gamma
 
GPUArray< dVec > alternateSequence
 
GPUArray< scalarsumReductionIntermediate
 Utility array for simple reductions. More...
 
GPUArray< scalarsumReductionIntermediate2
 
GPUArray< scalarsumReductions
 Utility array for simple reductions. More...
 
shared_ptr< kernelTunerdotProductTuner
 kernel tuner for performance More...
 
shared_ptr< kernelTunerminimizationTuner
 
int nThreads =1
 number of threads to use More...
 
int Period
 The period of the updater... the updater will work every Period timesteps. More...
 
int Phase
 The phase of the updater... the updater will work every Period timesteps offset by a phase. More...
 
bool useGPU
 whether the updater does its work on the GPU or not More...
 
bool neverGPU
 whether the updater never does work on the GPU More...
 
int Ndof
 some measure of the number of degrees of freedom the equations of motion might need to know about locally More...
 
int nTotal
 the total number of non-object sites across all ranks More...
 
bool reproducible
 whether the RNGs give reproducible results More...
 
scalar deltaT
 The internal time step size. More...
 
int maxIterations
 The maximum number of iterations allowed. More...
 

Constructor & Destructor Documentation

◆ energyMinimizerNesterovAG() [1/2]

energyMinimizerNesterovAG::energyMinimizerNesterovAG ( )
inline

The basic constructor.

References initializeParameters().

◆ energyMinimizerNesterovAG() [2/2]

energyMinimizerNesterovAG::energyMinimizerNesterovAG ( shared_ptr< simpleModel system)

The basic constructor that feeds in a target system to minimize.

References initializeFromModel(), initializeParameters(), and updater::setModel().

Member Function Documentation

◆ initializeParameters()

void energyMinimizerNesterovAG::initializeParameters ( )
virtual

Sets a bunch of default parameters that do not depend on the number of degrees of freedom.

Initialize the minimizer with some default parameters. that do not depend on Ndof

References dotProductTuner, forceMax, updater::iterations, lambda, minimizationTuner, GPUArray< T >::resize(), scheduledMomentum, updater::setGPU(), updater::setMaximumIterations(), setNesterovAGParameters(), and sumReductions.

Referenced by energyMinimizerNesterovAG().

◆ initializeFromModel()

void energyMinimizerNesterovAG::initializeFromModel ( )
virtual

◆ minimize()

void energyMinimizerNesterovAG::minimize ( )

◆ performUpdate()

virtual void energyMinimizerNesterovAG::performUpdate ( )
inlinevirtual

The "intergate equatios of motion just calls minimize.

Reimplemented from equationOfMotion.

References minimize().

◆ setNesterovAGParameters()

void energyMinimizerNesterovAG::setNesterovAGParameters ( scalar  _dt = 0.0001,
scalar  _mu = 0.01,
scalar  fc = 1e-12 
)
inline

References updater::deltaT, mu, and setForceCutoff().

Referenced by initializeParameters().

◆ getMaxForce()

scalar energyMinimizerNesterovAG::getMaxForce ( )
inlinevirtual

Return the maximum force.

Reimplemented from updater.

References forceMax.

◆ setForceCutoff()

void energyMinimizerNesterovAG::setForceCutoff ( scalar  fc)
inline

Set the force cutoff.

References forceCutoff.

Referenced by setNesterovAGParameters().

◆ nesterovStepCPU()

void energyMinimizerNesterovAG::nesterovStepCPU ( )
protected

◆ nesterovStepGPU()

void energyMinimizerNesterovAG::nesterovStepGPU ( )
protected

◆ integrateEquationOfMotion()

virtual void equationOfMotion::integrateEquationOfMotion ( )
inlinevirtualinherited

◆ integrateEOMGPU()

virtual void equationOfMotion::integrateEOMGPU ( )
inlinevirtualinherited

◆ integrateEOMCPU()

virtual void equationOfMotion::integrateEOMCPU ( )
inlinevirtualinherited

◆ getClassSize()

virtual scalar equationOfMotion::getClassSize ( )
inlinevirtualinherited

◆ Update()

virtual void updater::Update ( int  timestep)
inlinevirtualinherited

The fundamental function that a controlling Simulation can call.

References updater::performUpdate(), updater::Period, and updater::Phase.

◆ setSimulation()

void updater::setSimulation ( shared_ptr< basicSimulation _sim)
inlineinherited

set the simulation

References updater::sim.

◆ setModel()

virtual void updater::setModel ( shared_ptr< simpleModel _model)
inlinevirtualinherited

◆ setPeriod()

void updater::setPeriod ( int  _p)
inlineinherited

set the period

References updater::Period.

◆ setPhase()

void updater::setPhase ( int  _p)
inlineinherited

set the phase

References updater::Phase.

◆ spatialSorting()

virtual void updater::spatialSorting ( )
inlinevirtualinherited

allow for spatial sorting to be called if necessary...

◆ setReproducible()

virtual void updater::setReproducible ( bool  rep)
inlinevirtualinherited

Allow for a reproducibility call to be made.

References updater::reproducible.

◆ setGPU()

virtual void updater::setGPU ( bool  _useGPU = true)
inlinevirtualinherited

◆ getNdof()

int updater::getNdof ( )
inlineinherited

Get the number of degrees of freedom of the equation of motion.

References updater::Ndof.

◆ setNdof()

void updater::setNdof ( int  _n)
inlineinherited

Set the number of degrees of freedom of the equation of motion.

References updater::Ndof.

◆ setDeltaT()

virtual void updater::setDeltaT ( scalar  dt)
inlinevirtualinherited

allow all updaters to potentially implement an internal time scale

Reimplemented in energyMinimizerFIRE.

References updater::deltaT.

Referenced by energyMinimizerGradientDescent::initializeParameters(), and energyMinimizerGradientDescent::setGradientDescentParameters().

◆ setNThreads()

virtual void updater::setNThreads ( int  n)
inlinevirtualinherited

allow for setting multiple threads

References n, and updater::nThreads.

◆ setMaximumIterations()

void updater::setMaximumIterations ( int  maxIt)
inlineinherited

◆ getCurrentIterations()

int updater::getCurrentIterations ( )
inlineinherited

References updater::iterations.

◆ getMaxIterations()

int updater::getMaxIterations ( )
inlineinherited

◆ setCurrentIterations()

void updater::setCurrentIterations ( int  newIterations)
inlineinherited

References updater::iterations.

◆ getNTotal()

int updater::getNTotal ( )
inherited

communicate the number of non-object sites across ranks

References access_location::host, updater::model, updater::Ndof, updater::nTotal, access_mode::read, updater::sim, and updater::updaterData.

Member Data Documentation

◆ scheduledMomentum

bool energyMinimizerNesterovAG::scheduledMomentum

Referenced by initializeParameters(), and minimize().

◆ mu

scalar energyMinimizerNesterovAG::mu
protected

◆ forceMax

scalar energyMinimizerNesterovAG::forceMax
protected

◆ forceCutoff

scalar energyMinimizerNesterovAG::forceCutoff
protected

The cutoff value of the maximum force.

Referenced by minimize(), and setForceCutoff().

◆ lambda

scalar energyMinimizerNesterovAG::lambda
protected

Referenced by initializeParameters(), and minimize().

◆ gamma

scalar energyMinimizerNesterovAG::gamma
protected

Referenced by minimize().

◆ alternateSequence

GPUArray<dVec> energyMinimizerNesterovAG::alternateSequence
protected

◆ sumReductionIntermediate

GPUArray<scalar> energyMinimizerNesterovAG::sumReductionIntermediate
protected

Utility array for simple reductions.

Referenced by initializeFromModel(), and nesterovStepGPU().

◆ sumReductionIntermediate2

GPUArray<scalar> energyMinimizerNesterovAG::sumReductionIntermediate2
protected

◆ sumReductions

GPUArray<scalar> energyMinimizerNesterovAG::sumReductions
protected

Utility array for simple reductions.

Referenced by initializeParameters(), and nesterovStepGPU().

◆ dotProductTuner

shared_ptr<kernelTuner> energyMinimizerNesterovAG::dotProductTuner
protected

kernel tuner for performance

Referenced by initializeParameters(), and nesterovStepGPU().

◆ minimizationTuner

shared_ptr<kernelTuner> energyMinimizerNesterovAG::minimizationTuner
protected

◆ displacement

GPUArray<dVec> equationOfMotion::displacement
inherited

◆ sim

shared_ptr<basicSimulation> updater::sim
inherited

◆ model

shared_ptr<simpleModel> updater::model
inherited

◆ updaterData

vector<scalar> updater::updaterData
inherited

◆ iterations

int updater::iterations
inherited

◆ nThreads

int updater::nThreads =1
protectedinherited

number of threads to use

Referenced by updater::setNThreads().

◆ Period

int updater::Period
protectedinherited

The period of the updater... the updater will work every Period timesteps.

Referenced by updater::setPeriod(), updater::Update(), and updater::updater().

◆ Phase

int updater::Phase
protectedinherited

The phase of the updater... the updater will work every Period timesteps offset by a phase.

Referenced by updater::setPhase(), updater::Update(), and updater::updater().

◆ useGPU

bool updater::useGPU
protectedinherited

◆ neverGPU

bool updater::neverGPU
protectedinherited

◆ Ndof

int updater::Ndof
protectedinherited

◆ nTotal

int updater::nTotal
protectedinherited

◆ reproducible

bool updater::reproducible
protectedinherited

whether the RNGs give reproducible results

Referenced by updater::setReproducible(), and updater::updater().

◆ deltaT

scalar updater::deltaT
protectedinherited

◆ maxIterations

int updater::maxIterations
protectedinherited

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