From b55ac507e11fd57f014f501cbb3303cd1d3e06b3 Mon Sep 17 00:00:00 2001 From: dp-yuanyn <139571209+dp-yuanyn@users.noreply.github.com> Date: Fri, 12 Apr 2024 11:49:32 +0800 Subject: [PATCH 1/5] env readd mgltools and remove tests using ad4 temporary (#121) --- unidock_tools/Dockerfile | 2 + .../tests/applications/test_unidock.py | 36 ++++++------ .../tests/ut/dock/test_run_unidock.py | 58 +++++++++---------- 3 files changed, 49 insertions(+), 47 deletions(-) diff --git a/unidock_tools/Dockerfile b/unidock_tools/Dockerfile index 95127f2..6fe18ee 100644 --- a/unidock_tools/Dockerfile +++ b/unidock_tools/Dockerfile @@ -21,6 +21,8 @@ RUN wget --quiet -O CDPKit.sh https://github.com/molinfo-vienna/CDPKit/releases/ WORKDIR /opt RUN mamba install -y ipython requests tqdm python-lmdb openbabel ambertools openmm -c conda-forge +RUN mamba create -y -n mgltools mgltools autogrid -c bioconda +ENV PATH $PATH:/opt/conda/envs/mgltools/bin COPY . /opt/unidock_tools RUN cd /opt/unidock_tools && \ diff --git a/unidock_tools/tests/applications/test_unidock.py b/unidock_tools/tests/applications/test_unidock.py index 3df1df6..f4b604e 100644 --- a/unidock_tools/tests/applications/test_unidock.py +++ b/unidock_tools/tests/applications/test_unidock.py @@ -79,24 +79,24 @@ def test_unidock_pipeline_ligand_index(receptor, ligand, pocket): shutil.rmtree(results_dir, ignore_errors=True) -def test_unidock_pipeline_scoring_ad4(receptor, ligand, pocket): - results_dir = "unidock_results_ad4" - cmd = f"unidocktools unidock_pipeline -r {receptor} -l {ligand} -sd {results_dir} \ - -cx {pocket['center_x']} -cy {pocket['center_y']} -cz {pocket['center_z']} \ - -sx {pocket['size_x']} -sy {pocket['size_y']} -sz {pocket['size_z']} \ - -sf ad4 -nm 1 --seed 181129" - print(cmd) - resp = subprocess.run(cmd, shell=True, capture_output=True, encoding="utf-8") - print(resp.stdout) - assert resp.returncode == 0, f"run unidock pipeline app err:\n{resp.stderr}" - - result_file = os.path.join(results_dir, Path(ligand).name) - assert os.path.exists(result_file), f"docking result file not found" - - score_list = read_scores(result_file, "docking_score") - score = score_list[0] - assert -20 <= score <= 0, f"Uni-Dock score not in range: {score}" - shutil.rmtree(results_dir, ignore_errors=True) +# def test_unidock_pipeline_scoring_ad4(receptor, ligand, pocket): +# results_dir = "unidock_results_ad4" +# cmd = f"unidocktools unidock_pipeline -r {receptor} -l {ligand} -sd {results_dir} \ +# -cx {pocket['center_x']} -cy {pocket['center_y']} -cz {pocket['center_z']} \ +# -sx {pocket['size_x']} -sy {pocket['size_y']} -sz {pocket['size_z']} \ +# -sf ad4 -nm 1 --seed 181129" +# print(cmd) +# resp = subprocess.run(cmd, shell=True, capture_output=True, encoding="utf-8") +# print(resp.stdout) +# assert resp.returncode == 0, f"run unidock pipeline app err:\n{resp.stderr}" + +# result_file = os.path.join(results_dir, Path(ligand).name) +# assert os.path.exists(result_file), f"docking result file not found" + +# score_list = read_scores(result_file, "docking_score") +# score = score_list[0] +# assert -20 <= score <= 0, f"Uni-Dock score not in range: {score}" +# shutil.rmtree(results_dir, ignore_errors=True) def test_unidock_pipeline_multi_pose(receptor, ligand, pocket): diff --git a/unidock_tools/tests/ut/dock/test_run_unidock.py b/unidock_tools/tests/ut/dock/test_run_unidock.py index d4639e2..4283a6b 100644 --- a/unidock_tools/tests/ut/dock/test_run_unidock.py +++ b/unidock_tools/tests/ut/dock/test_run_unidock.py @@ -55,32 +55,32 @@ def test_run_unidock_vina(receptor, ligand, pocket): shutil.rmtree(workdir, ignore_errors=True) -def test_run_unidock_ad4(receptor, ligand, pocket): - from unidock_tools.modules.docking import run_unidock - - workdir = Path(f"./tmp+{uuid.uuid4()}") - workdir.mkdir(parents=True, exist_ok=True) - - result_ligands, scores_list = run_unidock( - receptor=receptor, - ligands=[ligand], - output_dir=workdir, - center_x=pocket[0], - center_y=pocket[1], - center_z=pocket[2], - size_x=pocket[3], - size_y=pocket[4], - size_z=pocket[5], - scoring="ad4", - num_modes=5, - energy_range=6.0, - seed=181129, - ) - - result_ligand = result_ligands[0] - assert os.path.exists(result_ligand) - - scores = scores_list[0] - assert len(scores) == 5 - - shutil.rmtree(workdir, ignore_errors=True) \ No newline at end of file +# def test_run_unidock_ad4(receptor, ligand, pocket): +# from unidock_tools.modules.docking import run_unidock + +# workdir = Path(f"./tmp+{uuid.uuid4()}") +# workdir.mkdir(parents=True, exist_ok=True) + +# result_ligands, scores_list = run_unidock( +# receptor=receptor, +# ligands=[ligand], +# output_dir=workdir, +# center_x=pocket[0], +# center_y=pocket[1], +# center_z=pocket[2], +# size_x=pocket[3], +# size_y=pocket[4], +# size_z=pocket[5], +# scoring="ad4", +# num_modes=5, +# energy_range=6.0, +# seed=181129, +# ) + +# result_ligand = result_ligands[0] +# assert os.path.exists(result_ligand) + +# scores = scores_list[0] +# assert len(scores) == 5 + +# shutil.rmtree(workdir, ignore_errors=True) \ No newline at end of file From ab4d8cd46886949da10e62a5f10cd5d8839ef76f Mon Sep 17 00:00:00 2001 From: dp-yuanyn <139571209+dp-yuanyn@users.noreply.github.com> Date: Fri, 12 Apr 2024 12:23:10 +0800 Subject: [PATCH 2/5] readd ad4 tests (#122) --- .../tests/applications/test_unidock.py | 36 ++++++------ .../tests/ut/dock/test_run_unidock.py | 58 +++++++++---------- 2 files changed, 47 insertions(+), 47 deletions(-) diff --git a/unidock_tools/tests/applications/test_unidock.py b/unidock_tools/tests/applications/test_unidock.py index f4b604e..3df1df6 100644 --- a/unidock_tools/tests/applications/test_unidock.py +++ b/unidock_tools/tests/applications/test_unidock.py @@ -79,24 +79,24 @@ def test_unidock_pipeline_ligand_index(receptor, ligand, pocket): shutil.rmtree(results_dir, ignore_errors=True) -# def test_unidock_pipeline_scoring_ad4(receptor, ligand, pocket): -# results_dir = "unidock_results_ad4" -# cmd = f"unidocktools unidock_pipeline -r {receptor} -l {ligand} -sd {results_dir} \ -# -cx {pocket['center_x']} -cy {pocket['center_y']} -cz {pocket['center_z']} \ -# -sx {pocket['size_x']} -sy {pocket['size_y']} -sz {pocket['size_z']} \ -# -sf ad4 -nm 1 --seed 181129" -# print(cmd) -# resp = subprocess.run(cmd, shell=True, capture_output=True, encoding="utf-8") -# print(resp.stdout) -# assert resp.returncode == 0, f"run unidock pipeline app err:\n{resp.stderr}" - -# result_file = os.path.join(results_dir, Path(ligand).name) -# assert os.path.exists(result_file), f"docking result file not found" - -# score_list = read_scores(result_file, "docking_score") -# score = score_list[0] -# assert -20 <= score <= 0, f"Uni-Dock score not in range: {score}" -# shutil.rmtree(results_dir, ignore_errors=True) +def test_unidock_pipeline_scoring_ad4(receptor, ligand, pocket): + results_dir = "unidock_results_ad4" + cmd = f"unidocktools unidock_pipeline -r {receptor} -l {ligand} -sd {results_dir} \ + -cx {pocket['center_x']} -cy {pocket['center_y']} -cz {pocket['center_z']} \ + -sx {pocket['size_x']} -sy {pocket['size_y']} -sz {pocket['size_z']} \ + -sf ad4 -nm 1 --seed 181129" + print(cmd) + resp = subprocess.run(cmd, shell=True, capture_output=True, encoding="utf-8") + print(resp.stdout) + assert resp.returncode == 0, f"run unidock pipeline app err:\n{resp.stderr}" + + result_file = os.path.join(results_dir, Path(ligand).name) + assert os.path.exists(result_file), f"docking result file not found" + + score_list = read_scores(result_file, "docking_score") + score = score_list[0] + assert -20 <= score <= 0, f"Uni-Dock score not in range: {score}" + shutil.rmtree(results_dir, ignore_errors=True) def test_unidock_pipeline_multi_pose(receptor, ligand, pocket): diff --git a/unidock_tools/tests/ut/dock/test_run_unidock.py b/unidock_tools/tests/ut/dock/test_run_unidock.py index 4283a6b..d4639e2 100644 --- a/unidock_tools/tests/ut/dock/test_run_unidock.py +++ b/unidock_tools/tests/ut/dock/test_run_unidock.py @@ -55,32 +55,32 @@ def test_run_unidock_vina(receptor, ligand, pocket): shutil.rmtree(workdir, ignore_errors=True) -# def test_run_unidock_ad4(receptor, ligand, pocket): -# from unidock_tools.modules.docking import run_unidock - -# workdir = Path(f"./tmp+{uuid.uuid4()}") -# workdir.mkdir(parents=True, exist_ok=True) - -# result_ligands, scores_list = run_unidock( -# receptor=receptor, -# ligands=[ligand], -# output_dir=workdir, -# center_x=pocket[0], -# center_y=pocket[1], -# center_z=pocket[2], -# size_x=pocket[3], -# size_y=pocket[4], -# size_z=pocket[5], -# scoring="ad4", -# num_modes=5, -# energy_range=6.0, -# seed=181129, -# ) - -# result_ligand = result_ligands[0] -# assert os.path.exists(result_ligand) - -# scores = scores_list[0] -# assert len(scores) == 5 - -# shutil.rmtree(workdir, ignore_errors=True) \ No newline at end of file +def test_run_unidock_ad4(receptor, ligand, pocket): + from unidock_tools.modules.docking import run_unidock + + workdir = Path(f"./tmp+{uuid.uuid4()}") + workdir.mkdir(parents=True, exist_ok=True) + + result_ligands, scores_list = run_unidock( + receptor=receptor, + ligands=[ligand], + output_dir=workdir, + center_x=pocket[0], + center_y=pocket[1], + center_z=pocket[2], + size_x=pocket[3], + size_y=pocket[4], + size_z=pocket[5], + scoring="ad4", + num_modes=5, + energy_range=6.0, + seed=181129, + ) + + result_ligand = result_ligands[0] + assert os.path.exists(result_ligand) + + scores = scores_list[0] + assert len(scores) == 5 + + shutil.rmtree(workdir, ignore_errors=True) \ No newline at end of file From 26aafdf3733ccd44e4bab7084c252a5d4af1b515 Mon Sep 17 00:00:00 2001 From: dp-yuanyn <139571209+dp-yuanyn@users.noreply.github.com> Date: Fri, 26 Apr 2024 16:58:23 +0800 Subject: [PATCH 3/5] fix:ligand index list too long err (#127) --- .../src/unidock_tools/application/unidock_pipeline.py | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/unidock_tools/src/unidock_tools/application/unidock_pipeline.py b/unidock_tools/src/unidock_tools/application/unidock_pipeline.py index d0559f5..cc4db05 100644 --- a/unidock_tools/src/unidock_tools/application/unidock_pipeline.py +++ b/unidock_tools/src/unidock_tools/application/unidock_pipeline.py @@ -212,11 +212,10 @@ def main(args: dict): if args.get("ligand_index"): with open(args["ligand_index"], "r") as f: index_content = f.read() - index_lines1 = [Path(line.strip()).resolve() for line in index_content.split("\n") - if line.strip() and Path(line.strip()).exists()] - index_lines2 = [Path(line.strip()).resolve() for line in index_content.split(" ") - if line.strip() and Path(line.strip()).exists()] + index_lines1 = [line.strip() for line in index_content.split("\n") if line.strip()] + index_lines2 = [line.strip() for line in index_content.split(" ") if line.strip()] ligands.extend(index_lines2 if len(index_lines2) > len(index_lines1) else index_lines1) + ligands = [Path(ligand).resolve() for ligand in ligands if Path(ligand).exists()] if len(ligands) == 0: logging.error("No ligands found.") From d7d958f7a29b6689b001a0ca1f3f11d60696197b Mon Sep 17 00:00:00 2001 From: dp-yuanyn <139571209+dp-yuanyn@users.noreply.github.com> Date: Sun, 28 Apr 2024 11:00:21 +0800 Subject: [PATCH 4/5] build: change docker build runner from github to self (#128) * just to re build docker image * build:change docker build runner from github to self * Update docker.yml --------- Co-authored-by: Chun Cai --- .github/workflows/docker.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/docker.yml b/.github/workflows/docker.yml index d449f93..1a18270 100644 --- a/.github/workflows/docker.yml +++ b/.github/workflows/docker.yml @@ -9,7 +9,7 @@ on: jobs: build_and_push_docker_image: - runs-on: ubuntu-latest + runs-on: t4 if: github.repository_owner == 'dptech-corp' strategy: matrix: From 6c4c72da22755b8dcb336c18b96ed62d01993c2f Mon Sep 17 00:00:00 2001 From: YANG SHAOYI <34128364+ysyecust@users.noreply.github.com> Date: Sun, 28 Apr 2024 18:31:13 +0800 Subject: [PATCH 5/5] feat: update ligand group method (#125) * feat: update ligand group method * test: change unidock-tools dock energy range * test: unidock_tools dock test case energy_range * Update random seed --- unidock/src/cuda/kernel.h | 60 +++++++++++++++---- unidock/src/cuda/monte_carlo.cu | 35 +++++++++++ unidock/src/main/main.cpp | 53 ++++++++++------ .../tests/ut/dock/test_run_unidock.py | 8 +-- 4 files changed, 121 insertions(+), 35 deletions(-) diff --git a/unidock/src/cuda/kernel.h b/unidock/src/cuda/kernel.h index 2e15918..03a72f4 100644 --- a/unidock/src/cuda/kernel.h +++ b/unidock/src/cuda/kernel.h @@ -96,10 +96,10 @@ static constexpr size_t MAX_THREAD_ = 41700000 ; // modified for vina1.2, to cal static constexpr size_t MAX_LIGAND_NUM_ = 10250; }; struct SmallConfig { -static constexpr size_t MAX_NUM_OF_LIG_TORSION_ = 14; +static constexpr size_t MAX_NUM_OF_LIG_TORSION_ = 8; static constexpr size_t MAX_NUM_OF_FLEX_TORSION_ = 1; -static constexpr size_t MAX_NUM_OF_RIGID_ = 14; -static constexpr size_t MAX_NUM_OF_ATOMS_ = 80; +static constexpr size_t MAX_NUM_OF_RIGID_ = 12; +static constexpr size_t MAX_NUM_OF_ATOMS_ = 40; static constexpr size_t SIZE_OF_MOLEC_STRUC_ = ((3 + 4 + MAX_NUM_OF_LIG_TORSION_ + MAX_NUM_OF_FLEX_TORSION_ + 1) * sizeof(float)); static constexpr size_t SIZE_OF_CHANGE_STRUC_ = @@ -132,10 +132,10 @@ static constexpr size_t MAX_THREAD_ = 41700000 ; // modified for vina1.2, to cal static constexpr size_t MAX_LIGAND_NUM_ = 10250; }; struct MediumConfig { -static constexpr size_t MAX_NUM_OF_LIG_TORSION_ = 18; +static constexpr size_t MAX_NUM_OF_LIG_TORSION_ = 16; static constexpr size_t MAX_NUM_OF_FLEX_TORSION_ = 1; static constexpr size_t MAX_NUM_OF_RIGID_ = 18; -static constexpr size_t MAX_NUM_OF_ATOMS_ = 100; +static constexpr size_t MAX_NUM_OF_ATOMS_ = 80; static constexpr size_t SIZE_OF_MOLEC_STRUC_ = ((3 + 4 + MAX_NUM_OF_LIG_TORSION_ + MAX_NUM_OF_FLEX_TORSION_ + 1) * sizeof(float)); static constexpr size_t SIZE_OF_CHANGE_STRUC_ = @@ -143,7 +143,7 @@ static constexpr size_t SIZE_OF_CHANGE_STRUC_ = static constexpr size_t MAX_HESSIAN_MATRIX_D_SIZE_ = ((6 + MAX_NUM_OF_LIG_TORSION_ + MAX_NUM_OF_FLEX_TORSION_) * (6 + MAX_NUM_OF_LIG_TORSION_ + MAX_NUM_OF_FLEX_TORSION_ + 1) / 2); -static constexpr size_t MAX_NUM_OF_LIG_PAIRS_ =330; +static constexpr size_t MAX_NUM_OF_LIG_PAIRS_ =600; static constexpr size_t MAX_NUM_OF_BFGS_STEPS_ =64; static constexpr size_t MAX_NUM_OF_RANDOM_MAP_= 1000 ;// not too large (stack overflow!) static constexpr size_t GRIDS_SIZE_ =37 ; // larger than vina1.1, max(XS_TYPE_SIZE, AD_TYPE_SIZE + 2) @@ -170,8 +170,8 @@ static constexpr size_t MAX_LIGAND_NUM_ = 10250; struct LargeConfig { static constexpr size_t MAX_NUM_OF_LIG_TORSION_ = 24; static constexpr size_t MAX_NUM_OF_FLEX_TORSION_ = 1; -static constexpr size_t MAX_NUM_OF_RIGID_ = 24; -static constexpr size_t MAX_NUM_OF_ATOMS_ = 100; +static constexpr size_t MAX_NUM_OF_RIGID_ = 36; +static constexpr size_t MAX_NUM_OF_ATOMS_ = 120; static constexpr size_t SIZE_OF_MOLEC_STRUC_ = ((3 + 4 + MAX_NUM_OF_LIG_TORSION_ + MAX_NUM_OF_FLEX_TORSION_ + 1) * sizeof(float)); static constexpr size_t SIZE_OF_CHANGE_STRUC_ = @@ -179,7 +179,7 @@ static constexpr size_t SIZE_OF_CHANGE_STRUC_ = static constexpr size_t MAX_HESSIAN_MATRIX_D_SIZE_ = ((6 + MAX_NUM_OF_LIG_TORSION_ + MAX_NUM_OF_FLEX_TORSION_) * (6 + MAX_NUM_OF_LIG_TORSION_ + MAX_NUM_OF_FLEX_TORSION_ + 1) / 2); -static constexpr size_t MAX_NUM_OF_LIG_PAIRS_ =512; +static constexpr size_t MAX_NUM_OF_LIG_PAIRS_ =1024; static constexpr size_t MAX_NUM_OF_BFGS_STEPS_ =64; static constexpr size_t MAX_NUM_OF_RANDOM_MAP_= 1000 ;// not too large (stack overflow!) static constexpr size_t GRIDS_SIZE_ =37 ; // larger than vina1.1, max(XS_TYPE_SIZE, AD_TYPE_SIZE + 2) @@ -204,10 +204,46 @@ static constexpr size_t MAX_THREAD_ = 41700000 ; // modified for vina1.2, to cal static constexpr size_t MAX_LIGAND_NUM_ = 10250; }; struct ExtraLargeConfig { +static constexpr size_t MAX_NUM_OF_LIG_TORSION_ = 36; +static constexpr size_t MAX_NUM_OF_FLEX_TORSION_ = 1; +static constexpr size_t MAX_NUM_OF_RIGID_ = 64; +static constexpr size_t MAX_NUM_OF_ATOMS_ = 160; +static constexpr size_t SIZE_OF_MOLEC_STRUC_ = +((3 + 4 + MAX_NUM_OF_LIG_TORSION_ + MAX_NUM_OF_FLEX_TORSION_ + 1) * sizeof(float)); +static constexpr size_t SIZE_OF_CHANGE_STRUC_ = + ((3 + 3 + MAX_NUM_OF_LIG_TORSION_ + MAX_NUM_OF_FLEX_TORSION_ + 1) * sizeof(float)); +static constexpr size_t MAX_HESSIAN_MATRIX_D_SIZE_ = + ((6 + MAX_NUM_OF_LIG_TORSION_ + MAX_NUM_OF_FLEX_TORSION_) + * (6 + MAX_NUM_OF_LIG_TORSION_ + MAX_NUM_OF_FLEX_TORSION_ + 1) / 2); +static constexpr size_t MAX_NUM_OF_LIG_PAIRS_ =2048; +static constexpr size_t MAX_NUM_OF_BFGS_STEPS_ =64; +static constexpr size_t MAX_NUM_OF_RANDOM_MAP_= 1000 ;// not too large (stack overflow!) +static constexpr size_t GRIDS_SIZE_ =37 ; // larger than vina1.1, max(XS_TYPE_SIZE, AD_TYPE_SIZE + 2) + +static constexpr size_t MAX_NUM_OF_GRID_MI_ =128; // 55 +static constexpr size_t MAX_NUM_OF_GRID_MJ_= 128; // 55 +static constexpr size_t MAX_NUM_OF_GRID_MK_ =128 ; // 81 +static constexpr size_t MAX_NUM_OF_GRID_POINT_ =512000; + +//#define GRID_MI 65//55 +//#define GRID_MJ 71//55 +//#define GRID_MK 61//81 +static constexpr size_t MAX_PRECAL_NUM_ATOM_ =30; +static constexpr size_t MAX_P_DATA_M_DATA_SIZE_ =MAX_NUM_OF_ATOMS_*(MAX_NUM_OF_ATOMS_+1)/2; +// modified for vina1.2, should be larger, n*(n+1)/2, n=num_of_atom, select n=140 +//#define MAX_NUM_OF_GRID_ATOMS 150 +static constexpr size_t FAST_SIZE_ =2051 ;// modified for vina1.2 m_max_cutoff^2 * factor + 3, ad4=13424 +static constexpr size_t SMOOTH_SIZE_ =2051; +static constexpr size_t MAX_CONTAINER_SIZE_EVERY_WI_ =5; + +static constexpr size_t MAX_THREAD_ = 41700000 ; // modified for vina1.2, to calculate random map memory upper bound +static constexpr size_t MAX_LIGAND_NUM_ = 10250; +}; +struct MaxConfig { static constexpr size_t MAX_NUM_OF_LIG_TORSION_ = 48; static constexpr size_t MAX_NUM_OF_FLEX_TORSION_ = 1; -static constexpr size_t MAX_NUM_OF_RIGID_ = 48; -static constexpr size_t MAX_NUM_OF_ATOMS_ = 150; +static constexpr size_t MAX_NUM_OF_RIGID_ = 128; +static constexpr size_t MAX_NUM_OF_ATOMS_ = 300; static constexpr size_t SIZE_OF_MOLEC_STRUC_ = ((3 + 4 + MAX_NUM_OF_LIG_TORSION_ + MAX_NUM_OF_FLEX_TORSION_ + 1) * sizeof(float)); static constexpr size_t SIZE_OF_CHANGE_STRUC_ = @@ -215,7 +251,7 @@ static constexpr size_t SIZE_OF_CHANGE_STRUC_ = static constexpr size_t MAX_HESSIAN_MATRIX_D_SIZE_ = ((6 + MAX_NUM_OF_LIG_TORSION_ + MAX_NUM_OF_FLEX_TORSION_) * (6 + MAX_NUM_OF_LIG_TORSION_ + MAX_NUM_OF_FLEX_TORSION_ + 1) / 2); -static constexpr size_t MAX_NUM_OF_LIG_PAIRS_ =1024; +static constexpr size_t MAX_NUM_OF_LIG_PAIRS_ =4096; static constexpr size_t MAX_NUM_OF_BFGS_STEPS_ =64; static constexpr size_t MAX_NUM_OF_RANDOM_MAP_= 1000 ;// not too large (stack overflow!) static constexpr size_t GRIDS_SIZE_ =37 ; // larger than vina1.1, max(XS_TYPE_SIZE, AD_TYPE_SIZE + 2) diff --git a/unidock/src/cuda/monte_carlo.cu b/unidock/src/cuda/monte_carlo.cu index 979880e..d98625f 100644 --- a/unidock/src/cuda/monte_carlo.cu +++ b/unidock/src/cuda/monte_carlo.cu @@ -1130,6 +1130,34 @@ std::vector monte_carlo_template::cuda_to_vina(ou } return results_vina; } +template<> +std::vector monte_carlo_template::cuda_to_vina(output_type_cuda_t_ results_ptr[], + int thread) const { + // DEBUG_PRINTF("entering cuda_to_vina\n"); + std::vector results_vina; + for (int i = 0; i < thread; ++i) { + output_type_cuda_t_ results = results_ptr[i]; + conf tmp_c; + tmp_c.ligands.resize(1); + // Position + for (int j = 0; j < 3; j++) tmp_c.ligands[0].rigid.position[j] = results.position[j]; + // Orientation + qt q(results.orientation[0], results.orientation[1], results.orientation[2], + results.orientation[3]); + tmp_c.ligands[0].rigid.orientation = q; + output_type tmp_vina(tmp_c, results.e); + // torsion + for (int j = 0; j < results.lig_torsion_size; j++) + tmp_vina.c.ligands[0].torsions.push_back(results.lig_torsion[j]); + // coords + for (int j = 0; j < MaxConfig::MAX_NUM_OF_ATOMS_; j++) { + vec v_tmp(results.coords[j][0], results.coords[j][1], results.coords[j][2]); + if (v_tmp[0] * v_tmp[1] * v_tmp[2] != 0) tmp_vina.coords.push_back(v_tmp); + } + results_vina.push_back(tmp_vina); + } + return results_vina; +} __host__ void monte_carlo::operator()( std::vector &m_gpu, std::vector &out_gpu, std::vector &p_gpu, triangular_matrix_cuda_t *m_data_list_gpu, @@ -2972,6 +3000,13 @@ __host__ void monte_carlo_template::do_docking(std::vector> &bias_batch_list) const { monte_carlo_template::do_docking_base(m_gpu, out_gpu,p_gpu, m_data_list_gpu,ig, corner1, corner2, generator, verbosity,seed, bias_batch_list); } +template <> +__host__ void monte_carlo_template::do_docking(std::vector &m_gpu, std::vector &out_gpu, + std::vector &p_gpu, triangular_matrix_cuda_t *m_data_list_gpu, + const igrid &ig, const vec &corner1, const vec &corner2, rng &generator, int verbosity, + unsigned long long seed, std::vector> &bias_batch_list) const { + monte_carlo_template::do_docking_base(m_gpu, out_gpu,p_gpu, m_data_list_gpu,ig, corner1, corner2, generator, verbosity,seed, bias_batch_list); + } /* Above based on monte-carlo.cpp */ // #endif diff --git a/unidock/src/main/main.cpp b/unidock/src/main/main.cpp index 3d1a9f5..a230188 100644 --- a/unidock/src/main/main.cpp +++ b/unidock/src/main/main.cpp @@ -90,6 +90,30 @@ float calculateScore(const Ligand &ligand) { bool compareLigands(const Ligand &a, const Ligand &b) { return a.score < b.score; } +void classifyLigands(const std::vector& ligands,std::vector &smallGroup, std::vector &mediumGroup,std::vector & largeGroup, std::vector &extraLargeGroup, std::vector &overflowGroup) { + const int atomThresholds[5] = {40, 80, 120, 160, 300}; + const int torsionThresholds[5] = {8, 16, 24, 36, 48}; + const int rigidThresholds[5] = {12, 24, 36, 64, 128}; + const int pairThresholds[5] = {300, 600, 1024, 2048, 4096}; + + for (const auto& lig : ligands) { + if (lig.num_atoms <= atomThresholds[0] && lig.num_torsions <= torsionThresholds[0] && + lig.num_rigids <= rigidThresholds[0] && lig.num_lig_pairs <= pairThresholds[0]) { + smallGroup.push_back(lig); + } else if (lig.num_atoms <= atomThresholds[1] && lig.num_torsions <= torsionThresholds[1] && + lig.num_rigids <= rigidThresholds[1] && lig.num_lig_pairs <= pairThresholds[1]) { + mediumGroup.push_back(lig); + } else if (lig.num_atoms <= atomThresholds[2] && lig.num_torsions <= torsionThresholds[2] && + lig.num_rigids <= rigidThresholds[2] && lig.num_lig_pairs <= pairThresholds[2]) { + largeGroup.push_back(lig); + } else if (lig.num_atoms <= atomThresholds[3] && lig.num_torsions <= torsionThresholds[3] && + lig.num_rigids <= rigidThresholds[3] && lig.num_lig_pairs <= pairThresholds[3]) { + extraLargeGroup.push_back(lig); + } else { + overflowGroup.push_back(lig); + } + } +} void printMaxValues(const std::vector& group) { int max_atoms = std::numeric_limits::min(); int max_torsions = std::numeric_limits::min(); @@ -986,19 +1010,6 @@ bug reporting, license agreements, and more information. \n"; max_num_torsions = std::max(max_num_torsions, num_torsions_vector.at(i)); max_num_rigids = std::max(max_num_rigids,num_rigids_vector.at(i)); max_num_lig_pairs = std::max(max_num_lig_pairs,num_lig_pairs_vector.at(i)); - - // printf("num_atoms%ld\n",num_atoms_vector.at(i)); - // printf("num_torsions:%ld\n",num_torsions_vector.at(i)); - // printf("num_rigids:%ld\n",num_rigids_vector.at(i)); - // printf("num_internal_pairs:%ld\n",num_lig_pairs_vector.at(i)); - - // all_ligands[i].second.about(); - - // printf("max_num_ligands%ld\n",max_num_ligands); - // printf("max_num_other_pairs%ld\n",max_num_other_pairs); - // printf("max_num_flex%ld\n",max_num_flex); - // printf("max_num_ligand_degrees_of_freedom%ld\n",max_num_ligand_degrees_of_freedom); - // printf("max_num_internal_pairs%ld\n",max_num_internal_pairs); } printf("max_num_atoms%ld\n",max_num_atoms); @@ -1016,12 +1027,13 @@ bug reporting, license agreements, and more information. \n"; lig.score = calculateScore(lig); ligands.push_back(lig); } - std::sort(ligands.begin(), ligands.end(), compareLigands); - int groupSize = ligands.size() / 4; - std::vector smallGroup(ligands.begin(), ligands.begin() + groupSize); - std::vector mediumGroup(ligands.begin() + groupSize, ligands.begin() + 2 * groupSize); - std::vector largeGroup(ligands.begin() + 2 * groupSize, ligands.begin() + 3 * groupSize); - std::vector extraLargeGroup(ligands.begin() + 3 * groupSize, ligands.end()); + + std::vector smallGroup; + std::vector mediumGroup; + std::vector largeGroup; + std::vector extraLargeGroup; + std::vector maxGroup; + classifyLigands(ligands,smallGroup,mediumGroup,largeGroup,extraLargeGroup,maxGroup); std::cout << "Small Group:" << std::endl; printMaxValues(smallGroup); @@ -1053,6 +1065,9 @@ bug reporting, license agreements, and more information. \n"; template_batch_docking(v,all_ligands,extraLargeGroup,"Extra Large",exhaustiveness, multi_bias,max_memory, receptor_atom_numbers, out_dir,bias_file, num_modes, min_rmsd,max_evals,max_step,seed, refine_step, local_only, energy_range); + template_batch_docking(v,all_ligands,maxGroup,"Max",exhaustiveness, multi_bias,max_memory, + receptor_atom_numbers, out_dir,bias_file, num_modes, + min_rmsd,max_evals,max_step,seed, refine_step, local_only, energy_range); } } } diff --git a/unidock_tools/tests/ut/dock/test_run_unidock.py b/unidock_tools/tests/ut/dock/test_run_unidock.py index d4639e2..da7f662 100644 --- a/unidock_tools/tests/ut/dock/test_run_unidock.py +++ b/unidock_tools/tests/ut/dock/test_run_unidock.py @@ -40,7 +40,7 @@ def test_run_unidock_vina(receptor, ligand, pocket): size_z=pocket[5], scoring="vina", num_modes=10, - energy_range=6.0, + energy_range=9.0, seed=181129, ) @@ -73,8 +73,8 @@ def test_run_unidock_ad4(receptor, ligand, pocket): size_z=pocket[5], scoring="ad4", num_modes=5, - energy_range=6.0, - seed=181129, + energy_range=12.0, + seed=42, ) result_ligand = result_ligands[0] @@ -83,4 +83,4 @@ def test_run_unidock_ad4(receptor, ligand, pocket): scores = scores_list[0] assert len(scores) == 5 - shutil.rmtree(workdir, ignore_errors=True) \ No newline at end of file + shutil.rmtree(workdir, ignore_errors=True)