main.py 2.18 KB
Newer Older
Stelios Karozis's avatar
Stelios Karozis committed
1
import tooba_f as tbf
Stelios Karozis's avatar
Stelios Karozis committed
2 3 4 5 6 7 8 9 10 11 12 13 14 15
###################################################
#NOTICE:    resids of head in each subdomain may differ in tail case
#           keep all atoms of group in the first occurent subdomain
#           in case of tail is the one closest to the head, hence
#           the code is a good approximation 
###################################################
TRAJ='traj.trr'
NUM_FR=1
GRO='initial.gro'
HEAD=True
HD_GROUP={'MMA':['C1', 'C2']}
TAIL=True
TL_GROUP={'MMA':['C3', 'C4', 'C5']}
###################################################
16
#Read .trr file
Stelios Karozis's avatar
Stelios Karozis committed
17
data_all=tbf.fr_export(trajfile=TRAJ,num_frames=NUM_FR)
18
#Read .gro file
Stelios Karozis's avatar
Stelios Karozis committed
19
_,data_num,_,res_num,res_type,atom_type,atom_num,_ = tbf.read_gro(GRO)
20 21
#Create subdomains coordinates
box_p=tbf.domain_decomposition(data=data_all,dx=2,dy=2,dz=2)
Stelios Karozis's avatar
Stelios Karozis committed
22

23 24 25
###################################################
if HEAD==True:
    #Find atom type index in lists created above
Stelios Karozis's avatar
Stelios Karozis committed
26
    group_ndx=tbf.atomid_data(res_num, atom_type, atom_num, group=HD_GROUP)
27 28 29 30 31 32 33 34 35 36 37
    #Assign desired atoms (from above function) to subdomains
    ##result1: {step:{res:{atom_type:{atom_num:(subX,subYsubZ)}}}}
    ##result2: {step:{res:{atom_type:{(subX,subYsubZ):[atom_num]}}}}
    _,box_res=tbf.atom2grid(data_all,box_p, group_ndx)
    #Creates dictionary with coordinates per subdomain for each frame
    coord_norm,_=tbf.sub_coord(box=box_res, data=data_all, res_num=res_num)
    #Creates dictionary with c, normal per subdomain for each frame
    surf=tbf.coord2norm(coord_norm,img=True)
###################################################
if TAIL==True:
    #Find atom type index in lists created above
Stelios Karozis's avatar
Stelios Karozis committed
38
    group_ndx=tbf.atomid_data(res_num, atom_type, atom_num, group=TL_GROUP)
39 40 41 42 43 44
    #Assign desired atoms (from above function) to subdomains
    ##result1: {step:{res:{atom_type:{atom_num:(subX,subYsubZ)}}}}
    ##result2: {step:{res:{atom_type:{(subX,subYsubZ):[atom_num]}}}}
    _,box_res=tbf.atom2grid(data_all,box_p, group_ndx)
    #Creates dictionary with coordinates per subdomain for each frame
    _,coord_vector=tbf.sub_coord(box=box_res, data=data_all, res_num=res_num)
Stelios Karozis's avatar
Stelios Karozis committed
45 46 47
    vector=tbf.coord2vector(coord_vector)
###################################################
tbf.SurfVector_angle(surf,vector)