DiffAb / design_dock.py
luost26's picture
Update
605bb4b
import os
import shutil
import argparse
from diffab.tools.dock.hdock import HDockAntibody
from diffab.tools.runner.design_for_pdb import args_factory, design_for_pdb
def main():
parser = argparse.ArgumentParser()
parser.add_argument('--antigen', type=str, required=True)
parser.add_argument('--antibody', type=str, default='./data/examples/3QHF_Fv.pdb')
parser.add_argument('--heavy', type=str, default='H', help='Chain id of the heavy chain.')
parser.add_argument('--light', type=str, default='L', help='Chain id of the light chain.')
parser.add_argument('--hdock_bin', type=str, default='./bin/hdock')
parser.add_argument('--createpl_bin', type=str, default='./bin/createpl')
parser.add_argument('-n', '--num_docks', type=int, default=10)
parser.add_argument('-c', '--config', type=str, default='./configs/test/codesign_single.yml')
parser.add_argument('-o', '--out_root', type=str, default='./results')
parser.add_argument('-t', '--tag', type=str, default='')
parser.add_argument('-s', '--seed', type=int, default=None)
parser.add_argument('-d', '--device', type=str, default='cuda')
parser.add_argument('-b', '--batch_size', type=int, default=16)
args = parser.parse_args()
print('[INFO] Start docking...')
hdock_missing = []
if not os.path.exists(args.hdock_bin):
hdock_missing.append(args.hdock_bin)
if not os.path.exists(args.createpl_bin):
hdock_missing.append(args.createpl_bin)
if len(hdock_missing) > 0:
print("[WARNING] The following HDOCK applications are missing:")
for f in hdock_missing:
print(f" > {f}")
print("Please download HDOCK from http://huanglab.phys.hust.edu.cn/software/hdocklite/ "
"and put `hdock` and `createpl` to the above path.")
exit()
antigen_name = os.path.basename(os.path.splitext(args.antigen)[0])
docked_pdb_dir = os.path.join(os.path.splitext(args.antigen)[0] + '_dock')
os.makedirs(docked_pdb_dir, exist_ok=True)
docked_pdb_paths = []
for fname in os.listdir(docked_pdb_dir):
if fname.endswith('.pdb'):
docked_pdb_paths.append(os.path.join(docked_pdb_dir, fname))
if len(docked_pdb_paths) < args.num_docks:
with HDockAntibody() as dock_session:
dock_session.set_antigen(args.antigen)
dock_session.set_antibody(args.antibody)
docked_tmp_paths = dock_session.dock()
for i, tmp_path in enumerate(docked_tmp_paths[:args.num_docks]):
dest_path = os.path.join(docked_pdb_dir, f"{antigen_name}_Ab_{i:04d}.pdb")
shutil.copyfile(tmp_path, dest_path)
print(f'[INFO] Copy {tmp_path} -> {dest_path}')
docked_pdb_paths.append(dest_path)
for pdb_path in docked_pdb_paths:
current_args = vars(args)
current_args['tag'] += antigen_name
design_args = args_factory(
pdb_path = pdb_path,
**current_args,
)
design_for_pdb(design_args)
if __name__ == '__main__':
main()