Full write of constant volume plugin
| | |
| | | ts_double (*vm_energy_after_prepare)(void *vesicle, ts_vertex *vtx); |
| | | ts_double (*vm_energy_after_execute)(void *vesicle, ts_vertex *vtx); |
| | | ts_double (*vm_before_montecarlo_constraint)(void *vesicle, ts_vertex *vtx, ts_vertex *old_vtx); |
| | | ts_double (*vm_new_state_accepted)(void *vesicle, ts_vertex *vtx); |
| | | ts_double (*vm_new_state_rejected)(void *vesicle, ts_vertex *vtx); |
| | | ts_double (*vm_new_state_accepted)(void *vesicle, ts_vertex *vtx, ts_vertex *old_vtx); |
| | | ts_double (*vm_new_state_rejected)(void *vesicle, ts_vertex *vtx, ts_vertex *old_vtx); |
| | | void (*cleanup)(void); |
| | | } ts_plugin_function; |
| | | |
| | |
| | | ts_plugin_chain *vm_energy_before_prepare; |
| | | ts_plugin_chain *vm_energy_after_execute; |
| | | ts_plugin_chain *vm_before_montecarlo_constraint; |
| | | ts_plugin_chain *vm_new_state_accepted; |
| | | ts_plugin_chain *cleanup; |
| | | } ts_plugin_chains; |
| | | |
| | |
| | | if(plist->plugin[i]->function->vm_before_montecarlo_constraint!=NULL){ |
| | | plist->chain->vm_before_montecarlo_constraint=plugin_to_chain(plist->chain->vm_before_montecarlo_constraint, plist->plugin[i]); |
| | | } |
| | | if(plist->plugin[i]->function->vm_new_state_accepted!=NULL){ |
| | | plist->chain->vm_new_state_accepted=plugin_to_chain(plist->chain->vm_new_state_accepted, plist->plugin[i]); |
| | | } |
| | | } |
| | | plist->n=number_of_plugins; |
| | | return plist; |
| | |
| | | if(fabs(vesicle->volume+data->dvol-data->V0)>data->epsvol) return TS_FAIL; |
| | | } |
| | | return TS_SUCCESS; |
| | | // if(vesicle->tape->constvolswitch==2){ |
| | | // /*check whether the dvol is gt than epsvol */ |
| | | // if(fabs(vesicle->volume+data->dvol-data->V0)>data->epsvol) return TS_FAIL; |
| | | //This part doesn't work as expected yet. Delta_energy_cv shoould be accounted for in the total energy change. |
| | | } |
| | | |
| | | /* }else if(vesicle->tape->constvolswitch == 1){ |
| | | retval=constvolume(vesicle, vtx, -dvol, &delta_energy_cv, &constvol_vtx_moved,&constvol_vtx_backup); |
| | | if(retval==TS_FAIL){ // if we couldn't move the vertex to assure constant volume |
| | | return TS_FAIL; |
| | | } */ |
| | | return TS_SUCCESS; |
| | | |
| | | void vm_new_state_accepted(ts_vesicle *vesicle, ts_vertex *vtx, ts_vertex *old_vtx){ |
| | | if(vesicle->tape->constvolswitch >0){ |
| | | plugin_data *data=(plugin_data *)vesicle->plist->pointer->plugin->details->data; |
| | | vesicle->volume+=data->dvol; |
| | | } |
| | | } |
| | |
| | | ts_double delta_energy, oenergy,dvol=0.0, darea=0.0, dstretchenergy=0.0; |
| | | ts_double costheta,sintheta,phi,r; |
| | | //This will hold all the information of vtx and its neighbours |
| | | ts_vertex backupvtx[20], *constvol_vtx_moved=NULL, *constvol_vtx_backup=NULL; |
| | | ts_vertex backupvtx[20]; // *constvol_vtx_moved=NULL, *constvol_vtx_backup=NULL; |
| | | memcpy((void *)&backupvtx[0],(void *)vtx,sizeof(ts_vertex)); |
| | | |
| | | //random move in a sphere with radius stepsize: |
| | |
| | | } |
| | | |
| | | // fprintf(stderr, "before vtx(x,y,z)=%e,%e,%e\n",constvol_vtx_moved->x, constvol_vtx_moved->y, constvol_vtx_moved->z); |
| | | if(vesicle->tape->constvolswitch == 1){ |
| | | constvolumerestore(constvol_vtx_moved,constvol_vtx_backup); |
| | | } |
| | | // if(vesicle->tape->constvolswitch == 1){ |
| | | // constvolumerestore(constvol_vtx_moved,constvol_vtx_backup); |
| | | // } |
| | | // fprintf(stderr, "after vtx(x,y,z)=%e,%e,%e\n",constvol_vtx_moved->x, constvol_vtx_moved->y, constvol_vtx_moved->z); |
| | | // vesicle_volume(vesicle); |
| | | // fprintf(stderr,"Volume after fail=%1.16e\n", vesicle->volume); |
| | |
| | | |
| | | if(vesicle->tape->constvolswitch == 2){ |
| | | vesicle->volume+=dvol; |
| | | } else |
| | | if(vesicle->tape->constvolswitch == 1){ |
| | | constvolumeaccept(vesicle,constvol_vtx_moved,constvol_vtx_backup); |
| | | } |
| | | |
| | | |
| | | |
| | | if(vesicle->tape->constareaswitch==2){ |
| | | vesicle->area+=darea; |
| | | } |
| | | // if(oldcellidx); |
| | | //END MONTE CARLOOOOOOO |
| | | // vesicle_volume(vesicle); |
| | | // fprintf(stderr,"Volume after success=%1.16e\n", vesicle->volume); |
| | | |
| | | |
| | | /* Entry point for plugin vm_before_montecarlo_constraint() function */ |
| | | vesicle->plist->pointer=vesicle->plist->chain->vm_new_state_accepted; |
| | | while(vesicle->plist->pointer!=NULL){ |
| | | vesicle->plist->pointer->plugin->function->vm_new_state_accepted(vesicle,vtx, &backupvtx[0]); |
| | | vesicle->plist->pointer=vesicle->plist->pointer->next; |
| | | } |
| | | /* End of vm_before_montecarlo_constraint() */ |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | return TS_SUCCESS; |
| | | } |
| | | |