-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathmc_demo.cpp
83 lines (61 loc) · 1.8 KB
/
mc_demo.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
#include <pybind11/pybind11.h>
#include <pybind11/stl.h>
#include <string>
#include <iostream>
#include <pybind11/numpy.h>
#include <cmath>
namespace py = pybind11;
double system_energy (py::array_t <double> x_coords,
py::array_t <double> y_coords,
py::array_t <double> z_coords,
double box_length, double cutoff2)
{
py::buffer_info x_coords_info = x_coords.request();
py::buffer_info y_coords_info = y_coords.request();
py::buffer_info z_coords_info = z_coords.request();
int num_particles = x_coords_info.shape[0];
// Maybe add checks to make sure arrays are same size
const double * x_data = static_cast<double *>(x_coords_info.ptr);
const double * y_data = static_cast<double *>(y_coords_info.ptr);
const double * z_data = static_cast<double *>(z_coords_info.ptr);
double i_x, i_y, i_z;
double j_x, j_y, j_z;
double rijx, rijy, rijz, rij2;
double sig_by_r6;
double sig_by_r12;
double lj_pot, e_total;
e_total = 0.0;
for (int i = 0; i < num_particles; i++)
{
i_x = x_data[3*i];
i_y = y_data[3*i];
i_z = z_data[3*i];
for (int j = i + 1; j < num_particles; j++)
{
j_x = x_data[3*j];
j_y = y_data[3*j];
j_z = z_data[3*j];
rijx = j_x - i_x;
rijy = j_y - i_y;
rijz = j_z - i_z;
rijx = rijx - box_length * round(rijx / box_length);
rijy = rijy - box_length * round(rijy / box_length);
rijz = rijz - box_length * round(rijz / box_length);
rij2 = pow(rijx,2) + pow(rijy,2) + pow(rijz,2);
if (rij2 < cutoff2)
{
sig_by_r6 = pow((1 / rij2),3);
sig_by_r12 = pow(sig_by_r6,2);
lj_pot = 4.0 * (sig_by_r12 - sig_by_r6);
e_total += lj_pot;
}
}
}
return e_total;
}
PYBIND11_PLUGIN(mc_demo)
{
py::module m("mc_demo", "Dibyendu's basic module");
m.def("system_energy", &system_energy);
return m.ptr();
}