source: tests/regression/Simple_configuration/3/post/test.conf@ b9c847

Action_Thermostats Add_AtomRandomPerturbation Add_FitFragmentPartialChargesAction Add_RotateAroundBondAction Add_SelectAtomByNameAction Added_ParseSaveFragmentResults AddingActions_SaveParseParticleParameters Adding_Graph_to_ChangeBondActions Adding_MD_integration_tests Adding_ParticleName_to_Atom Adding_StructOpt_integration_tests AtomFragments Automaking_mpqc_open AutomationFragmentation_failures Candidate_v1.5.4 Candidate_v1.6.0 Candidate_v1.6.1 Candidate_v1.7.0 ChangeBugEmailaddress ChangingTestPorts ChemicalSpaceEvaluator CombiningParticlePotentialParsing Combining_Subpackages Debian_Package_split Debian_package_split_molecuildergui_only Disabling_MemDebug Docu_Python_wait EmpiricalPotential_contain_HomologyGraph EmpiricalPotential_contain_HomologyGraph_documentation Enable_parallel_make_install Enhance_userguide Enhanced_StructuralOptimization Enhanced_StructuralOptimization_continued Example_ManyWaysToTranslateAtom Exclude_Hydrogens_annealWithBondGraph FitPartialCharges_GlobalError Fix_BoundInBox_CenterInBox_MoleculeActions Fix_ChargeSampling_PBC Fix_ChronosMutex Fix_FitPartialCharges Fix_FitPotential_needs_atomicnumbers Fix_ForceAnnealing Fix_IndependentFragmentGrids Fix_ParseParticles Fix_ParseParticles_split_forward_backward_Actions Fix_PopActions Fix_QtFragmentList_sorted_selection Fix_Restrictedkeyset_FragmentMolecule Fix_StatusMsg Fix_StepWorldTime_single_argument Fix_Verbose_Codepatterns Fix_fitting_potentials Fixes ForceAnnealing_goodresults ForceAnnealing_oldresults ForceAnnealing_tocheck ForceAnnealing_with_BondGraph ForceAnnealing_with_BondGraph_continued ForceAnnealing_with_BondGraph_continued_betteresults ForceAnnealing_with_BondGraph_contraction-expansion FragmentAction_writes_AtomFragments FragmentMolecule_checks_bonddegrees GeometryObjects Gui_Fixes Gui_displays_atomic_force_velocity ImplicitCharges IndependentFragmentGrids IndependentFragmentGrids_IndividualZeroInstances IndependentFragmentGrids_IntegrationTest IndependentFragmentGrids_Sole_NN_Calculation JobMarket_RobustOnKillsSegFaults JobMarket_StableWorkerPool JobMarket_unresolvable_hostname_fix MoreRobust_FragmentAutomation ODR_violation_mpqc_open PartialCharges_OrthogonalSummation PdbParser_setsAtomName PythonUI_with_named_parameters QtGui_reactivate_TimeChanged_changes Recreated_GuiChecks Rewrite_FitPartialCharges RotateToPrincipalAxisSystem_UndoRedo SaturateAtoms_findBestMatching SaturateAtoms_singleDegree StoppableMakroAction Subpackage_CodePatterns Subpackage_JobMarket Subpackage_LinearAlgebra Subpackage_levmar Subpackage_mpqc_open Subpackage_vmg Switchable_LogView ThirdParty_MPQC_rebuilt_buildsystem TrajectoryDependenant_MaxOrder TremoloParser_IncreasedPrecision TremoloParser_MultipleTimesteps TremoloParser_setsAtomName Ubuntu_1604_changes stable
Last change on this file since b9c847 was 274d45, checked in by Frederik Heber <heber@…>, 15 years ago

FIX: Atoms were stored not in the sequence they were loaded.

  1. The main problem is molecule::atomSet which is a set<atom *>, i.e. atoms are sorted by their appearance in memory. As memory need not be allocated sequentially, this gives rise to extreme arbitririty which is not desired. Instead the atoms should be stored in the sequence they were loaded/created. The solution is as follows:
  • config::SaveAll()
  • molecule::atomSet is now a list<atom *>
  • molecule::atomIds is a new set<atomId_t> (atomIdSet) which controls that (global) ids remain unique in the no more Atomset's set (but list)
  • molecule::erase() erases also in atomIds
  • molecule::insert() checks whether id is present by atomIds
  • molecule::find() as std::list does not have a find, we just go through the list until the object is found (or not), this may be speeded up by another internal list.
  • molecule::InternalPointer made lots of confusion as virtual function GoToFirst() is const, hence begin() (needed therein) returns const_iterator, which then cannot be simply re-cast into an iterator: We make it a pointer, reinterpret_cast the pointer and reference it back. Although InternalPointer is mutable, the compiler cannot use the non-const function begin() (it cannot be made const, as overloading is not allowed). (this is noted in the code also extensively.)
  • molecule::containsAtom() does not use count but the new find, as it returns only boolean anyway.
  • rewrote MoleculeListClass::SimpleMerge() to get rid of the extra iterator, as we remove all atoms in the end anyway.
  • FIX: MoleculeListClass::SimpleMultiMerge() - the created mol was not inserted into the moleculelist in the end, although it is the only one to remain.
  1. All other databases had missing headers with respect to those stored in elements_db.cpp. Hence, valence of hydrogen was not parsed and this caused several failures in CalculateOrbitals() (Psi numbers and MaxMinSetp in pcp conf file).
  1. Subsequenytly, various test cases (12, 21, 30, 31, 36-38, 39) were broken. This had two reasons:
  • Seemingly, CalculateOrbitals() was broken before hence MaxMinStep (pcp config) and MaxPsiDouble/PsiMaxNn[Up|Down] were always 0. (10-21,30-31,39)
  • As the order is now correct, fixes from commits c9217161ec2a5d5db508557fe98a32068461f45b and 22a6da8380911571debebd69444d2615450bbbd8 were obselete and have been reverted (order of the Ion?_Type...): Molecules/6 (30), Molecules/7 (31), Filling/1 (39)
  • Due to different ordering, Tesselation/3 (38) had completely different .dat file (though same tesselation)
  • r3d had small differences, mostly order or epsilon (0 not being 0 but ..-e16), hence diffing was deactivated, as r3d is deprecated anyway (since vmd can render triangles as well and better).

Signed-off-by: Frederik Heber <heber@…>

  • Property mode set to 100644
File size: 3.5 KB
Line 
1# ParallelCarParinello - main configuration file - created with molecuilder
2
3mainname pcp # programm name (for runtime files)
4defaultpath not specified # where to put files during runtime
5pseudopotpath not specified # where to find pseudopotentials
6
7ProcPEGamma 8 # for parallel computing: share constants
8ProcPEPsi 1 # for parallel computing: share wave functions
9DoOutVis 0 # Output data for OpenDX
10DoOutMes 1 # Output data for measurements
11DoOutOrbitals 0 # Output all Orbitals
12DoOutCurr 0 # Ouput current density for OpenDx
13DoOutNICS 0 # Output Nucleus independent current shieldings
14DoPerturbation 0 # Do perturbation calculate and determine susceptibility and shielding
15DoFullCurrent 0 # Do full perturbation
16DoConstrainedMD 0 # Do perform a constrained (>0, relating to current MD step) instead of unconstrained (0) MD
17Thermostat Berendsen 2.5 # Which Thermostat and its parameters to use in MD case.
18CommonWannier 0 # Put virtual centers at indivual orbits, all common, merged by variance, to grid point, to cell center
19SawtoothStart 0.01 # Absolute value for smooth transition at cell border
20VectorPlane 0 # Cut plane axis (x, y or z: 0,1,2) for two-dim current vector plot
21VectorCut 0 # Cut plane axis value
22AddGramSch 1 # Additional GramSchmidtOrtogonalization to be safe
23Seed 1 # initial value for random seed for Psi coefficients
24
25MaxOuterStep 0 # number of MolecularDynamics/Structure optimization steps
26Deltat 0.01 # time per MD step
27OutVisStep 10 # Output visual data every ...th step
28OutSrcStep 5 # Output "restart" data every ..th step
29TargetTemp 0.000950045 # Target temperature
30MaxPsiStep 0 # number of Minimisation steps per state (0 - default)
31EpsWannier 1e-07 # tolerance value for spread minimisation of orbitals
32
33# Values specifying when to stop
34MaxMinStep 100 # Maximum number of steps
35RelEpsTotalE 1e-07 # relative change in total energy
36RelEpsKineticE 1e-05 # relative change in kinetic energy
37MaxMinStopStep 1 # check every ..th steps
38MaxMinGapStopStep 0 # check every ..th steps
39
40# Values specifying when to stop for INIT, otherwise same as above
41MaxInitMinStep 100 # Maximum number of steps
42InitRelEpsTotalE 1e-05 # relative change in total energy
43InitRelEpsKineticE 0.0001 # relative change in kinetic energy
44InitMaxMinStopStep 1 # check every ..th steps
45InitMaxMinGapStopStep 0 # check every ..th steps
46
47BoxLength # (Length of a unit cell)
4820
490 20
500 0 20
51
52ECut 128 # energy cutoff for discretization in Hartrees
53MaxLevel 5 # number of different levels in the code, >=2
54Level0Factor 2 # factor by which node number increases from S to 0 level
55RiemannTensor 0 # (Use metric)
56PsiType 1 # 0 - doubly occupied, 1 - SpinUp,SpinDown
57MaxPsiDouble 0 # here: specifying both maximum number of SpinUp- and -Down-states
58PsiMaxNoUp 0 # here: specifying maximum number of SpinUp-states
59PsiMaxNoDown 1 # here: specifying maximum number of SpinDown-states
60AddPsis 0 # Additional unoccupied Psis for bandgap determination
61
62RCut 20 # R-cut for the ewald summation
63StructOpt 0 # Do structure optimization beforehand
64IsAngstroem 1 # 0 - Bohr, 1 - Angstroem
65RelativeCoord 0 # whether ion coordinates are relative (1) or absolute (0)
66MaxTypes 1 # maximum number of different ion types
67
68# Ion type data (PP = PseudoPotential, Z = atomic number)
69#Ion_TypeNr. Amount Z RGauss L_Max(PP)L_Loc(PP)IonMass # chemical name, symbol
70Ion_Type1 1 1 1.0 3 3 1.00800000000 Hydrogen H
71#Ion_TypeNr._Nr.R[0] R[1] R[2] MoveType (0 MoveIon, 1 FixedIon)
72Ion_Type1_1 10.000000000 10.000000000 10.000000000 0 # molecule nr 0
Note: See TracBrowser for help on using the repository browser.