-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhexagonal_phase.py
80 lines (57 loc) · 1.86 KB
/
hexagonal_phase.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
import numpy as np
from scipy import spatial
import mrcfile
import random
import dill as pickle
import pdf
#parameters grid
minx=-150
maxx=150
nx=300
miny=-150
maxy=150
ny=300
minz=-150
maxz=150
nz=300
#density selection
density_skin=0.41
density_skin_thickness=0.01
#beads restraints
xaxis = np.linspace(minx,maxx, nx)
yaxis = np.linspace(miny,maxy, ny)
zaxis = np.linspace(minz,maxz, nz)
#create an hexagonal mesh
import numpy as np
import matplotlib.pyplot as plt
cell_dist=60.0
ratio = np.sqrt(3)/2 # cos(60°)
hexa=np.array([(0,0),(1,0),(-1,0),(-1/2,-ratio),(+1/2,-ratio),(-1/2,ratio),(+1/2,ratio)])
hexa*=cell_dist
pdfs=[]
for t in hexa:
x=t[0]
y=t[1]
pdfs.append(pdf.cylinder(x,y,r=20))
# create the cylinders
joint=pdf.joinpdf(pdfs)
# remove cylinders exceeding a distance
#cf=cylinder_filter(0,0,r=180)
#filterpdf=intersectpdf([joint,cf])
# remove part of the cyliner outside the sphere
sf=pdf.sphere_filter(r=140)
filterpdf=pdf.intersectpdf([joint,sf])
cylinders_density = filterpdf(xaxis[:,None,None], yaxis[None,:,None], zaxis[None,None,:])
pdf.save_density(cylinders_density, 1.0, "cylinders.mrc", origin=None)
# add an external sphere
sphere=pdf.sphere(r=140,tolerance=1000)
sphere_density = sphere(xaxis[:,None,None], yaxis[None,:,None], zaxis[None,None,:])
pdf.save_density(sphere_density, 1.0, "sphere.mrc", origin=None)
cylinder_threshold=(0.06,0.01)
sphere_threshold=(0.04,0.01)
rs,points,radii=pdf.sample_surface(cylinders_density,cylinder_threshold[0],cylinder_threshold[1],min_distance_beads=4)
pdf.save_density(rs, 1.0, "points_cylinder.mrc", origin=None)
pickle.dump((points,radii),open("points_cylinder.pkl","wb"))
rs,points,radii=pdf.sample_surface(sphere_density,sphere_threshold[0],sphere_threshold[1],min_distance_beads=6)
pdf.save_density(rs, 1.0, "points_sphere.mrc", origin=None)
pickle.dump((points,radii),open("points_sphere.pkl","wb"))