customGBGradientChainRule.cc 1.13 KB
Newer Older
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
/**
 * Compute chain rule terms for computed values that depend explicitly on particle coordinates.
 */

KERNEL void computeGradientChainRuleTerms(GLOBAL const real4* RESTRICT posq,
#ifdef SUPPORTS_64_BIT_ATOMICS
    GLOBAL mm_long* RESTRICT forceBuffers
#else
    GLOBAL real4* RESTRICT forceBuffers
#endif
        PARAMETER_ARGUMENTS) {
    INIT_PARAM_DERIVS
    const real scale = RECIP((real) 0x100000000);
    for (int index = GLOBAL_ID; index < NUM_ATOMS; index += GLOBAL_SIZE) {
        real4 pos = posq[index];
#ifdef SUPPORTS_64_BIT_ATOMICS
        real3 force = make_real3(scale*forceBuffers[index], scale*forceBuffers[index+PADDED_NUM_ATOMS], scale*forceBuffers[index+PADDED_NUM_ATOMS*2]);
#else
        real3 force = trimTo3(forceBuffers[index]);
#endif
        COMPUTE_FORCES
#ifdef SUPPORTS_64_BIT_ATOMICS
        forceBuffers[index] = (mm_long) (force.x*0x100000000);
        forceBuffers[index+PADDED_NUM_ATOMS] = (mm_long) (force.y*0x100000000);
        forceBuffers[index+PADDED_NUM_ATOMS*2] = (mm_long) (force.z*0x100000000);
#else
        forceBuffers[index] = make_real4(force.x, force.y, force.z, 0);
#endif
    }
    SAVE_PARAM_DERIVS
}