2016-06-18 07:07:51 +08:00
|
|
|
// -*- c++ -*-
|
2014-10-08 04:30:25 +08:00
|
|
|
|
2016-12-28 02:17:34 +08:00
|
|
|
// This file is part of the Collective Variables module (Colvars).
|
|
|
|
// The original version of Colvars and its updates are located at:
|
2020-01-28 02:39:58 +08:00
|
|
|
// https://github.com/Colvars/colvars
|
2016-12-28 02:17:34 +08:00
|
|
|
// Please update all Colvars source files before making any changes.
|
|
|
|
// If you wish to distribute your changes, please submit them to the
|
|
|
|
// Colvars repository at GitHub.
|
|
|
|
|
2012-05-24 00:20:04 +08:00
|
|
|
#ifndef COLVARBIAS_H
|
|
|
|
#define COLVARBIAS_H
|
|
|
|
|
|
|
|
#include "colvar.h"
|
|
|
|
#include "colvarparse.h"
|
2016-04-16 00:07:01 +08:00
|
|
|
#include "colvardeps.h"
|
2012-05-24 00:20:04 +08:00
|
|
|
|
|
|
|
|
|
|
|
/// \brief Collective variable bias, base class
|
2016-12-28 02:17:34 +08:00
|
|
|
class colvarbias
|
|
|
|
: public virtual colvarparse, public virtual colvardeps {
|
2012-05-24 00:20:04 +08:00
|
|
|
public:
|
|
|
|
|
|
|
|
/// Name of this bias
|
2016-07-16 06:25:17 +08:00
|
|
|
std::string name;
|
|
|
|
|
2020-02-28 08:44:33 +08:00
|
|
|
/// Keyword indicating the type of this bias
|
2016-07-16 06:25:17 +08:00
|
|
|
std::string bias_type;
|
|
|
|
|
2020-02-28 08:44:33 +08:00
|
|
|
/// Keyword used in state files (== bias_type most of the time)
|
|
|
|
std::string state_keyword;
|
|
|
|
|
2016-07-16 06:25:17 +08:00
|
|
|
/// If there is more than one bias of this type, record its rank
|
|
|
|
int rank;
|
2013-06-28 06:48:27 +08:00
|
|
|
|
2012-05-24 00:20:04 +08:00
|
|
|
/// Add a new collective variable to this bias
|
2016-07-16 06:25:17 +08:00
|
|
|
int add_colvar(std::string const &cv_name);
|
2012-05-24 00:20:04 +08:00
|
|
|
|
2017-03-10 22:16:58 +08:00
|
|
|
/// How many variables are defined for this bias
|
|
|
|
inline size_t num_variables() const
|
2016-12-28 02:17:34 +08:00
|
|
|
{
|
|
|
|
return colvars.size();
|
|
|
|
}
|
|
|
|
|
2017-03-10 22:16:58 +08:00
|
|
|
/// Access the variables vector
|
|
|
|
inline std::vector<colvar *> *variables()
|
|
|
|
{
|
|
|
|
return &colvars;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Access the i-th variable
|
|
|
|
inline colvar * variables(int i) const
|
|
|
|
{
|
|
|
|
return colvars[i];
|
|
|
|
}
|
|
|
|
|
2012-05-24 00:20:04 +08:00
|
|
|
/// Retrieve colvar values and calculate their biasing forces
|
2020-01-28 02:39:58 +08:00
|
|
|
/// Some implementations may use calc_energy() and calc_forces()
|
2016-04-16 00:07:01 +08:00
|
|
|
virtual int update();
|
2012-05-24 00:20:04 +08:00
|
|
|
|
2020-01-28 02:39:58 +08:00
|
|
|
/// Compute the energy of the bias
|
|
|
|
/// Uses the vector of colvar values provided if not NULL, and the values
|
|
|
|
/// currently cached in the bias instance otherwise
|
|
|
|
virtual int calc_energy(std::vector<colvarvalue> const *values);
|
|
|
|
|
|
|
|
/// Compute the forces due to the bias
|
|
|
|
/// Uses the vector of colvar values provided if not NULL, and the values
|
|
|
|
/// currently cached in the bias instance otherwise
|
|
|
|
virtual int calc_forces(std::vector<colvarvalue> const *values);
|
2017-03-10 22:16:58 +08:00
|
|
|
|
|
|
|
/// Send forces to the collective variables
|
2020-02-28 08:44:33 +08:00
|
|
|
void communicate_forces();
|
2014-10-08 04:30:25 +08:00
|
|
|
|
2018-11-16 22:51:17 +08:00
|
|
|
/// Carry out operations needed before next step is run
|
|
|
|
virtual int end_of_step();
|
|
|
|
|
2012-05-24 00:20:04 +08:00
|
|
|
/// Load new configuration - force constant and/or centers only
|
2016-12-28 02:17:34 +08:00
|
|
|
virtual int change_configuration(std::string const &conf);
|
2012-05-24 00:20:04 +08:00
|
|
|
|
|
|
|
/// Calculate change in energy from using alternate configuration
|
|
|
|
virtual cvm::real energy_difference(std::string const &conf);
|
|
|
|
|
2014-10-29 03:53:17 +08:00
|
|
|
/// Give the total number of bins for a given bias.
|
2017-03-10 22:16:58 +08:00
|
|
|
// FIXME this is currently 1D only
|
2014-10-29 03:53:17 +08:00
|
|
|
virtual int bin_num();
|
|
|
|
/// Calculate the bin index for a given bias.
|
2017-03-10 22:16:58 +08:00
|
|
|
// FIXME this is currently 1D only
|
2014-10-29 03:53:17 +08:00
|
|
|
virtual int current_bin();
|
|
|
|
//// Give the count at a given bin index.
|
2017-03-10 22:16:58 +08:00
|
|
|
// FIXME this is currently 1D only
|
2014-12-02 10:09:53 +08:00
|
|
|
virtual int bin_count(int bin_index);
|
2014-10-29 03:53:17 +08:00
|
|
|
//// Share information between replicas, whatever it may be.
|
2014-12-02 10:09:53 +08:00
|
|
|
virtual int replica_share();
|
2014-10-29 03:53:17 +08:00
|
|
|
|
2012-05-24 00:20:04 +08:00
|
|
|
/// Perform analysis tasks
|
2015-04-30 22:09:42 +08:00
|
|
|
virtual void analyze() {}
|
2012-05-24 00:20:04 +08:00
|
|
|
|
|
|
|
/// \brief Constructor
|
2016-07-16 06:25:17 +08:00
|
|
|
colvarbias(char const *key);
|
|
|
|
|
|
|
|
/// \brief Parse config string and (re)initialize
|
|
|
|
virtual int init(std::string const &conf);
|
|
|
|
|
2019-04-30 21:50:12 +08:00
|
|
|
/// \brief Initialize dependency tree
|
|
|
|
virtual int init_dependencies();
|
|
|
|
|
2016-07-16 06:25:17 +08:00
|
|
|
/// \brief Set to zero all mutable data
|
|
|
|
virtual int reset();
|
|
|
|
|
2016-12-28 02:17:34 +08:00
|
|
|
private:
|
2012-05-24 00:20:04 +08:00
|
|
|
|
|
|
|
/// Default constructor
|
|
|
|
colvarbias();
|
|
|
|
|
2016-07-16 06:25:17 +08:00
|
|
|
/// Copy constructor
|
|
|
|
colvarbias(colvarbias &);
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
/// \brief Delete everything
|
|
|
|
virtual int clear();
|
|
|
|
|
2017-10-14 01:25:02 +08:00
|
|
|
/// \brief Delete only the allocatable data (save memory)
|
|
|
|
virtual int clear_state_data();
|
|
|
|
|
2012-05-24 00:20:04 +08:00
|
|
|
/// Destructor
|
2014-10-08 04:30:25 +08:00
|
|
|
virtual ~colvarbias();
|
2012-05-24 00:20:04 +08:00
|
|
|
|
2016-12-28 02:17:34 +08:00
|
|
|
/// Write the values of specific mutable properties to a string
|
|
|
|
virtual std::string const get_state_params() const;
|
|
|
|
|
|
|
|
/// Read the values of specific mutable properties from a string
|
|
|
|
virtual int set_state_params(std::string const &state_conf);
|
|
|
|
|
|
|
|
/// Write all mutable data not already written by get_state_params()
|
|
|
|
virtual std::ostream & write_state_data(std::ostream &os)
|
|
|
|
{
|
|
|
|
return os;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Read all mutable data not already set by set_state_params()
|
|
|
|
virtual std::istream & read_state_data(std::istream &is)
|
|
|
|
{
|
|
|
|
return is;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Read a keyword from the state data (typically a header)
|
|
|
|
std::istream & read_state_data_key(std::istream &is, char const *key);
|
2012-05-24 00:20:04 +08:00
|
|
|
|
2016-12-28 02:17:34 +08:00
|
|
|
/// Write the bias configuration to a restart file or other stream
|
2020-02-28 08:44:33 +08:00
|
|
|
std::ostream & write_state(std::ostream &os);
|
2016-12-28 02:17:34 +08:00
|
|
|
|
|
|
|
/// Read the bias configuration from a restart file or other stream
|
2020-02-28 08:44:33 +08:00
|
|
|
std::istream & read_state(std::istream &is);
|
2012-05-24 00:20:04 +08:00
|
|
|
|
2013-06-28 06:48:27 +08:00
|
|
|
/// Write a label to the trajectory file (comment line)
|
2014-12-02 10:09:53 +08:00
|
|
|
virtual std::ostream & write_traj_label(std::ostream &os);
|
2013-06-28 06:48:27 +08:00
|
|
|
|
|
|
|
/// Output quantities such as the bias energy to the trajectory file
|
2014-12-02 10:09:53 +08:00
|
|
|
virtual std::ostream & write_traj(std::ostream &os);
|
2013-06-28 06:48:27 +08:00
|
|
|
|
2016-12-28 02:17:34 +08:00
|
|
|
/// (Re)initialize the output files (does not write them yet)
|
|
|
|
virtual int setup_output()
|
|
|
|
{
|
|
|
|
return COLVARS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Write any output files that this bias may have (e.g. PMF files)
|
2015-04-30 22:09:42 +08:00
|
|
|
virtual int write_output_files()
|
|
|
|
{
|
|
|
|
return COLVARS_OK;
|
|
|
|
}
|
|
|
|
|
2017-03-10 22:16:58 +08:00
|
|
|
/// Use this prefix for all output files
|
|
|
|
std::string output_prefix;
|
|
|
|
|
2016-12-28 02:17:34 +08:00
|
|
|
/// If this bias is communicating with other replicas through files, send it to them
|
|
|
|
virtual int write_state_to_replicas()
|
|
|
|
{
|
|
|
|
return COLVARS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline cvm::real get_energy()
|
|
|
|
{
|
2014-10-08 04:30:25 +08:00
|
|
|
return bias_energy;
|
|
|
|
}
|
2016-04-16 00:07:01 +08:00
|
|
|
|
|
|
|
/// \brief Implementation of the feature list for colvarbias
|
|
|
|
static std::vector<feature *> cvb_features;
|
|
|
|
|
|
|
|
/// \brief Implementation of the feature list accessor for colvarbias
|
2019-04-30 21:50:12 +08:00
|
|
|
virtual const std::vector<feature *> &features() const
|
2017-08-10 21:22:53 +08:00
|
|
|
{
|
|
|
|
return cvb_features;
|
|
|
|
}
|
|
|
|
virtual std::vector<feature *> &modify_features()
|
2016-12-28 02:17:34 +08:00
|
|
|
{
|
2016-04-16 00:07:01 +08:00
|
|
|
return cvb_features;
|
|
|
|
}
|
2017-10-14 01:25:02 +08:00
|
|
|
static void delete_features() {
|
|
|
|
for (size_t i=0; i < cvb_features.size(); i++) {
|
|
|
|
delete cvb_features[i];
|
|
|
|
}
|
|
|
|
cvb_features.clear();
|
|
|
|
}
|
2016-12-28 02:17:34 +08:00
|
|
|
|
2012-05-24 00:20:04 +08:00
|
|
|
protected:
|
|
|
|
|
|
|
|
/// \brief Pointers to collective variables to which the bias is
|
|
|
|
/// applied; current values and metric functions will be obtained
|
|
|
|
/// through each colvar object
|
|
|
|
std::vector<colvar *> colvars;
|
|
|
|
|
2020-02-28 08:44:33 +08:00
|
|
|
/// \brief Up to date value of each colvar
|
|
|
|
std::vector<colvarvalue> colvar_values;
|
|
|
|
|
2017-03-10 22:16:58 +08:00
|
|
|
/// \brief Current forces from this bias to the variables
|
2012-05-24 00:20:04 +08:00
|
|
|
std::vector<colvarvalue> colvar_forces;
|
|
|
|
|
2017-10-14 01:25:02 +08:00
|
|
|
/// \brief Forces last applied by this bias to the variables
|
|
|
|
std::vector<colvarvalue> previous_colvar_forces;
|
|
|
|
|
2013-06-28 06:48:27 +08:00
|
|
|
/// \brief Current energy of this bias (colvar_forces should be obtained by deriving this)
|
2012-05-24 00:20:04 +08:00
|
|
|
cvm::real bias_energy;
|
|
|
|
|
2013-06-28 06:48:27 +08:00
|
|
|
/// Whether to write the current bias energy from this bias to the trajectory file
|
|
|
|
bool b_output_energy;
|
|
|
|
|
2012-05-24 00:20:04 +08:00
|
|
|
/// \brief Whether this bias has already accumulated information
|
2016-07-16 06:25:17 +08:00
|
|
|
/// (for history-dependent biases)
|
2012-05-24 00:20:04 +08:00
|
|
|
bool has_data;
|
|
|
|
|
2016-12-28 02:17:34 +08:00
|
|
|
/// \brief Step number read from the last state file
|
2019-04-30 21:50:12 +08:00
|
|
|
cvm::step_number state_file_step;
|
2016-12-28 02:17:34 +08:00
|
|
|
|
2020-02-28 08:44:33 +08:00
|
|
|
/// Flag used to tell if the state string being read is for this bias
|
|
|
|
bool matching_state;
|
|
|
|
|
2012-05-24 00:20:04 +08:00
|
|
|
};
|
|
|
|
|
2017-10-14 01:25:02 +08:00
|
|
|
|
|
|
|
class colvar_grid_gradient;
|
|
|
|
class colvar_grid_count;
|
|
|
|
|
|
|
|
/// \brief Base class for unconstrained thermodynamic-integration FE estimator
|
|
|
|
class colvarbias_ti : public virtual colvarbias {
|
|
|
|
public:
|
|
|
|
|
|
|
|
colvarbias_ti(char const *key);
|
|
|
|
virtual ~colvarbias_ti();
|
|
|
|
|
|
|
|
virtual int clear_state_data();
|
|
|
|
|
|
|
|
virtual int init(std::string const &conf);
|
|
|
|
virtual int init_grids();
|
|
|
|
virtual int update();
|
|
|
|
|
|
|
|
/// Subtract applied forces (either last forces or argument) from the total
|
|
|
|
/// forces
|
|
|
|
virtual int update_system_forces(std::vector<colvarvalue> const
|
|
|
|
*subtract_forces);
|
|
|
|
|
|
|
|
virtual std::string const get_state_params() const;
|
|
|
|
virtual int set_state_params(std::string const &state_conf);
|
|
|
|
virtual std::ostream & write_state_data(std::ostream &os);
|
|
|
|
virtual std::istream & read_state_data(std::istream &is);
|
|
|
|
virtual int write_output_files();
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
|
|
|
/// \brief Forces exerted from the system to the associated variables
|
|
|
|
std::vector<colvarvalue> ti_system_forces;
|
|
|
|
|
|
|
|
/// Averaged system forces
|
|
|
|
colvar_grid_gradient *ti_avg_forces;
|
|
|
|
|
|
|
|
/// Histogram of sampled data
|
|
|
|
colvar_grid_count *ti_count;
|
|
|
|
|
|
|
|
/// Because total forces may be from the last simulation step,
|
|
|
|
/// store the index of the variables then
|
|
|
|
std::vector<int> ti_bin;
|
|
|
|
};
|
|
|
|
|
2012-05-24 00:20:04 +08:00
|
|
|
#endif
|