"plugins/rpmd/platforms/cuda/src/CudaRpmdKernels.h" did not exist on "a46c15a311bde0c7502e4aa9fc4a6210d93c2fb3"
customCentroidBond.cc 4.05 KB
Newer Older
1
2
3
/**
 * Compute the center of each group.
 */
4
5
6
7
KERNEL void computeGroupCenters(int numParticleGroups, GLOBAL const real4* RESTRICT posq, GLOBAL const int* RESTRICT groupParticles,
        GLOBAL const real* RESTRICT groupWeights, GLOBAL const int* RESTRICT groupOffsets, GLOBAL real4* RESTRICT centerPositions) {
    LOCAL volatile real3 temp[64];
    for (int group = GROUP_ID; group < numParticleGroups; group += NUM_GROUPS) {
8
        // The threads in this block work together to compute the center one group.
9

10
11
        int firstIndex = groupOffsets[group];
        int lastIndex = groupOffsets[group+1];
12
13
        real3 center = make_real3(0);
        for (int index = LOCAL_ID; index < lastIndex-firstIndex; index += LOCAL_SIZE) {
14
15
16
17
18
19
20
            int atom = groupParticles[firstIndex+index];
            real weight = groupWeights[firstIndex+index];
            real4 pos = posq[atom];
            center.x += weight*pos.x;
            center.y += weight*pos.y;
            center.z += weight*pos.z;
        }
21

22
        // Sum the values.
23

24
        int thread = LOCAL_ID;
25
26
27
        temp[thread].x = center.x;
        temp[thread].y = center.y;
        temp[thread].z = center.z;
28
        SYNC_THREADS;
29
30
31
32
33
        if (thread < 32) {
            temp[thread].x += temp[thread+32].x;
            temp[thread].y += temp[thread+32].y;
            temp[thread].z += temp[thread+32].z;
        }
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
        SYNC_WARPS;
        if (thread < 16) {
            temp[thread].x += temp[thread+16].x;
            temp[thread].y += temp[thread+16].y;
            temp[thread].z += temp[thread+16].z;
        }
        SYNC_WARPS;
        if (thread < 8) {
            temp[thread].x += temp[thread+8].x;
            temp[thread].y += temp[thread+8].y;
            temp[thread].z += temp[thread+8].z;
        }
        SYNC_WARPS;
        if (thread < 4) {
            temp[thread].x += temp[thread+4].x;
            temp[thread].y += temp[thread+4].y;
            temp[thread].z += temp[thread+4].z;
        }
        SYNC_WARPS;
        if (thread < 2) {
            temp[thread].x += temp[thread+2].x;
            temp[thread].y += temp[thread+2].y;
            temp[thread].z += temp[thread+2].z;
        }
        SYNC_WARPS;
59
        if (thread == 0)
60
            centerPositions[group] = make_real4(temp[0].x+temp[1].x, temp[0].y+temp[1].y, temp[0].z+temp[1].z, 0);
61
62
63
64
65
66
    }
}

/**
 * Compute the forces on groups based on the bonds.
 */
67
68
KERNEL void computeGroupForces(int numParticleGroups, GLOBAL mm_ulong* RESTRICT groupForce, GLOBAL mixed* RESTRICT energyBuffer, GLOBAL const real4* RESTRICT centerPositions,
        GLOBAL const int* RESTRICT bondGroups, real4 periodicBoxSize, real4 invPeriodicBoxSize, real4 periodicBoxVecX, real4 periodicBoxVecY, real4 periodicBoxVecZ
69
        EXTRA_ARGS) {
70
    mixed energy = 0;
71
    INIT_PARAM_DERIVS
72
    for (int index = GLOBAL_ID; index < NUM_BONDS; index += GLOBAL_SIZE) {
73
74
        COMPUTE_FORCE
    }
75
    energyBuffer[GLOBAL_ID] += energy;
76
    SAVE_PARAM_DERIVS
77
78
79
80
81
}

/**
 * Apply the forces from the group centers to the individual atoms.
 */
82
83
84
85
86
87
KERNEL void applyForcesToAtoms(int numParticleGroups, GLOBAL const int* RESTRICT groupParticles, GLOBAL const real* RESTRICT groupWeights, GLOBAL const int* RESTRICT groupOffsets,
        GLOBAL const mm_long* RESTRICT groupForce, GLOBAL mm_ulong* RESTRICT atomForce) {
    for (int group = GROUP_ID; group < numParticleGroups; group += NUM_GROUPS) {
        mm_long fx = groupForce[group];
        mm_long fy = groupForce[group+numParticleGroups];
        mm_long fz = groupForce[group+numParticleGroups*2];
88
89
        int firstIndex = groupOffsets[group];
        int lastIndex = groupOffsets[group+1];
90
        for (int index = LOCAL_ID; index < lastIndex-firstIndex; index += LOCAL_SIZE) {
91
92
            int atom = groupParticles[firstIndex+index];
            real weight = groupWeights[firstIndex+index];
93
94
95
            ATOMIC_ADD(&atomForce[atom], (mm_ulong) ((mm_long) (fx*weight)));
            ATOMIC_ADD(&atomForce[atom+PADDED_NUM_ATOMS], (mm_ulong) ((mm_long) (fy*weight)));
            ATOMIC_ADD(&atomForce[atom+2*PADDED_NUM_ATOMS], (mm_ulong) ((mm_long) (fz*weight)));
96
97
98
        }
    }
}