X-Git-Url: https://www.hackdaworld.org/gitweb/?a=blobdiff_plain;f=moldyn.c;h=9d782d657fbc89c5ab800ed7705de48c87739a1e;hb=76f807f6dda48b6d606309cea79005e612e4f665;hp=509a45da344a3f374567d8a727638763e68ed392;hpb=d888d2a17d4afa924939eb0d6528b2b73213d4f3;p=physik%2Fposic.git diff --git a/moldyn.c b/moldyn.c index 509a45d..9d782d6 100644 --- a/moldyn.c +++ b/moldyn.c @@ -41,8 +41,9 @@ int moldyn_init(t_moldyn *moldyn,int argc,char **argv) { int moldyn_shutdown(t_moldyn *moldyn) { - link_cell_shutdown(moldyn); + printf("[moldyn] shutdown\n"); moldyn_log_shutdown(moldyn); + link_cell_shutdown(moldyn); rand_close(&(moldyn->random)); free(moldyn->atom); @@ -156,7 +157,7 @@ int moldyn_set_log(t_moldyn *moldyn,u8 type,char *fb,int timer) { strncpy(moldyn->sfb,fb,63); break; case VISUAL_STEP: - moldyn->mwrite=timer; + moldyn->vwrite=timer; strncpy(moldyn->vfb,fb,63); visual_init(&(moldyn->vis),fb); break; @@ -170,9 +171,10 @@ int moldyn_set_log(t_moldyn *moldyn,u8 type,char *fb,int timer) { int moldyn_log_shutdown(t_moldyn *moldyn) { + printf("[moldyn] log shutdown\n"); if(moldyn->efd) close(moldyn->efd); if(moldyn->mfd) close(moldyn->mfd); - if(moldyn->visual) visual_tini(moldyn->visual); + if(&(moldyn->vis)) visual_tini(&(moldyn->vis)); return 0; } @@ -234,7 +236,7 @@ int create_lattice(t_moldyn *moldyn,u8 type,double lc,int element,double mass, } int add_atom(t_moldyn *moldyn,int element,double mass,u8 bnum,u8 attr, - t_3dvec r,t_3dvec v) { + t_3dvec *r,t_3dvec *v) { t_atom *atom; void *ptr; @@ -248,13 +250,15 @@ int add_atom(t_moldyn *moldyn,int element,double mass,u8 bnum,u8 attr, perror("[moldyn] realloc (add atom)"); return -1; } - - atom=ptr; - atom->r=r; - atom->v=v; - atom->element=element; - atom->bnum=bnum; - atom->attr=attr; + moldyn->atom=ptr; + + atom=moldyn->atom; + atom[count-1].r=*r; + atom[count-1].v=*v; + atom[count-1].element=element; + atom[count-1].mass=mass; + atom[count-1].bnum=bnum; + atom[count-1].attr=attr; return 0; } @@ -325,6 +329,12 @@ int scale_velocity(t_moldyn *moldyn) { /* * - velocity scaling (E = 3/2 N k T), E: kinetic energy */ + + if(moldyn->t==0.0) { + printf("[moldyn] no velocity scaling for T = 0 K\n"); + return -1; + } + e=0.0; for(i=0;icount;i++) e+=0.5*atom[i].mass*v3_absolute_square(&(atom[i].v)); @@ -381,15 +391,19 @@ t_3dvec get_total_p(t_moldyn *moldyn) { return p_total; } -double estimate_time_step(t_moldyn *moldyn,double nn_dist,double t) { +double estimate_time_step(t_moldyn *moldyn,double nn_dist) { double tau; - tau=0.05*nn_dist/(sqrt(3.0*K_BOLTZMANN*t/moldyn->atom[0].mass)); - tau*=1.0E-9; - if(tautau) - printf("[moldyn] warning: time step (%f > %.15f)\n", - moldyn->tau,tau); + /* nn_dist is the nearest neighbour distance */ + + if(moldyn->t==5.0) { + printf("[moldyn] i do not estimate timesteps below %f K!\n", + MOLDYN_CRITICAL_EST_TEMP); + return 23.42; + } + + tau=(0.05*nn_dist*moldyn->atom[0].mass)/sqrt(3.0*K_BOLTZMANN*moldyn->t); return tau; } @@ -404,6 +418,9 @@ int link_cell_init(t_moldyn *moldyn) { t_linkcell *lc; int i; + int fd; + + fd=open("/dev/null",O_WRONLY); lc=&(moldyn->lc); @@ -418,10 +435,11 @@ int link_cell_init(t_moldyn *moldyn) { lc->cells=lc->nx*lc->ny*lc->nz; lc->subcell=malloc(lc->cells*sizeof(t_list)); - printf("initializing linked cells (%d)\n",lc->cells); + printf("[moldyn] initializing linked cells (%d)\n",lc->cells); for(i=0;icells;i++) - list_init(&(lc->subcell[i]),1); + //list_init(&(lc->subcell[i]),1); + list_init(&(lc->subcell[i]),fd); link_cell_update(moldyn); @@ -541,6 +559,7 @@ int moldyn_add_schedule(t_moldyn *moldyn,int runs,double tau) { perror("[moldyn] realloc (runs)"); return -1; } + moldyn->schedule.runs=ptr; moldyn->schedule.runs[count-1]=runs; ptr=realloc(schedule->tau,count*sizeof(double)); @@ -548,6 +567,7 @@ int moldyn_add_schedule(t_moldyn *moldyn,int runs,double tau) { perror("[moldyn] realloc (tau)"); return -1; } + moldyn->schedule.tau=ptr; moldyn->schedule.tau[count-1]=tau; return 0; @@ -575,11 +595,13 @@ int moldyn_integrate(t_moldyn *moldyn) { unsigned int e,m,s,v; t_3dvec p; t_moldyn_schedule *schedule; + t_atom *atom; int fd; char fb[128]; schedule=&(moldyn->schedule); + atom=moldyn->atom; /* initialize linked cell method */ link_cell_init(moldyn); @@ -650,12 +672,13 @@ int moldyn_integrate(t_moldyn *moldyn) { } if(v) { if(!(i%v)) { - visual_atoms(moldyn->visual,i*moldyn->tau, + visual_atoms(&(moldyn->vis),moldyn->time, moldyn->atom,moldyn->count); - printf("\rsteps: %d",i); + printf("\rsched: %d, steps: %d",sched,i); fflush(stdout); } } + } /* check for hooks */ @@ -687,7 +710,7 @@ int velocity_verlet(t_moldyn *moldyn) { v3_add(&(atom[i].r),&(atom[i].r),&delta); v3_scale(&delta,&(atom[i].f),0.5*tau_square/atom[i].mass); v3_add(&(atom[i].r),&(atom[i].r),&delta); - v3_per_bound(&(atom[i].r),&(moldyn->dim)); + check_per_bound(moldyn,&(atom[i].r)); /* velocities */ v3_scale(&delta,&(atom[i].f),0.5*tau/atom[i].mass); @@ -695,15 +718,11 @@ int velocity_verlet(t_moldyn *moldyn) { } /* neighbour list update */ -printf("list update ...\n"); link_cell_update(moldyn); -printf("done\n"); /* forces depending on chosen potential */ -printf("calc potential/force ...\n"); potential_force_calc(moldyn); //moldyn->potential_force_function(moldyn); -printf("done\n"); for(i=0;idim.x/2)/lc->x, (atom[i].r.y+moldyn->dim.y/2)/lc->y, @@ -885,7 +904,6 @@ int harmonic_oscillator(t_moldyn *moldyn,t_atom *ai,t_atom *aj,u8 bc) { v3_sub(&distance,&(ai->r),&(aj->r)); - v3_per_bound(&distance,&(moldyn->dim)); if(bc) check_per_bound(moldyn,&distance); d=v3_norm(&distance); if(d<=moldyn->cutoff) { @@ -929,7 +947,7 @@ int lennard_jones(t_moldyn *moldyn,t_atom *ai,t_atom *aj,u8 bc) { d=+h1-h2; d*=eps; v3_scale(&force,&distance,d); - v3_add(&(ai->f),&(aj->f),&force); + v3_add(&(ai->f),&(ai->f),&force); } return 0;