Changeset 5e588b5
- Timestamp:
- Jul 1, 2010, 2:24:25 PM (15 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:
- 205d9b
- Parents:
- b5bf84
- Location:
- src/Shapes
- Files:
-
- 3 edited
Legend:
- Unmodified
- Added
- Removed
-
src/Shapes/ShapeOps.cpp
rb5bf84 r5e588b5 10 10 11 11 #include "Helpers/Assert.hpp" 12 13 /********************* Resize ********************/ 12 14 13 15 Resize_impl::Resize_impl(const Shape::impl_ptr &_arg,double _size) : … … 28 30 } 29 31 32 /*************************** translate *******************/ 33 30 34 Translate_impl::Translate_impl(const Shape::impl_ptr &_arg, const Vector &_offset) : 31 35 arg(_arg),offset(_offset) … … 42 46 return Shape(impl); 43 47 } 48 49 /*********************** stretch ******************/ 50 51 Stretch_impl::Stretch_impl(const Shape::impl_ptr &_arg, const Vector &_factors) : 52 arg(_arg),factors(_factors) 53 { 54 ASSERT(factors[0]>0,"cannot stretch a shape by a negative amount"); 55 ASSERT(factors[1]>0,"cannot stretch a shape by a negative amount"); 56 ASSERT(factors[2]>0,"cannot stretch a shape by a negative amount"); 57 for(int i = NDIM;i--;){ 58 reciFactors[i] = 1/factors[i]; 59 } 60 } 61 62 Stretch_impl::~Stretch_impl(){} 63 64 bool Stretch_impl::isInside(const Vector& point){ 65 Vector helper=point; 66 helper.ScaleAll(reciFactors); 67 return arg->isInside(helper); 68 } 69 70 Shape stretch(const Shape &arg, const Vector &factors){ 71 Shape::impl_ptr impl = Shape::impl_ptr(new Stretch_impl(getShapeImpl(arg),factors)); 72 return Shape(impl); 73 } 74 75 /************************* transform *****************/ 76 77 Transform_impl::Transform_impl(const Shape::impl_ptr &_arg, const Matrix &_transformation) : 78 arg(_arg),transformation(_transformation) 79 { 80 transformationInv = transformation.invert(); 81 } 82 83 Transform_impl::~Transform_impl(){} 84 85 bool Transform_impl::isInside(const Vector& point){ 86 return arg->isInside(transformationInv * point); 87 } 88 89 Shape transform(const Shape &arg, const Matrix &transformation){ 90 Shape::impl_ptr impl = Shape::impl_ptr(new Transform_impl(getShapeImpl(arg),transformation)); 91 return Shape(impl); 92 } -
src/Shapes/ShapeOps.hpp
rb5bf84 r5e588b5 11 11 #include "Shapes/Shape.hpp" 12 12 13 class Matrix; 14 13 15 Shape resize(const Shape&,double); 14 15 16 Shape translate(const Shape&, const Vector&); 17 Shape stretch(const Shape&, const Vector&); 18 Shape transform(const Shape&,const Matrix&); 16 19 17 20 #endif /* SHAPEOPS_HPP_ */ -
src/Shapes/ShapeOps_impl.hpp
rb5bf84 r5e588b5 11 11 #include "Shapes/Shape_impl.hpp" 12 12 #include "vector.hpp" 13 #include "Matrix.hpp" 13 14 14 15 class Resize_impl : public Shape_impl … … 34 35 }; 35 36 37 class Stretch_impl : public Shape_impl 38 { 39 public: 40 Stretch_impl(const Shape::impl_ptr&, const Vector&); 41 virtual ~Stretch_impl(); 42 virtual bool isInside(const Vector& point); 43 private: 44 Shape::impl_ptr arg; 45 Vector factors; 46 Vector reciFactors; 47 }; 48 49 class Transform_impl : public Shape_impl 50 { 51 public: 52 Transform_impl(const Shape::impl_ptr&, const Matrix&); 53 virtual ~Transform_impl(); 54 virtual bool isInside(const Vector& point); 55 private: 56 Shape::impl_ptr arg; 57 Matrix transformation; 58 Matrix transformationInv; 59 }; 60 36 61 #endif /* SHAPEOPS_IMPL_HPP_ */
Note:
See TracChangeset
for help on using the changeset viewer.