IMP logo
IMP Reference Guide  2.6.2
The Integrative Modeling Platform
markers.py
1 ## \example atom/markers.py
2 # It is often useful to be able to add extra particles to a model to act as markers for particular features. Examples include creating a bounding sphere for some part of a molecule and using the bounding sphere particle in a distance restraint. The IMP.atom.create_cover() is such a function, creating a particle whose IMP.core.XYZR sphere contains the passed IMP.atom.Selection at all times.
3 #
4 # The same code also works (more efficiently in fact) if the protein is made into a rigid body.
5 #
6 
7 import IMP.atom
8 import IMP.display
9 import sys
10 
11 IMP.setup_from_argv(sys.argv, "markers")
12 
13 m = IMP.Model()
14 h = IMP.atom.read_pdb(IMP.atom.get_example_path("example_protein.pdb"),
15  m)
16 # residues 100 and 153 are two residues that are close together
17 # spatially, create a marker for the volume around them
18 s = IMP.atom.Selection(h, residue_indexes=[100, 153])
19 marker = IMP.atom.create_cover(s, "my marker")
20 m.update()
21 
22 # if we now move the protein, marker will move along with it
25 IMP.atom.transform(h, tr)
26 m.update()
27 
28 # display it to a file
29 w = IMP.display.PymolWriter("marker.pym")
30 g = IMP.core.XYZRGeometry(marker)
31 g.set_color(IMP.display.Color(0, 1, 0))
34 gs.set_color(IMP.display.Color(1, 0, 0))
35 w.add_geometry(g)
36 w.add_geometry(gp)
37 w.add_geometry(gs)
Simple 3D transformation class.
Represent an RGB color.
Definition: Color.h:24
Strings setup_from_argv(const Strings &argv, std::string description, std::string positional_description, int num_positional)
Rotation3D get_random_rotation_3d(const Rotation3D &center, double distance)
Pick a rotation at random near the provided one.
Display a Selection.
Definition: Selection.h:348
std::string get_example_path(std::string file_name)
Return the full path to one of this module's example files.
void read_pdb(TextInput input, int model, Hierarchy h)
Class for storing model, its restraints, constraints, and particles.
Definition: Model.h:72
void transform(Hierarchy h, const algebra::Transformation3D &tr)
Transform a hierarchy. This is aware of rigid bodies.
core::XYZR create_cover(const Selection &s, std::string name=std::string())
VectorD< 3 > Vector3D
Definition: VectorD.h:395
Write a CGO file with the geometry.
Definition: PymolWriter.h:34
Output IMP model data in various file formats.
Functionality for loading, creating, manipulating and scoring atomic structures.
Select hierarchy particles identified by the biological name.
Definition: Selection.h:66
Display an IMP::atom::Hierarchy particle as balls.
Display an IMP::core::XYZR particle as a ball.
Definition: XYZR.h:149