Changes in src/moleculelist.cpp [ca2587:437922]
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
src/moleculelist.cpp
rca2587 r437922 35 35 * \return true - add successful 36 36 */ 37 boolMoleculeListClass::insert(molecule *mol)37 void MoleculeListClass::insert(molecule *mol) 38 38 { 39 39 mol->IndexNr = MaxIndex++; … … 128 128 atom *Walker = NULL; 129 129 int Counts[MAX_ELEMENTS]; 130 double size=0; 131 Vector Origin; 130 132 131 133 // header 132 *out << "Index\tName\t No.Atoms\tformula" << endl;134 *out << "Index\tName\t\tAtoms\tFormula\tCenter\tSize" << endl; 133 135 cout << Verbose(0) << "-----------------------------------------------" << endl; 134 136 if (ListOfMolecules.size() == 0) 135 137 *out << "\tNone" << endl; 136 138 else { 139 Origin.Zero(); 137 140 for (MoleculeList::iterator ListRunner = ListOfMolecules.begin(); ListRunner != ListOfMolecules.end(); ListRunner++) { 138 141 // reset element counts 139 142 for (int j = 0; j<MAX_ELEMENTS;j++) 140 143 Counts[j] = 0; 141 // count atoms per element 144 // count atoms per element and determine size of bounding sphere 145 size=0.; 142 146 Walker = (*ListRunner)->start; 143 147 while (Walker->next != (*ListRunner)->end) { 144 148 Walker = Walker->next; 145 149 Counts[Walker->type->Z]++; 150 if (Walker->x.DistanceSquared(&Origin) > size) 151 size = Walker->x.DistanceSquared(&Origin); 146 152 } 147 153 // output Index, Name, number of atoms, chemical formula 148 154 *out << ((*ListRunner)->ActiveFlag ? "*" : " ") << (*ListRunner)->IndexNr << "\t" << (*ListRunner)->name << "\t\t" << (*ListRunner)->AtomCount << "\t"; 149 155 Elemental = (*ListRunner)->elemente->end; 150 while(Elemental != (*ListRunner)->elemente->start) {156 while(Elemental->previous != (*ListRunner)->elemente->start) { 151 157 Elemental = Elemental->previous; 152 158 if (Counts[Elemental->Z] != 0) 153 159 *out << Elemental->symbol << Counts[Elemental->Z]; 154 160 } 155 *out << endl; 161 // Center and size 162 *out << "\t" << (*ListRunner)->Center << "\t" << sqrt(size) << endl; 156 163 } 157 164 } … … 164 171 molecule * MoleculeListClass::ReturnIndex(int index) 165 172 { 166 int count = 1; 167 MoleculeList::iterator ListRunner = ListOfMolecules.begin(); 168 for(; ((ListRunner != ListOfMolecules.end()) && (count < index)); ListRunner++); 169 if (count == index) 170 return (*ListRunner); 171 else 172 return NULL; 173 for(MoleculeList::iterator ListRunner = ListOfMolecules.begin(); ListRunner != ListOfMolecules.end(); ListRunner++) 174 if ((*ListRunner)->IndexNr == index) 175 return (*ListRunner); 176 return NULL; 173 177 }; 174 178 … … 523 527 524 528 // open file for the force factors 525 *out << Verbose(1) << "Saving 529 *out << Verbose(1) << "Saving force factors ... "; 526 530 line << path << "/" << FRAGMENTPREFIX << FORCESFILE; 527 531 ForcesFile.open(line.str().c_str(), ios::out); … … 691 695 MoleculeLeafClass::MoleculeLeafClass(MoleculeLeafClass *PreviousLeaf = NULL) 692 696 { 693 // 694 // 695 // 696 // 697 // 697 // if (Up != NULL) 698 // if (Up->DownLeaf == NULL) // are we the first down leaf for the upper leaf? 699 // Up->DownLeaf = this; 700 // UpLeaf = Up; 701 // DownLeaf = NULL; 698 702 Leaf = NULL; 699 703 previous = PreviousLeaf; … … 711 715 MoleculeLeafClass::~MoleculeLeafClass() 712 716 { 713 // 714 // 715 // 716 // 717 // 718 // 719 // 720 // 721 // 722 // 717 // if (DownLeaf != NULL) {// drop leaves further down 718 // MoleculeLeafClass *Walker = DownLeaf; 719 // MoleculeLeafClass *Next; 720 // do { 721 // Next = Walker->NextLeaf; 722 // delete(Walker); 723 // Walker = Next; 724 // } while (Walker != NULL); 725 // // Last Walker sets DownLeaf automatically to NULL 726 // } 723 727 // remove the leaf itself 724 728 if (Leaf != NULL) { … … 729 733 if (previous != NULL) 730 734 previous->next = next; 731 // 732 // 733 // NextLeaf->UpLeaf = UpLeaf;// either null as we are top level or the upleaf of the first node734 // 735 // UpLeaf->DownLeaf = NextLeaf;// either null as we are only leaf or NextLeaf if we are just the first736 // 737 // 735 // } else { // we are first in list (connects to UpLeaf->DownLeaf) 736 // if ((NextLeaf != NULL) && (NextLeaf->UpLeaf == NULL)) 737 // NextLeaf->UpLeaf = UpLeaf; // either null as we are top level or the upleaf of the first node 738 // if (UpLeaf != NULL) 739 // UpLeaf->DownLeaf = NextLeaf; // either null as we are only leaf or NextLeaf if we are just the first 740 // } 741 // UpLeaf = NULL; 738 742 if (next != NULL) // are we last in list 739 743 next->previous = previous;
Note:
See TracChangeset
for help on using the changeset viewer.