Package ffx.potential.nonbonded.pme
Class PermanentFieldRegion
java.lang.Object
edu.rit.pj.ParallelConstruct
edu.rit.pj.ParallelRegion
ffx.potential.nonbonded.pme.PermanentFieldRegion
- All Implemented Interfaces:
- MaskingInterface
Parallel computation of the permanent field.
 
This class can be executed by a ParallelTeam with exactly 2 threads.
The Real Space and Reciprocal Space Sections will be run concurrently, each with the number of threads defined by their respective ParallelTeam instances.
- Since:
- 1.0
- Author:
- Michael J. Schnieders
- 
Field SummaryFieldsModifier and TypeFieldDescriptiondouble[][][]Dimensions of [nsymm][nAtoms][3]double[][][]protected int[][]Polarization groups.
- 
Constructor SummaryConstructorsConstructorDescriptionPermanentFieldRegion(ParallelTeam pt, ForceField forceField, boolean lambdaTerm) 
- 
Method SummaryModifier and TypeMethodDescriptionvoidapplyMask(int i, boolean[] is14, double[]... masks) Apply permanent field masking rules.longgetInitTime(int threadId) longgetPermTime(int threadId) longvoidinit(Atom[] atoms, Crystal crystal, double[][][] coordinates, double[][][] globalMultipole, double[][][] inducedDipole, double[][][] inducedDipoleCR, int[][][] neighborLists, ScaleParameters scaleParameters, boolean[] use, int[] molecule, double[] ipdamp, double[] thole, int[][] ip11, int[][] mask12, int[][] mask13, int[][] mask14, LambdaMode lambdaMode, boolean reciprocalSpaceTerm, ReciprocalSpace reciprocalSpace, EwaldParameters ewaldParameters, PCGSolver pcgSolver, IntegerSchedule permanentSchedule, RealSpaceNeighborParameters realSpaceNeighborParameters, AtomicDoubleArray3D field, AtomicDoubleArray3D fieldCR) voidvoidremoveMask(int i, boolean[] is14, double[]... masks) Remove permanent field masking rules.voidrun()Execute parallel code.Methods inherited from class edu.rit.pj.ParallelRegionbarrier, barrier, critical, critical, criticalNonexclusive, criticalNonexclusive, execute, execute, execute, execute, execute, execute, execute, execute, execute, execute, execute, execute, execute, execute, execute, execute, execute, execute, execute, execute, execute, execute, finish, startMethods inherited from class edu.rit.pj.ParallelConstructgetThreadCount, getThreadIndex, isExecutingInParallel, region, team
- 
Field Details- 
inducedDipolepublic double[][][] inducedDipoleDimensions of [nsymm][nAtoms][3]
- 
inducedDipoleCRpublic double[][][] inducedDipoleCR
- 
ip11protected int[][] ip11Polarization groups.
 
- 
- 
Constructor Details- 
PermanentFieldRegion
 
- 
- 
Method Details- 
applyMaskpublic void applyMask(int i, boolean[] is14, double[]... masks) Apply permanent field masking rules.- Specified by:
- applyMaskin interface- MaskingInterface
- Parameters:
- i- The atom whose masking rules should be applied.
- is14- True if atom i and the current atom are 1-4 to each other.
- masks- One or more masking arrays.
 
- 
initTimingspublic void initTimings()
- 
getRealSpacePermTimepublic long getRealSpacePermTime()
- 
getInitTimepublic long getInitTime(int threadId) 
- 
getPermTimepublic long getPermTime(int threadId) 
- 
initpublic void init(Atom[] atoms, Crystal crystal, double[][][] coordinates, double[][][] globalMultipole, double[][][] inducedDipole, double[][][] inducedDipoleCR, int[][][] neighborLists, ScaleParameters scaleParameters, boolean[] use, int[] molecule, double[] ipdamp, double[] thole, int[][] ip11, int[][] mask12, int[][] mask13, int[][] mask14, LambdaMode lambdaMode, boolean reciprocalSpaceTerm, ReciprocalSpace reciprocalSpace, EwaldParameters ewaldParameters, PCGSolver pcgSolver, IntegerSchedule permanentSchedule, RealSpaceNeighborParameters realSpaceNeighborParameters, AtomicDoubleArray3D field, AtomicDoubleArray3D fieldCR) 
- 
removeMaskpublic void removeMask(int i, boolean[] is14, double[]... masks) Remove permanent field masking rules.- Specified by:
- removeMaskin interface- MaskingInterface
- Parameters:
- i- The atom whose masking rules should be removed.
- is14- True if atom i and the current atom are 1-4 to each other.
- masks- One or more masking arrays.
 
- 
runpublic void run()Description copied from class:ParallelRegionExecute parallel code. All threads of the parallel team call therun()method concurrently.The run()method must be implemented in a subclass.- Specified by:
- runin class- ParallelRegion
 
 
-