本文整理汇总了C++中Interaction::E方法的典型用法代码示例。如果您正苦于以下问题:C++ Interaction::E方法的具体用法?C++ Interaction::E怎么用?C++ Interaction::E使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Interaction
的用法示例。
在下文中一共展示了Interaction::E方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: scatter
void BaseSpecies::scatter(t_particle &particle)
{
//select interacting species
double gamma = rnd->uni() / lifetime;
double tmp = 0.0;
size_t specid;
// We do not iterate over the last item in rates_species array,
// it should be select automatically if no other species was
// chosen before
for(specid=0; specid < rates_by_species.size()-1; specid++)
{
tmp += rates_by_species[specid];
if(tmp > gamma)
break;
}
// Generate the interacting particle
// use a random sample from velocity distribution of "continuum" species,
// otherwise select a random particle from the ensemble
double vr2,vz2,vt2;
t_particle * partner = NULL;
if(speclist[specid]->particles.size() == 0)
speclist[specid]->rndv(vr2,vz2,vt2);
else
{
partner = speclist[specid]->random_particle();
vr2 = partner->vx;
vz2 = partner->vz;
vt2 = partner->vy;
}
//cout << " v1 = " << vr2 << " " << vz2 << " " << vt2 <<endl;
double v_rel = norm(particle.vx-vr2, particle.vz-vz2, particle.vy-vt2);
double m2 = speclist[specid]->mass;
//select interaction
gamma = rnd->uni() * rates_by_species[specid];
tmp = 0.0;
size_t intid;
for(intid=0; intid < interactions_by_species[specid].size(); intid++)
{
tmp += interactions_by_species[specid][intid]->sigma_v(v_rel) * speclist[specid]->density;
if(tmp > gamma)
break;
}
// Null collision selected
if(intid==interactions_by_species[specid].size()) return;
Interaction * interaction = interactions_by_species[specid][intid];
//cout << "interaction " << interaction->name << " of " <<
// interaction->primary->name << " with " << interaction->secondary->name <<endl;
//cout << "interaction type " << interaction->type << " ELASTIC: " << ELASTIC <<endl;
switch(interaction->type)
{
case SUPERELASTIC:
{
double E = interaction->E(v_rel) + interaction->DE;
double v1_cm = interaction->v_rel(E);
// fix this v_rel // v1_cm
// cout << E <<" "<< interaction->E(v_rel) << " " << "CRR"<<endl;
double v1_cm_x, v1_cm_z, v1_cm_y;
rnd->rot(v1_cm, v1_cm_x, v1_cm_z, v1_cm_y);
particle.vx = v1_cm_x + (particle.vx*mass + vr2*m2)*tmp;
particle.vz = v1_cm_y + (particle.vz*mass + vz2*m2)*tmp;
particle.vy = v1_cm_z + (particle.vy*mass + vt2*m2)*tmp;
}
break;
case COULOMB:
case ELASTIC:
{
double tmp = 1.0/(mass+m2);
//transform to center of mass system
double v_cm_x = (particle.vx*mass + vr2*m2)*tmp;
double v_cm_z = (particle.vz*mass + vz2*m2)*tmp;
double v_cm_y = (particle.vy*mass + vt2*m2)*tmp;
double v1_cm_x = particle.vx - v_cm_x;
double v1_cm_z = particle.vz - v_cm_z;
double v1_cm_y = particle.vy - v_cm_y;
//isotropic random rotation
rnd->rot(v1_cm_x,v1_cm_y,v1_cm_z);
//cout << " v1 = " << v1_cm_x << " " << v1_cm_y << " " << v1_cm_z ;
//reverse transformation
//particle.vx = v1_cm_x + v_cm_x;
particle.vx = v1_cm_x + v_cm_x;
particle.vz = v1_cm_z + v_cm_z;
particle.vy = v1_cm_y + v_cm_y;
//cout << " v1 = " << particle.vx << " " << particle.vy << " " << particle.vz <<endl;
if(interaction->type == COULOMB)
{
//v2 = (p_CM - p1)/m2
//.........这里部分代码省略.........