forked from picografix/VESPER_python
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathVESPER.py
78 lines (63 loc) · 2.04 KB
/
VESPER.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
# imports
import time
import concurrent.futures
import copy
import math
import multiprocessing
import os
import mrcfile
import numba
import numpy as np
import pyfftw
import scipy.fft
from numba.typed import List
from scipy.spatial.transform import Rotation as R
from tqdm.notebook import tqdm
# import utils
from utils import *
from CMD import CMD
import command
start = time.time()
# set threads
pyfftw.config.PLANNER_EFFORT = "FFTW_MEASURE"
pyfftw.config.NUM_THREADS = multiprocessing.cpu_count()
print("Threads Initialized")
# code begins here
cmd = CMD() #creates a CMD object for input
command.input(cmd) #takes input if provided otherwise runs with default input
# initialize mrc_obj
mrc1 = mrc_obj(cmd.file1)
mrc2 = mrc_obj(cmd.file2)
print("mrc Initialized")
# set vox size
mrc1, mrc_N1 = mrc_set_vox_size(mrc1,voxel_size=cmd.ssize)
mrc2, mrc_N2 = mrc_set_vox_size(mrc2,voxel_size=cmd.ssize)
if mrc_N1.xdim > mrc_N2.xdim:
mrc_N2.xdim = mrc_N2.ydim = mrc_N2.zdim = mrc_N1.xdim
mrc_N2.orig["x"] = mrc_N2.cent[0] - 0.5 * 7 * mrc_N2.xdim
mrc_N2.orig["y"] = mrc_N2.cent[1] - 0.5 * 7 * mrc_N2.xdim
mrc_N2.orig["z"] = mrc_N2.cent[2] - 0.5 * 7 * mrc_N2.xdim
else:
mrc_N1.xdim = mrc_N1.ydim = mrc_N1.zdim = mrc_N2.xdim
mrc_N1.orig["x"] = mrc_N1.cent[0] - 0.5 * 7 * mrc_N1.xdim
mrc_N1.orig["y"] = mrc_N1.cent[1] - 0.5 * 7 * mrc_N1.xdim
mrc_N1.orig["z"] = mrc_N1.cent[2] - 0.5 * 7 * mrc_N1.xdim
print("set voc size complete")
# run fastVEC
print("FastVec Started")
mrc_N1 = fastVEC(mrc1, mrc_N1,dreso=cmd.dreso)
mrc_N2 = fastVEC(mrc2, mrc_N2,dreso=cmd.dreso)
print("FastVec Complete")
# rotate mrc
# print("Mrc Rotation Started")
# mrc = rot_mrc(mrc_N2.data, mrc_N2.vec, (48, 48, 48), [0, 0, 30])
# print("Mrc Rotation Complete")
#run search map fftw
print("Search Map Started")
score_list = search_map_fft(mrc_N1, mrc_N2, ang=cmd.ang, mode="VecProduct")
print("Search Map End")
print(sorted(score_list, key=lambda x: x[1], reverse=True)[:10])
# end
print("process complete")
end = time.time()
print(f"Runtime of the program is {end - start}")