Changeset 192397 for src


Ignore:
Timestamp:
Sep 19, 2013, 8:24:28 PM (11 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:
00eda9
Parents:
87ec81
git-author:
Frederik Heber <heber@…> (08/30/13 23:20:49)
git-committer:
Frederik Heber <heber@…> (09/19/13 20:24:28)
Message:

Added new ShapeType molecule-surface.

  • uses getBoundingShape() of the first currently selected molecule.
Location:
src/Shapes
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • src/Shapes/ShapeFactory.cpp

    r87ec81 r192397  
    3737#include "ShapeFactory.hpp"
    3838
     39#include "CodePatterns/Log.hpp"
     40
    3941#include "BaseShapes.hpp"
    4042#include "ShapeOps.hpp"
     
    4345#include "LinearAlgebra/Vector.hpp"
    4446#include "LinearAlgebra/RealSpaceMatrix.hpp"
     47#include "molecule.hpp"
     48#include "World.hpp"
    4549
    4650ShapeFactory::ShapeFactory()
     
    5458  shapeNameMap[CombinedType] = "combined";
    5559  shapeNameMap[CylinderType] = "cylinder";
     60  shapeNameMap[MoleculeSurfaceType] = "molecule-surface";
    5661
    5762  // Create inverse map.
     
    6166  // Create baseShapeName list.
    6267  for (ShapeNameMap::iterator iter = shapeNameMap.begin(); iter != shapeNameMap.end(); ++ iter)
    63     if (iter->second != "combined")
     68    if ((iter->second != "combined") || (iter->second != "molecule-surface"))
    6469      baseShapeNames.push_back(iter->second);
    6570}
     
    121126      s = Cylinder();
    122127      break;
     128    case MoleculeSurfaceType:
     129    {
     130      const std::vector<molecule *> molecules = World::getInstance().getSelectedMolecules();
     131      if (molecules.empty()) {
     132        ELOG(2, "No molecule is selected, cannot factorize its bounding shape.");
     133        s = Nowhere();
     134      } else {
     135        const molecule * const mol = (*molecules.begin());
     136        LOG(2, "DEBUG: Factoring shape from bounding box of molecule " << mol->getName() << ".");
     137        s = mol->getBoundingShape(stretch[0]);
     138      }
     139      break;
     140    }
    123141    default:
    124142      ASSERT(false,
     
    126144  }
    127145
    128   // Transform (if necessary).
    129   if (stretch != Vector(1., 1., 1.))
    130     s = ::stretch(s, stretch);
    131   if ((angleX != 0) || (angleY != 0) || (angleZ != 0)){
    132     RealSpaceMatrix rotation;
    133     rotation.setRotation(angleX, angleY, angleZ);
    134     s = transform(s, rotation);
     146  if (type != MoleculeSurfaceType) {
     147    // Transform (if necessary).
     148    if (stretch != Vector(1., 1., 1.))
     149      s = ::stretch(s, stretch);
     150    if ((angleX != 0) || (angleY != 0) || (angleZ != 0)){
     151      RealSpaceMatrix rotation;
     152      rotation.setRotation(angleX, angleY, angleZ);
     153      s = transform(s, rotation);
     154    }
     155    if (!translation.IsZero())
     156      s = translate(s, translation);
    135157  }
    136   if (!translation.IsZero())
    137     s = translate(s, translation);
    138158
    139159  return s;
  • src/Shapes/ShapeType.hpp

    r87ec81 r192397  
    2323        CombinedType,
    2424  CylinderType,
     25  MoleculeSurfaceType,
    2526        MAX_ShapeType
    2627};
Note: See TracChangeset for help on using the changeset viewer.