Biochemical Algorithms Library |
|
Developer(s) | BALL project team |
---|---|
Stable release | 1.4.1 / 28.11.2011 |
Written in | C++, python |
Operating system | Linux/Unix, Windows, MacOS X |
Type | library or framework and 3D molecular modelling application |
License | Lesser GNU Public License (LGPL) |
Website | www.ball-project.org |
The open source project BALL consists of the versatile C++ class framework BALL (Biochemical Algorithms Library), a library of algorithms and data structures targeting molecular modelling and computational structural bioinformatics, a Python interface to this library and the open source graphical interface to BALL, the molecular viewer BALLView (also open source).
The library BALL is supplemented with a Python interface for scripting functionality. In addition, BALL offers command line utilities.
BALL has been ported to the operating systems Linux, Solaris, Microsoft Windows and MacOS X. BALL uses Qt as well as OpenGL. BALL has evolved from a commercial product into a free-of-charge, open source software licensed under the GNU Lesser General Public License (LGPL).
Its molecular viewer BALLView is developed by the ball project team as well and allows for the three dimensional visualization as well as direct application of the algorithms of the BALL library via it's graphical user interface.
BALLView uses OpenGL and the real time ray tracer RTFact as render backends. For both BALLView offers stereoscopic visualization in several different modes.
BALLView is a C++ application of BALL and is available under the GPL license for Linux, Solaris, Microsoft Windows, and MacOS X.
The BALL project is developed and maintained by groups at Saarland University, Mainz University, and University of Tübingen. Both the library and the viewer are heavily used for education and research alike. BALL packages have been made available in the Debian project in 04/2010.
Contents |
(*) Experimental functionality of the next version
(+) functionality of BALLView
The Biochemical Algorithms Library BALL is a comprehensive rapid application development framework for structural bioinformatics. BALL has been carefully designed to address programming experts as well as novices. Users can take advantage of BALL's rich functionality while being offered an extensive framework of C++ data structures and algorithms. A variety of standard structural bioinformatics algorithms are offered and new algorithms can be easily added.
Using BALL as a programming toolbox does not only allow to greatly reduce application development times but also helps in ensuring stability and correctness by avoiding the error-prone reimplementation of complex algorithms and replacing them with calls into the library that has been well-tested by a large number of developers.
BALL supports a rich variety of molecular file formats like PDB, MOL2, MOL, HIN, XYZ, KCF, SD, AC as well as secondary data sources like DCD, DSN6, GAMESS, JCAMP, SCWRL, and TRR. Molecules can also be created using BALL’s peptide builder or based on SMILES expressions.
Further preparation and structure validation is enabled by, e.g., Kekuliser-, Aromaticity-, Bondorder-, HBond-, and Secondary Structure processors. A Fragment Library automatically infers missing information, e.g., a protein’s hydrogens or bonds. A Rotamer Library allows determining, assigning, and switching between a protein’s most likely side chain conformations. BALL’s Transformation processors guide generation of valid 3D structures. Its selection mechanism enables to specify parts of a molecule by simple expressions (SMILES, SMARTS, element types). This selection can be used by all modeling classes like the processors or force fields.
Fast and stable implementations of the popular force fields CHARMM, Amber, and MMFF94 can be combined with BALL’s minimizer and simulation classes (steepest decent, conjugate gradient, L-BFGS, and shifted L-VMM).
A variety of standard structural bioinformatics algorithms are offered and new algorithms can be easily added.
The following program reads a PDB file, adds missing information like bonds and hydrogens, optimizes the hydrogen positions using the AMBER force field, and writes the resulting molecule into a second pdb file.
using namespace std; using namespace BALL; int main() { // read a PDB file PDBFile file("test.pdb"); System S; file >> S; file.close(); // add missing information // e.g. hydrogens and bonds FragmentDB fragment_db(""); S.apply(fragment_db.normalize_names); S.apply(fragment_db.add_hydrogens); S.apply(fragment_db.build_bonds); // check for charges, bond lengths, // and missing atoms ResidueChecker checker(fragment_db); S.apply(checker); // create an AMBER force field AmberFF FF; S.deselect(); FF.setup(S); Selector selector("element(H)"); S.apply(selector); // optimize the hydrogen's positions ConjugateGradientMinimizer minimizer; minimizer.setup(FF); minimizer.setEnergyOutputFrequency(1); minimizer.minimize(50); // write a PDB File file.open("test_out.pdb", ios::out); file << S; file.close(); }
SIP is used to automatically create python classes for all relevant C++ classes in the BALL library to allow for the same class interfaces. The Python classes have the same name as the C++ classes, so porting code that uses BALL from C++ to Python (and vice versa) is usually a trivial task.
For instance, the above C++ code translates to
# Example file = PDBFile("test.pdb") system = System() file.read(system) file.close() # add missing information # e.g. hydrogens and bonds fragment_db = FragmentDB("") system.apply(fragment_db.normalize_names) system.apply(fragment_db.add_hydrogens) system.apply(fragment_db.build_bonds) # check for charges, bond lengths, # and missing atoms checker = ResidueChecker(fragment_db) system.apply(checker) # create an AMBER force field FF = AmberFF() system.deselect() FF.setup(system) selector = Selector("element(H)") system.apply(selector) # optimize the hydrogen's positions minimizer = ConjugateGradientMinimizer() minimizer.setup(FF) minimizer.setEnergyOutputFrequency(1) minimizer.minimize(50) # write a PDB File outfile = PDBFile("test_out.pdb", File.MODE_OUT) outfile.write(system) outfile.close()
The python interface is fully integrated into the viewer application BALLView and thus allows for direct visualization of results computed by python scripts. In addition, BALLView can be operated from the scripting interface and recurring tasks can be automated.
BALLView is BALL’s standalone molecular modeling and visualization application. Furthermore, it is also a framework for developing molecular visualization functionality.
BALLView offers standard visualization models for atoms, bonds, and surfaces as well as grid based visualization for e.g. electrostatic potentials. BALLView allows to load a number of molecules at the same time and all representations can be hidden or shown at will. A large part of the functionality of the library BALL can be applied directly to the loaded molecule in BALLView.
BALLView supports a number of modern visualization and input methods like, e.g., different stereo modes, space navigator, and VRPN-supported Input devices.
At CEBIT 2009, for BALLView was prominently presented as the first complete integration of real-time ray tracing technology into a molecular viewer and modelling tool.[1]