Changeset bbf1bd for src/LinearAlgebra/Vector.cpp
- Timestamp:
- Dec 4, 2010, 11:54:32 PM (14 years ago)
- 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:
- 6e06bd, b4cf2b
- Parents:
- 5ada94
- git-author:
- Frederik Heber <heber@…> (11/15/10 20:00:30)
- git-committer:
- Frederik Heber <heber@…> (12/04/10 23:54:32)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
src/LinearAlgebra/Vector.cpp
r5ada94 rbbf1bd 41 41 Vector::Vector() 42 42 { 43 content = new VectorContent(); 44 }; 45 46 /** 47 * Copy constructor 48 */ 49 43 content = new VectorContent((size_t) NDIM); 44 }; 45 46 /** Copy constructor. 47 * \param &src source Vector reference 48 */ 50 49 Vector::Vector(const Vector& src) 51 50 { 52 content = new VectorContent(); 53 gsl_vector_memcpy(content->content, src.content->content); 51 content = new VectorContent(*(src.content)); 54 52 } 55 53 56 54 /** Constructor of class vector. 55 * \param x1 first component 56 * \param x2 second component 57 * \param x3 third component 57 58 */ 58 59 Vector::Vector(const double x1, const double x2, const double x3) 59 60 { 60 content = new VectorContent( );61 gsl_vector_set(content->content,0,x1);62 gsl_vector_set(content->content,1,x2);63 gsl_vector_set(content->content,2,x3);61 content = new VectorContent((size_t) NDIM); 62 content->at(0) = x1; 63 content->at(1) = x2; 64 content->at(2) = x3; 64 65 }; 65 66 66 67 /** Constructor of class vector. 68 * \param x[3] three values to initialize Vector with 67 69 */ 68 70 Vector::Vector(const double x[3]) 69 71 { 70 content = new VectorContent(); 71 gsl_vector_set(content->content,0,x[0]); 72 gsl_vector_set(content->content,1,x[1]); 73 gsl_vector_set(content->content,2,x[2]); 74 }; 75 76 Vector::Vector(VectorContent *_content) : 77 content(_content) 78 {} 79 80 /** 81 * Assignment operator 72 content = new VectorContent((size_t) NDIM); 73 for (size_t i = NDIM; i--; ) 74 content->at(i) = x[i]; 75 }; 76 77 /** Copy constructor of class vector from VectorContent. 78 * \note This is destructive, i.e. we take over _content. 79 */ 80 Vector::Vector(VectorContent *&_content) : 81 content(_content) 82 { 83 _content = NULL; 84 } 85 86 /** Copy constructor of class vector from VectorContent. 87 * \note This is non-destructive, i.e. _content is copied. 88 */ 89 Vector::Vector(VectorContent &_content) 90 { 91 content = new VectorContent(_content); 92 } 93 94 /** Assignment operator. 95 * \param &src source vector to assign \a *this to 96 * \return reference to \a *this 82 97 */ 83 98 Vector& Vector::operator=(const Vector& src){ 84 99 // check for self assignment 85 100 if(&src!=this){ 86 gsl_vector_memcpy(content->content, src.content->content);101 *content = *(src.content); 87 102 } 88 103 return *this; … … 90 105 91 106 /** Desctructor of class vector. 107 * Vector::content is deleted. 92 108 */ 93 109 Vector::~Vector() {
Note:
See TracChangeset
for help on using the changeset viewer.