|
|
#include <iostream> |
|
|
#include <Eigen/Core> |
|
|
|
|
|
using namespace Eigen; |
|
|
|
|
|
#ifndef SCALAR |
|
|
#define SCALAR float |
|
|
#endif |
|
|
|
|
|
#ifndef SIZE |
|
|
#define SIZE 10000 |
|
|
#endif |
|
|
|
|
|
#ifndef REPEAT |
|
|
#define REPEAT 10000 |
|
|
#endif |
|
|
|
|
|
typedef Matrix<SCALAR, Eigen::Dynamic, 1> Vec; |
|
|
|
|
|
using namespace std; |
|
|
|
|
|
SCALAR E_VDW(const Vec &interactions1, const Vec &interactions2) |
|
|
{ |
|
|
return (interactions2.cwise()/interactions1) |
|
|
.cwise().cube() |
|
|
.cwise().square() |
|
|
.cwise().square() |
|
|
.sum(); |
|
|
} |
|
|
|
|
|
int main() |
|
|
{ |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Vec interactions1(SIZE), interactions2(SIZE); |
|
|
|
|
|
SCALAR rab = 1.0; |
|
|
interactions1.setConstant(2.4); |
|
|
interactions2.setConstant(rab); |
|
|
|
|
|
|
|
|
SCALAR energy = 0.0; |
|
|
for (unsigned int i = 0; i<REPEAT; ++i) { |
|
|
energy += E_VDW(interactions1, interactions2); |
|
|
energy *= 1 + 1e-20 * i; |
|
|
} |
|
|
cout << "energy = " << energy << endl; |
|
|
} |
|
|
|