2014-10-08 04:30:53 +08:00
|
|
|
// -*- c++ -*-
|
|
|
|
|
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:
|
|
|
|
// https://github.com/colvars/colvars
|
|
|
|
// 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.
|
|
|
|
|
2014-10-08 04:30:53 +08:00
|
|
|
#include <cstdlib>
|
2018-05-08 12:17:57 +08:00
|
|
|
#include <cstring>
|
2014-12-02 10:09:53 +08:00
|
|
|
|
2017-10-14 01:25:02 +08:00
|
|
|
#define COLVARSCRIPT_CPP
|
2014-10-08 04:30:53 +08:00
|
|
|
#include "colvarscript.h"
|
2017-10-14 01:25:02 +08:00
|
|
|
#undef COLVARSCRIPT_CPP
|
|
|
|
|
2017-07-20 02:10:43 +08:00
|
|
|
#include "colvarproxy.h"
|
2017-03-10 22:16:58 +08:00
|
|
|
#include "colvardeps.h"
|
2014-10-08 04:30:53 +08:00
|
|
|
|
|
|
|
|
2014-12-02 10:09:53 +08:00
|
|
|
colvarscript::colvarscript(colvarproxy *p)
|
|
|
|
: proxy(p),
|
|
|
|
colvars(p->colvars),
|
|
|
|
proxy_error(0)
|
2014-10-08 04:30:53 +08:00
|
|
|
{
|
2017-10-14 01:25:02 +08:00
|
|
|
comm_help.resize(colvarscript::cv_n_commands);
|
|
|
|
comm_fns.resize(colvarscript::cv_n_commands);
|
|
|
|
#define COLVARSCRIPT_INIT_FN
|
|
|
|
#include "colvarscript.h"
|
|
|
|
#undef COLVARSCRIPT_INIT_FN
|
2014-10-08 04:30:53 +08:00
|
|
|
}
|
|
|
|
|
2016-10-25 04:48:20 +08:00
|
|
|
|
|
|
|
extern "C" {
|
|
|
|
|
|
|
|
// Generic hooks; NAMD and VMD have Tcl-specific versions in the respective proxies
|
|
|
|
|
2017-07-20 02:10:43 +08:00
|
|
|
int run_colvarscript_command(int objc, unsigned char *const objv[])
|
2016-10-25 04:48:20 +08:00
|
|
|
{
|
|
|
|
colvarproxy *cvp = cvm::proxy;
|
|
|
|
if (!cvp) {
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
if (!cvp->script) {
|
|
|
|
cvm::error("Called run_colvarscript_command without a script object initialized.\n");
|
|
|
|
return -1;
|
|
|
|
}
|
2017-07-20 02:10:43 +08:00
|
|
|
return cvp->script->run(objc, objv);
|
2016-10-25 04:48:20 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
const char * get_colvarscript_result()
|
|
|
|
{
|
|
|
|
colvarproxy *cvp = cvm::proxy;
|
|
|
|
if (!cvp->script) {
|
|
|
|
cvm::error("Called run_colvarscript_command without a script object initialized.\n");
|
|
|
|
return "";
|
|
|
|
}
|
|
|
|
return cvp->script->result.c_str();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-10-08 04:30:53 +08:00
|
|
|
/// Run method based on given arguments
|
2017-07-20 02:10:43 +08:00
|
|
|
int colvarscript::run(int objc, unsigned char *const objv[])
|
|
|
|
{
|
|
|
|
result.clear();
|
2014-10-08 04:30:53 +08:00
|
|
|
|
|
|
|
if (cvm::debug()) {
|
2017-07-20 02:10:43 +08:00
|
|
|
cvm::log("Called script run with " + cvm::to_str(objc) + " args:");
|
|
|
|
for (int i = 0; i < objc; i++) {
|
|
|
|
cvm::log(obj_to_str(objv[i]));
|
|
|
|
}
|
2014-10-08 04:30:53 +08:00
|
|
|
}
|
|
|
|
|
2017-07-20 02:10:43 +08:00
|
|
|
if (objc < 2) {
|
2018-02-23 21:34:53 +08:00
|
|
|
set_str_result("No commands given: use \"cv help\" "
|
|
|
|
"for a list of commands.");
|
|
|
|
return COLVARSCRIPT_ERROR;
|
2014-10-08 04:30:53 +08:00
|
|
|
}
|
|
|
|
|
2017-07-20 02:10:43 +08:00
|
|
|
std::string const cmd(obj_to_str(objv[1]));
|
2014-10-08 04:30:53 +08:00
|
|
|
|
2016-03-02 04:40:25 +08:00
|
|
|
int error_code = COLVARS_OK;
|
|
|
|
|
2018-11-03 05:45:20 +08:00
|
|
|
// If command is found in map, execute it
|
|
|
|
std::string const cmd_key("cv_"+cmd);
|
|
|
|
if (comm_str_map.count(cmd_key) > 0) {
|
|
|
|
error_code |= (*(comm_fns[comm_str_map[cmd_key]]))(
|
|
|
|
reinterpret_cast<void *>(this), objc, objv);
|
|
|
|
return error_code;
|
|
|
|
}
|
|
|
|
|
2014-10-08 04:30:53 +08:00
|
|
|
if (cmd == "colvar") {
|
2017-07-20 02:10:43 +08:00
|
|
|
if (objc < 3) {
|
|
|
|
result = "Missing parameters\n" + help_string();
|
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
|
|
|
std::string const name(obj_to_str(objv[2]));
|
|
|
|
colvar *cv = cvm::colvar_by_name(name);
|
|
|
|
if (cv == NULL) {
|
|
|
|
result = "Colvar not found: " + name;
|
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
|
|
|
return proc_colvar(cv, objc-1, &(objv[1]));
|
2014-10-08 04:30:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
if (cmd == "bias") {
|
2017-07-20 02:10:43 +08:00
|
|
|
if (objc < 3) {
|
|
|
|
result = "Missing parameters\n" + help_string();
|
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
|
|
|
std::string const name(obj_to_str(objv[2]));
|
|
|
|
colvarbias *b = cvm::bias_by_name(name);
|
|
|
|
if (b == NULL) {
|
|
|
|
result = "Bias not found: " + name;
|
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
|
|
|
return proc_bias(b, objc-1, &(objv[1]));
|
2014-10-08 04:30:53 +08:00
|
|
|
}
|
|
|
|
|
2015-03-09 22:50:53 +08:00
|
|
|
if (cmd == "version") {
|
|
|
|
result = COLVARS_VERSION;
|
2016-03-02 04:40:25 +08:00
|
|
|
return COLVARS_OK;
|
2015-03-09 22:50:53 +08:00
|
|
|
}
|
|
|
|
|
2014-10-08 04:30:53 +08:00
|
|
|
if (cmd == "reset") {
|
|
|
|
/// Delete every child object
|
|
|
|
colvars->reset();
|
2016-03-02 04:40:25 +08:00
|
|
|
return COLVARS_OK;
|
2014-10-08 04:30:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
if (cmd == "delete") {
|
|
|
|
// Note: the delete bit may be ignored by some backends
|
|
|
|
// it is mostly useful in VMD
|
2018-02-23 21:34:53 +08:00
|
|
|
return proxy->request_deletion();
|
2014-10-08 04:30:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
if (cmd == "update") {
|
2016-09-09 04:20:32 +08:00
|
|
|
error_code |= proxy->update_input();
|
2019-04-30 21:50:12 +08:00
|
|
|
if (error_code) {
|
|
|
|
result += "Error updating the Colvars module.\n";
|
|
|
|
return error_code;
|
|
|
|
}
|
2016-09-09 04:20:32 +08:00
|
|
|
error_code |= colvars->calc();
|
|
|
|
error_code |= proxy->update_output();
|
2016-03-02 04:40:25 +08:00
|
|
|
if (error_code) {
|
2017-07-20 02:10:43 +08:00
|
|
|
result += "Error updating the Colvars module.\n";
|
2016-03-02 04:40:25 +08:00
|
|
|
}
|
|
|
|
return error_code;
|
2014-10-08 04:30:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
if (cmd == "list") {
|
2017-07-20 02:10:43 +08:00
|
|
|
if (objc == 2) {
|
2014-10-08 04:30:53 +08:00
|
|
|
for (std::vector<colvar *>::iterator cvi = colvars->colvars.begin();
|
|
|
|
cvi != colvars->colvars.end();
|
|
|
|
++cvi) {
|
|
|
|
result += (cvi == colvars->colvars.begin() ? "" : " ") + (*cvi)->name;
|
|
|
|
}
|
2016-03-02 04:40:25 +08:00
|
|
|
return COLVARS_OK;
|
2017-07-20 02:10:43 +08:00
|
|
|
} else if (objc == 3 && !strcmp(obj_to_str(objv[2]), "biases")) {
|
2014-10-08 04:30:53 +08:00
|
|
|
for (std::vector<colvarbias *>::iterator bi = colvars->biases.begin();
|
|
|
|
bi != colvars->biases.end();
|
|
|
|
++bi) {
|
|
|
|
result += (bi == colvars->biases.begin() ? "" : " ") + (*bi)->name;
|
|
|
|
}
|
2016-03-02 04:40:25 +08:00
|
|
|
return COLVARS_OK;
|
2014-10-08 04:30:53 +08:00
|
|
|
} else {
|
2015-04-06 23:14:53 +08:00
|
|
|
result = "Wrong arguments to command \"list\"\n" + help_string();
|
2014-10-08 04:30:53 +08:00
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Parse config from file
|
|
|
|
if (cmd == "configfile") {
|
2017-07-20 02:10:43 +08:00
|
|
|
if (objc < 3) {
|
2015-04-06 23:14:53 +08:00
|
|
|
result = "Missing arguments\n" + help_string();
|
2014-10-08 04:30:53 +08:00
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
2017-07-20 02:10:43 +08:00
|
|
|
if (colvars->read_config_file(obj_to_str(objv[2])) == COLVARS_OK) {
|
2016-03-02 04:40:25 +08:00
|
|
|
return COLVARS_OK;
|
2014-10-08 04:30:53 +08:00
|
|
|
} else {
|
2015-04-06 23:14:53 +08:00
|
|
|
result = "Error parsing configuration file";
|
2014-10-08 04:30:53 +08:00
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Parse config from string
|
|
|
|
if (cmd == "config") {
|
2017-10-14 01:25:02 +08:00
|
|
|
return exec_command(cv_config, NULL, objc, objv);
|
2014-10-08 04:30:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/// Load an input state file
|
|
|
|
if (cmd == "load") {
|
2017-07-20 02:10:43 +08:00
|
|
|
if (objc < 3) {
|
2015-04-06 23:14:53 +08:00
|
|
|
result = "Missing arguments\n" + help_string();
|
2014-10-08 04:30:53 +08:00
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
2017-07-20 02:10:43 +08:00
|
|
|
proxy->input_prefix() = obj_to_str(objv[2]);
|
2014-10-08 04:30:53 +08:00
|
|
|
if (colvars->setup_input() == COLVARS_OK) {
|
2016-03-02 04:40:25 +08:00
|
|
|
return COLVARS_OK;
|
2014-10-08 04:30:53 +08:00
|
|
|
} else {
|
2015-04-06 23:14:53 +08:00
|
|
|
result = "Error loading state file";
|
2014-10-08 04:30:53 +08:00
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-04-30 22:09:42 +08:00
|
|
|
/// Save to an output state file
|
|
|
|
if (cmd == "save") {
|
2017-07-20 02:10:43 +08:00
|
|
|
if (objc < 3) {
|
2015-04-30 22:09:42 +08:00
|
|
|
result = "Missing arguments";
|
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
2017-07-20 02:10:43 +08:00
|
|
|
proxy->output_prefix() = obj_to_str(objv[2]);
|
2015-04-30 22:09:42 +08:00
|
|
|
int error = 0;
|
2016-09-09 04:20:32 +08:00
|
|
|
error |= colvars->setup_output();
|
2017-10-14 01:25:02 +08:00
|
|
|
error |= colvars->write_restart_file(colvars->output_prefix()+
|
|
|
|
".colvars.state");
|
2016-09-09 04:20:32 +08:00
|
|
|
error |= colvars->write_output_files();
|
2016-03-02 04:40:25 +08:00
|
|
|
return error ? COLVARSCRIPT_ERROR : COLVARS_OK;
|
2015-04-30 22:09:42 +08:00
|
|
|
}
|
2014-10-08 04:30:53 +08:00
|
|
|
|
|
|
|
/// Print the values that would go on colvars.traj
|
|
|
|
if (cmd == "printframelabels") {
|
|
|
|
std::ostringstream os;
|
2014-12-02 10:09:53 +08:00
|
|
|
colvars->write_traj_label(os);
|
2014-10-08 04:30:53 +08:00
|
|
|
result = os.str();
|
2016-03-02 04:40:25 +08:00
|
|
|
return COLVARS_OK;
|
2014-10-08 04:30:53 +08:00
|
|
|
}
|
|
|
|
if (cmd == "printframe") {
|
|
|
|
std::ostringstream os;
|
2014-12-02 10:09:53 +08:00
|
|
|
colvars->write_traj(os);
|
2014-10-08 04:30:53 +08:00
|
|
|
result = os.str();
|
2016-03-02 04:40:25 +08:00
|
|
|
return COLVARS_OK;
|
2014-10-08 04:30:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
if (cmd == "frame") {
|
2017-07-20 02:10:43 +08:00
|
|
|
if (objc == 2) {
|
2016-09-09 04:20:32 +08:00
|
|
|
long int f;
|
|
|
|
int error = proxy->get_frame(f);
|
|
|
|
if (error == COLVARS_OK) {
|
2014-12-02 10:09:53 +08:00
|
|
|
result = cvm::to_str(f);
|
2016-03-02 04:40:25 +08:00
|
|
|
return COLVARS_OK;
|
2014-10-08 04:30:53 +08:00
|
|
|
} else {
|
|
|
|
result = "Frame number is not available";
|
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
2017-07-20 02:10:43 +08:00
|
|
|
} else if (objc == 3) {
|
2014-10-08 04:30:53 +08:00
|
|
|
// Failure of this function does not trigger an error, but
|
2016-09-09 04:20:32 +08:00
|
|
|
// returns nonzero, to let scripts detect available frames
|
2017-07-20 02:10:43 +08:00
|
|
|
int error = proxy->set_frame(strtol(obj_to_str(objv[2]), NULL, 10));
|
2016-09-09 04:20:32 +08:00
|
|
|
result = cvm::to_str(error == COLVARS_OK ? 0 : -1);
|
2016-03-02 04:40:25 +08:00
|
|
|
return COLVARS_OK;
|
2014-10-08 04:30:53 +08:00
|
|
|
} else {
|
2015-04-06 23:14:53 +08:00
|
|
|
result = "Wrong arguments to command \"frame\"\n" + help_string();
|
2014-10-08 04:30:53 +08:00
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-03-10 22:16:58 +08:00
|
|
|
if (cmd == "addenergy") {
|
2017-07-20 02:10:43 +08:00
|
|
|
if (objc == 3) {
|
|
|
|
colvars->total_bias_energy += strtod(obj_to_str(objv[2]), NULL);
|
2017-03-10 22:16:58 +08:00
|
|
|
return COLVARS_OK;
|
|
|
|
} else {
|
|
|
|
result = "Wrong arguments to command \"addenergy\"\n" + help_string();
|
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-10-14 01:25:02 +08:00
|
|
|
if (cmd == "help") {
|
|
|
|
return exec_command(cv_help, NULL, objc, objv);
|
|
|
|
}
|
|
|
|
|
2015-04-06 23:14:53 +08:00
|
|
|
result = "Syntax error\n" + help_string();
|
2014-10-08 04:30:53 +08:00
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-07-20 02:10:43 +08:00
|
|
|
int colvarscript::proc_colvar(colvar *cv, int objc, unsigned char *const objv[]) {
|
2015-04-06 23:14:53 +08:00
|
|
|
|
2019-04-30 21:50:12 +08:00
|
|
|
if (objc < 3) {
|
|
|
|
result = "Missing arguments";
|
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
2017-07-20 02:10:43 +08:00
|
|
|
std::string const subcmd(obj_to_str(objv[2]));
|
2014-10-08 04:30:53 +08:00
|
|
|
|
|
|
|
if (subcmd == "value") {
|
2014-12-02 10:09:53 +08:00
|
|
|
result = (cv->value()).to_simple_string();
|
2016-03-02 04:40:25 +08:00
|
|
|
return COLVARS_OK;
|
2014-12-02 10:09:53 +08:00
|
|
|
}
|
|
|
|
|
2018-02-23 21:34:53 +08:00
|
|
|
if (subcmd == "run_ave") {
|
|
|
|
result = (cv->run_ave()).to_simple_string();
|
|
|
|
return COLVARS_OK;
|
|
|
|
}
|
|
|
|
|
2014-12-02 10:09:53 +08:00
|
|
|
if (subcmd == "width") {
|
|
|
|
result = cvm::to_str(cv->width, 0, cvm::cv_prec);
|
2016-03-02 04:40:25 +08:00
|
|
|
return COLVARS_OK;
|
2014-10-08 04:30:53 +08:00
|
|
|
}
|
|
|
|
|
2015-03-09 22:50:53 +08:00
|
|
|
if (subcmd == "type") {
|
|
|
|
result = cv->value().type_desc(cv->value().value_type);
|
2016-03-02 04:40:25 +08:00
|
|
|
return COLVARS_OK;
|
2015-03-09 22:50:53 +08:00
|
|
|
}
|
|
|
|
|
2014-10-08 04:30:53 +08:00
|
|
|
if (subcmd == "update") {
|
2014-10-29 03:53:17 +08:00
|
|
|
cv->calc();
|
2016-04-16 00:07:01 +08:00
|
|
|
cv->update_forces_energy();
|
2014-12-02 10:09:53 +08:00
|
|
|
result = (cv->value()).to_simple_string();
|
2016-03-02 04:40:25 +08:00
|
|
|
return COLVARS_OK;
|
2014-10-08 04:30:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
if (subcmd == "delete") {
|
2018-11-03 05:45:20 +08:00
|
|
|
while (cv->biases.size() > 0) {
|
|
|
|
size_t i = cv->biases.size()-1;
|
|
|
|
cvm::log("Warning: before deleting colvar " + cv->name
|
|
|
|
+ ", deleting parent bias " + cv->biases[i]->name);
|
2017-03-10 22:16:58 +08:00
|
|
|
delete cv->biases[i];
|
2014-10-08 04:30:53 +08:00
|
|
|
}
|
|
|
|
// colvar destructor is tasked with the cleanup
|
|
|
|
delete cv;
|
|
|
|
// TODO this could be done by the destructors
|
2017-10-14 01:25:02 +08:00
|
|
|
if (colvars->cv_traj_os != NULL) {
|
|
|
|
colvars->write_traj_label(*(colvars->cv_traj_os));
|
|
|
|
}
|
2016-03-02 04:40:25 +08:00
|
|
|
return COLVARS_OK;
|
2014-10-08 04:30:53 +08:00
|
|
|
}
|
|
|
|
|
2015-03-09 22:50:53 +08:00
|
|
|
if (subcmd == "getconfig") {
|
|
|
|
result = cv->get_config();
|
2016-03-02 04:40:25 +08:00
|
|
|
return COLVARS_OK;
|
2015-03-09 22:50:53 +08:00
|
|
|
}
|
|
|
|
|
2019-04-30 21:50:12 +08:00
|
|
|
if (subcmd == "getatomgroups") {
|
|
|
|
std::vector<std::vector<int> > lists = cv->get_atom_lists();
|
|
|
|
std::vector<std::vector<int> >::iterator li = lists.begin();
|
|
|
|
|
|
|
|
for ( ; li != lists.end(); ++li) {
|
|
|
|
result += "{";
|
|
|
|
std::vector<int>::iterator lj = (*li).begin();
|
|
|
|
for ( ; lj != (*li).end(); ++lj) {
|
|
|
|
result += cvm::to_str(*lj);
|
|
|
|
result += " ";
|
|
|
|
}
|
|
|
|
result += "} ";
|
|
|
|
}
|
|
|
|
return COLVARS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (subcmd == "getatomids") {
|
|
|
|
std::vector<int>::iterator li = cv->atom_ids.begin();
|
|
|
|
|
|
|
|
for ( ; li != cv->atom_ids.end(); ++li) {
|
|
|
|
result += cvm::to_str(*li);
|
|
|
|
result += " ";
|
|
|
|
}
|
|
|
|
return COLVARS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (subcmd == "getgradients") {
|
|
|
|
std::vector<cvm::rvector>::iterator li = cv->atomic_gradients.begin();
|
|
|
|
|
|
|
|
for ( ; li != cv->atomic_gradients.end(); ++li) {
|
|
|
|
result += "{";
|
|
|
|
int j;
|
|
|
|
for (j = 0; j < 3; ++j) {
|
|
|
|
result += cvm::to_str((*li)[j]);
|
|
|
|
result += " ";
|
|
|
|
}
|
|
|
|
result += "} ";
|
|
|
|
}
|
|
|
|
return COLVARS_OK;
|
|
|
|
}
|
|
|
|
|
2016-04-16 00:07:01 +08:00
|
|
|
if (subcmd == "getappliedforce") {
|
2016-09-30 20:15:44 +08:00
|
|
|
result = (cv->applied_force()).to_simple_string();
|
2016-04-16 00:07:01 +08:00
|
|
|
return COLVARS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (subcmd == "getsystemforce") {
|
2016-09-30 20:15:44 +08:00
|
|
|
// TODO warning here
|
|
|
|
result = (cv->total_force()).to_simple_string();
|
|
|
|
return COLVARS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (subcmd == "gettotalforce") {
|
2016-09-09 04:20:32 +08:00
|
|
|
result = (cv->total_force()).to_simple_string();
|
2016-04-16 00:07:01 +08:00
|
|
|
return COLVARS_OK;
|
|
|
|
}
|
|
|
|
|
2014-10-08 04:30:53 +08:00
|
|
|
if (subcmd == "addforce") {
|
2017-07-20 02:10:43 +08:00
|
|
|
if (objc < 4) {
|
2015-04-06 23:14:53 +08:00
|
|
|
result = "addforce: missing parameter: force value\n" + help_string();
|
2014-10-08 04:30:53 +08:00
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
2017-07-20 02:10:43 +08:00
|
|
|
std::string const f_str(obj_to_str(objv[3]));
|
2014-12-02 10:09:53 +08:00
|
|
|
std::istringstream is(f_str);
|
2014-10-08 04:30:53 +08:00
|
|
|
is.width(cvm::cv_width);
|
|
|
|
is.precision(cvm::cv_prec);
|
2014-12-02 10:09:53 +08:00
|
|
|
colvarvalue force(cv->value());
|
2014-10-08 04:30:53 +08:00
|
|
|
force.is_derivative();
|
2014-12-02 10:09:53 +08:00
|
|
|
if (force.from_simple_string(is.str()) != COLVARS_OK) {
|
|
|
|
result = "addforce : error parsing force value";
|
2014-10-08 04:30:53 +08:00
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
|
|
|
cv->add_bias_force(force);
|
2014-12-02 10:09:53 +08:00
|
|
|
result = force.to_simple_string();
|
2016-03-02 04:40:25 +08:00
|
|
|
return COLVARS_OK;
|
2015-07-22 22:36:59 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
if (subcmd == "cvcflags") {
|
2017-07-20 02:10:43 +08:00
|
|
|
if (objc < 4) {
|
2015-07-22 22:36:59 +08:00
|
|
|
result = "cvcflags: missing parameter: vector of flags";
|
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
2017-07-20 02:10:43 +08:00
|
|
|
std::string const flags_str(obj_to_str(objv[3]));
|
2015-07-22 22:36:59 +08:00
|
|
|
std::istringstream is(flags_str);
|
|
|
|
std::vector<bool> flags;
|
|
|
|
|
|
|
|
int flag;
|
|
|
|
while (is >> flag) {
|
|
|
|
flags.push_back(flag != 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
int res = cv->set_cvc_flags(flags);
|
|
|
|
if (res != COLVARS_OK) {
|
|
|
|
result = "Error setting CVC flags";
|
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
|
|
|
result = "0";
|
2016-03-02 04:40:25 +08:00
|
|
|
return COLVARS_OK;
|
2014-10-08 04:30:53 +08:00
|
|
|
}
|
|
|
|
|
2018-11-03 05:45:20 +08:00
|
|
|
if (subcmd == "modifycvcs") {
|
|
|
|
if (objc < 4) {
|
|
|
|
result = "cvcflags: missing parameter: vector of strings";
|
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
|
|
|
std::vector<std::string> const confs(proxy->script_obj_to_str_vector(objv[3]));
|
|
|
|
cvm::increase_depth();
|
|
|
|
int res = cv->update_cvc_config(confs);
|
|
|
|
cvm::decrease_depth();
|
|
|
|
if (res != COLVARS_OK) {
|
|
|
|
result = "Error setting CVC flags";
|
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
|
|
|
result = "0";
|
|
|
|
return COLVARS_OK;
|
|
|
|
}
|
|
|
|
|
2017-03-10 22:16:58 +08:00
|
|
|
if ((subcmd == "get") || (subcmd == "set") || (subcmd == "state")) {
|
2017-07-20 02:10:43 +08:00
|
|
|
return proc_features(cv, objc, objv);
|
2016-06-18 07:07:51 +08:00
|
|
|
}
|
|
|
|
|
2015-04-06 23:14:53 +08:00
|
|
|
result = "Syntax error\n" + help_string();
|
2014-10-08 04:30:53 +08:00
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-07-20 02:10:43 +08:00
|
|
|
int colvarscript::proc_bias(colvarbias *b, int objc, unsigned char *const objv[]) {
|
2014-10-08 04:30:53 +08:00
|
|
|
|
2019-04-30 21:50:12 +08:00
|
|
|
if (objc < 3) {
|
|
|
|
result = "Missing arguments";
|
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
2017-07-20 02:10:43 +08:00
|
|
|
std::string const subcmd(obj_to_str(objv[2]));
|
2014-10-08 04:30:53 +08:00
|
|
|
|
|
|
|
if (subcmd == "energy") {
|
|
|
|
result = cvm::to_str(b->get_energy());
|
2016-03-02 04:40:25 +08:00
|
|
|
return COLVARS_OK;
|
2014-10-08 04:30:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
if (subcmd == "update") {
|
|
|
|
b->update();
|
|
|
|
result = cvm::to_str(b->get_energy());
|
2016-03-02 04:40:25 +08:00
|
|
|
return COLVARS_OK;
|
2014-10-08 04:30:53 +08:00
|
|
|
}
|
|
|
|
|
2015-03-09 22:50:53 +08:00
|
|
|
if (subcmd == "getconfig") {
|
|
|
|
result = b->get_config();
|
2016-03-02 04:40:25 +08:00
|
|
|
return COLVARS_OK;
|
2015-03-09 22:50:53 +08:00
|
|
|
}
|
|
|
|
|
2014-12-02 10:09:53 +08:00
|
|
|
// Subcommands for MW ABF
|
|
|
|
if (subcmd == "bin") {
|
|
|
|
int r = b->current_bin();
|
|
|
|
result = cvm::to_str(r);
|
2016-03-02 04:40:25 +08:00
|
|
|
return COLVARS_OK;
|
2014-12-02 10:09:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
if (subcmd == "binnum") {
|
|
|
|
int r = b->bin_num();
|
|
|
|
if (r < 0) {
|
|
|
|
result = "Error: calling bin_num() for bias " + b->name;
|
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
|
|
|
result = cvm::to_str(r);
|
2016-03-02 04:40:25 +08:00
|
|
|
return COLVARS_OK;
|
2014-12-02 10:09:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
if (subcmd == "share") {
|
|
|
|
int r = b->replica_share();
|
|
|
|
if (r < 0) {
|
|
|
|
result = "Error: calling replica_share() for bias " + b->name;
|
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
|
|
|
result = cvm::to_str(r);
|
2016-03-02 04:40:25 +08:00
|
|
|
return COLVARS_OK;
|
2014-12-02 10:09:53 +08:00
|
|
|
}
|
|
|
|
// End commands for MW ABF
|
|
|
|
|
2014-10-08 04:30:53 +08:00
|
|
|
if (subcmd == "delete") {
|
|
|
|
// the bias destructor takes care of the cleanup at cvm level
|
|
|
|
delete b;
|
|
|
|
// TODO this could be done by the destructors
|
2017-10-14 01:25:02 +08:00
|
|
|
if (colvars->cv_traj_os != NULL) {
|
|
|
|
colvars->write_traj_label(*(colvars->cv_traj_os));
|
|
|
|
}
|
2016-03-02 04:40:25 +08:00
|
|
|
return COLVARS_OK;
|
2014-10-08 04:30:53 +08:00
|
|
|
}
|
|
|
|
|
2017-03-10 22:16:58 +08:00
|
|
|
if ((subcmd == "get") || (subcmd == "set") || (subcmd == "state")) {
|
2017-07-20 02:10:43 +08:00
|
|
|
return proc_features(b, objc, objv);
|
2017-03-10 22:16:58 +08:00
|
|
|
}
|
|
|
|
|
2017-07-20 02:10:43 +08:00
|
|
|
if (objc >= 4) {
|
|
|
|
std::string const param(obj_to_str(objv[3]));
|
2014-12-02 10:09:53 +08:00
|
|
|
if (subcmd == "count") {
|
|
|
|
int index;
|
|
|
|
if (!(std::istringstream(param) >> index)) {
|
|
|
|
result = "bin_count: error parsing bin index";
|
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
|
|
|
result = cvm::to_str(b->bin_count(index));
|
2016-03-02 04:40:25 +08:00
|
|
|
return COLVARS_OK;
|
2014-12-02 10:09:53 +08:00
|
|
|
}
|
2014-10-08 04:30:53 +08:00
|
|
|
|
2015-04-06 23:14:53 +08:00
|
|
|
result = "Syntax error\n" + help_string();
|
2014-10-08 04:30:53 +08:00
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
2015-04-06 23:14:53 +08:00
|
|
|
|
|
|
|
result = "Syntax error\n" + help_string();
|
2014-10-08 04:30:53 +08:00
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
2015-04-06 23:14:53 +08:00
|
|
|
|
|
|
|
|
2017-03-10 22:16:58 +08:00
|
|
|
int colvarscript::proc_features(colvardeps *obj,
|
2017-07-20 02:10:43 +08:00
|
|
|
int objc, unsigned char *const objv[]) {
|
2017-03-10 22:16:58 +08:00
|
|
|
// size was already checked before calling
|
2017-07-20 02:10:43 +08:00
|
|
|
std::string const subcmd(obj_to_str(objv[2]));
|
2017-03-10 22:16:58 +08:00
|
|
|
|
2017-07-20 02:10:43 +08:00
|
|
|
if (objc == 3) {
|
2017-03-10 22:16:58 +08:00
|
|
|
if (subcmd == "state") {
|
|
|
|
// TODO make this returned as result?
|
|
|
|
obj->print_state();
|
|
|
|
return COLVARS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
// get and set commands require more arguments
|
|
|
|
result = "Syntax error\n" + help_string();
|
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ((subcmd == "get") || (subcmd == "set")) {
|
2017-08-10 21:22:53 +08:00
|
|
|
std::vector<colvardeps::feature *> const &features = obj->features();
|
2017-07-20 02:10:43 +08:00
|
|
|
std::string const req_feature(obj_to_str(objv[3]));
|
2017-03-10 22:16:58 +08:00
|
|
|
colvardeps::feature *f = NULL;
|
|
|
|
int fid = 0;
|
|
|
|
for (fid = 0; fid < int(features.size()); fid++) {
|
|
|
|
if (features[fid]->description ==
|
|
|
|
colvarparse::to_lower_cppstr(req_feature)) {
|
|
|
|
f = features[fid];
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (f == NULL) {
|
|
|
|
|
|
|
|
result = "Error: feature \""+req_feature+"\" does not exist.\n";
|
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
if (! obj->is_available(fid)) {
|
|
|
|
result = "Error: feature \""+req_feature+"\" is unavailable.\n";
|
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (subcmd == "get") {
|
|
|
|
result = cvm::to_str(obj->is_enabled(fid) ? 1 : 0);
|
|
|
|
return COLVARS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (subcmd == "set") {
|
2017-07-20 02:10:43 +08:00
|
|
|
if (objc == 5) {
|
2017-03-10 22:16:58 +08:00
|
|
|
std::string const yesno =
|
2017-07-20 02:10:43 +08:00
|
|
|
colvarparse::to_lower_cppstr(std::string(obj_to_str(objv[4])));
|
2017-03-10 22:16:58 +08:00
|
|
|
if ((yesno == std::string("yes")) ||
|
|
|
|
(yesno == std::string("on")) ||
|
|
|
|
(yesno == std::string("1"))) {
|
|
|
|
obj->enable(fid);
|
|
|
|
return COLVARS_OK;
|
|
|
|
} else if ((yesno == std::string("no")) ||
|
|
|
|
(yesno == std::string("off")) ||
|
|
|
|
(yesno == std::string("0"))) {
|
2017-07-20 02:10:43 +08:00
|
|
|
obj->disable(fid);
|
2017-03-10 22:16:58 +08:00
|
|
|
return COLVARS_OK;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
result = "Syntax error\n" + help_string();
|
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
result = "Syntax error\n" + help_string();
|
|
|
|
return COLVARSCRIPT_ERROR;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-10-14 01:25:02 +08:00
|
|
|
std::string colvarscript::help_string() const
|
2015-04-06 23:14:53 +08:00
|
|
|
{
|
|
|
|
std::string buf;
|
|
|
|
buf = "Usage: cv <subcommand> [args...]\n\
|
|
|
|
\n\
|
2017-07-20 02:10:43 +08:00
|
|
|
Managing the Colvars module:\n\
|
2015-04-06 23:14:53 +08:00
|
|
|
configfile <file name> -- read configuration from a file\n\
|
|
|
|
config <string> -- read configuration from the given string\n\
|
2018-11-03 05:45:20 +08:00
|
|
|
getconfig -- get the module's configuration string\n\
|
|
|
|
resetindexgroups -- clear the index groups loaded so far\n\
|
2015-04-06 23:14:53 +08:00
|
|
|
reset -- delete all internal configuration\n\
|
2017-07-20 02:10:43 +08:00
|
|
|
delete -- delete this Colvars module instance\n\
|
2017-10-14 01:25:02 +08:00
|
|
|
version -- return version of Colvars code\n\
|
2015-04-06 23:14:53 +08:00
|
|
|
\n\
|
|
|
|
Input and output:\n\
|
|
|
|
list -- return a list of all variables\n\
|
|
|
|
list biases -- return a list of all biases\n\
|
|
|
|
load <file name> -- load a state file (requires configuration)\n\
|
2015-10-23 06:08:30 +08:00
|
|
|
save <file name> -- save a state file (requires configuration)\n\
|
2016-04-28 22:48:56 +08:00
|
|
|
update -- recalculate colvars and biases\n\
|
2017-03-10 22:16:58 +08:00
|
|
|
addenergy <E> -- add <E> to the total bias energy\n\
|
2015-04-06 23:14:53 +08:00
|
|
|
printframe -- return a summary of the current frame\n\
|
|
|
|
printframelabels -- return labels to annotate printframe's output\n";
|
|
|
|
|
2016-09-09 04:20:32 +08:00
|
|
|
long int tmp;
|
|
|
|
if (proxy->get_frame(tmp) != COLVARS_NOT_IMPLEMENTED) {
|
2015-04-06 23:14:53 +08:00
|
|
|
buf += "\
|
|
|
|
frame -- return current frame number\n\
|
|
|
|
frame <new_frame> -- set frame number\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
buf += "\n\
|
|
|
|
Accessing collective variables:\n\
|
|
|
|
colvar <name> value -- return the current value of colvar <name>\n\
|
|
|
|
colvar <name> update -- recalculate colvar <name>\n\
|
|
|
|
colvar <name> type -- return the type of colvar <name>\n\
|
|
|
|
colvar <name> delete -- delete colvar <name>\n\
|
|
|
|
colvar <name> addforce <F> -- apply given force on colvar <name>\n\
|
2017-10-14 01:25:02 +08:00
|
|
|
colvar <name> getappliedforce -- return applied force of colvar <name>\n\
|
|
|
|
colvar <name> gettotalforce -- return total force of colvar <name>\n\
|
2015-04-06 23:14:53 +08:00
|
|
|
colvar <name> getconfig -- return config string of colvar <name>\n\
|
2015-10-23 06:08:30 +08:00
|
|
|
colvar <name> cvcflags <fl> -- enable or disable cvcs according to 0/1 flags\n\
|
2018-11-03 05:45:20 +08:00
|
|
|
colvar <name> modifycvcs <str> -- pass new config strings to each CVC\n\
|
2017-03-10 22:16:58 +08:00
|
|
|
colvar <name> get <f> -- get the value of the colvar feature <f>\n\
|
|
|
|
colvar <name> set <f> <val> -- set the value of the colvar feature <f>\n\
|
2015-04-06 23:14:53 +08:00
|
|
|
\n\
|
|
|
|
Accessing biases:\n\
|
|
|
|
bias <name> energy -- return the current energy of bias <name>\n\
|
|
|
|
bias <name> update -- recalculate bias <name>\n\
|
|
|
|
bias <name> delete -- delete bias <name>\n\
|
2017-03-10 22:16:58 +08:00
|
|
|
bias <name> getconfig -- return config string of bias <name>\n\
|
|
|
|
bias <name> get <f> -- get the value of the bias feature <f>\n\
|
|
|
|
bias <name> set <f> <val> -- set the value of the bias feature <f>\n\
|
|
|
|
";
|
2015-04-06 23:14:53 +08:00
|
|
|
|
|
|
|
return buf;
|
|
|
|
}
|