| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899 |
- /*
- Bullet Continuous Collision Detection and Physics Library
- Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
- This software is provided 'as-is', without any express or implied warranty.
- In no event will the authors be held liable for any damages arising from the use of this software.
- Permission is granted to anyone to use this software for any purpose,
- including commercial applications, and to alter it and redistribute it freely,
- subject to the following restrictions:
- 1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
- 2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
- 3. This notice may not be removed or altered from any source distribution.
- */
- #include "BulletMultiThreaded/GpuSoftBodySolvers/CPU/btSoftBodySolverData.h"
- #include "btSoftBodySolverBuffer_OpenCL.h"
- #ifndef BT_SOFT_BODY_SOLVER_LINK_DATA_OPENCL_H
- #define BT_SOFT_BODY_SOLVER_LINK_DATA_OPENCL_H
- class btSoftBodyLinkDataOpenCL : public btSoftBodyLinkData
- {
- public:
- bool m_onGPU;
- cl_command_queue m_cqCommandQue;
- btOpenCLBuffer<LinkNodePair> m_clLinks;
- btOpenCLBuffer<float> m_clLinkStrength;
- btOpenCLBuffer<float> m_clLinksMassLSC;
- btOpenCLBuffer<float> m_clLinksRestLengthSquared;
- btOpenCLBuffer<Vectormath::Aos::Vector3> m_clLinksCLength;
- btOpenCLBuffer<float> m_clLinksLengthRatio;
- btOpenCLBuffer<float> m_clLinksRestLength;
- btOpenCLBuffer<float> m_clLinksMaterialLinearStiffnessCoefficient;
- struct BatchPair
- {
- int start;
- int length;
- BatchPair() :
- start(0),
- length(0)
- {
- }
- BatchPair( int s, int l ) :
- start( s ),
- length( l )
- {
- }
- };
- /**
- * Link addressing information for each cloth.
- * Allows link locations to be computed independently of data batching.
- */
- btAlignedObjectArray< int > m_linkAddresses;
- /**
- * Start and length values for computation batches over link data.
- */
- btAlignedObjectArray< BatchPair > m_batchStartLengths;
- btSoftBodyLinkDataOpenCL(cl_command_queue queue, cl_context ctx);
- virtual ~btSoftBodyLinkDataOpenCL();
- /** Allocate enough space in all link-related arrays to fit numLinks links */
- virtual void createLinks( int numLinks );
-
- /** Insert the link described into the correct data structures assuming space has already been allocated by a call to createLinks */
- virtual void setLinkAt(
- const LinkDescription &link,
- int linkIndex );
- virtual bool onAccelerator();
- virtual bool moveToAccelerator();
- virtual bool moveFromAccelerator();
- /**
- * Generate (and later update) the batching for the entire link set.
- * This redoes a lot of work because it batches the entire set when each cloth is inserted.
- * In theory we could delay it until just before we need the cloth.
- * It's a one-off overhead, though, so that is a later optimisation.
- */
- void generateBatches();
- };
- #endif // #ifndef BT_SOFT_BODY_SOLVER_LINK_DATA_OPENCL_H
|