BioSimSpace.Protocol.FreeEnergyMinimisation#

class BioSimSpace.Protocol.FreeEnergyMinimisation(lam=0.0, lam_vals=None, min_lam=0.0, max_lam=1.0, num_lam=11, steps=10000, perturbation_type='full', restraint=None, force_constant=10 kcal mol-1 Å-2)[source]#

A class for storing free energy minimisation protocols.

__init__(lam=0.0, lam_vals=None, min_lam=0.0, max_lam=1.0, num_lam=11, steps=10000, perturbation_type='full', restraint=None, force_constant=10 kcal mol-1 Å-2)[source]#

Constructor.

Parameters:
  • lam (float) – The perturbation parameter: [0.0, 1.0]

  • lam_vals ([float]) – The list of lambda parameters.

  • min_lam (float) – The minimum lambda value.

  • max_lam (float) – The maximum lambda value.

  • num_lam (int) – The number of lambda values.

  • steps (int) – The maximum number of steps to perform.

  • perturbation_type (str) –

    The type of perturbation to perform. Options are:

    ”full” : A full perturbation of all terms (default option). “discharge_soft” : Perturb all discharging soft atom charge terms (i.e. value->0.0). “vanish_soft” : Perturb all vanishing soft atom LJ terms (i.e. value->0.0). “flip” : Perturb all hard atom terms as well as bonds/angles. “grow_soft” : Perturb all growing soft atom LJ terms (i.e. 0.0->value). “charge_soft” : Perturb all charging soft atom LJ terms (i.e. 0.0->value).

    Currently perturubation_type != “full” is only supported by BioSimSpace.Process.Somd.

  • restraint (str, [int]) –

    The type of restraint to perform. This should be one of the following options:

    ”backbone”

    Protein backbone atoms. The matching is done by a name template, so is unreliable on conversion between molecular file formats.

    ”heavy”

    All non-hydrogen atoms that aren’t part of water molecules or free ions.

    ”all”

    All atoms that aren’t part of water molecules or free ions.

    Alternatively, the user can pass a list of atom indices for more fine-grained control. If None, then no restraints are used.

  • force_constant (GeneralUnit, float) – The force constant for the restraint potential. If a ‘float’ is passed, then default units of ‘kcal_per_mol / angstrom**2’ will be used.

Methods

__init__([lam, lam_vals, min_lam, max_lam, ...])

Constructor.

getForceConstant()

Return the force constant for the restraint.

getLambda()

Get the value of the perturbation parameter.

getLambdaIndex()

Get the index of the lambda value within the lambda array.

getLambdaValues()

Get the list of lambda values.

getPerturbationType()

Get the perturbation type.

getRestraint()

Return the type of restraint.

getSteps()

Return the maximum number of steps.

restraints()

Return a list of the supported restraint keywords.

setForceConstant(force_constant)

Set the force constant for the restraint.

setLambdaValues(lam[, lam_vals, min_lam, ...])

Set the list of lambda values.

setPerturbationType(perturbation_type)

Set the perturbation type.

setRestraint(restraint)

Set the type of restraint.

setSteps(steps)

Set the maximum number of steps.

getForceConstant()#

Return the force constant for the restraint.

Returns:

force_constant – The force constant for the restraint, in units of kcal_per_mol/angstrom**2.

Return type:

float, str, class:GeneralUnit

getLambda()#

Get the value of the perturbation parameter.

Returns:

lam – The value of the perturbation parameter.

Return type:

float

getLambdaIndex()#

Get the index of the lambda value within the lambda array.

Returns:

index – The index of the lambda value in teh lambda array.

Return type:

int

getLambdaValues()#

Get the list of lambda values.

Returns:

lam_vals – The list of lambda values.

Return type:

[float]

getPerturbationType()#

Get the perturbation type.

Returns:

perturbation_type – The perturbation type.

Return type:

str

getRestraint()#

Return the type of restraint.

Returns:

restraint – The type of restraint, either a keyword or a list of atom indices.

Return type:

str, [int]

getSteps()#

Return the maximum number of steps.

Returns:

steps – The maximum number of minimisation steps.

Return type:

int

classmethod restraints()#

Return a list of the supported restraint keywords.

Returns:

restraints – A list of the supported restraint keywords.

Return type:

[str]

setForceConstant(force_constant)#

Set the force constant for the restraint.

Parameters:

force_constant (int, float, str, GeneralUnit, float) – The force constant for the restraint, in units of kcal_per_mol/angstrom**2.

setLambdaValues(lam, lam_vals=None, min_lam=None, max_lam=None, num_lam=None)#

Set the list of lambda values.

Parameters:
  • lam (float) – The perturbation parameter: [0.0, 1.0]

  • lam_vals ([float]) – A list of lambda values.

  • min_lam (float) – The minimum lambda value.

  • max_lam (float) – The maximum lambda value.

  • num_lam (int) – The number of lambda values.

setPerturbationType(perturbation_type)#

Set the perturbation type.

Parameters:

perturbation_type (str) –

The type of perturbation to perform. Options are:

”full” : A full perturbation of all terms (default option). “discharge_soft” : Perturb all discharging soft atom charge terms (i.e. value->0.0). “vanish_soft” : Perturb all vanishing soft atom LJ terms (i.e. value->0.0). “flip” : Perturb all hard atom terms as well as bonds/angles. “grow_soft” : Perturb all growing soft atom LJ terms (i.e. 0.0->value). “charge_soft” : Perturb all charging soft atom LJ terms (i.e. 0.0->value).

setRestraint(restraint)#

Set the type of restraint.

Parameters:

restraint (str, [int]) –

The type of restraint to perform. This should be one of the following options:

”backbone”

Protein backbone atoms. The matching is done by a name template, so is unreliable on conversion between molecular file formats.

”heavy”

All non-hydrogen atoms that aren’t part of water molecules or free ions.

”all”

All atoms that aren’t part of water molecules or free ions.

Alternatively, the user can pass a list of atom indices for more fine-grained control.

setSteps(steps)#

Set the maximum number of steps.

Parameters:

steps (int) – The maximum number of minimisation steps.