Changeset b92e4a


Ignore:
Timestamp:
Mar 28, 2012, 3:17:38 PM (13 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:
735940
Parents:
6a7fcbb
git-author:
Frederik Heber <heber@…> (01/18/12 00:21:51)
git-committer:
Frederik Heber <heber@…> (03/28/12 15:17:38)
Message:

Shape identify themselves via an enumerated Type.

  • this is required lateron for preparing Mesh class out of a given Shape.
Location:
src/Shapes
Files:
1 added
7 edited

Legend:

Unmodified
Added
Removed
  • src/Shapes/BaseShapes.cpp

    r6a7fcbb rb92e4a  
    6161}
    6262
    63 std::string Sphere_impl::toString(){
     63std::string Sphere_impl::toString() const{
    6464  return "Sphere()";
     65}
     66
     67enum ShapeType Sphere_impl::getType() const
     68{
     69        return SphereType;
    6570}
    6671
     
    192197}
    193198
    194 std::string Cuboid_impl::toString(){
     199std::string Cuboid_impl::toString() const{
    195200  return "Cuboid()";
     201}
     202
     203enum ShapeType Cuboid_impl::getType() const
     204{
     205        return CuboidType;
    196206}
    197207
  • src/Shapes/BaseShapes_impl.hpp

    r6a7fcbb rb92e4a  
    2020#include "Shapes/Shape_impl.hpp"
    2121#include "Shapes/ShapeExceptions.hpp"
     22#include "Shapes/ShapeType.hpp"
    2223
    2324class Sphere_impl : public Shape_impl {
     
    2627  virtual Vector getNormal(const Vector &point) throw(NotOnSurfaceException);
    2728  virtual LineSegmentSet getLineIntersections(const Line&);
    28   virtual std::string toString();
     29  virtual std::string toString() const;
     30  virtual enum ShapeType getType() const;
    2931  virtual std::vector<Vector> getHomogeneousPointsOnSurface(const size_t N) const;
    3032};
     
    3537  virtual Vector getNormal(const Vector &point) throw(NotOnSurfaceException);
    3638  virtual LineSegmentSet getLineIntersections(const Line&);
    37   virtual std::string toString();
     39  virtual std::string toString() const;
     40  virtual enum ShapeType getType() const;
    3841  virtual std::vector<Vector> getHomogeneousPointsOnSurface(const size_t N) const;
    3942};
  • src/Shapes/Shape.cpp

    r6a7fcbb rb92e4a  
    2626#include "Shapes/Shape_impl.hpp"
    2727#include "Shapes/ShapeExceptions.hpp"
     28#include "Shapes/ShapeType.hpp"
    2829
    2930#include <string>
     
    6768}
    6869
     70bool Shape::operator==(const Shape &rhs) const{
     71        return (this->getType() == rhs.getType());
     72}
     73
    6974std::string Shape::toString() const{
    7075  return impl->toString();
     76}
     77
     78enum ShapeType Shape::getType() const{
     79        return impl->getType();
    7180}
    7281
     
    153162}
    154163
    155 std::string AndShape_impl::toString() {
     164std::string AndShape_impl::toString() const{
    156165  return std::string("(") + lhs->toString() + std::string("&&") + rhs->toString() + std::string(")");
     166}
     167
     168enum ShapeType AndShape_impl::getType() const{
     169        return CombinedType;
    157170}
    158171
     
    239252}
    240253
    241 std::string OrShape_impl::toString() {
     254std::string OrShape_impl::toString() const{
    242255  return std::string("(") + lhs->toString() + std::string("||") + rhs->toString() + std::string(")");
     256}
     257
     258enum ShapeType OrShape_impl::getType() const{
     259        return CombinedType;
    243260}
    244261
     
    289306}
    290307
    291 std::string NotShape_impl::toString(){
     308std::string NotShape_impl::toString() const{
    292309  return std::string("!") + arg->toString();
     310}
     311
     312enum ShapeType NotShape_impl::getType() const{
     313        return CombinedType;
    293314}
    294315
  • src/Shapes/Shape.hpp

    r6a7fcbb rb92e4a  
    1919
    2020#include "Shapes/ShapeExceptions.hpp"
     21#include "Shapes/ShapeType.hpp"
    2122
    2223#include <vector>
     
    4142  Vector getNormal(const Vector &point) const throw(NotOnSurfaceException);
    4243
     44  Vector getCenter() const;
     45  Vector getRadius() const;
     46
    4347  LineSegmentSet getLineIntersections(const Line&);
    4448  std::vector<Vector> getHomogeneousPointsOnSurface(const size_t N) const;
     
    4650  Shape &operator=(const Shape& rhs);
    4751
     52  bool operator==(const Shape &rhs) const;
     53
    4854  std::string toString() const;
     55  enum ShapeType getType() const;
     56
    4957protected:
    5058  impl_ptr getImpl() const;
  • src/Shapes/ShapeOps.cpp

    r6a7fcbb rb92e4a  
    7171}
    7272
     73enum ShapeType ShapeOpsBase_impl::getType() const {
     74        return getArg()->getType();
     75}
     76
    7377std::vector<Vector> ShapeOpsBase_impl::getHomogeneousPointsOnSurface(const size_t N) const {
    7478  return getArg()->getHomogeneousPointsOnSurface(N);;
     
    105109}
    106110
    107 std::string Resize_impl::toString() {
     111std::string Resize_impl::toString() const{
    108112  std::stringstream sstr;
    109113  sstr << "resize(" << getArg()->toString() << "," << size << ")";
     
    149153}
    150154
    151 std::string Translate_impl::toString() {
     155std::string Translate_impl::toString() const{
    152156  std::stringstream sstr;
    153157  sstr << "translate(" << getArg()->toString() << "," << offset << ")";
     
    213217}
    214218
    215 std::string Stretch_impl::toString() {
     219std::string Stretch_impl::toString() const{
    216220  std::stringstream sstr;
    217221  sstr << "stretch(" << getArg()->toString() << "," << factors << ")";
     
    259263}
    260264
    261 std::string Transform_impl::toString() {
     265std::string Transform_impl::toString() const{
    262266  std::stringstream sstr;
    263267  sstr << "transform(" << getArg()->toString() << "," << transformation << ")";
  • src/Shapes/ShapeOps_impl.hpp

    r6a7fcbb rb92e4a  
    1717#include "Shapes/Shape_impl.hpp"
    1818#include "Shapes/ShapeExceptions.hpp"
     19#include "Shapes/ShapeType.hpp"
    1920#include "LinearAlgebra/Vector.hpp"
    2021#include "LinearAlgebra/RealSpaceMatrix.hpp"
     
    3233  virtual Vector getNormal(const Vector &point) throw (NotOnSurfaceException);
    3334  virtual LineSegmentSet getLineIntersections(const Line&);
     35  virtual enum ShapeType getType() const;
    3436  virtual std::vector<Vector> getHomogeneousPointsOnSurface(const size_t N) const;
    3537protected:
     
    5153  virtual Vector translateOutPos(const Vector &point);
    5254  virtual Vector translateOutNormal(const Vector &point);
    53   virtual std::string toString();
     55  virtual std::string toString() const;
    5456  virtual bool isInside(const Vector& point);
    5557  virtual std::vector<Vector> getHomogeneousPointsOnSurface(const size_t N) const;
     
    6769  virtual Vector translateOutPos(const Vector &point);
    6870  virtual Vector translateOutNormal(const Vector &point);
    69   virtual std::string toString();
     71  virtual std::string toString() const;
    7072  virtual bool isInside(const Vector& point);
    7173  virtual std::vector<Vector> getHomogeneousPointsOnSurface(const size_t N) const;
     
    8385  virtual Vector translateOutPos(const Vector &point);
    8486  virtual Vector translateOutNormal(const Vector &point);
    85   virtual std::string toString();
     87  virtual std::string toString() const;
    8688  virtual bool isInside(const Vector& point);
    8789  virtual std::vector<Vector> getHomogeneousPointsOnSurface(const size_t N) const;
     
    100102  virtual Vector translateOutPos(const Vector &point);
    101103  virtual Vector translateOutNormal(const Vector &point);
    102   virtual std::string toString();
     104  virtual std::string toString() const;
    103105  virtual bool isInside(const Vector& point);
    104106  virtual std::vector<Vector> getHomogeneousPointsOnSurface(const size_t N) const;
  • src/Shapes/Shape_impl.hpp

    r6a7fcbb rb92e4a  
    1919#include "Shapes/Shape.hpp"
    2020#include "Shapes/ShapeExceptions.hpp"
     21#include "Shapes/ShapeType.hpp"
    2122#include "LinearAlgebra/Line.hpp"
    2223#include "LinearAlgebra/LineSegment.hpp"
     
    3334  virtual Vector getNormal(const Vector &point) throw(NotOnSurfaceException)=0;
    3435  virtual LineSegmentSet getLineIntersections(const Line&)=0;
    35   virtual std::string toString()=0;
     36  virtual std::string toString() const =0;
     37  virtual enum ShapeType getType() const =0;
    3638  virtual std::vector<Vector> getHomogeneousPointsOnSurface(const size_t N) const=0;
    3739};
     
    5355    return res;
    5456  }
    55   virtual std::string toString(){
     57  virtual std::string toString() const{
    5658    return "Everywhere()";
     59  }
     60  virtual enum ShapeType getType() const {
     61        return EverywhereType;
    5762  }
    5863  virtual std::vector<Vector> getHomogeneousPointsOnSurface(const size_t N) const {
     
    7580    return LineSegmentSet(line);
    7681  }
    77   virtual std::string toString(){
     82  virtual std::string toString() const{
    7883    return "Nowhere()";
     84  }
     85  virtual enum ShapeType getType() const {
     86        return NowhereType;
    7987  }
    8088  virtual std::vector<Vector> getHomogeneousPointsOnSurface(const size_t N) const {
     
    92100  virtual Vector getNormal(const Vector &point) throw(NotOnSurfaceException);
    93101  virtual LineSegmentSet getLineIntersections(const Line&);
    94   virtual std::string toString();
     102  virtual std::string toString() const;
     103  virtual enum ShapeType getType() const;
    95104  virtual std::vector<Vector> getHomogeneousPointsOnSurface(const size_t N) const;
    96105private:
     
    107116  virtual Vector getNormal(const Vector &point) throw(NotOnSurfaceException);
    108117  virtual LineSegmentSet getLineIntersections(const Line&);
    109   virtual std::string toString();
     118  virtual std::string toString() const;
     119  virtual enum ShapeType getType() const;
    110120  virtual std::vector<Vector> getHomogeneousPointsOnSurface(const size_t N) const;
    111121private:
     
    122132  virtual Vector getNormal(const Vector &point) throw(NotOnSurfaceException);
    123133  virtual LineSegmentSet getLineIntersections(const Line&);
    124   virtual std::string toString();
     134  virtual std::string toString() const;
     135  virtual enum ShapeType getType() const;
    125136  virtual std::vector<Vector> getHomogeneousPointsOnSurface(const size_t N) const;
    126137private:
Note: See TracChangeset for help on using the changeset viewer.