nonbondedExceptions.cl 512 Bytes
Newer Older
Peter Eastman's avatar
Peter Eastman committed
1
float4 exceptionParams = PARAMS[index];
2
3
4
5
real4 delta = pos2-pos1;
real r2 = delta.x*delta.x + delta.y*delta.y + delta.z*delta.z;
real invR = RSQRT(r2);
real sig2 = invR*exceptionParams.y;
Peter Eastman's avatar
Peter Eastman committed
6
sig2 *= sig2;
7
8
9
real sig6 = sig2*sig2*sig2;
real dEdR = exceptionParams.z*(12.0f*sig6-6.0f)*sig6;
real tempEnergy = exceptionParams.z*(sig6-1.0f)*sig6;
Peter Eastman's avatar
Peter Eastman committed
10
11
12
13
14
dEdR += exceptionParams.x*invR;
dEdR *= invR*invR;
tempEnergy += exceptionParams.x*invR;
energy += tempEnergy;
delta.xyz *= dEdR;
15
16
real4 force1 = -delta;
real4 force2 = delta;