Skip to content

Commit

Permalink
Fixed a bug that appears when you try to sum all the elements in a ma…
Browse files Browse the repository at this point in the history
…trix
  • Loading branch information
Gareth Aneurin Tribello authored and Gareth Aneurin Tribello committed Apr 12, 2024
1 parent e7e3445 commit 9b64405
Show file tree
Hide file tree
Showing 12 changed files with 319 additions and 11 deletions.
1 change: 1 addition & 0 deletions regtest/adjmat/rt-matrixsum/Makefile
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
include ../../scripts/test.make
18 changes: 18 additions & 0 deletions regtest/adjmat/rt-matrixsum/colvar.reference
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
#! FIELDS time s
0.000000 0.1870
1.000000 0.1453
2.000000 0.5477
3.000000 -0.6148
4.000000 -0.7783
5.000000 -4.3542
6.000000 2.8148
7.000000 0.1168
8.000000 2.1041
9.000000 1.6821
10.000000 -2.4892
11.000000 -1.7454
12.000000 4.1613
13.000000 4.8999
14.000000 4.9588
15.000000 0.0031
16.000000 0.5671
5 changes: 5 additions & 0 deletions regtest/adjmat/rt-matrixsum/config
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
type=driver
plumed_modules=adjmat
# this is to test a different name
arg="--plumed plumed.dat --ixyz isomers.xyz --dump-forces forces --dump-forces-fmt=%8.4f" # --debug-forces forces.num"
extra_files="../../trajectories/isomers.xyz"
272 changes: 272 additions & 0 deletions regtest/adjmat/rt-matrixsum/forces.reference
Original file line number Diff line number Diff line change
@@ -0,0 +1,272 @@
14
0.0551 0.1000 0.0318
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
14
0.0891 0.0179 0.0383
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
14
0.7019 -0.0828 -0.0714
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
14
-0.5030 -0.6063 0.4945
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
14
-0.7070 -0.5915 0.5203
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
14
-0.0001 0.0006 -4.3546
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
14
0.8508 2.7512 -0.7873
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
14
-0.8875 0.8609 0.1435
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
14
1.2470 1.6980 -0.8409
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
14
1.2582 1.0255 -0.6016
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
14
-1.5972 -0.4468 -0.4453
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
14
-0.7369 0.0000 -1.0085
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
14
3.0714 1.5978 -0.5078
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
14
2.8973 2.0113 -0.0086
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
14
2.8124 2.0181 0.1283
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
14
-0.0714 0.0767 -0.0021
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
14
0.0625 0.0127 0.4918
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 1.0000 1.0000 1.0000
X -1.0000 -1.0000 -1.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
6 changes: 6 additions & 0 deletions regtest/adjmat/rt-matrixsum/plumed.dat
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
d1: DISTANCE COMPONENTS ATOMS1=1,2 ATOMS2=3,4 ATOMS3=5,6
v: VSTACK ARG=d1.x,d1.y,d1.z
vT: TRANSPOSE ARG=v
s: SUM ARG=vT PERIODIC=NO
PRINT ARG=s FILE=colvar FMT=%8.4f
BIASVALUE ARG=s
4 changes: 2 additions & 2 deletions regtest/symfunc/rt-smac/forces.reference
Original file line number Diff line number Diff line change
Expand Up @@ -167398,8 +167398,8 @@ X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X -0.0028 -0.0064 -0.0065
X -0.0006 0.0000 0.0054
X -0.0028 0.0150 -0.0065
X -0.0006 -0.0214 0.0054
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
X 0.0000 0.0000 0.0000
Expand Down
5 changes: 2 additions & 3 deletions src/adjmat/ActionWithMatrix.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,6 @@
along with plumed. If not, see <http://www.gnu.org/licenses/>.
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
#include "ActionWithMatrix.h"
#include "AdjacencyMatrixBase.h"

namespace PLMD {
namespace adjmat {
Expand Down Expand Up @@ -72,7 +71,7 @@ void ActionWithMatrix::finishChainBuild( ActionWithVector* act ) {
else {
next_action_in_chain=am;
// Build the list of things we are going to loop over in runTask
AdjacencyMatrixBase* aa=dynamic_cast<AdjacencyMatrixBase*>(act); if( aa || act->getName()=="VSTACK" ) return ;
if( am->isAdjacencyMatrix() || act->getName()=="VSTACK" ) return ;
plumed_massert( !matrix_to_do_after, "cannot add " + act->getLabel() + " in " + getLabel() + " as have already added " + matrix_to_do_after->getLabel() );
matrix_to_do_after=am; am->matrix_to_do_before=this;
}
Expand Down Expand Up @@ -134,7 +133,7 @@ void ActionWithMatrix::performTask( const unsigned& task_index, MultiValue& myva
void ActionWithMatrix::runTask( const std::string& controller, const unsigned& current, const unsigned colno, MultiValue& myvals ) const {
double outval=0; myvals.setTaskIndex(current); myvals.setSecondTaskIndex( colno );
if( isActive() ) performTask( controller, current, colno, myvals );
bool hasval=false;
bool hasval = !isAdjacencyMatrix();
for(int i=0; i<getNumberOfComponents(); ++i) {
if( fabs(myvals.get( getConstPntrToComponent(i)->getPositionInStream()) )>0 ) { hasval=true; break; }
}
Expand Down
2 changes: 2 additions & 0 deletions src/adjmat/ActionWithMatrix.h
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,8 @@ class ActionWithMatrix : public ActionWithVector {
static void registerKeywords( Keywords& keys );
explicit ActionWithMatrix(const ActionOptions&);
virtual ~ActionWithMatrix();
///
virtual bool isAdjacencyMatrix() const { return false; }
///
void getAllActionLabelsInMatrixChain( std::vector<std::string>& mylabels ) const override ;
/// Get the first matrix in this chain
Expand Down
1 change: 1 addition & 0 deletions src/adjmat/AdjacencyMatrixBase.h
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,7 @@ class AdjacencyMatrixBase : public ActionWithMatrix {
public:
static void registerKeywords( Keywords& keys );
explicit AdjacencyMatrixBase(const ActionOptions&);
bool isAdjacencyMatrix() const override { return true; }
unsigned getNumberOfDerivatives() override ;
unsigned getNumberOfColumns() const override;
void prepare() override;
Expand Down
8 changes: 6 additions & 2 deletions src/adjmat/FunctionOfMatrix.h
Original file line number Diff line number Diff line change
Expand Up @@ -324,12 +324,16 @@ void FunctionOfMatrix<T>::performTask( const std::string& controller, const unsi
}
} else {
unsigned base=0; ind2 = index2;
if( index2>=getConstPntrToComponent(0)->getShape()[0] ) ind2 = index2 - getConstPntrToComponent(0)->getShape()[0];
for(unsigned j=argstart; j<getNumberOfArguments(); ++j) {
if( getPntrToArgument(j)->getRank()!=2 ) continue ;
if( index2>=getPntrToArgument(j)->getShape()[0] ) ind2 = index2 - getPntrToArgument(j)->getShape()[0];
break;
}
for(unsigned j=argstart; j<getNumberOfArguments(); ++j) {
if( getPntrToArgument(j)->getRank()==2 ) {
for(int i=0; i<getNumberOfComponents(); ++i) {
unsigned ostrn=getConstPntrToComponent(i)->getPositionInStream();
unsigned myind = base + getConstPntrToComponent(i)->getShape()[1]*index1 + ind2;
unsigned myind = base + getPntrToArgument(j)->getShape()[1]*index1 + ind2;
myvals.addDerivative( ostrn, myind, derivatives(i,j) );
myvals.updateIndex( ostrn, myind );
}
Expand Down
5 changes: 2 additions & 3 deletions src/adjmat/MatrixTimesMatrix.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,6 @@
along with plumed. If not, see <http://www.gnu.org/licenses/>.
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
#include "ActionWithMatrix.h"
#include "AdjacencyMatrixBase.h"
#include "core/ActionRegister.h"

//+PLUMEDOC MCOLVAR MATRIX_PRODUCT
Expand Down Expand Up @@ -101,8 +100,8 @@ void MatrixTimesMatrix::prepare() {

void MatrixTimesMatrix::getAdditionalTasksRequired( ActionWithVector* action, std::vector<unsigned>& atasks ) {

AdjacencyMatrixBase* adj=dynamic_cast<AdjacencyMatrixBase*>( getPntrToArgument(0)->getPntrToAction() );
if( !adj ) return;
ActionWithMatrix* adj=dynamic_cast<ActionWithMatrix*>( getPntrToArgument(0)->getPntrToAction() );
if( !adj->isAdjacencyMatrix() ) return;
adj->retrieveAtoms(); adj->getAdditionalTasksRequired( action, atasks );
}

Expand Down
Loading

0 comments on commit 9b64405

Please sign in to comment.