Changes in / [0bcd11:48c338]
- Files:
-
- 3 added
- 37 edited
Legend:
- Unmodified
- Added
- Removed
-
src/Actions/AnalysisAction/MolecularVolumeAction.cpp
r0bcd11 r48c338 7 7 8 8 #include "Actions/AnalysisAction/MolecularVolumeAction.hpp" 9 #include "CommandLineParser.hpp"10 9 #include "boundary.hpp" 11 10 #include "config.hpp" -
src/Actions/AnalysisAction/PairCorrelationAction.cpp
r0bcd11 r48c338 7 7 8 8 #include "Actions/AnalysisAction/PairCorrelationAction.hpp" 9 #include "CommandLineParser.hpp"10 9 #include "analysis_correlation.hpp" 11 10 #include "boundary.hpp" -
src/Actions/AnalysisAction/PrincipalAxisSystemAction.cpp
r0bcd11 r48c338 7 7 8 8 #include "Actions/AnalysisAction/PrincipalAxisSystemAction.hpp" 9 #include "CommandLineParser.hpp"10 9 #include "molecule.hpp" 11 10 #include "log.hpp" -
src/Actions/AtomAction/AddAction.cpp
r0bcd11 r48c338 7 7 8 8 #include "Actions/AtomAction/AddAction.hpp" 9 #include "CommandLineParser.hpp"10 9 #include "atom.hpp" 11 10 #include "element.hpp" -
src/Actions/AtomAction/ChangeElementAction.cpp
r0bcd11 r48c338 7 7 8 8 #include "Actions/AtomAction/ChangeElementAction.hpp" 9 #include "CommandLineParser.hpp"10 9 #include "atom.hpp" 11 10 #include "log.hpp" -
src/Actions/AtomAction/RemoveAction.cpp
r0bcd11 r48c338 7 7 8 8 #include "Actions/AtomAction/RemoveAction.hpp" 9 #include "CommandLineParser.hpp"10 9 #include "atom.hpp" 11 10 #include "Descriptors/AtomDescriptor.hpp" -
src/Actions/CmdAction/BondLengthTableAction.cpp
r0bcd11 r48c338 7 7 8 8 #include "Actions/CmdAction/BondLengthTableAction.hpp" 9 #include "CommandLineParser.hpp"10 9 #include "config.hpp" 11 10 #include "log.hpp" … … 40 39 41 40 if(dialog->display()) { 41 DoLog(0) && (Log() << Verbose(0) << "Using " << BondGraphFileName << " as bond length table." << endl); 42 42 delete dialog; 43 43 } else { 44 44 delete dialog; 45 return Action::failure; 45 46 } 46 47 -
src/Actions/CmdAction/ElementDbAction.cpp
r0bcd11 r48c338 7 7 8 8 #include "Actions/CmdAction/ElementDbAction.hpp" 9 #include "CommandLineParser.hpp"10 9 #include "config.hpp" 11 10 #include "log.hpp" … … 41 40 config *configuration = World::getInstance().getConfig(); 42 41 dialog->queryString(NAME, &databasepath, MapOfActions::getInstance().getDescription(NAME)); 43 strcpy(configuration->databasepath, databasepath.c_str());44 42 45 43 if(dialog->display()) { 44 strcpy(configuration->databasepath, databasepath.c_str()); 46 45 delete dialog; 47 46 } else { 48 47 delete dialog; 48 return Action::failure; 49 49 } 50 50 -
src/Actions/CmdAction/FastParsingAction.cpp
r0bcd11 r48c338 7 7 8 8 #include "Actions/CmdAction/FastParsingAction.hpp" 9 #include "CommandLineParser.hpp"10 9 #include "config.hpp" 11 10 #include "log.hpp" -
src/Actions/CmdAction/VerboseAction.cpp
r0bcd11 r48c338 7 7 8 8 #include "Actions/CmdAction/VerboseAction.hpp" 9 #include "CommandLineParser.hpp"10 9 #include "log.hpp" 11 10 #include "verbose.hpp" -
src/Actions/CmdAction/VersionAction.cpp
r0bcd11 r48c338 7 7 8 8 #include "Actions/CmdAction/VersionAction.hpp" 9 #include "CommandLineParser.hpp"10 9 11 10 #include <iostream> -
src/Actions/FragmentationAction/DepthFirstSearchAction.cpp
r0bcd11 r48c338 7 7 8 8 #include "Actions/FragmentationAction/DepthFirstSearchAction.hpp" 9 #include "CommandLineParser.hpp"10 9 #include "atom.hpp" 11 10 #include "config.hpp" -
src/Actions/FragmentationAction/FragmentationAction.cpp
r0bcd11 r48c338 7 7 8 8 #include "Actions/FragmentationAction/FragmentationAction.hpp" 9 #include "CommandLineParser.hpp"10 9 #include "atom.hpp" 11 10 #include "config.hpp" -
src/Actions/FragmentationAction/SubgraphDissectionAction.cpp
r0bcd11 r48c338 7 7 8 8 #include "Actions/FragmentationAction/SubgraphDissectionAction.hpp" 9 #include "CommandLineParser.hpp"10 9 #include "atom.hpp" 11 10 #include "config.hpp" -
src/Actions/MapOfActions.cpp
r0bcd11 r48c338 50 50 v = boost::any(BoxValue(BV)); 51 51 } 52 53 52 54 53 /** Constructor of class MapOfActions. … … 85 84 DescriptionMap["nonconvex-envelope"] = "create the non-convex envelope for a molecule"; 86 85 DescriptionMap["molecular-volume"] = "calculate the volume of a given molecule"; 87 DescriptionMap["pair-correlation"] = "pair correlation analysis between two elements"; 88 DescriptionMap["pair-correlation-point"] = "pair correlation analysis between atoms of a element to a given point"; 89 DescriptionMap["pair-correlation-surface"] = "pair correlation analysis between atoms of a given element and a surface"; 86 DescriptionMap["pair-correlation"] = "pair correlation analysis between two elements, element and point or element and surface"; 90 87 DescriptionMap["parse-xyz"] = "parse xyz file into World"; 91 88 DescriptionMap["principal-axis-system"] = "calculate the principal axis system of the specified molecule"; … … 113 110 DescriptionMap["distances"] = "list of three of distances in space, one for each axis direction"; 114 111 DescriptionMap["DoRotate"] = "whether to rotate or just report angles"; 115 DescriptionMap["element"] = "set of elements"; 112 DescriptionMap["element"] = "single element"; 113 DescriptionMap["elements"] = "set of elements"; 116 114 DescriptionMap["end-mol"] = "last or end step"; 117 115 DescriptionMap["input"] = "name of input file"; … … 120 118 DescriptionMap["MaxDistance"] = "maximum distance in space"; 121 119 DescriptionMap["molecule-by-id"] = "index of a molecule"; 120 DescriptionMap["molecule-by-name"] = "name of a molecule"; 122 121 DescriptionMap["order"] = "order of a discretization, dissection, ..."; 123 122 DescriptionMap["output-file"] = "name of the output file"; … … 146 145 ShortFormMap["linear-interpolate"] = "L"; 147 146 ShortFormMap["nonconvex-envelope"] = "N"; 148 ShortFormMap["pair-correlation"] = "CE"; 149 ShortFormMap["pair-correlation-point"] = "CP"; 150 ShortFormMap["pair-correlation-surface"] = "CS"; 147 ShortFormMap["pair-correlation"] = "C"; 151 148 ShortFormMap["parse-xyz"] = "p"; 152 149 ShortFormMap["remove-atom"] = "r"; … … 188 185 TypeMap["nonconvex-envelope"] = Molecule; 189 186 TypeMap["parse-xyz"] = String; 190 TypeMap["principal-axis-system"] = Axis; 187 TypeMap["pair-correlation"] = String; 188 TypeMap["principal-axis-system"] = Molecule; 191 189 TypeMap["remove-atom"] = Atom; 192 190 TypeMap["remove-sphere"] = Atom; … … 208 206 TypeMap["bin-end"] = Double; 209 207 TypeMap["bin-start"] = Double; 208 TypeMap["bin-width"] = Double; 210 209 TypeMap["distance"] = Double; 211 210 TypeMap["distances"] = Vector; … … 217 216 TypeMap["MaxDistance"] = Double; 218 217 TypeMap["molecule-by-id"] = Molecule; 218 TypeMap["molecule-by-name"] = Molecule; 219 219 TypeMap["order"] = Integer; 220 220 TypeMap["output-file"] = String; … … 224 224 // default values for any action that needs one (always string!) 225 225 DefaultValue["molecule-by-id"] = "-1"; 226 DefaultValue["bin-width"] = "0.5"; 227 DefaultValue["periodic"] = "0"; 226 228 227 229 … … 229 231 // generic.insert("add-atom"); 230 232 // generic.insert("bond-file"); 231 //generic.insert("bond-table");233 generic.insert("bond-table"); 232 234 generic.insert("boundary"); 233 235 // generic.insert("bound-in-box"); … … 240 242 // generic.insert("default-molname"); 241 243 generic.insert("depth-first-search"); 242 //generic.insert("element-db");244 generic.insert("element-db"); 243 245 // generic.insert("fastparsing"); 244 246 generic.insert("fill-molecule"); … … 248 250 // generic.insert("molecular-volume"); 249 251 // generic.insert("nonconvex-envelope"); 250 // generic.insert("pair-correlation"); 251 // generic.insert("pair-correlation-point"); 252 // generic.insert("pair-correlation-surface"); 252 generic.insert("pair-correlation"); 253 253 // generic.insert("parse-xyz"); 254 254 // generic.insert("principal-axis-system"); … … 256 256 // generic.insert("remove-sphere"); 257 257 generic.insert("repeat-box"); 258 //generic.insert("rotate-to-pas");258 generic.insert("rotate-to-pas"); 259 259 // generic.insert("save-adjacency"); 260 260 // generic.insert("save-bonds"); … … 269 269 generic.insert("version"); 270 270 // // list of generic values 271 // generic.insert("bin-output-file");272 // generic.insert("bin-end");273 // generic.insert("bin-start");274 271 // generic.insert("distance"); 275 272 // generic.insert("distances"); … … 278 275 generic.insert("input"); 279 276 // generic.insert("length"); 280 // generic.insert("output-file");281 // generic.insert("periodic");282 // generic.insert("position");283 277 // generic.insert("start-mol"); 284 278 … … 287 281 288 282 // hidden arguments 283 generic.insert("bin-end"); 284 generic.insert("bin-output-file"); 285 generic.insert("bin-start"); 286 generic.insert("bin-width"); 289 287 generic.insert("distance"); 290 288 generic.insert("DoRotate"); 291 289 generic.insert("distances"); 290 generic.insert("element"); 291 generic.insert("elements"); 292 292 generic.insert("lengths"); 293 293 generic.insert("MaxDistance"); 294 294 generic.insert("molecule-by-id"); 295 generic.insert("molecule-by-name"); 295 296 generic.insert("order"); 297 generic.insert("output-file"); 298 generic.insert("periodic"); 299 generic.insert("position"); 296 300 } 297 301 … … 541 545 } 542 546 547 /** Returns the inverse to MapOfActions::ShortFormMap, i.e. lookup actionname for its short form. 548 * \return map from short form of action to name of action 549 */ 550 map <std::string, std::string> MapOfActions::getShortFormToActionMap() 551 { 552 map <std::string, std::string> result; 553 554 for (map<std::string, std::string>::iterator iter = ShortFormMap.begin(); iter != ShortFormMap.end(); ++iter) 555 result[iter->second] = iter->first; 556 557 return result; 558 } 543 559 544 560 -
src/Actions/MapOfActions.hpp
r0bcd11 r48c338 30 30 std::string getKeyAndShortForm(string actionname); 31 31 std::string getShortForm(string actionname); 32 map <std::string, std::string> getShortFormToActionMap(); 32 33 33 34 void AddOptionsToParser(); -
src/Actions/WorldAction/AddEmptyBoundaryAction.cpp
r0bcd11 r48c338 7 7 8 8 #include "Actions/WorldAction/AddEmptyBoundaryAction.hpp" 9 #include "CommandLineParser.hpp"10 9 #include "atom.hpp" 11 10 #include "log.hpp" -
src/Actions/WorldAction/BoundInBoxAction.cpp
r0bcd11 r48c338 7 7 8 8 #include "Actions/WorldAction/BoundInBoxAction.hpp" 9 #include "CommandLineParser.hpp"10 9 #include "log.hpp" 11 10 #include "molecule.hpp" -
src/Actions/WorldAction/CenterInBoxAction.cpp
r0bcd11 r48c338 7 7 8 8 #include "Actions/WorldAction/CenterInBoxAction.hpp" 9 #include "CommandLineParser.hpp"10 9 #include "log.hpp" 11 10 #include "molecule.hpp" -
src/Actions/WorldAction/CenterOnEdgeAction.cpp
r0bcd11 r48c338 7 7 8 8 #include "Actions/WorldAction/CenterOnEdgeAction.hpp" 9 #include "CommandLineParser.hpp"10 9 #include "atom.hpp" 11 10 #include "log.hpp" -
src/Actions/WorldAction/ChangeBoxAction.cpp
r0bcd11 r48c338 7 7 8 8 #include "Actions/WorldAction/ChangeBoxAction.hpp" 9 #include "CommandLineParser.hpp"10 9 #include "log.hpp" 11 10 #include "verbose.hpp" -
src/Actions/WorldAction/RemoveSphereOfAtomsAction.cpp
r0bcd11 r48c338 7 7 8 8 #include "Actions/WorldAction/RemoveSphereOfAtomsAction.hpp" 9 #include "CommandLineParser.hpp"10 9 #include "atom.hpp" 11 10 #include "Descriptors/AtomDescriptor.hpp" -
src/Actions/WorldAction/RepeatBoxAction.cpp
r0bcd11 r48c338 7 7 8 8 #include "Actions/WorldAction/RepeatBoxAction.hpp" 9 #include "CommandLineParser.hpp"10 9 #include "atom.hpp" 11 10 #include "log.hpp" -
src/Actions/WorldAction/ScaleBoxAction.cpp
r0bcd11 r48c338 7 7 8 8 #include "Actions/WorldAction/ScaleBoxAction.hpp" 9 #include "CommandLineParser.hpp"10 9 #include "atom.hpp" 11 10 #include "log.hpp" -
src/Actions/WorldAction/SetDefaultNameAction.cpp
r0bcd11 r48c338 7 7 8 8 #include "Actions/WorldAction/SetDefaultNameAction.hpp" 9 #include "CommandLineParser.hpp"10 9 #include "log.hpp" 11 10 #include "World.hpp" -
src/Actions/WorldAction/SetGaussianBasisAction.cpp
r0bcd11 r48c338 7 7 8 8 #include "Actions/WorldAction/SetGaussianBasisAction.hpp" 9 #include "CommandLineParser.hpp"10 9 #include "config.hpp" 11 10 #include "World.hpp" -
src/CommandLineParser.cpp
r0bcd11 r48c338 9 9 #include <fstream> 10 10 #include <iostream> 11 #include <map> 11 12 12 13 #include "Patterns/Singleton_impl.hpp" 13 14 #include "CommandLineParser.hpp" 15 #include "log.hpp" 16 #include "verbose.hpp" 14 17 15 18 using namespace std; … … 45 48 } 46 49 50 /** Scan the argument list for -a or --arguments and store their order for later use. 51 * \param &ShortFormToActionMap e.g. gives "help" for "h" 52 */ 53 void CommandLineParser::scanforSequenceOfArguments(map <std::string, std::string> &ShortFormToActionMap) 54 { 55 // go through all arguments 56 for (int i=1;i<argc;i++) { 57 (cout << Verbose(1) << "Checking on " << argv[i] << endl); 58 // check whether they begin with - or -- and check that next letter is not numeric, if so insert 59 if (argv[i][0] == '-') { 60 (cout << Verbose(1) << "Possible argument: " << argv[i] << endl); 61 if (argv[i][1] == '-') { 62 (cout << Verbose(1) << "Putting " << argv[i] << " into the sequence." << endl); 63 SequenceOfActions.push_back(&(argv[i][2])); 64 } else if (((argv[i][1] < '0') || (argv[i][1] > '9')) && ((argv[i][1] != '.'))) { 65 map <std::string, std::string>::iterator iter = ShortFormToActionMap.find(&(argv[i][1])); 66 if (iter != ShortFormToActionMap.end()) { 67 (cout << Verbose(1) << "Putting " << iter->second << " for " << iter->first << " into the sequence." << endl); 68 SequenceOfActions.push_back(iter->second); 69 } 70 } 71 } 72 } 73 } 47 74 48 75 … … 72 99 * \param **_argv argument array from main() 73 100 */ 74 void CommandLineParser::Run(int _argc, char **_argv )101 void CommandLineParser::Run(int _argc, char **_argv, map <std::string, std::string> &ShortFormToActionMap) 75 102 { 76 103 setOptions(_argc,_argv); 77 104 Parse(); 105 scanforSequenceOfArguments(ShortFormToActionMap); 78 106 } 79 107 -
src/CommandLineParser.hpp
r0bcd11 r48c338 15 15 #include "Patterns/Singleton.hpp" 16 16 17 #include <list> 17 18 18 19 class CommandLineParser : public Singleton<CommandLineParser> { … … 21 22 22 23 // Parses the command line arguments in CommandLineParser::**argv with currently known options. 23 void Run(int _argc, char **_argv );24 void Run(int _argc, char **_argv, std::map <std::string, std::string> &ShortFormToActionMap); 24 25 25 26 // Checks whether there have been any commands on the command line. … … 40 41 po::variables_map vm; 41 42 43 // private sequence of actions as they appeared on the command line 44 std::list<std::string> SequenceOfActions; 45 42 46 private: 43 47 // private constructor and destructor … … 57 61 void Parse(); 58 62 63 // as boost's program_options does not care about of order of appearance but we do for actions, 64 // we have to have a list and a function to obtain it. 65 void scanforSequenceOfArguments(std::map <std::string, std::string> &ShortFormToActionMap); 66 59 67 // argument counter and array passed on from main() 60 68 int argc; -
src/Makefile.am
r0bcd11 r48c338 114 114 Descriptors/MoleculeDescriptor.cpp \ 115 115 Descriptors/MoleculeIdDescriptor.cpp \ 116 Descriptors/MoleculeNameDescriptor.cpp \ 116 117 Descriptors/MoleculePtrDescriptor.cpp 117 118 … … 122 123 Descriptors/MoleculeDescriptor.hpp \ 123 124 Descriptors/MoleculeIdDescriptor.hpp \ 125 Descriptors/MoleculeNameDescriptor.hpp \ 124 126 Descriptors/MoleculePtrDescriptor.hpp 125 127 -
src/UIElements/CommandLineUI/CommandLineWindow.cpp
r0bcd11 r48c338 79 79 void CommandLineWindow::display() { 80 80 // go through all possible actions 81 for ( po::variables_map::iterator CommandRunner = CommandLineParser::getInstance().vm.begin(); CommandRunner != CommandLineParser::getInstance().vm.end(); ++CommandRunner) {82 cout << "Checking presence of " << CommandRunner->first<< endl;83 if (ActionRegistry::getInstance().isActionByNamePresent( CommandRunner->first))84 ActionRegistry::getInstance().getActionByName( CommandRunner->first)->call();81 for (std::list<std::string>::iterator CommandRunner = CommandLineParser::getInstance().SequenceOfActions.begin(); CommandRunner != CommandLineParser::getInstance().SequenceOfActions.end(); ++CommandRunner) { 82 cout << "Checking presence of " << *CommandRunner << endl; 83 if (ActionRegistry::getInstance().isActionByNamePresent(*CommandRunner)) 84 ActionRegistry::getInstance().getActionByName(*CommandRunner)->call(); 85 85 } 86 86 } -
src/analysis_correlation.cpp
r0bcd11 r48c338 179 179 } 180 180 181 // outmap = new PairCorrelationMap;182 // for (MoleculeList::const_iterator MolWalker = molecules->ListOfMolecules.begin(); MolWalker != molecules->ListOfMolecules.end(); MolWalker++)183 // if ((*MolWalker)->ActiveFlag) {184 // double * FullMatrix = ReturnFullMatrixforSymmetric(World::getInstance().getDomain());185 // double * FullInverseMatrix = InverseMatrix(FullMatrix);186 // DoeLog(2) && (eLog()<< Verbose(2) << "Current molecule is " << *MolWalker << "." << endl);187 // for (molecule::const_iterator iter = (*MolWalker)->begin(); iter != (*MolWalker)->end(); ++iter) {188 // DoLog(3) && (Log() << Verbose(3) << "Current atom is " << **iter << "." << endl);189 // if ((type1 == NULL) || ((*iter)->type == type1)) {190 // periodicX = *(*iter)->node;191 // periodicX.MatrixMultiplication(FullInverseMatrix); // x now in [0,1)^3192 // // go through every range in xyz and get distance193 // for (n[0]=-ranges[0]; n[0] <= ranges[0]; n[0]++)194 // for (n[1]=-ranges[1]; n[1] <= ranges[1]; n[1]++)195 // for (n[2]=-ranges[2]; n[2] <= ranges[2]; n[2]++) {196 // checkX = Vector(n[0], n[1], n[2]) + periodicX;197 // checkX.MatrixMultiplication(FullMatrix);198 // for (MoleculeList::const_iterator MolOtherWalker = MolWalker; MolOtherWalker != molecules->ListOfMolecules.end(); MolOtherWalker++)199 // if ((*MolOtherWalker)->ActiveFlag) {200 // DoLog(2) && (Log() << Verbose(2) << "Current other molecule is " << *MolOtherWalker << "." << endl);201 // for (molecule::const_iterator runner = (*MolOtherWalker)->begin(); runner != (*MolOtherWalker)->end(); ++runner) {202 // DoLog(3) && (Log() << Verbose(3) << "Current otheratom is " << **runner << "." << endl);203 // if ((*iter)->nr < (*runner)->nr)204 // if ((type2 == NULL) || ((*runner)->type == type2)) {205 // periodicOtherX = *(*runner)->node;206 // periodicOtherX.MatrixMultiplication(FullInverseMatrix); // x now in [0,1)^3207 // // go through every range in xyz and get distance208 // for (Othern[0]=-ranges[0]; Othern[0] <= ranges[0]; Othern[0]++)209 // for (Othern[1]=-ranges[1]; Othern[1] <= ranges[1]; Othern[1]++)210 // for (Othern[2]=-ranges[2]; Othern[2] <= ranges[2]; Othern[2]++) {211 // checkOtherX = Vector(Othern[0], Othern[1], Othern[2]) + periodicOtherX;212 // checkOtherX.MatrixMultiplication(FullMatrix);213 // distance = checkX.distance(checkOtherX);214 // //Log() << Verbose(1) <<"Inserting " << *(*iter) << " and " << *(*runner) << endl;215 // outmap->insert ( pair<double, pair <atom *, atom*> > (distance, pair<atom *, atom*> ((*iter), (*runner)) ) );216 // }217 // }218 // }219 // }220 // }221 // }222 // }223 // delete[](FullMatrix);224 // delete[](FullInverseMatrix);225 // }226 227 181 return outmap; 228 182 }; … … 239 193 CorrelationToPointMap *outmap = NULL; 240 194 double distance = 0.; 195 double *cell_size = World::getInstance().getDomain(); 241 196 242 197 if (molecules->ListOfMolecules.empty()) { … … 254 209 for (vector<element *>::const_iterator type = elements.begin(); type != elements.end(); ++type) 255 210 if ((*type == NULL) || ((*iter)->type == *type)) { 256 distance = (*iter)->node->PeriodicDistance(*point, World::getInstance().getDomain());211 distance = (*iter)->node->PeriodicDistance(*point, cell_size); 257 212 DoLog(4) && (Log() << Verbose(4) << "Current distance is " << distance << "." << endl); 258 213 outmap->insert ( pair<double, pair<atom *, const Vector*> >(distance, pair<atom *, const Vector*> ((*iter), point) ) ); -
src/builder.cpp
r0bcd11 r48c338 1555 1555 performCriticalExit(); 1556 1556 } else { 1557 DoLog(0) && (Log() << Verbose(0) << "Using " << argv[argptr] << " as elements database." << endl); 1558 strncpy (configuration.databasepath, argv[argptr], MAXSTRINGSIZE-1); 1559 DatabasePathGiven = true; 1557 ArgcList.insert(argptr-1); 1558 ArgcList.insert(argptr); 1560 1559 argptr+=1; 1561 1560 } … … 1566 1565 performCriticalExit(); 1567 1566 } else { 1568 BondGraphFileName = argv[argptr];1569 DoLog(0) && (Log() << Verbose(0) << "Using " << BondGraphFileName << " as bond length table." << endl);1567 ArgcList.insert(argptr-1); 1568 ArgcList.insert(argptr); 1570 1569 argptr+=1; 1571 1570 } … … 1601 1600 1602 1601 // 3a. Parse the element database 1603 if (DatabasePathGiven)1604 if (periode->LoadPeriodentafel(configuration.databasepath)) {1605 DoLog(0) && (Log() << Verbose(0) << "Element list loaded successfully." << endl);1606 //periode->Output();1607 } else {1608 DoLog(0) && (Log() << Verbose(0) << "Element list loading failed." << endl);1609 return 1;1610 }1602 // if (DatabasePathGiven) 1603 // if (periode->LoadPeriodentafel(configuration.databasepath)) { 1604 // DoLog(0) && (Log() << Verbose(0) << "Element list loaded successfully." << endl); 1605 // //periode->Output(); 1606 // } else { 1607 // DoLog(0) && (Log() << Verbose(0) << "Element list loading failed." << endl); 1608 // return 1; 1609 // } 1611 1610 // 3b. Find config file name and parse if possible, also BondGraphFileName 1612 1611 if (argv[1][0] != '-') { … … 1763 1762 switch(argv[argptr][0]) { 1764 1763 case 'E': 1765 { 1766 if ((argptr+6 >= argc) || (!IsValidNumber(argv[argptr+1])) || (!IsValidNumber(argv[argptr+5])) || (!IsValidNumber(argv[argptr+6])) || (!IsValidNumber(argv[argptr+2])) || (argv[argptr+1][0] == '-') || (argv[argptr+2][0] == '-') || (argv[argptr+3][0] == '-') || (argv[argptr+4][0] == '-')) { 1767 ExitFlag = 255; 1768 DoeLog(0) && (eLog()<< Verbose(0) << "Not enough or invalid arguments given for pair correlation analysis: -C E <Z1> <Z2> <output> <bin output> <binstart> <binend>" << endl); 1769 performCriticalExit(); 1770 } else { 1771 ofstream output(argv[argptr+3]); 1772 ofstream binoutput(argv[argptr+4]); 1773 const double BinStart = atof(argv[argptr+5]); 1774 const double BinEnd = atof(argv[argptr+6]); 1775 1776 std::vector<element *> elements; 1777 elements.push_back(periode->FindElement((const int) atoi(argv[argptr+1]))); 1778 elements.push_back(periode->FindElement((const int) atoi(argv[argptr+2]))); 1779 PairCorrelationMap *correlationmap = NULL; 1780 if (periodic) 1781 correlationmap = PeriodicPairCorrelation(molecules, elements, ranges); 1782 else 1783 correlationmap = PairCorrelation(molecules, elements); 1784 OutputPairCorrelation(&output, correlationmap); 1785 BinPairMap *binmap = BinData( correlationmap, 0.5, BinStart, BinEnd ); 1786 OutputCorrelation ( &binoutput, binmap ); 1787 output.close(); 1788 binoutput.close(); 1789 delete(binmap); 1790 delete(correlationmap); 1791 argptr+=7; 1792 } 1793 } 1764 ArgcList.insert(argptr-1); 1765 ArgcList.insert(argptr); 1766 ArgcList.insert(argptr+1); 1767 ArgcList.insert(argptr+2); 1768 ArgcList.insert(argptr+3); 1769 ArgcList.insert(argptr+4); 1770 ArgcList.insert(argptr+5); 1771 ArgcList.insert(argptr+6); 1772 ArgcList.insert(argptr+7); 1773 ArgcList.insert(argptr+8); 1774 ArgcList.insert(argptr+9); 1775 ArgcList.insert(argptr+10); 1776 ArgcList.insert(argptr+11); 1777 argptr+=12; 1794 1778 break; 1795 1779 1796 1780 case 'P': 1797 { 1798 if ((argptr+8 >= argc) || (!IsValidNumber(argv[argptr+1])) || (!IsValidNumber(argv[argptr+2])) || (!IsValidNumber(argv[argptr+3])) || (!IsValidNumber(argv[argptr+4])) || (!IsValidNumber(argv[argptr+7])) || (!IsValidNumber(argv[argptr+8])) || (argv[argptr+1][0] == '-') || (argv[argptr+2][0] == '-') || (argv[argptr+3][0] == '-') || (argv[argptr+4][0] == '-') || (argv[argptr+5][0] == '-') || (argv[argptr+6][0] == '-')) { 1799 ExitFlag = 255; 1800 DoeLog(0) && (eLog()<< Verbose(0) << "Not enough or invalid arguments given for pair correlation analysis: -C P <Z1> <x> <y> <z> <output> <bin output> <binstart> <binend>" << endl); 1801 performCriticalExit(); 1802 } else { 1803 ofstream output(argv[argptr+5]); 1804 ofstream binoutput(argv[argptr+6]); 1805 const double BinStart = atof(argv[argptr+7]); 1806 const double BinEnd = atof(argv[argptr+8]); 1807 1808 std::vector<element *> elements; 1809 elements.push_back(periode->FindElement((const int) atoi(argv[argptr+1]))); 1810 Vector *Point = new Vector((const double) atof(argv[argptr+1]),(const double) atof(argv[argptr+2]),(const double) atof(argv[argptr+3])); 1811 CorrelationToPointMap *correlationmap = NULL; 1812 if (periodic) 1813 correlationmap = PeriodicCorrelationToPoint(molecules, elements, Point, ranges); 1814 else 1815 correlationmap = CorrelationToPoint(molecules, elements, Point); 1816 OutputCorrelationToPoint(&output, correlationmap); 1817 BinPairMap *binmap = BinData( correlationmap, 0.5, BinStart, BinEnd ); 1818 OutputCorrelation ( &binoutput, binmap ); 1819 output.close(); 1820 binoutput.close(); 1821 delete(Point); 1822 delete(binmap); 1823 delete(correlationmap); 1824 argptr+=9; 1825 } 1826 } 1781 ArgcList.insert(argptr-1); 1782 ArgcList.insert(argptr); 1783 ArgcList.insert(argptr+1); 1784 ArgcList.insert(argptr+2); 1785 ArgcList.insert(argptr+3); 1786 ArgcList.insert(argptr+4); 1787 ArgcList.insert(argptr+5); 1788 ArgcList.insert(argptr+6); 1789 ArgcList.insert(argptr+7); 1790 ArgcList.insert(argptr+8); 1791 ArgcList.insert(argptr+9); 1792 ArgcList.insert(argptr+10); 1793 ArgcList.insert(argptr+11); 1794 ArgcList.insert(argptr+12); 1795 ArgcList.insert(argptr+13); 1796 ArgcList.insert(argptr+14); 1797 argptr+=15; 1827 1798 break; 1828 1799 1829 1800 case 'S': 1830 { 1831 if ((argptr+6 >= argc) || (!IsValidNumber(argv[argptr+1])) || (!IsValidNumber(argv[argptr+4])) || (!IsValidNumber(argv[argptr+5])) || (!IsValidNumber(argv[argptr+6])) || (argv[argptr+1][0] == '-') || (argv[argptr+2][0] == '-') || (argv[argptr+3][0] == '-')) { 1832 ExitFlag = 255; 1833 DoeLog(0) && (eLog()<< Verbose(0) << "Not enough or invalid arguments given for pair correlation analysis: -C S <Z> <output> <bin output> <BinWidth> <BinStart> <BinEnd>" << endl); 1834 performCriticalExit(); 1835 } else { 1836 ofstream output(argv[argptr+2]); 1837 ofstream binoutput(argv[argptr+3]); 1838 const double radius = 4.; 1839 const double BinWidth = atof(argv[argptr+4]); 1840 const double BinStart = atof(argv[argptr+5]); 1841 const double BinEnd = atof(argv[argptr+6]); 1842 double LCWidth = 20.; 1843 if (BinEnd > 0) { 1844 if (BinEnd > 2.*radius) 1845 LCWidth = BinEnd; 1846 else 1847 LCWidth = 2.*radius; 1848 } 1849 1850 // get the boundary 1851 class molecule *Boundary = NULL; 1852 class Tesselation *TesselStruct = NULL; 1853 const LinkedCell *LCList = NULL; 1854 // find biggest molecule 1855 int counter = 0; 1856 for (MoleculeList::iterator BigFinder = molecules->ListOfMolecules.begin(); BigFinder != molecules->ListOfMolecules.end(); BigFinder++) { 1857 if ((Boundary == NULL) || (Boundary->getAtomCount() < (*BigFinder)->getAtomCount())) { 1858 Boundary = *BigFinder; 1859 } 1860 counter++; 1861 } 1862 bool *Actives = new bool[counter]; 1863 counter = 0; 1864 for (MoleculeList::iterator BigFinder = molecules->ListOfMolecules.begin(); BigFinder != molecules->ListOfMolecules.end(); BigFinder++) { 1865 Actives[counter++] = (*BigFinder)->ActiveFlag; 1866 (*BigFinder)->ActiveFlag = (*BigFinder == Boundary) ? false : true; 1867 } 1868 LCList = new LinkedCell(Boundary, LCWidth); 1869 std::vector<element *> elements; 1870 elements.push_back(periode->FindElement((const int) atoi(argv[argptr+1]))); 1871 FindNonConvexBorder(Boundary, TesselStruct, LCList, radius, NULL); 1872 CorrelationToSurfaceMap *surfacemap = NULL; 1873 if (periodic) 1874 surfacemap = PeriodicCorrelationToSurface( molecules, elements, TesselStruct, LCList, ranges); 1875 else 1876 surfacemap = CorrelationToSurface( molecules, elements, TesselStruct, LCList); 1877 OutputCorrelationToSurface(&output, surfacemap); 1878 // check whether radius was appropriate 1879 { 1880 double start; double end; 1881 GetMinMax( surfacemap, start, end); 1882 if (LCWidth < end) 1883 DoeLog(1) && (eLog()<< Verbose(1) << "Linked Cell width is smaller than the found range of values! Bins can only be correct up to: " << radius << "." << endl); 1884 } 1885 BinPairMap *binmap = BinData( surfacemap, BinWidth, BinStart, BinEnd ); 1886 OutputCorrelation ( &binoutput, binmap ); 1887 output.close(); 1888 binoutput.close(); 1889 counter = 0; 1890 for (MoleculeList::iterator BigFinder = molecules->ListOfMolecules.begin(); BigFinder != molecules->ListOfMolecules.end(); BigFinder++) 1891 (*BigFinder)->ActiveFlag = Actives[counter++]; 1892 delete[](Actives); 1893 delete(LCList); 1894 delete(TesselStruct); 1895 delete(binmap); 1896 delete(surfacemap); 1897 argptr+=7; 1898 } 1899 } 1801 ArgcList.insert(argptr-1); 1802 ArgcList.insert(argptr); 1803 ArgcList.insert(argptr+1); 1804 ArgcList.insert(argptr+2); 1805 ArgcList.insert(argptr+3); 1806 ArgcList.insert(argptr+4); 1807 ArgcList.insert(argptr+5); 1808 ArgcList.insert(argptr+6); 1809 ArgcList.insert(argptr+7); 1810 ArgcList.insert(argptr+8); 1811 ArgcList.insert(argptr+9); 1812 ArgcList.insert(argptr+10); 1813 ArgcList.insert(argptr+11); 1814 ArgcList.insert(argptr+12); 1815 ArgcList.insert(argptr+13); 1816 ArgcList.insert(argptr+14); 1817 argptr+=15; 1900 1818 break; 1901 1819 … … 2237 2155 SaveFlag = true; 2238 2156 DoLog(0) && (Log() << Verbose(0) << "Converting to prinicipal axis system." << endl); 2157 mol->PrincipalAxisSystem((bool)j); 2239 2158 } else 2240 DoLog(0) && (Log() << Verbose(0) << "Evaluating prinicipal axis." << endl);2241 mol->PrincipalAxisSystem((bool)j);2159 ArgcList.insert(argptr-1); 2160 argptr+=0; 2242 2161 break; 2243 2162 case 'o': … … 2395 2314 // handle remaining arguments by CommandLineParser 2396 2315 MapOfActions::getInstance().AddOptionsToParser(); 2397 CommandLineParser::getInstance().Run(ArgcSize,Arguments); 2316 map <std::string, std::string> ShortFormToActionMap = MapOfActions::getInstance().getShortFormToActionMap(); 2317 CommandLineParser::getInstance().Run(ArgcSize,Arguments, ShortFormToActionMap); 2398 2318 if (!CommandLineParser::getInstance().isEmpty()) { 2399 2319 DoLog(0) && (Log() << Verbose(0) << "Setting UI to CommandLine." << endl); -
src/moleculelist.cpp
r0bcd11 r48c338 799 799 strncat(molecules[i]->name, number, MAXSTRINGSIZE - strlen(mol->name) - 1); 800 800 } 801 DoLog(1) && (Log() << Verbose(1) << "MolName is " << molecules[i]->name << endl);801 DoLog(1) && (Log() << Verbose(1) << "MolName is " << molecules[i]->name << ", id is " << molecules[i]->getId() << endl); 802 802 for (molecule::iterator iter = MolecularWalker->Leaf->begin(); iter != MolecularWalker->Leaf->end(); ++iter) { 803 803 DoLog(1) && (Log() << Verbose(1) << **iter << endl); -
src/periodentafel.cpp
r0bcd11 r48c338 70 70 * \param *pointer element to be removed 71 71 */ 72 voidperiodentafel::RemoveElement(element * const pointer)73 { 74 RemoveElement(pointer->getNumber());72 size_t periodentafel::RemoveElement(element * const pointer) 73 { 74 return RemoveElement(pointer->getNumber()); 75 75 }; 76 76 … … 78 78 * \param Z element to be removed 79 79 */ 80 voidperiodentafel::RemoveElement(atomicNumber_t Z)81 { 82 elements.erase(Z);80 size_t periodentafel::RemoveElement(atomicNumber_t Z) 81 { 82 return elements.erase(Z); 83 83 }; 84 84 … … 233 233 strncat(filename, STANDARDELEMENTSDB, MAXSTRINGSIZE-strlen(filename)); 234 234 input.open(filename); 235 if (!input.fail()) 236 DoLog(0) && (Log() << Verbose(0) << "Using " << filename << " as elements database." << endl); 235 237 status = status && LoadElementsDatabase(&input); 238 input.close(); 239 input.clear(); 236 240 237 241 // fill valence DB per element … … 240 244 strncat(filename, STANDARDVALENCEDB, MAXSTRINGSIZE-strlen(filename)); 241 245 input.open(filename); 246 if (!input.fail()) 247 DoLog(0) && (Log() << Verbose(0) << "Using " << filename << " as valence database." << endl); 242 248 otherstatus = otherstatus && LoadValenceDatabase(&input); 249 input.close(); 250 input.clear(); 243 251 244 252 // fill orbitals DB per element … … 247 255 strncat(filename, STANDARDORBITALDB, MAXSTRINGSIZE-strlen(filename)); 248 256 input.open(filename); 257 if (!input.fail()) 258 DoLog(0) && (Log() << Verbose(0) << "Using " << filename << " as orbitals database." << endl); 249 259 otherstatus = otherstatus && LoadOrbitalsDatabase(&input); 260 input.close(); 261 input.clear(); 250 262 251 263 // fill H-BondAngle DB per element … … 254 266 strncat(filename, STANDARDHBONDANGLEDB, MAXSTRINGSIZE-strlen(filename)); 255 267 input.open(filename); 268 if (!input.fail()) 269 DoLog(0) && (Log() << Verbose(0) << "Using " << filename << " as H bond angle database." << endl); 256 270 otherstatus = otherstatus && LoadHBondAngleDatabase(&input); 271 input.close(); 272 input.clear(); 257 273 258 274 // fill H-BondDistance DB per element … … 261 277 strncat(filename, STANDARDHBONDDISTANCEDB, MAXSTRINGSIZE-strlen(filename)); 262 278 input.open(filename); 279 if (!input.fail()) 280 DoLog(0) && (Log() << Verbose(0) << "Using " << filename << " as H bond length database." << endl); 263 281 otherstatus = otherstatus && LoadHBondLengthsDatabase(&input); 282 input.close(); 283 input.clear(); 264 284 265 285 if (!otherstatus){ … … 278 298 bool status = true; 279 299 int counter = 0; 300 pair< std::map<atomicNumber_t,element*>::iterator, bool > InserterTest; 280 301 if (!(*input).fail()) { 281 302 (*input).getline(header1, MAXSTRINGSIZE); … … 303 324 //(*input) >> ws; 304 325 (*input) >> ws; 305 if (elements.count(neues->Z)) {// if element already present, remove and delete it306 element * const Elemental = FindElement(neues->Z);307 ASSERT(Elemental != NULL, "element should be present but is not??");308 RemoveElement(Elemental);309 delete(Elemental);310 }311 326 //neues->Output((ofstream *)&cout); 312 if ((neues->Z > 0) && (neues->Z < MAX_ELEMENTS)) { 313 DoLog(0) && (Log() << Verbose(0) << " " << neues->symbol); 314 elements[neues->getNumber()] = neues; 327 if ((neues->getNumber() > 0) && (neues->getNumber() < MAX_ELEMENTS)) { 328 if (elements.count(neues->getNumber())) {// if element already present, remove and delete old one (i.e. replace it) 329 //cout << neues->symbol << " is present already." << endl; 330 element * const Elemental = FindElement(neues->getNumber()); 331 ASSERT(Elemental != NULL, "element should be present but is not??"); 332 *Elemental = *neues; 333 } else { 334 InserterTest = elements.insert(pair <atomicNumber_t,element*> (neues->getNumber(), neues)); 335 ASSERT(InserterTest.second, "Could not insert new element into periodentafel on LoadElementsDatabase()."); 336 } 337 DoLog(0) && (Log() << Verbose(0) << " " << elements[neues->getNumber()]->symbol); 315 338 counter++; 316 339 } else { … … 321 344 } 322 345 DoLog(0) && (Log() << Verbose(0) << endl); 323 } else 346 } else { 347 DoeLog(1) && (eLog() << Verbose(1) << "Could not open the database." << endl); 324 348 status = false; 349 } 325 350 326 351 if (counter == 0) -
src/periodentafel.hpp
r0bcd11 r48c338 44 44 45 45 iterator AddElement(element * const pointer); 46 voidRemoveElement(element * const pointer);47 voidRemoveElement(atomicNumber_t);46 size_t RemoveElement(element * const pointer); 47 size_t RemoveElement(atomicNumber_t); 48 48 void CleanupPeriodtable(); 49 49 element * const FindElement(atomicNumber_t) const; -
tests/regression/Analysis/3/post/bin_output.csv
r0bcd11 r48c338 5 5 1.5 0 6 6 2 0 7 2.5 08 3 09 3.5 010 4 011 4.5 012 5 313 5.5 214 6 37 2.5 1 8 3 1 9 3.5 6 10 4 7 11 4.5 10 12 5 8 13 5.5 13 14 6 5 15 15 6.5 6 16 7 217 7.5 518 8 419 8.5 520 9 921 9.5 922 10 523 10.5 724 11 125 11.5 116 7 4 17 7.5 1 18 8 0 19 8.5 0 20 9 0 21 9.5 0 22 10 0 23 10.5 0 24 11 0 25 11.5 0 26 26 12 0 27 27 12.5 0 -
tests/regression/testsuite-analysis.at
r0bcd11 r48c338 4 4 AT_KEYWORDS([analysis]) 5 5 AT_CHECK([/bin/cp -f ${abs_top_srcdir}/${AUTOTEST_PATH}/Analysis/1/pre/test.conf .], 0) 6 AT_CHECK([../../molecuilder test.conf -e ${abs_top_srcdir}/src/ -v 3 -C E 1 8 output.csv bin_output.csv 020], 0, [stdout], [stderr])6 AT_CHECK([../../molecuilder test.conf -e ${abs_top_srcdir}/src/ -v 3 -C E --elements 1 8 --output-file output.csv --bin-output-file bin_output.csv --bin-start 0 --bin-end 20], 0, [stdout], [stderr]) 7 7 AT_CHECK([fgrep "Begin of PairCorrelation" stdout], 0, [ignore], [ignore]) 8 8 #AT_CHECK([file=output.csv; diff $file ${abs_top_srcdir}/${AUTOTEST_PATH}/Analysis/1/post/$file], 0, [ignore], [ignore]) … … 14 14 AT_KEYWORDS([analysis]) 15 15 AT_CHECK([/bin/cp -f ${abs_top_srcdir}/${AUTOTEST_PATH}/Analysis/2/pre/test.conf .], 0) 16 AT_CHECK([../../molecuilder test.conf -e ${abs_top_srcdir}/src/ -v 3 -C E 1 8 output-5.csv bin_output-5.csv 05], 0, [stdout], [stderr])16 AT_CHECK([../../molecuilder test.conf -e ${abs_top_srcdir}/src/ -v 3 -C E --elements 1 8 --output-file output-5.csv --bin-output-file bin_output-5.csv --bin-start 0 --bin-end 5], 0, [stdout], [stderr]) 17 17 #AT_CHECK([file=output-5.csv; diff $file ${abs_top_srcdir}/${AUTOTEST_PATH}/Analysis/2/post/$file], 0, [ignore], [ignore]) 18 18 AT_CHECK([file=bin_output-5.csv; diff $file ${abs_top_srcdir}/${AUTOTEST_PATH}/Analysis/2/post/$file], 0, [ignore], [ignore]) 19 AT_CHECK([../../molecuilder test.conf -e ${abs_top_srcdir}/src/ -v 3 -C E 1 8 output-10.csv bin_output-10.csv 510], 0, [stdout], [stderr])19 AT_CHECK([../../molecuilder test.conf -e ${abs_top_srcdir}/src/ -v 3 -C E --elements 1 8 --output-file output-10.csv --bin-output-file bin_output-10.csv --bin-start 5 --bin-end 10], 0, [stdout], [stderr]) 20 20 #AT_CHECK([file=output-10.csv; diff $file ${abs_top_srcdir}/${AUTOTEST_PATH}/Analysis/2/post/$file], 0, [ignore], [ignore]) 21 21 AT_CHECK([file=bin_output-10.csv; diff $file ${abs_top_srcdir}/${AUTOTEST_PATH}/Analysis/2/post/$file], 0, [ignore], [ignore]) 22 AT_CHECK([../../molecuilder test.conf -e ${abs_top_srcdir}/src/ -v 3 -C E 1 8 output-20.csv bin_output-20.csv 1020], 0, [stdout], [stderr])22 AT_CHECK([../../molecuilder test.conf -e ${abs_top_srcdir}/src/ -v 3 -C E --elements 1 8 --output-file output-20.csv --bin-output-file bin_output-20.csv --bin-start 10 --bin-end 20], 0, [stdout], [stderr]) 23 23 #AT_CHECK([file=output-20.csv; diff $file ${abs_top_srcdir}/${AUTOTEST_PATH}/Analysis/2/post/$file], 0, [ignore], [ignore]) 24 24 AT_CHECK([file=bin_output-20.csv; diff $file ${abs_top_srcdir}/${AUTOTEST_PATH}/Analysis/2/post/$file], 0, [ignore], [ignore]) … … 29 29 AT_KEYWORDS([analysis]) 30 30 AT_CHECK([/bin/cp -f ${abs_top_srcdir}/${AUTOTEST_PATH}/Analysis/3/pre/test.conf .], 0) 31 AT_CHECK([../../molecuilder test.conf -e ${abs_top_srcdir}/src/ -v 3 -C P 1 10. 10. 10. output.csv bin_output.csv 020], 0, [stdout], [stderr])31 AT_CHECK([../../molecuilder test.conf -e ${abs_top_srcdir}/src/ -v 7 -C P --elements 1 --position 10. 10. 10. --output-file output.csv --bin-output-file bin_output.csv --bin-start 0 --bin-end 20], 0, [stdout], [stderr]) 32 32 AT_CHECK([fgrep "Begin of CorrelationToPoint" stdout], 0, [ignore], [ignore]) 33 33 #AT_CHECK([file=output.csv; diff $file ${abs_top_srcdir}/${AUTOTEST_PATH}/Analysis/3/post/$file], 0, [ignore], [ignore]) … … 39 39 AT_KEYWORDS([analysis]) 40 40 AT_CHECK([/bin/cp -f ${abs_top_srcdir}/${AUTOTEST_PATH}/Analysis/4/pre/test.conf .], 0) 41 AT_CHECK([../../molecuilder test.conf -e ${abs_top_srcdir}/src/ -v 3 -I -C S 1 output.csv bin_output.csv 1. 0 20], 0, [stdout], [stderr])41 AT_CHECK([../../molecuilder test.conf -e ${abs_top_srcdir}/src/ -v 3 -I -C S --elements 1 --output-file output.csv --bin-output-file bin_output.csv --bin-start 0 --bin-width 1. --bin-end 20 --molecule-by-id 208], 0, [stdout], [stderr]) 42 42 AT_CHECK([fgrep "Begin of CorrelationToSurface" stdout], 0, [ignore], [ignore]) 43 43 #AT_CHECK([file=output.csv; diff $file ${abs_top_srcdir}/${AUTOTEST_PATH}/Analysis/4/post/$file], 0, [ignore], [ignore]) … … 45 45 AT_CLEANUP 46 46 47 # 4. principal axis system48 AT_SETUP([Analysis - principal axis system])49 AT_KEYWORDS([analysis])50 AT_CHECK([/bin/cp -f ${abs_top_srcdir}/${AUTOTEST_PATH}/Analysis/5/pre/test.conf .], 0)51 AT_CHECK([../../molecuilder test.conf -e ${abs_top_srcdir}/src/ -v 3 -m 0], 0, [stdout], [stderr])52 AT_CHECK([fgrep "eigenvalue = 4382.53," stdout], 0, [ignore], [ignore])53 AT_CHECK([fgrep "eigenvalue = 4369.24," stdout], 0, [ignore], [ignore])54 AT_CHECK([fgrep "eigenvalue = 28.9359," stdout], 0, [ignore], [ignore])55 AT_CLEANUP47 # 5. principal axis system 48 #AT_SETUP([Analysis - principal axis system]) 49 #AT_KEYWORDS([analysis]) 50 #AT_CHECK([/bin/cp -f ${abs_top_srcdir}/${AUTOTEST_PATH}/Analysis/5/pre/test.conf .], 0) 51 #AT_CHECK([../../molecuilder test.conf -e ${abs_top_srcdir}/src/ -v 3 -m 0], 0, [stdout], [stderr]) 52 #AT_CHECK([fgrep "eigenvalue = 4382.53," stdout], 0, [ignore], [ignore]) 53 #AT_CHECK([fgrep "eigenvalue = 4369.24," stdout], 0, [ignore], [ignore]) 54 #AT_CHECK([fgrep "eigenvalue = 28.9359," stdout], 0, [ignore], [ignore]) 55 #AT_CLEANUP
Note:
See TracChangeset
for help on using the changeset viewer.