Changes in / [1bab08:8d6d31]
- Files:
-
- 18 added
- 1 deleted
- 7 edited
Legend:
- Unmodified
- Added
- Removed
-
src/Actions/MoleculeAction/RotateAroundOriginByAngleAction.cpp
r1bab08 r8d6d31 52 52 {} 53 53 54 void MoleculeRotateAroundOriginByAngle( double angle) {54 void MoleculeRotateAroundOriginByAngle(const Vector &Axis, double angle) { 55 55 ValueStorage::getInstance().setCurrentValue(MoleculeRotateAroundOriginByAngleAction::NAME, angle); 56 ValueStorage::getInstance().setCurrentValue("position", Axis); 56 57 ActionRegistry::getInstance().getActionByName(MoleculeRotateAroundOriginByAngleAction::NAME)->call(Action::NonInteractive); 57 58 }; … … 82 83 alpha *= M_PI/180.; 83 84 85 // Creation Line that is the rotation axis 86 Line RotationAxis(Vector(0.,0.,0.), Axis); 87 84 88 DoLog(0) && (Log() << Verbose(0) << "Rotate around origin by " << alpha << " radian, axis from origin to " << Axis << "." << endl); 85 89 for (World::MoleculeSelectionIterator iter = World::getInstance().beginMoleculeSelection(); iter != World::getInstance().endMoleculeSelection(); ++iter) { 86 90 mol = iter->second; 87 91 88 // Creation Line that is the rotation axis89 Line RotationAxis(Vector(0.,0.,0.), Axis);90 91 92 for (molecule::iterator iter = mol->begin(); iter != mol->end(); ++iter) { 92 93 *((*iter)->node) = RotationAxis.rotateVector(*((*iter)->node), alpha); 93 94 } 94 DoLog(0) && (Log() << Verbose(0) << "done." << endl);95 95 } 96 DoLog(0) && (Log() << Verbose(0) << "done." << endl); 96 97 return Action::state_ptr(new MoleculeRotateAroundOriginByAngleState(World::getInstance().getSelectedMolecules(), Axis, alpha)); 97 98 } -
src/Actions/MoleculeAction/RotateAroundOriginByAngleAction.hpp
r1bab08 r8d6d31 17 17 18 18 class MoleculeRotateAroundOriginByAngleAction : public Action { 19 friend void MoleculeRotateAroundOriginByAngle( double angle);19 friend void MoleculeRotateAroundOriginByAngle(const Vector &Axis, double angle); 20 20 21 21 public: -
src/Actions/MoleculeAction/RotateAroundSelfByAngleAction.cpp
r1bab08 r8d6d31 34 34 class MoleculeRotateAroundSelfByAngleState : public ActionState { 35 35 public: 36 MoleculeRotateAroundSelfByAngleState(molecule * const _mol, const double _alpha) :36 MoleculeRotateAroundSelfByAngleState(molecule * const _mol, const Vector &_Axis, const double _alpha) : 37 37 mol(_mol), 38 Axis(_Axis), 38 39 alpha(_alpha) 39 40 {} 40 41 molecule* const mol; 42 Vector Axis; 41 43 double alpha; 42 44 }; … … 51 53 {} 52 54 53 void MoleculeRotateAroundSelfByAngle( double angle) {55 void MoleculeRotateAroundSelfByAngle(const Vector &Axis, const double angle) { 54 56 ValueStorage::getInstance().setCurrentValue(MoleculeRotateAroundSelfByAngleAction::NAME, angle); 57 ValueStorage::getInstance().setCurrentValue("position", Axis); 55 58 ActionRegistry::getInstance().getActionByName(MoleculeRotateAroundSelfByAngleAction::NAME)->call(Action::NonInteractive); 56 59 }; … … 60 63 61 64 dialog->queryDouble(NAME, MapOfActions::getInstance().getDescription(NAME)); 65 dialog->queryVector("position", false, MapOfActions::getInstance().getDescription(NAME)); 62 66 63 67 return dialog; … … 67 71 molecule *mol = NULL; 68 72 double alpha = 0.; 73 Vector Axis; 69 74 70 // obtain angle a round which rotate75 // obtain angle and axis around which rotate 71 76 ValueStorage::getInstance().queryCurrentValue(NAME, alpha); 77 ValueStorage::getInstance().queryCurrentValue("position", Axis); 72 78 73 79 // check whether a single atom and molecule is selected 74 if ((World::getInstance().getSelectedAtoms().size() != 1) || (World::getInstance().getSelectedMolecules().size() != 1)) 80 if (World::getInstance().getSelectedMolecules().size() != 1) 81 return Action::failure; 82 mol = World::getInstance().beginMoleculeSelection()->second; 83 84 // check whether Axis is valid 85 if (Axis.IsZero()) 75 86 return Action::failure; 76 87 77 DoLog(0) && (Log() << Verbose(0) << "Rotate around self by " << alpha << "." << endl);78 mol = World::getInstance().beginMoleculeSelection()->second;88 // convert from degrees to radian 89 alpha *= M_PI/180.; 79 90 80 91 // Creation Line that is the rotation axis 81 92 Vector *CenterOfGravity = mol->DetermineCenterOfGravity(); 82 Line RotationAxis(*CenterOfGravity, (World::getInstance().beginAtomSelection()->second)->x);93 Line RotationAxis(*CenterOfGravity, Axis); 83 94 delete(CenterOfGravity); 95 DoLog(0) && (Log() << Verbose(0) << "Rotate around self by " << alpha << " along " << RotationAxis << "." << endl); 84 96 85 97 for (molecule::iterator iter = mol->begin(); iter != mol->end(); ++iter) { … … 88 100 DoLog(0) && (Log() << Verbose(0) << "done." << endl); 89 101 90 return Action::state_ptr(new MoleculeRotateAroundSelfByAngleState(mol, alpha));102 return Action::state_ptr(new MoleculeRotateAroundSelfByAngleState(mol, Axis, alpha)); 91 103 } 92 104 … … 95 107 96 108 Vector *CenterOfGravity = state->mol->DetermineCenterOfGravity(); 97 Line RotationAxis(*CenterOfGravity, (World::getInstance().beginAtomSelection()->second)->x);109 Line RotationAxis(*CenterOfGravity, state->Axis); 98 110 delete(CenterOfGravity); 99 111 … … 109 121 110 122 Vector *CenterOfGravity = state->mol->DetermineCenterOfGravity(); 111 Line RotationAxis(*CenterOfGravity, (World::getInstance().beginAtomSelection()->second)->x);123 Line RotationAxis(*CenterOfGravity, state->Axis); 112 124 delete(CenterOfGravity); 113 125 -
src/Actions/MoleculeAction/RotateAroundSelfByAngleAction.hpp
r1bab08 r8d6d31 17 17 18 18 class MoleculeRotateAroundSelfByAngleAction : public Action { 19 friend void MoleculeRotateAroundSelfByAngle( double angle);19 friend void MoleculeRotateAroundSelfByAngle(const Vector &Axis, const double angle); 20 20 21 21 public: -
src/LinearAlgebra/Line.cpp
r1bab08 r8d6d31 241 241 return Line(x1,x1-x2); 242 242 } 243 244 ostream& operator<<(ostream& ost, const Line& m) 245 { 246 const Vector origin = m.getOrigin(); 247 const Vector direction = m.getDirection(); 248 ost << "("; 249 for (int i=0;i<NDIM;i++) { 250 ost << origin[i]; 251 if (i != 2) 252 ost << ","; 253 } 254 ost << ") -> ("; 255 for (int i=0;i<NDIM;i++) { 256 ost << direction[i]; 257 if (i != 2) 258 ost << ","; 259 } 260 ost << ")"; 261 return ost; 262 }; 263 -
src/LinearAlgebra/Line.hpp
r1bab08 r8d6d31 11 11 #include "LinearAlgebra/Space.hpp" 12 12 13 #include <iosfwd> 13 14 #include <memory> 14 15 #include <vector> … … 45 46 }; 46 47 48 std::ostream & operator << (std::ostream& ost, const Line &m); 49 47 50 /** 48 51 * Named constructor to make a line through two points -
tests/regression/testsuite-molecules.at
r1bab08 r8d6d31 61 61 62 62 # 8. Rotate to PAS 63 AT_SETUP([Molecules - BROKEN:Rotate to PAS])63 AT_SETUP([Molecules - Rotate to PAS]) 64 64 AT_KEYWORDS([Molecules]) 65 AT_CHECK([/bin/cp -f ${abs_top_srcdir}/${AUTOTEST_PATH}/Molecules/8/pre/test.* .], 0) 66 AT_CHECK([../../molecuilder -i test.conf -e ${abs_top_srcdir}/src/ --select-molecule-by-id 0 -m "0,0,1"], 0, [stdout], [stderr]) 67 #AT_CHECK([file=test.conf; diff $file ${abs_top_srcdir}/${AUTOTEST_PATH}/Molecules/8/post/$file], 0, [ignore], [ignore]) 65 AT_CHECK([/bin/cp -f ${abs_top_srcdir}/${AUTOTEST_PATH}/Molecules/8/pre/test-*.xyz .], 0) 66 AT_CHECK([../../molecuilder -i test-rotated-z90.xyz -e ${abs_top_srcdir}/src/ --select-molecule-by-id 0 -m "0,0,1"], 0, [stdout], [stderr]) 67 AT_CHECK([file="test-rotated-z90.xyz"; diff $file ${abs_top_srcdir}/${AUTOTEST_PATH}/Molecules/8/post/$file], 0, [ignore], [ignore]) 68 AT_CHECK([../../molecuilder -i test-rotated-z180.xyz -e ${abs_top_srcdir}/src/ --select-molecule-by-id 0 -m "0,0,1"], 0, [stdout], [stderr]) 69 AT_CHECK([file="test-rotated-z180.xyz"; diff $file ${abs_top_srcdir}/${AUTOTEST_PATH}/Molecules/8/post/$file], 0, [ignore], [ignore]) 70 AT_CHECK([../../molecuilder -i test-rotated-z360.xyz -e ${abs_top_srcdir}/src/ --select-molecule-by-id 0 -m "0,0,1"], 0, [stdout], [stderr]) 71 AT_CHECK([file="test-rotated-z360.xyz"; diff $file ${abs_top_srcdir}/${AUTOTEST_PATH}/Molecules/8/post/$file], 0, [ignore], [ignore]) 72 AT_CHECK([../../molecuilder -i test-rotated-xYz20.xyz -e ${abs_top_srcdir}/src/ --select-molecule-by-id 0 -m "0,0,1"], 0, [stdout], [stderr]) 73 AT_CHECK([file="test-rotated-xYz20.xyz"; diff $file ${abs_top_srcdir}/${AUTOTEST_PATH}/Molecules/8/post/$file], 0, [ignore], [ignore]) 68 74 AT_CLEANUP 69 75 76 # 9. Rotate around origin 77 AT_SETUP([Molecules - Rotate around origin]) 78 AT_KEYWORDS([Molecules]) 79 AT_CHECK([/bin/cp -f ${abs_top_srcdir}/${AUTOTEST_PATH}/Molecules/9/pre/test.xyz .], 0) 80 AT_CHECK([../../molecuilder -i test.xyz -e ${abs_top_srcdir}/src/ --select-all-molecules --rotate-origin 90. --position "0,0,1"], 0, [stdout], [stderr]) 81 AT_CHECK([diff test.xyz ${abs_top_srcdir}/${AUTOTEST_PATH}/Molecules/9/post/test-rotated-z90.xyz], 0, [ignore], [ignore]) 82 AT_CHECK([/bin/cp -f ${abs_top_srcdir}/${AUTOTEST_PATH}/Molecules/9/pre/test.xyz .], 0) 83 AT_CHECK([../../molecuilder -i test.xyz -e ${abs_top_srcdir}/src/ --select-all-molecules --rotate-origin 180. --position "0,0,1"], 0, [stdout], [stderr]) 84 AT_CHECK([diff test.xyz ${abs_top_srcdir}/${AUTOTEST_PATH}/Molecules/9/post/test-rotated-z180.xyz], 0, [ignore], [ignore]) 85 AT_CHECK([/bin/cp -f ${abs_top_srcdir}/${AUTOTEST_PATH}/Molecules/9/pre/test.xyz .], 0) 86 AT_CHECK([../../molecuilder -i test.xyz -e ${abs_top_srcdir}/src/ --select-all-molecules --rotate-origin 360. --position "0,0,1"], 0, [stdout], [stderr]) 87 AT_CHECK([diff test.xyz ${abs_top_srcdir}/${AUTOTEST_PATH}/Molecules/9/post/test-rotated-z360.xyz], 0, [ignore], [ignore]) 88 AT_CHECK([diff test.xyz ${abs_top_srcdir}/${AUTOTEST_PATH}/Molecules/9/pre/test.xyz], 0, [ignore], [ignore]) 89 AT_CHECK([/bin/cp -f ${abs_top_srcdir}/${AUTOTEST_PATH}/Molecules/9/pre/test.xyz .], 0) 90 AT_CHECK([../../molecuilder -i test.xyz -e ${abs_top_srcdir}/src/ --select-all-molecules --rotate-origin 20. --position "1,2,1"], 0, [stdout], [stderr]) 91 AT_CHECK([diff test.xyz ${abs_top_srcdir}/${AUTOTEST_PATH}/Molecules/9/post/test-rotated-xYz20.xyz], 0, [ignore], [ignore]) 92 AT_CLEANUP 93 94 # 9. Rotate around self 95 AT_SETUP([Molecules - Rotate around self]) 96 AT_KEYWORDS([Molecules]) 97 AT_CHECK([/bin/cp -f ${abs_top_srcdir}/${AUTOTEST_PATH}/Molecules/10/pre/test.xyz .], 0) 98 AT_CHECK([../../molecuilder -i test.xyz -e ${abs_top_srcdir}/src/ --select-all-molecules --rotate-self 90. --position "0,0,1"], 0, [stdout], [stderr]) 99 AT_CHECK([diff test.xyz ${abs_top_srcdir}/${AUTOTEST_PATH}/Molecules/10/post/test-rotated-z90.xyz], 0, [ignore], [ignore]) 100 AT_CHECK([/bin/cp -f ${abs_top_srcdir}/${AUTOTEST_PATH}/Molecules/10/pre/test.xyz .], 0) 101 AT_CHECK([../../molecuilder -i test.xyz -e ${abs_top_srcdir}/src/ --select-all-molecules --rotate-self 180. --position "0,0,1"], 0, [stdout], [stderr]) 102 AT_CHECK([diff test.xyz ${abs_top_srcdir}/${AUTOTEST_PATH}/Molecules/10/post/test-rotated-z180.xyz], 0, [ignore], [ignore]) 103 AT_CHECK([/bin/cp -f ${abs_top_srcdir}/${AUTOTEST_PATH}/Molecules/10/pre/test.xyz .], 0) 104 AT_CHECK([../../molecuilder -i test.xyz -e ${abs_top_srcdir}/src/ --select-all-molecules --rotate-self 360. --position "0,0,1"], 0, [stdout], [stderr]) 105 AT_CHECK([diff test.xyz ${abs_top_srcdir}/${AUTOTEST_PATH}/Molecules/10/post/test-rotated-z360.xyz], 0, [ignore], [ignore]) 106 AT_CHECK([diff test.xyz ${abs_top_srcdir}/${AUTOTEST_PATH}/Molecules/10/pre/test.xyz], 0, [ignore], [ignore]) 107 AT_CHECK([/bin/cp -f ${abs_top_srcdir}/${AUTOTEST_PATH}/Molecules/10/pre/test.xyz .], 0) 108 AT_CHECK([../../molecuilder -i test.xyz -e ${abs_top_srcdir}/src/ --select-all-molecules --rotate-self 20. --position "1,2,1"], 0, [stdout], [stderr]) 109 AT_CHECK([diff test.xyz ${abs_top_srcdir}/${AUTOTEST_PATH}/Molecules/10/post/test-rotated-xYz20.xyz], 0, [ignore], [ignore]) 110 AT_CLEANUP 111
Note:
See TracChangeset
for help on using the changeset viewer.