source: src/Shapes/Shape.cpp@ b5bf84

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 b5bf84 was e09b70, checked in by Tillmann Crueger <crueger@…>, 15 years ago

Added basic operations on shapes

  • Property mode set to 100644
File size: 2.2 KB
RevLine 
[997784]1/*
2 * Shape.cpp
3 *
4 * Created on: Jun 18, 2010
5 * Author: crueger
6 */
7
8#include "Shape.hpp"
9#include "Shape_impl.hpp"
10
11Shape::Shape(const Shape& src) :
12 impl(src.getImpl())
13{}
14
15Shape::~Shape(){}
16
17bool Shape::isInside(const Vector &point){
18 return impl->isInside(point);
19}
20
21Shape::Shape(Shape::impl_ptr _impl) :
22 impl(_impl)
23{}
24
25Shape &Shape::operator=(const Shape& rhs){
26 if(&rhs!=this){
27 impl=rhs.getImpl();
28 }
29 return *this;
30}
31
32Shape::impl_ptr Shape::getImpl() const{
33 return impl;
34}
35
[e09b70]36// allows arbitrary friendship, but only if implementation is known
37Shape::impl_ptr getShapeImpl(const Shape &shape){
38 return shape.getImpl();
39}
40
[997784]41/***************************** Some simple Shapes ***************************/
42
43Shape Everywhere(){
44 static Shape::impl_ptr impl = Shape::impl_ptr(new Everywhere_impl());
45 return Shape(impl);
46}
47
48Shape Nowhere(){
49 static Shape::impl_ptr impl = Shape::impl_ptr(new Nowhere_impl());
50 return Shape(impl);
51}
52
53/****************************** Operators ***********************************/
54
55// AND
56
57AndShape_impl::AndShape_impl(const Shape::impl_ptr &_lhs, const Shape::impl_ptr &_rhs) :
58 lhs(_lhs),rhs(_rhs)
59{}
60
61AndShape_impl::~AndShape_impl(){}
62
63bool AndShape_impl::isInside(const Vector &point){
64 return lhs->isInside(point) && rhs->isInside(point);
65}
66
67Shape operator&&(const Shape &lhs,const Shape &rhs){
[e09b70]68 Shape::impl_ptr newImpl = Shape::impl_ptr(new AndShape_impl(getShapeImpl(lhs),getShapeImpl(rhs)));
[997784]69 return Shape(newImpl);
70}
71
72// OR
73
74OrShape_impl::OrShape_impl(const Shape::impl_ptr &_lhs, const Shape::impl_ptr &_rhs) :
75 lhs(_lhs),rhs(_rhs)
76{}
77
78OrShape_impl::~OrShape_impl(){}
79
80bool OrShape_impl::isInside(const Vector &point){
81 return rhs->isInside(point) || lhs->isInside(point);
82}
83
84Shape operator||(const Shape &lhs,const Shape &rhs){
[e09b70]85 Shape::impl_ptr newImpl = Shape::impl_ptr(new OrShape_impl(getShapeImpl(lhs),getShapeImpl(rhs)));
[997784]86 return Shape(newImpl);
87}
88
89// NOT
90
91NotShape_impl::NotShape_impl(const Shape::impl_ptr &_arg) :
92 arg(_arg)
93{}
94
95NotShape_impl::~NotShape_impl(){}
96
97bool NotShape_impl::isInside(const Vector &point){
98 return !arg->isInside(point);
99}
100
101Shape operator!(const Shape &arg){
[e09b70]102 Shape::impl_ptr newImpl = Shape::impl_ptr(new NotShape_impl(getShapeImpl(arg)));
[997784]103 return Shape(newImpl);
104}
Note: See TracBrowser for help on using the repository browser.