/usr/include/BALL/SOLVATION/poissonBoltzmann.h is in libball1.4-dev 1.4.3~beta1-3.
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 864 865 866 867 868 869 870 871 872 873 874 875 876 877 878 879 880 881 882 883 884 885 886 887 888 889 890 891 892 893 894 895 896 897 898 899 900 901 902 903 904 905 906 907 908 909 910 911 912 913 914 915 916 917 918 919 920 921 922 923 924 925 926 927 928 929 930 931 932 933 934 935 936 937 938 939 940 941 942 943 944 945 946 947 948 | // -*- Mode: C++; tab-width: 2; -*-
// vi: set ts=2:
//
// $Id: poissonBoltzmann.h,v 1.31 2005/12/23 17:02:00 amoll Exp $
//
// Finite Difference Poisson Boltzmann Solver
#ifndef BALL_SOLVATION_POISSONBOLTZMANN_H
#define BALL_SOLVATION_POISSONBOLTZMANN_H
#ifndef BALL_COMMON_H_
# include <BALL/common.h>
#endif
#ifndef BALL_DATATYPE_REGULARDATA3D_H
# include <BALL/DATATYPE/regularData3D.h>
#endif
#ifndef BALL_KERNEL_SYSTEM_H
# include <BALL/KERNEL/system.h>
#endif
#ifndef BALL_DATATYPE_OPTIONS_H
# include <BALL/DATATYPE/options.h>
#endif
#include <vector>
using std::vector;
namespace BALL
{
/** Finite Difference Poisson Boltzmann Solver.
\ingroup Solvation
*/
class BALL_EXPORT FDPB
{
public:
/** Error codes: these are the possible error codes that can be produced by FDPB.
@see FDPB::getErrorCode()
@see FDPB::getErrorMessage()
*/
enum ErrorCode
{
/** No error.
*/
ERROR__NONE = -1,
/** Unknown error.
*/
ERROR__UNKNOWN = 0,
/** Not implemented error. Someone has been too lazy to implement the
this method. Wait for the next release...
*/
ERROR__NOT_IMPLEMENTED = 1,
/** Unable to create the atom array/out of memory.
FDPB internally creates a dynamic array
containing the atoms of the system.
If FDPB::setupAtomArray() cannot create this
array you normally ran out of virtual memory.
*/
ERROR__CANNOT_CREATE_ATOM_ARRAY,
/** Unable to create SAS grid/out of memory.
FDPB uses a TRegularData3D<char> (FDPB::SAS_grid) to describe
whether a point in space is inside the ion exclusion layer.
This grid is created by FDPB::setupSASGrid(). On failure
this error code is set. It usually indicates a lack of virtual memory.
*/
ERROR__CANNOT_CREATE_SAS_GRID,
/** Unable to create dielectric grid/out of memory.
FDPB uses a <tt>TRegularData3D<float></tt> ( \link FDPB::eps_grid FDPB::eps_grid \endlink ) to describe the
dielectric constant \f$\varepsilon\f$ as a function of space.
This grid is created by calling FDPB::setupEpsGrid().
It contains the relative dielectric constant between neighbouring grid points. \par
If virtual memory is exhausted and the grid could not be created
this error is set.
*/
ERROR__CANNOT_CREATE_EPSILON_GRID,
/** Unable to create grid for the modified Debye Hueckel parameter/out of memory.
The modified Debye Hueckel parameter \f$\bar{\kappa}\f$ is also a function of
space and therefore represented by a TRegularData3D<float> (FDPB::kappa_grid).
The grid is created by FDPB::setupKappaGrid(). \par
If the creation of this grid fails due to a alack of virtual memory
this error code is set.
*/
ERROR__CANNOT_CREATE_KAPPA_GRID,
/** Unable to create charge grid/out of memory.
FDPB::setupQGrid() distributes the charge of the atoms
in a grid. This grid is named FDPB::q_grid. \par
If the creation of this grid fails due to a lack of virtual memory,
this error code is set.
*/
ERROR__CANNOT_CREATE_CHARGE_GRID,
/** Unable to create electrostatic potential grid/out of memory.
FDPB::setupPhiGrid() creates a TRegularData3D<float> (FDPB::phi_grid)
containing the electrostatic potential as a function of space.
If the creation of this grid fails due to a lack of virtual memory,
this error code is set.
*/
ERROR__CANNOT_CREATE_PHI_GRID,
/** Create solvent accessible surface grid first.
This error code is set by FDPB::setupKappGrid() if it is called
but the ion excluded surface has not been set (usually by calling
FDPB::setupSASGrid). \par
Solution: call FDPB::setupKappaGrid after calling FDPB::setupSASGrid.
*/
ERROR__SAS_GRID_REQUIRED,
/** Create dielectric constant grid first.
This error code is set by FDPB::setupQGrid(), FDPB::setupKappaGrid(),
or FDPB::setupPhiGrid() if it was called,
but \link FDPB::eps_grid FDPB::eps_grid \endlink was not defined yet (this is usually done
by calling \link FDPB::setupEpsGrid FDPB::setupEpsGrid \endlink ). \par
Solution: call FDPB::setupEpsGrid first
*/
ERROR__EPSILON_GRID_REQUIRED,
/** Create atom array first.
This error code is set by FDPB::setupQGrid() or
FDPB::setupBoundary() if it was called but FDPB::atom_array
was not yet defined (this is usually done by calling FDPB::setupAtomArray()). \par
Solution: call FDPB::setupAtomArray() first
*/
ERROR__ATOM_ARRAY_REQUIRED,
/** Create electrostatic potential grid first.
FDPB::phi_grid contains the electrostatic
potential at each point in space. FDPB::setupBoundary()
sets this error code if it is called but FDPB::phi_grid
has not been set yet.
Solution: call FDPB::setupPhiGrid() before calling FDPB::setupBoundary()
*/
ERROR__PHI_GRID_REQUIRED,
/** Not enough virtual memory.
This error code is set if FDPB::solve() ran out of
virtual memory while creating some internal datastructures.
Solution: reduce grid dimensions or increase grid spacing.
*/
ERROR__OUT_OF_MEMORY,
/** The specified method to smooth the dielectric constant grid
is not allowed.
FDPB::setupEpsGrid sets this error code, if it cannot
identify the method given in FDPB::Option::dielectric_smoothing. \par
Solution: specify a valid smoothing method in FDPB::options
@see FDPB::Option::dielectric_smoothing
@see FDPB::DielectricSmoothing
*/
ERROR__UNKNOWN_DIELECTRIC_SMOOTHING_METHOD,
/** The specified charge distribution is not allowed.
FDPB::setupQGrid() sets this error code, if it cannot
identify the method given in FDPB::Option::charge_distribution. \par
Solution: specify a valid charge distribution method in FDPB::options
@see FDPB::Option::charge_distribution
@see FDPB::ChargeDistribution
*/
ERROR__UNKNOWN_CHARGE_DISTRIBUTION_METHOD,
/** The specified boundary condition type is not allowed.
FDPB::setupBoundary() sets this error code, if it cannot
identify the boundary condition given in FDPB::Option::boundary. \par
Solution: specify a valid boundary condition in FDPB::options
@see FDPB::Option::boundary
@see FDPB::Boundary
*/
ERROR__UNKNOWN_BOUNDARY_CONDITION_TYPE,
/** Upper or lower grid coordinates were specified in an incorrect format.
This error code is set by FDPB::setupEpsGrid if the string
given in FDPB::options (key FDPB::Option::LOWER or FDPB::Option::UPPER)
were not in vector format. \par
Solution: specify upper/lower coordinates in the correct format
@see Options::isVector
*/
ERROR__NOT_A_VECTOR_IN_UPPER_LOWER,
/** Lower and upper corner of the grid were set to wrong values.
Lower and upper corners of the grid given in FDPB::options
(key FDPB::Option::LOWER and FDPB::Option::UPPER)
must fulfill just one condition: every coordinate of lower
hast to be less (not equal!) to the corresponding coordinate of
upper. \par
Solution: specify a reasonable non-degenerate grid
*/
ERROR__ILLEGAL_VALUE_FOR_LOWER_UPPER,
/** Call setup first.
This error code is set by FDPB::solve() if FDPB::q_grid
or FDPB::phi_grid or FDPB::eps_grid are undefined. \par
Solution: define each of the above mentioned grids or call FDPB::setup()
*/
ERROR__SETUP_REQUIRED,
/** Total number of errors defined.
*/
NUMBER_OF_ERRORS
};
/** Symbolic names for option keys.
This struct contains a symbolic name
for each recognized key in FDPB::options. \par
For each symbol the required type is given under parameters.
*/
struct BALL_EXPORT Option
{
/** The verbosity level.
Use integer values with this option.
0 = terse \par
99 = tell me everything
@see Default::VERBOSITY
@param verbosity integer
*/
static const String VERBOSITY;
/** Print the timing for each step.
This prints the timing (if Option::verbosity > 1)
of each setup routine and the time needed to solve the
equations. \par
Results are also included in FDPB::results.
@see Default::PRINT_TIMING
@param print_timing bool
*/
static const String PRINT_TIMING;
/** The grid spacing in Angstrom.
Use this option to define the distance between a grid point
and its closest neighbour in units o Angstrom. The default
spacing is 0.6 A.
@see Default::SPACING
@param spacing float
*/
static const String SPACING;
/** The border of the system.
Use this option to define the aumount of space left between the
bounding box of the solute and the border of the cubic grid in
every direction. Use units of Angstrom with this option. The
default is 4 A.
@see Default::BORDER
@param border float
*/
static const String BORDER;
/** The ionic strength of the salt solution
This parameter defines the ionic strength of the salt solution in
which the Poisson-Boltzmann calculation takes place. This
parameter is given in units of mol/l. The default is 0, i. e.
only a Poisson equation will be calculated.
@see Default::IONIC_STRENGTH
@param ionic_strength float
*/
static const String IONIC_STRENGTH;
/** The dielectric constant of the solute. This parameter derfaults
to 2.0.
@see Default::SOLUTE_DC
@param solute_dielectric_constant float
*/
static const String SOLUTE_DC;
/** The dielectric constant of the solvent. This parameter defaults
to 78.0.
@see Default::SOLVENT_DC
@param solvent_dielectric_constant float
*/
static const String SOLVENT_DC;
/** The probe radius used for calculating the SAS of the molecule.
This parameter defaults to 1.4 A (water).
@see Default::PROBE_RADIUS
@param probe_radius float
*/
static const String PROBE_RADIUS;
/** The ion exclusion radius.
@see Default::ION_RADIUS
@param ion_radius float
*/
static const String ION_RADIUS;
/** The temperature of the system. This parameter needs values in
units of K. The default temperature is 298.15 K = 25.15 deg C.
@see Default::TEMPERATURE
@param temperature float
*/
static const String TEMPERATURE;
/** Boundary condition for solving the differential equation.
This parameter defines the type of boundary condition will be
used for initializing the equation solver. Possible options are:
zero, Debye, Coulomb, dipole and focusing. Default is dipole.
@see Default::BOUNDARY
@param boundary_condition String
*/
static const String BOUNDARY;
/** Charge distribution of the system.
This parameter chooses the method used for distributing charges
oiver grid points. Possible methods are: trilinear and uniform.
The default is uniform.
@see Default::BORDER
@param border float
*/
static const String CHARGE_DISTRIBUTION;
/** Smoothing the dielectric constant.
With this option you can choose a smoothing function for the
dielectric thus permitting a smooth transition from the inside of
the molecule (usually dc = 2.0) to the surrounding solvent
(78.5). You have the followin options: none, uniform and
harmonic. Default is none.
different dielectric constant
@see Default::DIELECTRIC_SMOOTHING
@param dielectric_smoothing String
*/
static const String DIELECTRIC_SMOOTHING;
/** Use an offset.
This option allows to offset the wohle system by the vector
defined in thos option. The calculation does not use an offset by
default. Use threedimensional vectors in units of Angstrom with
this option.
@param offset Vector3
*/
static const String OFFSET;
/** Define the RMS criterion.
This option defines the RMS criterion in Angstrom used for
terminating the iteration of the solver. If the RMS lies below
rms_criterion and the maximum residuals are below max_criterion,
the iteration terminates. The default is 1e-5 Angstrom.
@see Default::RMS_CRITERION
@param rms_criterion float
*/
static const String RMS_CRITERION;
/** Define the MAX criterion.
This option defines the upper limit for the residuals. If the
maximum residuals are below this value and the RMS lies below
rms_criterion, the iteration terminates. The default is 1e-4.
@see Default::MAX_CRITERION
@param max_criterion float
*/
static const String MAX_CRITERION;
/** Checking frequency.
This option defines the number of iterations which will be
performed without checking the criterions. The default is 10.
@see Default::CHECK_AFTER_ITERATIONS
@param check_after_iterations int
*/
static const String CHECK_AFTER_ITERATIONS;
/** The upper limit of iterations.
Use this option to define the maximum number of iterations to be
performed. If the solver does not terminate when this number of
iterations is reached, the calculation did not converge. The
default is 500 interations.
@see Default::MAX_ITERATIONS
@param max_iterations int
*/
static const String MAX_ITERATIONS;
/** The lower corner of the grid.
This option contains the lower corner of the grid. It can be used
to fix it before setting up the solver. If this option was not
used for initializing the solver gtrid it contains the
automatically computed lower corner after the calculation.
Use a vector of Angstroms with this option.
@param lower Vector3
*/
static const String LOWER;
/** The upper corner of the grid.
This is the analogous option to @see LOWER.
@param upper Vector3
*/
static const String UPPER;
/** The lower corner of the bounding box of the solute molecule.
This option works like @see LOWER for the bounding box of the
solvent molecule.
@param bounding_box_lower Vector3
*/
static const String BOUNDING_BOX_LOWER;
/** The upper corner of the bounding box of the solute molecule.
This is the analogous option to @see BOUNDING_BOX_LOWER.
@param bounding_box_upper Vector3
*/
static const String BOUNDING_BOX_UPPER;
};
/** This struct contains symbols for the available
boundary conditions.
*/
struct BALL_EXPORT Boundary
{
/** Boundary condition zero: boundary points have zero potential.
A Potential of zero is assigned to all points on the
grid boundary.
This is the simplest and least accurate method. It's use is
not recommended.
*/
static const String ZERO;
/** Boundary condition Debye: potential at boundary points is
estimated using Debye Hueckel theory.
The Potential at each point of the grid boundary is estimated
as the Debye Hueckel potential according to the following formula: \par
\f[
\phi_{x,y,z} = \sum_i \frac{1}{4 \pi \varepsilon \varepsilon_0}
\frac{q_i}{r} e^{-\frac{r}{d}}
\f]
This options tends to become <b> very </b> slow for large grids.
*/
static const String DEBYE;
/** Boundary condition Coulomb: potential at boundary points is estimated
using coulomb's law.
*/
static const String COULOMB;
/** Boundary condition Dipole: potential is estimated via dipole potentials
*/
static const String DIPOLE;
/** Boundary condition Focusing: potential is estimated via a larger but coarser grid.
Focusing calculates a larger grid (double extension in each direction)
centered on the final grid with a four times the spacing of the final grid.
Focusing also assigns an estimate of the electrostatic potential to
each grid point in the final grid, thus acceleratingthe convergence.
*/
static const String FOCUSING;
};
/** Constants to define the charge distribution methods.
*/
struct BALL_EXPORT ChargeDistribution
{
/** Charge distribution method Trilinear: charge is distributed
over the eight nearest gridpoints.
*/
static const String TRILINEAR;
/** Charge distribution method Uniform: charge is distributed
over all gridpoints inside the atom radius.
*/
static const String UNIFORM;
};
/** Constants to define the dielectric smoothing methods.
To increase the accuracy of a FDPB calculation it prooved
advantageous to smooth the discrete values for the dielectric
constant on the grid. We recommend the use of harmonic smoothing
(which happens to be the default Default::dielectric_smoothing).
*/
struct BALL_EXPORT DielectricSmoothing
{
/** Do not perform any smoothing
*/
static const String NONE;
/** Uniform smoothing.
This method assigns the arithmetic average of the point's value and
its 26 next grid neighbours to the grid point: \par
\f[
\varepsilon_0 = \frac{1}{27} \left( \sum_{i=1}^{26} \varepsilon_i + \varepsilon_0 \right)
\f] \par
*/
static const String UNIFORM;
/** Harmonic smoothing.
This method assigns the harmonic average of the point's value and
its 26 next grid neighbours to the grid point: \par
\f[
\varepsilon_0 = \frac{1}{\sum_{i=1}^{26} \frac{1}{\varepsilon_i} + \frac{1}{\varepsilon_0}}
\f] \par
*/
static const String HARMONIC;
};
/** Default values for FDPB options.
These values are used by
FDPB::setup methods if no options have been set.
*/
struct BALL_EXPORT Default
{
/** Default verbosity level.
0 - shut up!
@see Option::VERBOSITY
*/
static const int VERBOSITY;
/** Default timing verbosity.
false - don't tell anything
@see Option::print_timing
*/
static const bool PRINT_TIMING ;
/** Default grid spacing.
Default grid spacing is 0.6 Angstrom.
@see Option::SPACING
*/
static const float SPACING;
/** Default distance between outmost atom and border.
Default is 4.0 Angstrom.
@see Option::border
*/
static const float BORDER;
/** Default ionic strength of the solvent.
Default is 0.0 mol/l
@see Option::IONIC_STRENGTH
*/
static const float IONIC_STRENGTH;
/** Default temperature.
Default is 298.15 K
@see Option::TEMPERATURE
*/
static const float TEMPERATURE;
/** Default probe radius.
The probe radius used for the creation of the
solvent excluded surface of the solute. It should
be the solvent radius. Default is 1.5 Angstrom for water.
@see Option::PROBE_RADIUS
*/
static const float PROBE_RADIUS;
/** Default ionic exclusion radius.
Default is 2.0 Angstrom
@see Option::ION_RADIUS
*/
static const float ION_RADIUS;
/** Default boundary condition.
Default is Boundary::DIPOLE
@see Option::BOUNDARY
@see Boundary
*/
static const String BOUNDARY;
/** Default charge distribution method.
Default is ChargeDistribution::uniform
@see Option::charge_distribution
@see ChargeDistribution
*/
static const String CHARGE_DISTRIBUTION;
/** Default method for dielectric smoothing.
Default is DielectricSmoothing::HARMONIC
@see Option::DIELECTRIC_SMOOTHING
@see DielectricSmoothing
*/
static const String DIELECTRIC_SMOOTHING;
/** Default solvent dielectric constant.
Default is 78.0 (roughly the dielectric constant of water at 298 K)
@see Option::SOLVENT_DC
*/
static const float SOLVENT_DC;
/** Default solute dielectric constant.
Default is 2.0 (good average derive from organic solvents).
@see Option::SOLUTE_DC
*/
static const float SOLUTE_DC;
/** Default convergence criterion for RMS change.
Default is 1E-5
@see Option::RMS_CRITERION
@see Option::MAX_CRITERION
@see Default::MAX_CRITERION
*/
static const float RMS_CRITERION;
/** Default convergence criterion for maximum change in potential.
Default is 1E-4
@see Option::MAX_CRITERION
@see Option::RMS_CRITERION
@see Default::RMS_CRITERION
*/
static const float MAX_CRITERION;
/** Default for maximum number of iterations.
Default is 500. This value is inappropriate for
very large grids.
@see Option::MAX_ITERATIONS
*/
static const Index MAX_ITERATIONS;
/** Default for the number of iterations between two checks for convergence.
Default is 10
@see Option::CHECK_AFTER_ITERATIONS
*/
static const Index CHECK_AFTER_ITERATIONS;
};
/** Compact internal datastructure for the
administration of the atoms extracted from
the system.
This datastructure only contains position (x, y, z),
charge (q) and radius (r) of the atoms.
Index is used to store the index of the
gridpoint defining the lower left front corner of
the cube containing the atom. This is needed to
calculate the potential at the atom's position
(to calculate the total energy).
*/
struct BALL_EXPORT FastAtomStruct
{
float q;
float r;
float x, y, z;
Index index;
};
typedef struct FastAtomStruct FastAtom;
/** @name Constructors and Destructors
*/
//@{
/** Default constructor.
Creates an empty FDPB object.
*/
FDPB();
/** Copy constructor.
Copies an existing FDPB object.
*/
FDPB(const FDPB& fdpb);
/** Constructor.
Creates an instance of FDPB and calls
setup(system).
The options used are the default options.
@see setup(system)
*/
FDPB(System& system);
/** Constructor.
Creates an instance of FDPB and assigns
the given options to the FDPB object's options.
@see options
@see Options
*/
FDPB(Options& new_options);
/** Constructor.
Creates an instance of FDPB and calls
setup(system, options)
@see setup(system, options)
@see options
@see Options
*/
FDPB(System& system, Options& new_options);
/** Destructor.
*/
virtual ~FDPB();
/** Frees all allocated memory and destroys the options and results.
*/
void destroy();
/** Destroys all allocated grids and the atom array.
This method reverts the FDPB object to the state it had prior to
a call to setup. Especially it frees all memory intensive datastructures. \par
<b> destroyGrids </b> deletes eps_grid, kappa_grid, q_grid, phi_grid, and SAS_grid.
Contrary to destroy, it doesnt't clear options and results. \par
@see destroy
@see setup
*/
void destroyGrids();
//@}
/** @name Setup methods
Using these methods, a FDPB object can be prepared
for a calculation. \par
*/
//@{
/** General setup method.
Setup calls (in this order!)
- setupAtomArray
- setupEpsGrid
- setupSASGrid
- setupKappaGrid
- setupPhiGrid
- setupQGrid
- setupBoundary
If any of theses method invocations fail, it terminates at this point and
returns false. \par
On successful execution it returns true and the FDPB object is
ready to solve the Poisson Boltzmann equation by calling solve().
@see setup(System& system, Options& options)
@param system the molecular system to be examined.
@return bool true on success, call getErrorCode otherwise
*/
bool setup(System& system);
/** Setup with assignment of options.
This method copies the options given by options into the
options variable of the FDPB object and invokes setup(system) afterwards.
@see setup(System& system)
@param options the new options
@param system the molecular system to be evaluated
@return bool true on success, call getErrorCode otherwise
*/
bool setup(System& system, Options& options);
/** Setup the dielectric grid.
The Finite Difference Poisson Boltzmann Method is based
on the assumption that one can determine which points on a
given grid are inside a given solute (with low dielectric constant)
and which points are outside (i.e., they are in the high dielectric
constant solvent). \par
<tt>setupEpsGrid</tt> creates a grid containing the dielectric constant
between any two neighbouring grid points (i.e., it contains 3 N values).
Points inside the molecule (i.i, inside the radius of any atom) are set to
the solute dielectric constant, all other points are set to the solvent
dielectric constant. \par
This method also sets the coordinates and dimensions of the grid (extracted
from either options or system) and the grid spacing. \par
Normally this method is not called by the user, but automatically
by setup. If you consider to call it by yourself, be sure to call
the single setup methods in the correct order (as described for setup). \par
This method may set one of the following error codes and return false afterwards:
- ERROR__NOT_A_VECTOR_IN_UPPER_LOWER
- ERROR__ILLEGAL_VALUE_FOR_LOWER_UPPER
@param system the system to be evaluated
@return true on success, call getErrorCode otherwise
*/
bool setupEpsGrid(System& system);
// ?????
/** Setup the ion accessible grid.
Not yet implemented!
*/
bool setupSASGrid(System& system);
/** Setup an compact datastructure containing all charged atoms.
This method creates a dynamic array containing all charged atoms. \par
The method may set the error code to ERROR__CANNOT_CREATE_ATOM_ARRAY
and terminate with false if insufficient virtual memory is available to create
the array.
@param system the system to be evaluated
@return bool true on success, call getErrorCode otherwise
@see atom_array
@see FastAtom
*/
bool setupAtomArray(System& system);
/** Setup the Debye Hueckel parameter grid.
*/
bool setupKappaGrid();
/** Setup charge grid.
*/
bool setupQGrid();
/** Setup electrostatic potential grid
*/
bool setupPhiGrid();
/** Setup boundary conditions for the electrostatic potential.
*/
bool setupBoundary();
//@}
/** @name Executing the calculation and retrieving the results
*/
//@{
/** Solves the linearized Poisson-Boltzmann equation.
*/
bool solve();
/** Returns the energy of the last calculation.
The total electrostatic energy of the FDPB object after
the last iteration (even if no convergence was reached!)
is returned in units of kJ/mol.
@see getNumberOfIterations
@return energy in kJ/mol
*/
double getEnergy() const;
/** Return the reaction field energy.
@return reaction field energy in kJ/mol
*/
double getReactionFieldEnergy() const;
/** Calculate the reaction field energy.
@return reaction field energy in kJ/mol
*/
double calculateReactionFieldEnergy() const;
/** Returns the number of iterations needed to converge.
Returns the number of iterations taken in the last call to FDPB::solve().
If convergence could not be reached (i.e., the convergence criterions defined
in options could not be met), -1 is returned.
@return int number of iterations
@see Option::max_iterations
@see Default::max_iterations
*/
Size getNumberOfIterations() const;
//@}
/** @name Debugging
*/
//@{
/** Return the last error code.
If a method fails, an internal error code is set in
FDPB. This error code can be queried by calling this method.
If no error occured it should return FDPB::ERROR__NONE.
@see getErrorMessage
@see ErrorCodes
*/
Index getErrorCode() const;
/** Return the last error message.
@see getErrorCode
@see ErrorCodes
*/
static String getErrorMessage(Index error_code);
//@}
/** @name Options and results of the calculation
*/
//@{
/** The options for the FDPB calculation.
*/
Options options;
/** The results of the last calculation.
*/
Options results;
//@}
/** @name Grids and arrays
*/
//@{
/** The grid containing the spatial dependent dielectric constant.
The (relative) dielectric constant is unitless.
@see setupEpsGrid
*/
TRegularData3D<Vector3>* eps_grid;
/** The grid containing the modified Debye Hueckel parameter.
@see setupKappaGrid
*/
TRegularData3D<float>* kappa_grid;
/** The grid containing the atom charges (distributed).
Each atom's charge is distributed on the grid by setupQGrid, according
to the charge distribution method specified in options. \par
q_grid contains these partial charges. Units are elementary charges, if
the atom charges were given in multiples of the elementary charge (Atom::setCharge).
@see BALL_ELEMENTARY_CHARGE
@see setupQGrid
*/
TRegularData3D<float>* q_grid;
/** The grid containing the electrostatic potential.
Before a calculation this is grid is initialized with
the boundary condition. After the calculation (i.e. after
a call to <tt>solve()</tt>) it contains the electrostatic potential
in units of J/C resulting from the Poisson-Boltzmann equation).
@see setupPhiGrid()
@see setupBoundary()
@see solve()
*/
TRegularData3D<float>* phi_grid;
/** The grid describing the solvent accessible surface of the system.
*/
TRegularData3D<char>* SAS_grid;
/** An array containing a fast representation of all atoms in the system.
@see FastAtom
*/
vector<FDPB::FastAtom>* atom_array;
//@}
protected:
Vector3 lower_;
Vector3 upper_;
Vector3 offset_;
bool use_offset_;
float spacing_;
// final energy of the last calculation
double energy_;
// the reaction field energy of the last calculation
double reaction_field_energy_;
// the indices of the boundary points,
// i.e., the points that have at least one neighbouring
// grid point that is inside the solute
vector<Position> boundary_points_;
// number of iterations of the last calculation
Size number_of_iterations_;
// error code. use getErrorMessage to access the corresponding
// error message
int error_code_;
static const char* error_message_[];
};
} // namespace BALL
#endif
|