X-Git-Url: https://www.hackdaworld.org/gitweb/?p=physik%2Fposic.git;a=blobdiff_plain;f=mdrun.c;h=fb1cbe0233e3b62265755df993303143f4f910cc;hp=bb1cd21377ee706a31ecc489d19ac58fdf5d5450;hb=8e2583bfb346f0f054cf0f2ca35f25cd20a6f8d4;hpb=fe84cdc3fc897581636aff89b6f4fd12db1d2718 diff --git a/mdrun.c b/mdrun.c index bb1cd21..fb1cbe0 100644 --- a/mdrun.c +++ b/mdrun.c @@ -803,18 +803,35 @@ int del_atoms(t_moldyn *moldyn,t_mdrun *mdrun) { t_del_atoms_params *delp; int i; t_3dvec dist; - + u8 outer; + + outer=0; stage=mdrun->stage.current->data; delp=stage->params; + if(delp->r<0) + outer=1; + for(i=0;icount;i++) { v3_sub(&dist,&(delp->o),&(moldyn->atom[i].r)); //printf("%d ----> %f %f %f = %f | %f\n",i,dist.x,dist.y,dist.z,v3_absolute_square(&dist),delp->r*delp->r); if(v3_absolute_square(&dist)<=(delp->r*delp->r)) { - del_atom(moldyn,moldyn->atom[i].tag); - printf("%s atom deleted: %d %d %d\n",ME, - moldyn->atom[i].tag,moldyn->atom[i].element, - moldyn->atom[i].brand); + if(!outer) { + del_atom(moldyn,moldyn->atom[i].tag); + printf("%s atom deleted: %d %d %d\n",ME, + moldyn->atom[i].tag, + moldyn->atom[i].element, + moldyn->atom[i].brand); + } + } + else { + if(outer) { + del_atom(moldyn,moldyn->atom[i].tag); + printf("%s atom deleted: %d %d %d\n",ME, + moldyn->atom[i].tag, + moldyn->atom[i].element, + moldyn->atom[i].brand); + } } } @@ -1308,6 +1325,8 @@ int crt(t_moldyn *moldyn,t_mdrun *mdrun) { moldyn->count*sizeof(t_atom)); } close(fd); + /* visualize atoms */ + visual_atoms(moldyn); /* output energy */ printf(" crt energy: %d - %f\n\n",