| | #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; |
| | } |
| |
|