/usr/lib/python2.7/dist-packages/pymol/helping.py is in pymol 1.7.0.0-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831 832 833 834 835 836 837 838 839 840 841 842 843 844 845 846 847 848 849 850 851 852 853 854 855 856 857 858 859 860 861 862 863 | #A* -------------------------------------------------------------------
#B* This file contains source code for the PyMOL computer program
#C* Copyright (c) Schrodinger, LLC.
#D* -------------------------------------------------------------------
#E* It is unlawful to modify or remove this copyright notice.
#F* -------------------------------------------------------------------
#G* Please see the accompanying LICENSE file for further information.
#H* -------------------------------------------------------------------
#I* Additional authors of this source file include:
#-*
#-*
#-*
#Z* -------------------------------------------------------------------
if __name__=='pymol.helping':
import string
import thread
import cmd
from cmd import DEFAULT_ERROR, DEFAULT_SUCCESS, _raising, is_ok, is_error
def show_help(cmmd,_self=cmd): # INTERNAL
print "PyMOL>help %s" % cmmd
help(cmmd)
if _self.get_setting_legacy("internal_feedback")>0.1:
print "(Hit ESC to hide)"
def python_help(*arg):
r'''
DESCRIPTION
You have asked for help on a Python keyword which is available
from within the PyMOL command language. Please consult the
official Python documentation at http://www.python.org for
detailed information on Python keywords.
You may include Python blocks in your PyMOL command scripts, but do
note that multi-line blocks of Python in PyMOL command files will
require explicit continuation syntax in order to execute properly
(see below).
Generally, if you want to write Python block which span multiple
lines, you will want to use ".py" file, and then use "extend" in
order to expose your new code to the PyMOL command language. This
will give you better error checking and more predictable results.
EXAMPLES
a=1
while a<10: \
print a \
a=a+1
SEE ALSO
extend, run, @
'''
return None
def help(command = "commands",_self=cmd):
'''
DESCRIPTION
"help" prints out the online help for a given command.
USAGE
help command
'''
r = DEFAULT_SUCCESS
# if cmd.get_setting_legacy("internal_feedback")>0.1:
# cmd.set("text","1",quiet=1)
cmmd = _self.help_sc.auto_err(command,'topic')
if _self.keyword.has_key(cmmd):
doc = _self.keyword[cmmd][0].__doc__
if doc:
print "\n",string.strip(doc),"\n"
else:
print "Error: sorry no help available on that command."
elif _self.help_only.has_key(cmmd):
doc = _self.help_only[cmmd][0].__doc__
if doc:
print "\n",string.strip(doc),"\n"
else:
print "Error: sorry no help available on that command."
else:
print "Error: unrecognized command"
return r
def commands():
'''
COMMANDS
INPUT/OUTPUT load save delete quit
VIEW turn move clip rock
show hide enable disable
reset refresh rebuild
zoom origin orient
view get_view set_view
MOVIES mplay mstop mset mdo
mpng mmatrix frame
rewind middle ending
forward backward
IMAGING png mpng
RAY TRACING ray
MAPS isomesh isodot
DISPLAY cls viewport splash
SELECTIONS select mask
SETTINGS set button
ATOMS alter alter_state
EDITING create replace remove h_fill remove_picked
edit bond unbond h_add fuse
undo redo protect cycle_valence attach
FITTING fit rms rms_cur pair_fit
intra_fit intra_rms intra_rms_cur
COLORS color set_color
HELP help commands
DISTANCES dist
STEREO stereo
SYMMETRY symexp
SCRIPTS @ run
LANGUAGE alias extend
Try "help <command-name>". Also see the following extra topics:
"api", "editing", "edit_keys", "examples", "faster", "keyboard",
"launching", "mouse", "movies", "python", "povray", "release",
"selections", "skip", "sync", "stereochemistry", "text_type",
"transparency", "@".
'''
_self.help('commands')
def editing(_self=cmd):
'''
SUMMARY
PyMOL has a rudimentary, but quite functional molecular structure
editing capability. However, you will need to use an external mimizer
to "clean-up" your structures after editing. Furthermore, if you are
going to modify molecules other than proteins, then you will also need
a way of assigning atom types on the fly.
To edit a conformation or structure, you first need to enter editing
mode (see Mouse Menu). Then you can pick an atom (CTRL-Middle click)
or a bond (CTRL-Right click). Next, you can use the other
CTRL-key/click combinations listed on the right hand side of the
screen to adjust the attached fragments. For example, CTRL-left click
will move fragments about the selected torsion.
Editing structures is done through a series of CTRL key actions
applied to the currently selected atom or bonds. See "help edit_keys"
for the exact combinations. To build structures, you usually just
replace hydrogens with methyl groups, etc., and then repeat. They are
no short-cuts currently available for building common groups, but that
is planned for later versions.
NOTE
Only "lines" and "sticks" representations can be picked using the
mouse, however other representations will not interfere with picking
so long as one of these representation is present underneath.
'''
_self.help('editing')
def release(_self=cmd):
'''
RELEASE NOTES
PyMOL is a free, open, and expandable molecular graphics system
written by computational scientists to enable molecular modeling from
directly within Python. It will be of most benefit to hybrid
scientist/developers in the fields of structural biology,
computational chemistry, and informatics who seek an open and
unrestricted visualization tool for interfacing with their own
programs. PyMOL will also be of benefit to advanced non-developers
familiar with similar programs such as Midas, O, Grasp, X-PLOR and
CNS.
PyMOL currently includes a diverse command language, a powerful
application programmers interface (API), and a variety of mouse and
keyboard driven functionality for viewing, animation, rendering, and
molecular editing. A partial manual is now available on the web.
Two external GUI development options are supported for PyMOL:
"Tkinter" and "wxPython". Developers can take their pick.
Note that only Tkinter is supported under Windows with the default
PyMOL and Python distributions, so for maximum ease of installation
under Windows, stick with Tkinter (Tcl/Tk). For this reason, the
Tkinter-based GUI is going to be the default GUI for standard PyMOL
despite its drawbacks.
Warren L. DeLano (5/1/2001), warren@delanoscientific.com
Jason Vertrees (3/7/2011), jason.vertrees@schrodinger.com (update)
'''
_self.help('release')
def edit_keys(_self=cmd):
'''
EDITING KEYS
These are defaults, which can be redefined. Note that while
entering text on the command line, some of these control keys take on
text editing functions instead (CTRL - A, E, and K, and DELETE), so
you should clear the command line before trying to edit atoms.
ATOM REPLACEMENT
CTRL-C Replace picked atom with carbon (C)
CTRL-N Replace picked atom with nitrogen (N)
CTRL-O Replace picked atom with oxygen (O)
CTRL-S Replace picked atom with sulpher (S)
CTRL-G Replace picked atom with hydrogen (H)
CTRL-F Replace picked atom with fluorene (F)
CTRL-L Replace picked atom with chlorine (Cl)
CTRL-B Replace picked atom with bromine (Br)
CTRL-I Replace picked atom with iodine (I)
ATOM MODIFICATION
CTRL-J Set charge on picked atom to -1
CTRL-K Set charge on picked atom to +1
CTRL-D Remove atom or bond (DELETE works too).
CTRL-Y Add a hydrogen to the current atom
CTRL-R Adjust hydrogens on atom/bond to match valence.
CTRL-E Inverts the picked stereo center, but you must first
indicate the constant portions with the (lb) and (rb)
selections.
CTRL-T Connect atoms in the (lb) and (rb) selections.
CTRL-W Cycle the bond valence on the picked bond.
UNDO and REDO of conformational changes (not atom changes!)
CTRL-Z undo the previous conformational change.
(you can not currently undo atom modifications).
CTRL-A redo the previous conformational change.
'''
_self.help('edit_keys')
def at_sign(_self=cmd):
'''
DESCRIPTION
"@" sources a PyMOL command script as if all of the commands in the
file were typed into the PyMOL command line.
USAGE
@ <script-file>
PYMOL API
Not directly available. Instead, use cmd.do("@...").
'''
_self.help(at_sign)
def run(_self=cmd):
'''
DESCRIPTION
"run" executes an external Python script in a local name space,
the main Python namespace, the global PyMOL namespace, or in its
own namespace (as a module).
USAGE
run file [, namespace ]
ARGUMENTS
file = string: a Python program, typically ending in .py or .pym.
namespace = local, global, module, main, or private
PYMOL API
Not directly available. Instead, use cmd.do("run ...").
NOTES
The default mode for run is "global".
Due to an idiosyncracy in Pickle, you can not pickle objects
directly created at the main level in a script run as "module",
(because the pickled object becomes dependent on that module).
Workaround: delegate construction to an imported module.
'''
_self.help(run)
def spawn(_self=cmd):
'''
DESCRIPTION
"spawn" launches a Python script in a new thread which will run
concurrently with the PyMOL interpreter. It can be run in its own
namespace (like a Python module, default), a local name space, or
in the global namespace.
USAGE
run python-script [, ( local | global | module | main | private )]
PYMOL API
Not directly available. Instead, use cmd.do("spawn ...").
NOTES
The default mode for spawn is "module".
Due to an idiosyncracy in Pickle, you can not pickle objects
directly created at the main level in a script run as "module",
(because the pickled object becomes dependent on that module).
Workaround: delegate construction to an imported module.
The best way to spawn processes at startup is to use the -l option
(see "help launching").
'''
_self.help(spawn)
def api(_self=cmd):
'''
DESCRIPTION
The PyMOL Python Application Programming Interface (API) should be
accessed exclusively through the "cmd" module (never "_cmd"!). Nearly
all command-line functions have a corresponding API method.
USAGE
from pymol import cmd
result = cmd.<command-name>( argument , ... )
NOTES
Although the PyMOL core is not multi-threaded, the API is
thread-safe and can be called asynchronously by external python
programs. PyMOL handles the necessary locking to insure that
internal states do not get corrupted. This makes it very easy to
build complicated systems which involve direct realtime visualization.
'''
_self.help('api')
def keyboard(_self=cmd):
'''
KEYBOARD COMMANDS and MODIFIERS
ESC Toggle onscreen text.
INSERT Toggle rocking.
LEFT ARROW, RIGHT ARROW Go backward or forward one frame, or when
editing, go forward or back one character.
HOME, END Go to the beginning or end of a movie.
Command Entry Field in the Interal GUI (black window)
If text exists on the command line then control keys correspond to editing the command line:
TAB Complete commmand or filename (like in tcsh or bash).
CTRL-A Go to the beginning of the line.
CTRL-E Go to the end of the line.
CTRL-K Delete through to the end of the line.
CTRL-V Paste into command line (operating system dependent.)
If no text is on the command line, then control keys correspond to molecular editing:
Command Entry Field on the External GUI (gray window).
CTRL-A Select all atoms into the named selection "(sele)".
CTRL-C Copy current selection.
CTRL-I Invert currently active selection.
CTRL-V Paste copied or cut atoms into a new object.
CTRL-X Cut the selected atoms.
CTRL-Y Redo.
CTRL-Z Udno.
EDITING
type "help edit_keys" for keyboard shortcuts used in editing.
'''
_self.help('keyboard')
def transparency(_self=cmd):
'''
TRANSPARENCY
As of version 0.68, trasparent surfaces are supported in both
realtime (OpenGL) rendering mode as well as with ray-traced images.
Transparency is currently managed by setting either the global
transparency variable or one attached to an individual molecule object.
It isn't yet possible to control transparency on a per-atom basis.
EXAMPLES
set transparency=0.5 # makes all surfaces 50% transparent
set transparency=0.5, mol3 # makes only mol3's surface transparent
'''
cmd.help('transparency')
def mouse():
'''
MOUSE CONTROLS
The configuration can be changed using the "Mouse" menu. The
current configuration is described on screen with a small matrix on
the lower right hand corner, using the following abbreviations:
Buttons (Horizontal Axis)
L = left mouse click
M = middle mouse click
R = right mouse click
Modifiers (Veritical axis on the matrix)
None = no keys held down while clicking
Shft = hold SHIFT down while clicking
Ctrl = hold CTRL down while clicking
CtSh = hold both SHIFT and CTRL down while clicking
Visualization Functions
Rota = Rotates camera about X, Y, and Z axes
RotZ = Rotates camera about the Z axis
Move = Translates along the X and Y axes
MovZ = Translates along Z axis
Clip = Y motion moves the near clipping plane while
PkAt = Pick an atom
PkBd = Pick a bond
Orig = Move origin to selected atom
+lb = Add an atom into the (lb) selection
lb = Define the (lb) selection with the indicated atom.
rb = Define the (rb) selection with the indicated atom.
Editing Functions
RotF = Rotate fragment
MovF = Move fragment
TorF = Torsion fragment
'''
_self.help('mouse')
def examples(_self=cmd):
'''
EXAMPLE ATOM SELECTIONS
select bk = ( name ca or name c or name n )
* can be abbreviated as *
sel bk = (n;ca,c,n)
select hev = ( not hydro )
* can be abbreviated as *
sel hev = (!h;)
select site = ( byres ( resi 45:52 expand 5 ))
* can be abbreviated as *
sel site = (b;(i;45:52 x;5))
select combi = ( hev and not site )
* can be abbreviated as *
sel combi = (hev&!site)
'''
_self.help('examples')
def launching(_self=cmd):
'''
PyMOL COMMAND LINE OPTIONS
-c Command line mode, no GUI. For batch opeations.
-i Disable the internal OpenGL GUI (object list, menus, etc.)
-x Disable the external GUI module.
-t Use Tcl/Tk based external GUI module (pmg_tk).
-q Quiet launch. Suppress splash screen & other chatter.
-p Listen for commands on standard input.
-e Start in full-screen mode.
-2 Start in two-button mouse mode.
-o Disable security protections for session files.
-R Launch Greg Landrum's XMLRPC listener.
-B Enable blue-line stereo signal (for Mac stereo)
-G Start in Game mode.
-S Force and launch in stereo, if possible.
-M Force mono even when hardware stereo is present.
-X <int> -Y <int> -W <int> -H <int> -V <int> Adjust window geometry.
-f <# line> Controls display of commands and feedback in OpenGL (0=off).
-r <file.py> Run a Python program (in __main__) on startup.
-l <file.py> Spawn a python program in new thread.
-d <string> Run pymol command string upon startup.
-u <script> Load and append to this PyMOL script or program file.
-s <script> Save commands to this PyMOL script or program file.
-g <file.png> Write a PNG file (after evaluating previous arguments)
<file> can have one of the following extensions, and all
files provided will be loaded or run after PyMOL starts.
.pml PyMOL command script to be run on startup
.py, .pym, .pyc Python program to be run on startup
.pdb Protein Data Bank format file to be loaded on startup
.mmod Macromodel format to be loaded on startup
.mol MDL MOL file to be loaded on startup
.sdf MDL SD file to be parsed and loaded on startup
.xplor X-PLOR Map file (ASCII) to be loaded on startup
.ccp4 CCP4 map file (BINARY) to be loaded on startup
.cc1, .cc2 ChemDraw 3D cartesian coordinate file
.pkl Pickled ChemPy Model (class "chempy.model.Indexed")
.r3d Raster3D file
.cex CEX file (Metaphorics)
.top AMBER topology file
.crd AMBER coordinate file
.rst AMBER restart file
.trj AMBER trajectory
.pse PyMOL session file
.phi Delphi/Grasp Electrostatic Potential Map
'''
_self.help('launching')
def movies(_self=cmd):
'''
MOVIES
To create a movie, simply load multiple coordinate files
into the same object. This can be accomplish at the command line,
using script files, or by writing PyMOL API-based programs.
The commands:
load frame001.pdb,mov
load frame002.pdb,mov
will create a two frame movie. So will the following program:
from pymol import cmd
for a in ( "frame001.pdb","frame002.pdb" ):
cmd.load(a,"mov")
which can be executed at the command line using the "run" command.
Python built-in glob module can be useful for loading movies.
from pymol import cmd
import glob
for a in ( glob.glob("frame*.pdb") ):
cmd.load(a,"mov")
NOTE
Because PyMOL stores all movie frames in memory, there is a
a practical limit to the number of atoms in all coordinate files.
160 MB free RAM enables 500,000 atoms with line representations.
Complex representations require significantly more memory.
'''
_self.help('movies')
### -------------------------------------------------------------------
def selections(_self=cmd):
'''
DESCRIPTION
Selections are enclosed in parentheses and contain predicates,
logical operations, object names, selection names and nested
parenthesis: ( [... [(...) ... ]] )
name <atom names> n. <atom names>
resn <residue names> r. <residue names>
resi <residue identifiers> i. <residue identifiers>
chain <chain ID> c. <chain identifiers>
segi <segment identifiers> s. <segment identifiers>
elem <element symbol> e. <element symbols>
flag <number> f. <number>
alt <code>
numeric_type <numeric type> nt. <numeric type>
text_type <text type> tt. <text type>
b <operator> <value>
q <operator> <value>
formal_charge <op> <value> fc. <operator> <value>
partial_charge <op> <value> pc. <operator> <value>
id <original-index>
hydrogen h.
all *
visible v.
hetatm
<selection> and <selection> <selection> & <selection>
<selection> or <selection> <selection> | <selection>
not <selection> ! <selection>
byres <selection> br. <selection>
byobj <selection> bo. <selection>
around <distance> a. <distance>
expand <distance> e. <distance>
gap <distance>
in <selection>
like <selection> l. <selection>
<selection> within <distance> of <selection>
<selection> w. <distance> of <selection>
'''
_self.help('selections')
def povray(_self=cmd):
'''
DESCRIPTION
PovRay: Persistance of Vision Support Information
The built-in ray-tracer (technically a ray-caster) is as fast or
faster than PovRay for many figures (provided that hash_max is
tuned appropriately for your content). However, PovRay blows
PyMOL away when it comes to rendering images without using lots of
RAM, and with PovRay you get the ability use perspective,
textures, reflections, infinite objects, and a superior lighting
model.
Assuming that PovRay is built and in your path...
ray renderer=1 # will use PovRay instead of the built-in engine
set ray_default_renderer=1 # changes the default renderer to PovRay
ray # will now use PovRay by default
cmd.get_povray() # will give you a tuple of PovRay input strings
# which you can manipulate from Python
'''
_self.help('povray')
def stereochemistry(_self=cmd):
"""
PYMOL STEREOCHEMISTRY
PyMOL can label chiral centers; however, due to the recursive and
dependent nature of the determination, PyMOL will refuse to
label structures with alternate coordinates.
To determine stereochemistry for a structure that has alternate
coordinates, you either need to clear the alternate coordinates
field in the target object using:
alter objName, alt=''
or you need to create a new object from the old object selecting
just one set of coordinates per atom. For example, to create a
new object called 'newObj' from 'oldObj' using the only those
atoms with no alternate coordinates or those atoms with an
alternate coordinate label 'A' one types:
create newObj, oldObj and alt ''+alt 'A'
Similarly, to create an object from just alternate coordinates
'G' one types:
create newObj, oldObj and alt 'G'
PyMOL labels chiral centers using the IUPAC symbols 'R' for
rectus, 'S' for sinister, 'r' for pseudoasymmetric rectus and
's' for pseudoasymmetric sinister.
SEE ALSO
label, select
"""
help('stereochemistry')
def text_type(_self=cmd):
"""
PYMOL ATOM TYPING
PyMOL can label atom types with formats mol2/sybyl or macromodel/mmd.
The global setting atom_type_format is used to determine which type
is labelled. Due to the recursive and dependent nature of the
determination, PyMOL will refuse to label structures with alternate
coordinates.
To determine atom types for a structure that has alternate
coordinates, you either need to clear the alternate coordinates
field in the target object using:
alter objName, alt=''
or you need to create a new object from the old object selecting
just one set of coordinates per atom. For example, to create a
new object called 'newObj' from 'oldObj' using the only those
atoms with no alternate coordinates or those atoms with an
alternate coordinate label 'A' one types:
create newObj, oldObj and alt ''+alt 'A'
Similarly, to create an object from just alternate coordinates
'G' one types:
create newObj, oldObj and alt 'G'
SEE ALSO
label, select
"""
help('text_type')
def faster(_self=cmd):
'''
RAY TRACING OPTIMIZATION
1. Reduce object complexity to a minimum acceptable level.
For example, try lowering:
"cartoon_sampling"
"ribbon_sampling", and
"surface_quality", as appropriate.
2. Increase "hash_max" so as to obtain a voxel dimensions of
0.3-0.6. Proper tuning of "hash_max" can speed up
rendering by a factor of 2-5X for non-trivial scenes.
WARNING: memory usage depends on hash_max^3, so avoid
pushing into virtual memory. Roughly speaking:
hash_max = 80 --> ~9 MB hash + data
hash_max = 160 --> ~72 MB hash + data
hash_max = 240 --> ~243 MB hash + data
Avoid utilizing virtual memory for the voxel hash,
it will slow things way down.
3. Recompiling with optimizations on usually gives a 25-33%
performance boost for ray tracing.
'''
help('faster')
def abort(_self=cmd):
'''
DESCRIPTION
"abort" abruptly terminates execution of the PyMOL command script
without executing any additional commands.
SEE ALSO
embed, skip, python
'''
return None
def skip(_self=cmd):
'''
DESCRIPTION
"skip" delimits a block of commands that are skipped instead of
being executed.
EXAMPLE
skip
# the following command will not be executed
color blue, all
skip end
NOTES
If the "skip" command is commented out, the subsequent "skip end"
can be left in place, and will have no effect upon execution of
subsequent commands.
SEE ALSO
abort, embed, python
'''
return None
def python(_self=cmd):
'''
DESCRIPTION
"python" delimits a block of literal Python code embedded in a
PyMOL command script.
EXAMPLE
python
for a in range(1,10):
b = 10 - a
print a, b
python end
NOTES
Literal Python blocks avoid the annoying requirement of having to
use explicit line continuation markers for multi-line Python
commands embedded within Python scripts.
SEE ALSO
abort, embed, skip
'''
return None
def embed(_self=cmd):
'''
DESCRIPTION
"embed" delimits a block of data embedded in a PyMOL command
script.
USAGE
embed key [, type [, sentinel ]]
ARGUMENTS
key = string: unique indentifier for the data
type = pdb, mol, mol2, sdf, xplor
sentinel = string: a unique string signalling the end of the data {default: embed end}
EXAMPLE
embed wats, pdb
HETATM 1 O WAT 1 2.573 -1.034 -1.721
HETATM 2 H1 WAT 1 2.493 -1.949 -1.992
HETATM 3 H2 WAT 1 2.160 -0.537 -2.427
HETATM 4 O WAT 2 0.705 0.744 0.160
HETATM 5 H1 WAT 2 -0.071 0.264 0.450
HETATM 6 H2 WAT 2 1.356 0.064 -0.014
embed end
NOTES
Only text data formats can be used with embed
SEE ALSO
abort, skip, python
'''
return None
|