2016-06-18 07:07:51 +08:00
|
|
|
// -*- c++ -*-
|
2014-10-08 04:30:25 +08:00
|
|
|
|
2012-05-24 00:20:04 +08:00
|
|
|
#include "colvarmodule.h"
|
|
|
|
#include "colvarvalue.h"
|
|
|
|
#include "colvarbias.h"
|
|
|
|
|
|
|
|
|
2016-07-16 06:25:17 +08:00
|
|
|
colvarbias::colvarbias(char const *key)
|
|
|
|
: bias_type(to_lower_cppstr(key))
|
2012-05-24 00:20:04 +08:00
|
|
|
{
|
2016-04-16 00:07:01 +08:00
|
|
|
init_cvb_requires();
|
|
|
|
|
2016-07-16 06:25:17 +08:00
|
|
|
rank = 1;
|
2012-05-24 00:20:04 +08:00
|
|
|
|
2016-07-16 06:25:17 +08:00
|
|
|
if (bias_type == std::string("abf")) {
|
2012-05-24 00:20:04 +08:00
|
|
|
rank = cvm::n_abf_biases+1;
|
|
|
|
}
|
2016-07-16 06:25:17 +08:00
|
|
|
if (bias_type == std::string("harmonic") ||
|
|
|
|
bias_type == std::string("linear")) {
|
2014-08-15 07:29:25 +08:00
|
|
|
rank = cvm::n_rest_biases+1;
|
2012-05-24 00:20:04 +08:00
|
|
|
}
|
2016-07-16 06:25:17 +08:00
|
|
|
if (bias_type == std::string("histogram")) {
|
2012-05-24 00:20:04 +08:00
|
|
|
rank = cvm::n_histo_biases+1;
|
|
|
|
}
|
2016-07-16 06:25:17 +08:00
|
|
|
if (bias_type == std::string("metadynamics")) {
|
2012-05-24 00:20:04 +08:00
|
|
|
rank = cvm::n_meta_biases+1;
|
|
|
|
}
|
|
|
|
|
2016-07-16 06:25:17 +08:00
|
|
|
has_data = false;
|
|
|
|
b_output_energy = false;
|
|
|
|
reset();
|
2012-05-24 00:20:04 +08:00
|
|
|
|
2016-07-16 06:25:17 +08:00
|
|
|
// Start in active state by default
|
|
|
|
enable(f_cvb_active);
|
|
|
|
}
|
2012-06-30 01:52:31 +08:00
|
|
|
|
2016-04-16 00:07:01 +08:00
|
|
|
|
2016-07-16 06:25:17 +08:00
|
|
|
int colvarbias::init(std::string const &conf)
|
|
|
|
{
|
|
|
|
colvarparse::init(conf);
|
|
|
|
|
|
|
|
if (name.size() == 0) {
|
|
|
|
cvm::log("Initializing a new \""+bias_type+"\" instance.\n");
|
|
|
|
get_keyval(conf, "name", name, bias_type+cvm::to_str(rank));
|
|
|
|
|
|
|
|
{
|
|
|
|
colvarbias *bias_with_name = cvm::bias_by_name(this->name);
|
|
|
|
if (bias_with_name != NULL) {
|
|
|
|
if ((bias_with_name->rank != this->rank) ||
|
|
|
|
(bias_with_name->bias_type != this->bias_type)) {
|
|
|
|
cvm::error("Error: this bias cannot have the same name, \""+this->name+
|
|
|
|
"\", as another bias.\n", INPUT_ERROR);
|
|
|
|
return INPUT_ERROR;
|
|
|
|
}
|
|
|
|
}
|
2012-05-24 00:20:04 +08:00
|
|
|
}
|
2016-07-16 06:25:17 +08:00
|
|
|
|
|
|
|
description = "bias " + name;
|
|
|
|
|
|
|
|
{
|
|
|
|
// lookup the associated colvars
|
|
|
|
std::vector<std::string> colvar_names;
|
|
|
|
if (get_keyval(conf, "colvars", colvar_names)) {
|
|
|
|
if (colvars.size()) {
|
|
|
|
cvm::error("Error: cannot redefine the colvars that a bias was already defined on.\n",
|
|
|
|
INPUT_ERROR);
|
|
|
|
return INPUT_ERROR;
|
|
|
|
}
|
|
|
|
for (size_t i = 0; i < colvar_names.size(); i++) {
|
|
|
|
add_colvar(colvar_names[i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!colvars.size()) {
|
|
|
|
cvm::error("Error: no collective variables specified.\n", INPUT_ERROR);
|
|
|
|
return INPUT_ERROR;
|
|
|
|
}
|
|
|
|
|
|
|
|
} else {
|
|
|
|
cvm::log("Reinitializing bias \""+name+"\".\n");
|
2012-05-24 00:20:04 +08:00
|
|
|
}
|
2013-06-28 06:48:27 +08:00
|
|
|
|
2016-07-16 06:25:17 +08:00
|
|
|
get_keyval(conf, "outputEnergy", b_output_energy, b_output_energy);
|
|
|
|
|
|
|
|
return COLVARS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
int colvarbias::reset()
|
|
|
|
{
|
|
|
|
bias_energy = 0.0;
|
|
|
|
for (size_t i = 0; i < colvars.size(); i++) {
|
|
|
|
colvar_forces[i].reset();
|
|
|
|
}
|
|
|
|
return COLVARS_OK;
|
2012-05-24 00:20:04 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
colvarbias::colvarbias()
|
2014-12-02 10:09:53 +08:00
|
|
|
: colvarparse(), has_data(false)
|
2012-05-24 00:20:04 +08:00
|
|
|
{}
|
|
|
|
|
2016-07-16 06:25:17 +08:00
|
|
|
|
2014-10-08 04:30:25 +08:00
|
|
|
colvarbias::~colvarbias()
|
2016-07-16 06:25:17 +08:00
|
|
|
{
|
|
|
|
colvarbias::clear();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
int colvarbias::clear()
|
2014-10-08 04:30:25 +08:00
|
|
|
{
|
|
|
|
// Remove references to this bias from colvars
|
|
|
|
for (std::vector<colvar *>::iterator cvi = colvars.begin();
|
|
|
|
cvi != colvars.end();
|
|
|
|
++cvi) {
|
|
|
|
for (std::vector<colvarbias *>::iterator bi = (*cvi)->biases.begin();
|
|
|
|
bi != (*cvi)->biases.end();
|
|
|
|
++bi) {
|
|
|
|
if ( *bi == this) {
|
2014-12-02 10:09:53 +08:00
|
|
|
(*cvi)->biases.erase(bi);
|
2014-10-08 04:30:25 +08:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-07-16 06:25:17 +08:00
|
|
|
|
2014-10-08 04:30:25 +08:00
|
|
|
// ...and from the colvars module
|
|
|
|
for (std::vector<colvarbias *>::iterator bi = cvm::biases.begin();
|
|
|
|
bi != cvm::biases.end();
|
|
|
|
++bi) {
|
|
|
|
if ( *bi == this) {
|
2014-12-02 10:09:53 +08:00
|
|
|
cvm::biases.erase(bi);
|
2014-10-08 04:30:25 +08:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2016-07-16 06:25:17 +08:00
|
|
|
|
|
|
|
return COLVARS_OK;
|
2014-10-08 04:30:25 +08:00
|
|
|
}
|
2012-05-24 00:20:04 +08:00
|
|
|
|
2016-07-16 06:25:17 +08:00
|
|
|
|
|
|
|
int colvarbias::add_colvar(std::string const &cv_name)
|
2012-05-24 00:20:04 +08:00
|
|
|
{
|
2014-12-02 10:09:53 +08:00
|
|
|
if (colvar *cv = cvm::colvar_by_name(cv_name)) {
|
2016-04-16 00:07:01 +08:00
|
|
|
// Removed this as nor all biases apply forces eg histogram
|
|
|
|
// cv->enable(colvar::task_gradients);
|
2016-07-16 06:25:17 +08:00
|
|
|
if (cvm::debug()) {
|
2014-12-02 10:09:53 +08:00
|
|
|
cvm::log("Applying this bias to collective variable \""+
|
2016-07-16 06:25:17 +08:00
|
|
|
cv->name+"\".\n");
|
|
|
|
}
|
2014-12-02 10:09:53 +08:00
|
|
|
colvars.push_back(cv);
|
2016-07-16 06:25:17 +08:00
|
|
|
|
2014-12-02 10:09:53 +08:00
|
|
|
colvar_forces.push_back(colvarvalue());
|
2016-07-16 06:25:17 +08:00
|
|
|
colvar_forces.back().type(cv->value()); // make sure each force is initialized to zero
|
2014-12-02 10:09:53 +08:00
|
|
|
colvar_forces.back().reset();
|
2016-07-16 06:25:17 +08:00
|
|
|
|
2014-12-02 10:09:53 +08:00
|
|
|
cv->biases.push_back(this); // add back-reference to this bias to colvar
|
2016-07-16 06:25:17 +08:00
|
|
|
|
|
|
|
// Add dependency link.
|
|
|
|
// All biases need at least the value of each colvar
|
|
|
|
// although possibly not at all timesteps
|
|
|
|
add_child(cv);
|
|
|
|
|
2012-05-24 00:20:04 +08:00
|
|
|
} else {
|
2014-12-02 10:09:53 +08:00
|
|
|
cvm::error("Error: cannot find a colvar named \""+
|
2016-07-16 06:25:17 +08:00
|
|
|
cv_name+"\".\n", INPUT_ERROR);
|
|
|
|
return INPUT_ERROR;
|
2012-05-24 00:20:04 +08:00
|
|
|
}
|
2016-07-16 06:25:17 +08:00
|
|
|
return COLVARS_OK;
|
2012-05-24 00:20:04 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2016-04-16 00:07:01 +08:00
|
|
|
int colvarbias::update()
|
2015-07-22 22:36:59 +08:00
|
|
|
{
|
2016-04-16 00:07:01 +08:00
|
|
|
// Note: if anything is added here, it should be added also in the SMP block of calc_biases()
|
2016-07-16 06:25:17 +08:00
|
|
|
// TODO move here debug msg of bias update
|
2015-07-22 22:36:59 +08:00
|
|
|
has_data = true;
|
2016-04-16 00:07:01 +08:00
|
|
|
return COLVARS_OK;
|
2015-07-22 22:36:59 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-05-24 00:20:04 +08:00
|
|
|
void colvarbias::communicate_forces()
|
|
|
|
{
|
|
|
|
for (size_t i = 0; i < colvars.size(); i++) {
|
|
|
|
if (cvm::debug()) {
|
2014-12-02 10:09:53 +08:00
|
|
|
cvm::log("Communicating a force to colvar \""+
|
|
|
|
colvars[i]->name+"\".\n");
|
2012-05-24 00:20:04 +08:00
|
|
|
}
|
2014-12-02 10:09:53 +08:00
|
|
|
colvars[i]->add_bias_force(colvar_forces[i]);
|
2012-05-24 00:20:04 +08:00
|
|
|
}
|
2013-06-28 06:48:27 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void colvarbias::change_configuration(std::string const &conf)
|
|
|
|
{
|
2014-12-02 10:09:53 +08:00
|
|
|
cvm::error("Error: change_configuration() not implemented.\n");
|
2013-06-28 06:48:27 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
cvm::real colvarbias::energy_difference(std::string const &conf)
|
|
|
|
{
|
2014-12-02 10:09:53 +08:00
|
|
|
cvm::error("Error: energy_difference() not implemented.\n");
|
2013-06-28 06:48:27 +08:00
|
|
|
return 0.;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2016-09-09 04:20:32 +08:00
|
|
|
// So far, these are only implemented in colvarbias_abf
|
2014-10-29 03:53:17 +08:00
|
|
|
int colvarbias::bin_num()
|
|
|
|
{
|
2014-12-02 10:09:53 +08:00
|
|
|
cvm::error("Error: bin_num() not implemented.\n");
|
|
|
|
return COLVARS_NOT_IMPLEMENTED;
|
2014-10-29 03:53:17 +08:00
|
|
|
}
|
|
|
|
int colvarbias::current_bin()
|
|
|
|
{
|
2014-12-02 10:09:53 +08:00
|
|
|
cvm::error("Error: current_bin() not implemented.\n");
|
|
|
|
return COLVARS_NOT_IMPLEMENTED;
|
2014-10-29 03:53:17 +08:00
|
|
|
}
|
|
|
|
int colvarbias::bin_count(int bin_index)
|
|
|
|
{
|
2014-12-02 10:09:53 +08:00
|
|
|
cvm::error("Error: bin_count() not implemented.\n");
|
|
|
|
return COLVARS_NOT_IMPLEMENTED;
|
|
|
|
}
|
|
|
|
int colvarbias::replica_share()
|
|
|
|
{
|
|
|
|
cvm::error("Error: replica_share() not implemented.\n");
|
|
|
|
return COLVARS_NOT_IMPLEMENTED;
|
2014-10-29 03:53:17 +08:00
|
|
|
}
|
|
|
|
|
2014-12-02 10:09:53 +08:00
|
|
|
std::ostream & colvarbias::write_traj_label(std::ostream &os)
|
2013-06-28 06:48:27 +08:00
|
|
|
{
|
|
|
|
os << " ";
|
|
|
|
if (b_output_energy)
|
|
|
|
os << " E_"
|
2014-12-02 10:09:53 +08:00
|
|
|
<< cvm::wrap_string(this->name, cvm::en_width-2);
|
2013-06-28 06:48:27 +08:00
|
|
|
return os;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-12-02 10:09:53 +08:00
|
|
|
std::ostream & colvarbias::write_traj(std::ostream &os)
|
2013-06-28 06:48:27 +08:00
|
|
|
{
|
|
|
|
os << " ";
|
|
|
|
if (b_output_energy)
|
|
|
|
os << " "
|
|
|
|
<< bias_energy;
|
|
|
|
return os;
|
|
|
|
}
|
2016-04-16 00:07:01 +08:00
|
|
|
|
|
|
|
// Static members
|
|
|
|
|
2016-09-09 04:20:32 +08:00
|
|
|
std::vector<colvardeps::feature *> colvarbias::cvb_features;
|