Changeset b81f1c for src/LinearAlgebra


Ignore:
Timestamp:
Apr 6, 2011, 1:50:41 PM (15 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, 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
Children:
8766e72
Parents:
819cbe
git-author:
Frederik Heber <heber@…> (04/01/11 15:14:39)
git-committer:
Frederik Heber <heber@…> (04/06/11 13:50:41)
Message:

Removed libMolecuilderRandomNumbers from LinearAlgebra.

  • added RealSpaceMatrix::setRotation() that accepts phi[NDIM].
  • moved RealSpaceMatrix::setRandomRotation() to boundary.cpp where it is solely used.
Location:
src/LinearAlgebra
Files:
3 edited

Legend:

Unmodified
Added
Removed
  • src/LinearAlgebra/Makefile.am

    r819cbe rb81f1c  
    4848libMolecuilderLinearAlgebra_la_LIBADD = \
    4949        ../Exceptions/libMolecuilderExceptions.la \
    50         ../RandomNumbers/libMolecuilderRandomNumbers.la \
    5150        $(GSL_LIBS)
    5251nobase_libMolecuilderLinearAlgebra_la_include_HEADERS = ${LINALGHEADER}
  • src/LinearAlgebra/RealSpaceMatrix.cpp

    r819cbe rb81f1c  
    2828#include "LinearAlgebra/Vector.hpp"
    2929#include "LinearAlgebra/VectorContent.hpp"
    30 #include "RandomNumbers/RandomNumberGeneratorFactory.hpp"
    31 #include "RandomNumbers/RandomNumberGenerator.hpp"
    3230
    3331#include <gsl/gsl_blas.h>
     
    123121  set(2,1, cos(y)*sin(x));
    124122  set(2,2, cos(x)*cos(y));
    125 }
    126 
    127 void RealSpaceMatrix::setRandomRotation()
    128 {
    129   double phi[NDIM];
    130   RandomNumberGenerator &random = RandomNumberGeneratorFactory::getInstance().makeRandomNumberGenerator();
    131   const double rng_min = random.min();
    132   const double rng_max = random.max();
    133 
    134 
    135   for (int i=0;i<NDIM;i++) {
    136     phi[i] = (random()/(rng_max-rng_min))*(2.*M_PI);
    137     std::cout << "Random angle is " << phi[i] << std::endl;
    138   }
    139 
    140   set(0,0,  cos(phi[0])            *cos(phi[2]) + (sin(phi[0])*sin(phi[1])*sin(phi[2])));
    141   set(0,1,  sin(phi[0])            *cos(phi[2]) - (cos(phi[0])*sin(phi[1])*sin(phi[2])));
    142   set(0,2,              cos(phi[1])*sin(phi[2])                                        );
    143   set(1,0, -sin(phi[0])*cos(phi[1])                                                    );
    144   set(1,1,  cos(phi[0])*cos(phi[1])                                                    );
    145   set(1,2,              sin(phi[1])                                                    );
    146   set(2,0, -cos(phi[0])            *sin(phi[2]) + (sin(phi[0])*sin(phi[1])*cos(phi[2])));
    147   set(2,1, -sin(phi[0])            *sin(phi[2]) - (cos(phi[0])*sin(phi[1])*cos(phi[2])));
    148   set(2,2,              cos(phi[1])*cos(phi[2])                                        );
    149 }
    150 
     123//  double phi[NDIM];
     124//  phi[0] = x;
     125//  phi[0] = y;
     126//  phi[0] = z;
     127//  setRotation(phi);
     128}
     129
     130void RealSpaceMatrix::setRotation(const double phi[NDIM])
     131{
     132  setRotation(phi[0], phi[1], phi[2]);
     133//  set(0,0,  cos(phi[0])            *cos(phi[2]) + (sin(phi[0])*sin(phi[1])*sin(phi[2])));
     134//  set(0,1,  sin(phi[0])            *cos(phi[2]) - (cos(phi[0])*sin(phi[1])*sin(phi[2])));
     135//  set(0,2,              cos(phi[1])*sin(phi[2])                                        );
     136//  set(1,0, -sin(phi[0])*cos(phi[1])                                                    );
     137//  set(1,1,  cos(phi[0])*cos(phi[1])                                                    );
     138//  set(1,2,              sin(phi[1])                                                    );
     139//  set(2,0, -cos(phi[0])            *sin(phi[2]) + (sin(phi[0])*sin(phi[1])*cos(phi[2])));
     140//  set(2,1, -sin(phi[0])            *sin(phi[2]) - (cos(phi[0])*sin(phi[1])*cos(phi[2])));
     141//  set(2,2,              cos(phi[1])*cos(phi[2])                                        );
     142}
    151143
    152144RealSpaceMatrix &RealSpaceMatrix::operator=(const RealSpaceMatrix &src)
  • src/LinearAlgebra/RealSpaceMatrix.hpp

    r819cbe rb81f1c  
    7474   */
    7575  void setRotation(const double x, const double y, const double z);
    76   void setRandomRotation();
    7776
     77  /**
     78   * Sets all matrix corresponding to a rotation matrix,
     79   * first around the x-, then the y-, finally the z-axis
     80   * with given angles.
     81   */
     82  void setRotation(const double phi[NDIM]);
    7883  /**
    7984   * Access the matrix at index (i,j)
Note: See TracChangeset for help on using the changeset viewer.