| 171 |
|
if (!args_info.ShellRadius_given){ |
| 172 |
|
std::cout << "Creating a random nanoparticle" << std::endl; |
| 173 |
|
/* Check to see if we have enough components */ |
| 174 |
< |
if (nComponents != args_info.molFraction_given + 1){ |
| 174 |
> |
if (nComponents != args_info.molFraction_given && nComponents != 1){ |
| 175 |
|
std::cerr << "Number of components does not equal molFraction occurances." << std::endl; |
| 176 |
|
exit(1); |
| 177 |
|
} |
| 178 |
|
/* Build the mole fractions and number of molecules of each type */ |
| 179 |
|
int totComponents = 0; |
| 180 |
< |
for (int i = 0;i<nComponents-2;i++){ /* Figure out Percent for each component */ |
| 180 |
> |
for (int i = 0;i<nComponents-1;i++){ /* Figure out Percent for each component */ |
| 181 |
|
numMol[i] = int((double)numSites * args_info.molFraction_arg[i]); |
| 182 |
+ |
std::cout<<numMol[i]<<std::endl; |
| 183 |
|
totComponents += numMol[i]; |
| 184 |
|
} |
| 185 |
|
numMol[nComponents-1] = numSites - totComponents; |
| 186 |
+ |
|
| 187 |
|
/* do the iPod thing, Shuffle da vector */ |
| 188 |
|
std::random_shuffle(nanoParticleSites.begin(), nanoParticleSites.end()); |
| 189 |
|
} else{ /*Handle core-shell with multiple components.*/ |
| 199 |
|
//get the orientation of the cell sites |
| 200 |
|
//for the same type of molecule in same lattice, it will not change |
| 201 |
|
latticeOrt = nanoParticle.getPointsOrt(); |
| 202 |
+ |
std::cout<<"Orientational vector Size: "<< std::endl; |
| 203 |
+ |
std::cout<<latticeOrt.size()<< std::endl; |
| 204 |
+ |
|
| 205 |
|
|
| 206 |
< |
|
| 202 |
< |
|
| 206 |
> |
|
| 207 |
|
// needed for writing out new md file. |
| 208 |
|
|
| 209 |
|
outPrefix = getPrefix(inputFileName.c_str()) + "_" + latticeType; |
| 219 |
|
// We need to read in new siminfo object. |
| 220 |
|
//parse md file and set up the system |
| 221 |
|
//SimCreator NewCreator; |
| 222 |
+ |
SimCreator newCreator; |
| 223 |
+ |
SimInfo* NewInfo = newCreator.createSim(outMdFileName, false); |
| 224 |
|
|
| 219 |
– |
SimInfo* NewInfo = oldCreator.createSim(outMdFileName, false); |
| 225 |
|
|
| 221 |
– |
|
| 222 |
– |
std::cout << "Contents of nanoParticleSites to follow: " << std::endl; |
| 223 |
– |
for (int i=0; i< nanoParticleSites.size() |
| 224 |
– |
; i++) { |
| 225 |
– |
cout<<nanoParticleSites.at(i)<<endl; |
| 226 |
– |
} |
| 226 |
|
// Place molecules |
| 227 |
|
Molecule* mol; |
| 228 |
|
SimInfo::MoleculeIterator mi; |