aboutsummaryrefslogtreecommitdiff
path: root/tests/bullet/src/BulletMultiThreaded/GpuSoftBodySolvers/OpenCL/OpenCLC10/UpdatePositions.cl
blob: 3155a04e4a8c0b2d023349c5bc639ba06c186817 (plain)
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
MSTRINGIFY(

__kernel void 
updateVelocitiesFromPositionsWithoutVelocitiesKernel( 
	const int numNodes,
	const float isolverdt,
	__global float4 * g_vertexPositions,
	__global float4 * g_vertexPreviousPositions,
	__global int * g_vertexClothIndices,
	__global float * g_clothDampingFactor,
	__global float4 * g_vertexVelocities,
	__global float4 * g_vertexForces GUID_ARG)

{
	int nodeID = get_global_id(0);
	if( nodeID < numNodes )
	{	
		float4 position = g_vertexPositions[nodeID];
		float4 previousPosition = g_vertexPreviousPositions[nodeID];
		float4 velocity = g_vertexVelocities[nodeID];
		int clothIndex = g_vertexClothIndices[nodeID];
		float dampingFactor = g_clothDampingFactor[clothIndex];
		float velocityCoefficient = (1.f - dampingFactor);
		
		float4 difference = position - previousPosition;
				
		velocity = difference*velocityCoefficient*isolverdt;		
		
		g_vertexVelocities[nodeID] = velocity;
		g_vertexForces[nodeID] = (float4)(0.f, 0.f, 0.f, 0.f);								
	}
}

);