yade-dev team mailing list archive
-
yade-dev team
-
Mailing list archive
-
Message #08159
[Branch ~yade-dev/yade/trunk] Rev 2981: - normalize psdCumm2 after the scaling, not before (since the scaling is determined from absolute...
------------------------------------------------------------
revno: 2981
committer: Bruno Chareyre <bruno.chareyre@xxxxxxxxxxx>
branch nick: trunk
timestamp: Thu 2011-12-08 13:04:28 +0100
message:
- normalize psdCumm2 after the scaling, not before (since the scaling is determined from absolute psdCumm2).
modified:
pkg/dem/SpherePack.cpp
--
lp:yade
https://code.launchpad.net/~yade-dev/yade/trunk
Your team Yade developers is subscribed to branch lp:yade.
To unsubscribe from this branch go to https://code.launchpad.net/~yade-dev/yade/trunk/+edit-subscription
=== modified file 'pkg/dem/SpherePack.cpp'
--- pkg/dem/SpherePack.cpp 2011-12-07 21:01:08 +0000
+++ pkg/dem/SpherePack.cpp 2011-12-08 12:04:28 +0000
@@ -129,16 +129,13 @@
// check monotonicity
if(i>0 && (psdSizes[i-1]>psdSizes[i] || psdCumm[i-1]>psdCumm[i])) throw invalid_argument("SpherePack:makeCloud: psdSizes and psdCumm must be both non-decreasing.");
}
- //Normalize psdCumm2 so it's between 0 and 1
- if(distributeMass) for(size_t i=1; i<psdSizes.size(); i++) psdCumm2[i]/=psdCumm2[psdSizes.size()-1];
-
// check the consistency between sizes, num, and poro if all three are imposed. If target number will not fit in (1-poro)*volume, scale down particles sizes
if (num>1){
appliedPsdScaling=1;
if(distributeMass) {
if (psdCumm2[psdSizes.size()-1]<num) appliedPsdScaling=pow(psdCumm2[psdSizes.size()-1]/num,1./3.);
//Normalize psdCumm2 so it's between 0 and 1
- for(size_t i=1; i<psdSizes.size(); i++) psdCumm2[i]/=psdCumm2[psdSizes.size()-1];
+// for(size_t i=1; i<psdSizes.size(); i++) psdCumm2[i]/=psdCumm2[psdSizes.size()-1];
} else {
double totVol=0;
for(size_t i=1; i<psdSizes.size(); i++) totVol+= 4/3*Mathr::PI*(psdCumm[i]-psdCumm[i-1])*num*
@@ -147,7 +144,9 @@
if (volumeRatio>1) appliedPsdScaling=pow(volumeRatio,-1./3.);
}
if (appliedPsdScaling<1) for(size_t i=0; i<psdSizes.size(); i++) psdRadii[i]*=appliedPsdScaling;
- }
+ }
+ //Normalize psdCumm2 so it's between 0 and 1
+ if(distributeMass) for(size_t i=1; i<psdSizes.size(); i++) psdCumm2[i]/=psdCumm2[psdSizes.size()-1];
}
if(err || mode<0) throw invalid_argument("SpherePack.makeCloud: at least one of rMean, porosity, psdSizes & psdCumm arguments must be specified. rMean can't be combined with psdSizes.");
// adjust uniform distribution parameters with distributeMass; rMean has the meaning (dimensionally) of _volume_