IMP Reference Guide
develop.330bebda01,2025/01/21
The Integrative Modeling Platform
|
Nested sampling-based optimization of representation. More...
Nested sampling-based optimization of representation.
Python module to perform Nested Sampling-based optimization of representation for integrative structural modeling
Shreyas Arvindekar, Aditi S Pathak, Kartik Majila, Shruthi Viswanath, Optimizing representations for integrative structural modeling using Bayesian model selection, Bioinformatics, 40(3), btae106, 2024, at DOI. Data is deposited in Zenodo
See requirements.txt
for Python dependencies
(See also examples/
)
python -m IMP.nestor.xl_datasplitter {path}
where, path refers to the path of the target crosslinking file.examples/modeling.py
. One will also need to make separate topology files for different candidate representations. Make sure that the restraints that are to be used to inform the likelihood have weight=0
, and these are added to a separate list that is passed to the replica exchange macro as nestor_restraints
argument. Ensure the modeling script looks similar to the one in example/
. Specifically, ensure that the modeling instructions are enclosed in a function that is called so that the terminal stdout of the modeling is not returned to the terminal. One can use contextlib
as shown in the example.nestor_params.yaml
file.Run the NestOR wrapper as follows:
python -m IMP.nestor.wrapper_v6 -p {nestor_param_path}
where, nestor_param_path
refers to the absolute path to the nestor_params.yaml
file. If using topology file for representing the system, use -t
flag. This flag can be ommitted if the representation is defined in the modeling script. If only the plotting functionalities of NestOR are to be used, run the above command with -s
flag.
Note One NestOR run
corresponds to the set of all nested sampling runs for all candidate representations._ One can also compare results from NestOR runs
with different parameter settings by running python -m IMP.nestor.compare_runs_v2_w_pyplot {comparison_title} run_set1 run_set2 ...
where comparison_title is the title for the runs to be compared, run_set1 and run_set2 are the NestOR runs to be compared.
Step 1 in the Run command above, i.e. one NestOR run generates these plots:
*_params_evidence_errorbarplot.png
) shows the mean values of evidence for all the candidate representations along with errorbars showing the standard error on the mean.*_params_persteptime.png
) shows the time required to sample one MCMC step per run. This is computed as (time taken for iteration 0)/((number of initial frames)*(number of MCMC steps per frame))
*sterr_evi_and_proctime.png
) compares evidences and their sampling efficiency across representations.This file is generated upon completion of step 1 in the Run command
above.
Evidence related:
float
The estimated evidence value represented as natural logarithm of the estimated evidencefloat
Information obtained from the nested sampling runfloat
The analytical uncertainty associated with evidence estimation for a run by nested samplingEfficiency related
float
Time taken per MCMC step. This is computed as (time taken for iteration 0)/((number of initial frames)*(number of MCMC steps per frame))
float
Wall clock time taken by a nested sampling run to finish, represented in secondsTermination related
int
(0, 11, 12, 13) Exit code for a nested sampling runstr
Cause for run terminationint
Number of times Replica Exchange failed to obtain a sample from constrained prior in the current iteration of nested samplingint
Iteration count (number of iterations) when nested sampling terminatedint
Number of consecutive times the nested sampling protocol detected a plateau in the estimated evidenceExit codes:
If a run terminates with exit code = 12
, the run is considered incomplete (and is not rerun) and its results are not considered valid, i.e. these are not plotted and not used to infer optimal representation. Results from runs with exit codes 0 and 13 are used to infer the optimal representation.
Author(s): Shreyas Arvindekar, Shruthi Viswanath
Date: April 7th, 2023
License: CC BY-SA 4.0 This work is licensed under the Creative Commons Attribution-ShareAlike 4.0 International License.
Last known good IMP version: not tested
Testable: Yes
Parallelizeable: Yes
Publications: Arvindekar, S., et. al. Optimizing representations for integrative structural modeling using bayesian model selection, Bioinformatics, 40(3), btae106, 2024. DOI: 10.1093/bioinformatics/btae106.
Namespaces | |
compare_runs_v2_w_pyplot | |
Plotting script to compare NestOR runs. | |
wrapper_v6 | |
Top-level NestOR script. | |
xl_datasplitter | |
Script to split a CSV file for use in nested sampling. | |
Functions | |
def | get_data_path |
Return the full path to one of this module's data files. More... | |
def | get_example_path |
Return the full path to one of this module's example files. More... | |
def | get_module_name |
Return the fully-qualified name of this module. More... | |
def | get_module_version |
Return the version of this module, as a string. More... | |
def IMP.nestor.get_data_path | ( | fname | ) |
Return the full path to one of this module's data files.
Definition at line 359 of file nestor/__init__.py.
def IMP.nestor.get_example_path | ( | fname | ) |
Return the full path to one of this module's example files.
Definition at line 364 of file nestor/__init__.py.
def IMP.nestor.get_module_name | ( | ) |
Return the fully-qualified name of this module.
Definition at line 354 of file nestor/__init__.py.
def IMP.nestor.get_module_version | ( | ) |
Return the version of this module, as a string.
Definition at line 349 of file nestor/__init__.py.