Changeset f731ae for src/analyzer.cpp


Ignore:
Timestamp:
Oct 18, 2008, 3:05:54 PM (17 years ago)
Author:
Frederik Heber <heber@…>
Branches:
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, 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
Children:
b12a35, eeec8f
Parents:
85d278
Message:

ColumnCounter -> *ColumnCounter

columns of the MatrixContainer class may now be variable over each matrix. This was changed globally to allow for varying column numbers of the new class HessianMatrix.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • src/analyzer.cpp

    r85d278 rf731ae  
    9393
    9494  // ---------- Parse the TE Factors into an array -----------------
    95   if (!Energy.ParseIndices()) return 1;
    96   if (Hcorrected) Hcorrection.ParseIndices();
     95  if (!Energy.InitialiseIndices()) return 1;
     96  if (Hcorrected) Hcorrection.InitialiseIndices();
    9797 
    9898  // ---------- Parse the Force indices into an array ---------------
     
    132132  output << endl << "Total Energy" << endl << "==============" << endl << Energy.Header << endl;
    133133  for(int j=0;j<Energy.RowCounter[Energy.MatrixCounter];j++) {
    134     for(int k=0;k<Energy.ColumnCounter;k++)
     134    for(int k=0;k<Energy.ColumnCounter[Energy.MatrixCounter];k++)
    135135      output << scientific << Energy.Matrix[ Energy.MatrixCounter ][j][k] << "\t";
    136136    output << endl;
     
    140140  output << endl << "Total Forces" << endl << "===============" << endl << Force.Header << endl;
    141141  for(int j=0;j<Force.RowCounter[Force.MatrixCounter];j++) {
    142     for(int k=0;k<Force.ColumnCounter;k++)
     142    for(int k=0;k<Force.ColumnCounter[Force.MatrixCounter];k++)
    143143      output << scientific << Force.Matrix[ Force.MatrixCounter ][j][k] << "\t";
    144144    output << endl;
     
    149149    output << endl << "Total Shieldings" << endl << "===============" << endl << Shielding.Header << endl;
    150150    for(int j=0;j<Shielding.RowCounter[Shielding.MatrixCounter];j++) {
    151       for(int k=0;k<Shielding.ColumnCounter;k++)
     151      for(int k=0;k<Shielding.ColumnCounter[Shielding.MatrixCounter];k++)
    152152        output << scientific << Shielding.Matrix[ Shielding.MatrixCounter ][j][k] << "\t";
    153153      output << endl;
     
    157157    output << endl << "Total Shieldings PAS" << endl << "===============" << endl << ShieldingPAS.Header << endl;
    158158    for(int j=0;j<ShieldingPAS.RowCounter[ShieldingPAS.MatrixCounter];j++) {
    159       for(int k=0;k<ShieldingPAS.ColumnCounter;k++)
     159      for(int k=0;k<ShieldingPAS.ColumnCounter[ShieldingPAS.MatrixCounter];k++)
    160160        output << scientific << ShieldingPAS.Matrix[ ShieldingPAS.MatrixCounter ][j][k] << "\t";
    161161      output << endl;
     
    166166  output << endl << "Total Times" << endl << "===============" << endl << Time.Header << endl;
    167167  for(int j=0;j<Time.RowCounter[Time.MatrixCounter];j++) {
    168     for(int k=0;k<Time.ColumnCounter;k++) {
     168    for(int k=0;k<Time.ColumnCounter[Time.MatrixCounter];k++) {
    169169      output << scientific << Time.Matrix[ Time.MatrixCounter ][j][k] << "\t";
    170170    }
     
    173173  output << endl;
    174174  output.close();
    175   for(int k=0;k<Time.ColumnCounter;k++)
     175  for(int k=0;k<Time.ColumnCounter[Time.MatrixCounter];k++)
    176176    Time.Matrix[ Time.MatrixCounter ][ Time.RowCounter[Time.MatrixCounter] ][k] = Time.Matrix[ Time.MatrixCounter ][Time.RowCounter[Time.MatrixCounter]-1][k];
    177177
     
    187187  if (!OpenOutputFile(output2, argv[3], "DeltaSimTime-Order.dat" )) return false;
    188188  for(int j=Time.RowCounter[Time.MatrixCounter];j--;)
    189     for(int k=Time.ColumnCounter;k--;) {
     189    for(int k=Time.ColumnCounter[Time.MatrixCounter];k--;) {
    190190      Time.Matrix[ Time.MatrixCounter ][j][k] = 0.;
    191191    }
     
    196196    for(int i=KeySet.FragmentsPerOrder[BondOrder];i--;)
    197197      for(int j=Time.RowCounter[Time.MatrixCounter];j--;)
    198         for(int k=Time.ColumnCounter;k--;) {
     198        for(int k=Time.ColumnCounter[Time.MatrixCounter];k--;) {
    199199          Time.Matrix[ Time.MatrixCounter ][j][k] += Time.Matrix[ KeySet.OrderSet[BondOrder][i] ][j][k];
    200200        }
     
    202202    output << BondOrder+1 << "\t" << counter;
    203203    output2 << BondOrder+1 << "\t" << counter;
    204     for(int k=0;k<Time.ColumnCounter;k++) {
     204    for(int k=0;k<Time.ColumnCounter[Time.MatrixCounter];k++) {
    205205      output << "\t" << scientific << Time.Matrix[ Time.MatrixCounter ][ Time.RowCounter[Time.MatrixCounter]-1 ][k];
    206206      if (fabs(Time.Matrix[ Time.MatrixCounter ][ Time.RowCounter[Time.MatrixCounter] ][k]) > MYEPSILON)
     
    224224    for(int j=0;j<ShieldingPAS.RowCounter[ShieldingPAS.MatrixCounter];j++) {
    225225      output << j << "\t";
    226       for(int k=0;k<ShieldingPAS.ColumnCounter;k++)
     226      for(int k=0;k<ShieldingPAS.ColumnCounter[ShieldingPAS.MatrixCounter];k++)
    227227        output << scientific <<  ShieldingPAS.Matrix[ ShieldingPAS.MatrixCounter ][j][k] << "\t"; //*(((k>1) && (k<6))? 1.e6 : 1.) << "\t";
    228228      output << endl;
     
    256256  for(int j=0;j<Force.RowCounter[Force.MatrixCounter];j++) {
    257257    output << j << "\t";
    258     for(int k=0;k<Force.ColumnCounter;k++)
     258    for(int k=0;k<Force.ColumnCounter[Force.MatrixCounter];k++)
    259259      output << scientific <<  Force.Matrix[ Force.MatrixCounter ][j][k] << "\t";
    260260    output << endl;
Note: See TracChangeset for help on using the changeset viewer.