2
0

btSoftBodyInternals.h 61 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108
  1. /*
  2. Bullet Continuous Collision Detection and Physics Library
  3. Copyright (c) 2003-2006 Erwin Coumans http://continuousphysics.com/Bullet/
  4. This software is provided 'as-is', without any express or implied warranty.
  5. In no event will the authors be held liable for any damages arising from the use of this software.
  6. Permission is granted to anyone to use this software for any purpose,
  7. including commercial applications, and to alter it and redistribute it freely,
  8. subject to the following restrictions:
  9. 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.
  10. 2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
  11. 3. This notice may not be removed or altered from any source distribution.
  12. */
  13. ///btSoftBody implementation by Nathanael Presson
  14. #ifndef _BT_SOFT_BODY_INTERNALS_H
  15. #define _BT_SOFT_BODY_INTERNALS_H
  16. #include "btSoftBody.h"
  17. #include "LinearMath/btQuickprof.h"
  18. #include "LinearMath/btPolarDecomposition.h"
  19. #include "BulletCollision/BroadphaseCollision/btBroadphaseInterface.h"
  20. #include "BulletCollision/CollisionDispatch/btCollisionDispatcher.h"
  21. #include "BulletCollision/CollisionShapes/btConvexInternalShape.h"
  22. #include "BulletCollision/NarrowPhaseCollision/btGjkEpa2.h"
  23. #include "BulletDynamics/Featherstone/btMultiBodyLinkCollider.h"
  24. #include "BulletDynamics/Featherstone/btMultiBodyConstraint.h"
  25. #include <string.h> //for memset
  26. #include <cmath>
  27. #include "poly34.h"
  28. // Given a multibody link, a contact point and a contact direction, fill in the jacobian data needed to calculate the velocity change given an impulse in the contact direction
  29. static SIMD_FORCE_INLINE void findJacobian(const btMultiBodyLinkCollider* multibodyLinkCol,
  30. btMultiBodyJacobianData& jacobianData,
  31. const btVector3& contact_point,
  32. const btVector3& dir)
  33. {
  34. const int ndof = multibodyLinkCol->m_multiBody->getNumDofs() + 6;
  35. jacobianData.m_jacobians.resize(ndof);
  36. jacobianData.m_deltaVelocitiesUnitImpulse.resize(ndof);
  37. btScalar* jac = &jacobianData.m_jacobians[0];
  38. multibodyLinkCol->m_multiBody->fillContactJacobianMultiDof(multibodyLinkCol->m_link, contact_point, dir, jac, jacobianData.scratch_r, jacobianData.scratch_v, jacobianData.scratch_m);
  39. multibodyLinkCol->m_multiBody->calcAccelerationDeltasMultiDof(&jacobianData.m_jacobians[0], &jacobianData.m_deltaVelocitiesUnitImpulse[0], jacobianData.scratch_r, jacobianData.scratch_v);
  40. }
  41. static SIMD_FORCE_INLINE btVector3 generateUnitOrthogonalVector(const btVector3& u)
  42. {
  43. btScalar ux = u.getX();
  44. btScalar uy = u.getY();
  45. btScalar uz = u.getZ();
  46. btScalar ax = std::abs(ux);
  47. btScalar ay = std::abs(uy);
  48. btScalar az = std::abs(uz);
  49. btVector3 v;
  50. if (ax <= ay && ax <= az)
  51. v = btVector3(0, -uz, uy);
  52. else if (ay <= ax && ay <= az)
  53. v = btVector3(-uz, 0, ux);
  54. else
  55. v = btVector3(-uy, ux, 0);
  56. v.normalize();
  57. return v;
  58. }
  59. static SIMD_FORCE_INLINE bool proximityTest(const btVector3& x1, const btVector3& x2, const btVector3& x3, const btVector3& x4, const btVector3& normal, const btScalar& mrg, btVector3& bary)
  60. {
  61. btVector3 x43 = x4 - x3;
  62. if (std::abs(x43.dot(normal)) > mrg)
  63. return false;
  64. btVector3 x13 = x1 - x3;
  65. btVector3 x23 = x2 - x3;
  66. btScalar a11 = x13.length2();
  67. btScalar a22 = x23.length2();
  68. btScalar a12 = x13.dot(x23);
  69. btScalar b1 = x13.dot(x43);
  70. btScalar b2 = x23.dot(x43);
  71. btScalar det = a11 * a22 - a12 * a12;
  72. if (det < SIMD_EPSILON)
  73. return false;
  74. btScalar w1 = (b1 * a22 - b2 * a12) / det;
  75. btScalar w2 = (b2 * a11 - b1 * a12) / det;
  76. btScalar w3 = 1 - w1 - w2;
  77. btScalar delta = mrg / std::sqrt(0.5 * std::abs(x13.cross(x23).safeNorm()));
  78. bary = btVector3(w1, w2, w3);
  79. for (int i = 0; i < 3; ++i)
  80. {
  81. if (bary[i] < -delta || bary[i] > 1 + delta)
  82. return false;
  83. }
  84. return true;
  85. }
  86. static const int KDOP_COUNT = 13;
  87. static btVector3 dop[KDOP_COUNT] = {btVector3(1, 0, 0),
  88. btVector3(0, 1, 0),
  89. btVector3(0, 0, 1),
  90. btVector3(1, 1, 0),
  91. btVector3(1, 0, 1),
  92. btVector3(0, 1, 1),
  93. btVector3(1, -1, 0),
  94. btVector3(1, 0, -1),
  95. btVector3(0, 1, -1),
  96. btVector3(1, 1, 1),
  97. btVector3(1, -1, 1),
  98. btVector3(1, 1, -1),
  99. btVector3(1, -1, -1)};
  100. static inline int getSign(const btVector3& n, const btVector3& x)
  101. {
  102. btScalar d = n.dot(x);
  103. if (d > SIMD_EPSILON)
  104. return 1;
  105. if (d < -SIMD_EPSILON)
  106. return -1;
  107. return 0;
  108. }
  109. static SIMD_FORCE_INLINE bool hasSeparatingPlane(const btSoftBody::Face* face, const btSoftBody::Node* node, const btScalar& dt)
  110. {
  111. btVector3 hex[6] = {face->m_n[0]->m_x - node->m_x,
  112. face->m_n[1]->m_x - node->m_x,
  113. face->m_n[2]->m_x - node->m_x,
  114. face->m_n[0]->m_x + dt * face->m_n[0]->m_v - node->m_x,
  115. face->m_n[1]->m_x + dt * face->m_n[1]->m_v - node->m_x,
  116. face->m_n[2]->m_x + dt * face->m_n[2]->m_v - node->m_x};
  117. btVector3 segment = dt * node->m_v;
  118. for (int i = 0; i < KDOP_COUNT; ++i)
  119. {
  120. int s = getSign(dop[i], segment);
  121. int j = 0;
  122. for (; j < 6; ++j)
  123. {
  124. if (getSign(dop[i], hex[j]) == s)
  125. break;
  126. }
  127. if (j == 6)
  128. return true;
  129. }
  130. return false;
  131. }
  132. static SIMD_FORCE_INLINE bool nearZero(const btScalar& a)
  133. {
  134. return (a > -SAFE_EPSILON && a < SAFE_EPSILON);
  135. }
  136. static SIMD_FORCE_INLINE bool sameSign(const btScalar& a, const btScalar& b)
  137. {
  138. return (nearZero(a) || nearZero(b) || (a > SAFE_EPSILON && b > SAFE_EPSILON) || (a < -SAFE_EPSILON && b < -SAFE_EPSILON));
  139. }
  140. static SIMD_FORCE_INLINE bool diffSign(const btScalar& a, const btScalar& b)
  141. {
  142. return !sameSign(a, b);
  143. }
  144. inline btScalar evaluateBezier2(const btScalar& p0, const btScalar& p1, const btScalar& p2, const btScalar& t, const btScalar& s)
  145. {
  146. btScalar s2 = s * s;
  147. btScalar t2 = t * t;
  148. return p0 * s2 + p1 * btScalar(2.0) * s * t + p2 * t2;
  149. }
  150. inline btScalar evaluateBezier(const btScalar& p0, const btScalar& p1, const btScalar& p2, const btScalar& p3, const btScalar& t, const btScalar& s)
  151. {
  152. btScalar s2 = s * s;
  153. btScalar s3 = s2 * s;
  154. btScalar t2 = t * t;
  155. btScalar t3 = t2 * t;
  156. return p0 * s3 + p1 * btScalar(3.0) * s2 * t + p2 * btScalar(3.0) * s * t2 + p3 * t3;
  157. }
  158. static SIMD_FORCE_INLINE bool getSigns(bool type_c, const btScalar& k0, const btScalar& k1, const btScalar& k2, const btScalar& k3, const btScalar& t0, const btScalar& t1, btScalar& lt0, btScalar& lt1)
  159. {
  160. if (sameSign(t0, t1))
  161. {
  162. lt0 = t0;
  163. lt1 = t0;
  164. return true;
  165. }
  166. if (type_c || diffSign(k0, k3))
  167. {
  168. btScalar ft = evaluateBezier(k0, k1, k2, k3, t0, -t1);
  169. if (t0 < -0)
  170. ft = -ft;
  171. if (sameSign(ft, k0))
  172. {
  173. lt0 = t1;
  174. lt1 = t1;
  175. }
  176. else
  177. {
  178. lt0 = t0;
  179. lt1 = t0;
  180. }
  181. return true;
  182. }
  183. if (!type_c)
  184. {
  185. btScalar ft = evaluateBezier(k0, k1, k2, k3, t0, -t1);
  186. if (t0 < -0)
  187. ft = -ft;
  188. if (diffSign(ft, k0))
  189. {
  190. lt0 = t0;
  191. lt1 = t1;
  192. return true;
  193. }
  194. btScalar fk = evaluateBezier2(k1 - k0, k2 - k1, k3 - k2, t0, -t1);
  195. if (sameSign(fk, k1 - k0))
  196. lt0 = lt1 = t1;
  197. else
  198. lt0 = lt1 = t0;
  199. return true;
  200. }
  201. return false;
  202. }
  203. static SIMD_FORCE_INLINE void getBernsteinCoeff(const btSoftBody::Face* face, const btSoftBody::Node* node, const btScalar& dt, btScalar& k0, btScalar& k1, btScalar& k2, btScalar& k3)
  204. {
  205. const btVector3& n0 = face->m_n0;
  206. const btVector3& n1 = face->m_n1;
  207. btVector3 n_hat = n0 + n1 - face->m_vn;
  208. btVector3 p0ma0 = node->m_x - face->m_n[0]->m_x;
  209. btVector3 p1ma1 = node->m_q - face->m_n[0]->m_q;
  210. k0 = (p0ma0).dot(n0) * 3.0;
  211. k1 = (p0ma0).dot(n_hat) + (p1ma1).dot(n0);
  212. k2 = (p1ma1).dot(n_hat) + (p0ma0).dot(n1);
  213. k3 = (p1ma1).dot(n1) * 3.0;
  214. }
  215. static SIMD_FORCE_INLINE void polyDecomposition(const btScalar& k0, const btScalar& k1, const btScalar& k2, const btScalar& k3, const btScalar& j0, const btScalar& j1, const btScalar& j2, btScalar& u0, btScalar& u1, btScalar& v0, btScalar& v1)
  216. {
  217. btScalar denom = 4.0 * (j1 - j2) * (j1 - j0) + (j2 - j0) * (j2 - j0);
  218. u0 = (2.0 * (j1 - j2) * (3.0 * k1 - 2.0 * k0 - k3) - (j0 - j2) * (3.0 * k2 - 2.0 * k3 - k0)) / denom;
  219. u1 = (2.0 * (j1 - j0) * (3.0 * k2 - 2.0 * k3 - k0) - (j2 - j0) * (3.0 * k1 - 2.0 * k0 - k3)) / denom;
  220. v0 = k0 - u0 * j0;
  221. v1 = k3 - u1 * j2;
  222. }
  223. static SIMD_FORCE_INLINE bool rootFindingLemma(const btScalar& k0, const btScalar& k1, const btScalar& k2, const btScalar& k3)
  224. {
  225. btScalar u0, u1, v0, v1;
  226. btScalar j0 = 3.0 * (k1 - k0);
  227. btScalar j1 = 3.0 * (k2 - k1);
  228. btScalar j2 = 3.0 * (k3 - k2);
  229. polyDecomposition(k0, k1, k2, k3, j0, j1, j2, u0, u1, v0, v1);
  230. if (sameSign(v0, v1))
  231. {
  232. btScalar Ypa = j0 * (1.0 - v0) * (1.0 - v0) + 2.0 * j1 * v0 * (1.0 - v0) + j2 * v0 * v0; // Y'(v0)
  233. if (sameSign(Ypa, j0))
  234. {
  235. return (diffSign(k0, v1));
  236. }
  237. }
  238. return diffSign(k0, v0);
  239. }
  240. static SIMD_FORCE_INLINE void getJs(const btScalar& k0, const btScalar& k1, const btScalar& k2, const btScalar& k3, const btSoftBody::Node* a, const btSoftBody::Node* b, const btSoftBody::Node* c, const btSoftBody::Node* p, const btScalar& dt, btScalar& j0, btScalar& j1, btScalar& j2)
  241. {
  242. const btVector3& a0 = a->m_x;
  243. const btVector3& b0 = b->m_x;
  244. const btVector3& c0 = c->m_x;
  245. const btVector3& va = a->m_v;
  246. const btVector3& vb = b->m_v;
  247. const btVector3& vc = c->m_v;
  248. const btVector3 a1 = a0 + dt * va;
  249. const btVector3 b1 = b0 + dt * vb;
  250. const btVector3 c1 = c0 + dt * vc;
  251. btVector3 n0 = (b0 - a0).cross(c0 - a0);
  252. btVector3 n1 = (b1 - a1).cross(c1 - a1);
  253. btVector3 n_hat = n0 + n1 - dt * dt * (vb - va).cross(vc - va);
  254. const btVector3& p0 = p->m_x;
  255. const btVector3& vp = p->m_v;
  256. btVector3 p1 = p0 + dt * vp;
  257. btVector3 m0 = (b0 - p0).cross(c0 - p0);
  258. btVector3 m1 = (b1 - p1).cross(c1 - p1);
  259. btVector3 m_hat = m0 + m1 - dt * dt * (vb - vp).cross(vc - vp);
  260. btScalar l0 = m0.dot(n0);
  261. btScalar l1 = 0.25 * (m0.dot(n_hat) + m_hat.dot(n0));
  262. btScalar l2 = btScalar(1) / btScalar(6) * (m0.dot(n1) + m_hat.dot(n_hat) + m1.dot(n0));
  263. btScalar l3 = 0.25 * (m_hat.dot(n1) + m1.dot(n_hat));
  264. btScalar l4 = m1.dot(n1);
  265. btScalar k1p = 0.25 * k0 + 0.75 * k1;
  266. btScalar k2p = 0.5 * k1 + 0.5 * k2;
  267. btScalar k3p = 0.75 * k2 + 0.25 * k3;
  268. btScalar s0 = (l1 * k0 - l0 * k1p) * 4.0;
  269. btScalar s1 = (l2 * k0 - l0 * k2p) * 2.0;
  270. btScalar s2 = (l3 * k0 - l0 * k3p) * btScalar(4) / btScalar(3);
  271. btScalar s3 = l4 * k0 - l0 * k3;
  272. j0 = (s1 * k0 - s0 * k1) * 3.0;
  273. j1 = (s2 * k0 - s0 * k2) * 1.5;
  274. j2 = (s3 * k0 - s0 * k3);
  275. }
  276. static SIMD_FORCE_INLINE bool signDetermination1Internal(const btScalar& k0, const btScalar& k1, const btScalar& k2, const btScalar& k3, const btScalar& u0, const btScalar& u1, const btScalar& v0, const btScalar& v1)
  277. {
  278. btScalar Yu0 = k0 * (1.0 - u0) * (1.0 - u0) * (1.0 - u0) + 3.0 * k1 * u0 * (1.0 - u0) * (1.0 - u0) + 3.0 * k2 * u0 * u0 * (1.0 - u0) + k3 * u0 * u0 * u0; // Y(u0)
  279. btScalar Yv0 = k0 * (1.0 - v0) * (1.0 - v0) * (1.0 - v0) + 3.0 * k1 * v0 * (1.0 - v0) * (1.0 - v0) + 3.0 * k2 * v0 * v0 * (1.0 - v0) + k3 * v0 * v0 * v0; // Y(v0)
  280. btScalar sign_Ytp = (u0 > u1) ? Yu0 : -Yu0;
  281. btScalar L = sameSign(sign_Ytp, k0) ? u1 : u0;
  282. sign_Ytp = (v0 > v1) ? Yv0 : -Yv0;
  283. btScalar K = (sameSign(sign_Ytp, k0)) ? v1 : v0;
  284. return diffSign(L, K);
  285. }
  286. static SIMD_FORCE_INLINE bool signDetermination2Internal(const btScalar& k0, const btScalar& k1, const btScalar& k2, const btScalar& k3, const btScalar& j0, const btScalar& j1, const btScalar& j2, const btScalar& u0, const btScalar& u1, const btScalar& v0, const btScalar& v1)
  287. {
  288. btScalar Yu0 = k0 * (1.0 - u0) * (1.0 - u0) * (1.0 - u0) + 3.0 * k1 * u0 * (1.0 - u0) * (1.0 - u0) + 3.0 * k2 * u0 * u0 * (1.0 - u0) + k3 * u0 * u0 * u0; // Y(u0)
  289. btScalar sign_Ytp = (u0 > u1) ? Yu0 : -Yu0, L1, L2;
  290. if (diffSign(sign_Ytp, k0))
  291. {
  292. L1 = u0;
  293. L2 = u1;
  294. }
  295. else
  296. {
  297. btScalar Yp_u0 = j0 * (1.0 - u0) * (1.0 - u0) + 2.0 * j1 * (1.0 - u0) * u0 + j2 * u0 * u0;
  298. if (sameSign(Yp_u0, j0))
  299. {
  300. L1 = u1;
  301. L2 = u1;
  302. }
  303. else
  304. {
  305. L1 = u0;
  306. L2 = u0;
  307. }
  308. }
  309. btScalar Yv0 = k0 * (1.0 - v0) * (1.0 - v0) * (1.0 - v0) + 3.0 * k1 * v0 * (1.0 - v0) * (1.0 - v0) + 3.0 * k2 * v0 * v0 * (1.0 - v0) + k3 * v0 * v0 * v0; // Y(uv0)
  310. sign_Ytp = (v0 > v1) ? Yv0 : -Yv0;
  311. btScalar K1, K2;
  312. if (diffSign(sign_Ytp, k0))
  313. {
  314. K1 = v0;
  315. K2 = v1;
  316. }
  317. else
  318. {
  319. btScalar Yp_v0 = j0 * (1.0 - v0) * (1.0 - v0) + 2.0 * j1 * (1.0 - v0) * v0 + j2 * v0 * v0;
  320. if (sameSign(Yp_v0, j0))
  321. {
  322. K1 = v1;
  323. K2 = v1;
  324. }
  325. else
  326. {
  327. K1 = v0;
  328. K2 = v0;
  329. }
  330. }
  331. return (diffSign(K1, L1) || diffSign(L2, K2));
  332. }
  333. static SIMD_FORCE_INLINE bool signDetermination1(const btScalar& k0, const btScalar& k1, const btScalar& k2, const btScalar& k3, const btSoftBody::Face* face, const btSoftBody::Node* node, const btScalar& dt)
  334. {
  335. btScalar j0, j1, j2, u0, u1, v0, v1;
  336. // p1
  337. getJs(k0, k1, k2, k3, face->m_n[0], face->m_n[1], face->m_n[2], node, dt, j0, j1, j2);
  338. if (nearZero(j0 + j2 - j1 * 2.0))
  339. {
  340. btScalar lt0, lt1;
  341. getSigns(true, k0, k1, k2, k3, j0, j2, lt0, lt1);
  342. if (lt0 < -SAFE_EPSILON)
  343. return false;
  344. }
  345. else
  346. {
  347. polyDecomposition(k0, k1, k2, k3, j0, j1, j2, u0, u1, v0, v1);
  348. if (!signDetermination1Internal(k0, k1, k2, k3, u0, u1, v0, v1))
  349. return false;
  350. }
  351. // p2
  352. getJs(k0, k1, k2, k3, face->m_n[1], face->m_n[2], face->m_n[0], node, dt, j0, j1, j2);
  353. if (nearZero(j0 + j2 - j1 * 2.0))
  354. {
  355. btScalar lt0, lt1;
  356. getSigns(true, k0, k1, k2, k3, j0, j2, lt0, lt1);
  357. if (lt0 < -SAFE_EPSILON)
  358. return false;
  359. }
  360. else
  361. {
  362. polyDecomposition(k0, k1, k2, k3, j0, j1, j2, u0, u1, v0, v1);
  363. if (!signDetermination1Internal(k0, k1, k2, k3, u0, u1, v0, v1))
  364. return false;
  365. }
  366. // p3
  367. getJs(k0, k1, k2, k3, face->m_n[2], face->m_n[0], face->m_n[1], node, dt, j0, j1, j2);
  368. if (nearZero(j0 + j2 - j1 * 2.0))
  369. {
  370. btScalar lt0, lt1;
  371. getSigns(true, k0, k1, k2, k3, j0, j2, lt0, lt1);
  372. if (lt0 < -SAFE_EPSILON)
  373. return false;
  374. }
  375. else
  376. {
  377. polyDecomposition(k0, k1, k2, k3, j0, j1, j2, u0, u1, v0, v1);
  378. if (!signDetermination1Internal(k0, k1, k2, k3, u0, u1, v0, v1))
  379. return false;
  380. }
  381. return true;
  382. }
  383. static SIMD_FORCE_INLINE bool signDetermination2(const btScalar& k0, const btScalar& k1, const btScalar& k2, const btScalar& k3, const btSoftBody::Face* face, const btSoftBody::Node* node, const btScalar& dt)
  384. {
  385. btScalar j0, j1, j2, u0, u1, v0, v1;
  386. // p1
  387. getJs(k0, k1, k2, k3, face->m_n[0], face->m_n[1], face->m_n[2], node, dt, j0, j1, j2);
  388. if (nearZero(j0 + j2 - j1 * 2.0))
  389. {
  390. btScalar lt0, lt1;
  391. bool bt0 = true, bt1 = true;
  392. getSigns(false, k0, k1, k2, k3, j0, j2, lt0, lt1);
  393. if (lt0 < -SAFE_EPSILON)
  394. bt0 = false;
  395. if (lt1 < -SAFE_EPSILON)
  396. bt1 = false;
  397. if (!bt0 && !bt1)
  398. return false;
  399. }
  400. else
  401. {
  402. polyDecomposition(k0, k1, k2, k3, j0, j1, j2, u0, u1, v0, v1);
  403. if (!signDetermination2Internal(k0, k1, k2, k3, j0, j1, j2, u0, u1, v0, v1))
  404. return false;
  405. }
  406. // p2
  407. getJs(k0, k1, k2, k3, face->m_n[1], face->m_n[2], face->m_n[0], node, dt, j0, j1, j2);
  408. if (nearZero(j0 + j2 - j1 * 2.0))
  409. {
  410. btScalar lt0, lt1;
  411. bool bt0 = true, bt1 = true;
  412. getSigns(false, k0, k1, k2, k3, j0, j2, lt0, lt1);
  413. if (lt0 < -SAFE_EPSILON)
  414. bt0 = false;
  415. if (lt1 < -SAFE_EPSILON)
  416. bt1 = false;
  417. if (!bt0 && !bt1)
  418. return false;
  419. }
  420. else
  421. {
  422. polyDecomposition(k0, k1, k2, k3, j0, j1, j2, u0, u1, v0, v1);
  423. if (!signDetermination2Internal(k0, k1, k2, k3, j0, j1, j2, u0, u1, v0, v1))
  424. return false;
  425. }
  426. // p3
  427. getJs(k0, k1, k2, k3, face->m_n[2], face->m_n[0], face->m_n[1], node, dt, j0, j1, j2);
  428. if (nearZero(j0 + j2 - j1 * 2.0))
  429. {
  430. btScalar lt0, lt1;
  431. bool bt0 = true, bt1 = true;
  432. getSigns(false, k0, k1, k2, k3, j0, j2, lt0, lt1);
  433. if (lt0 < -SAFE_EPSILON)
  434. bt0 = false;
  435. if (lt1 < -SAFE_EPSILON)
  436. bt1 = false;
  437. if (!bt0 && !bt1)
  438. return false;
  439. }
  440. else
  441. {
  442. polyDecomposition(k0, k1, k2, k3, j0, j1, j2, u0, u1, v0, v1);
  443. if (!signDetermination2Internal(k0, k1, k2, k3, j0, j1, j2, u0, u1, v0, v1))
  444. return false;
  445. }
  446. return true;
  447. }
  448. static SIMD_FORCE_INLINE bool coplanarAndInsideTest(const btScalar& k0, const btScalar& k1, const btScalar& k2, const btScalar& k3, const btSoftBody::Face* face, const btSoftBody::Node* node, const btScalar& dt)
  449. {
  450. // Coplanar test
  451. if (diffSign(k1 - k0, k3 - k2))
  452. {
  453. // Case b:
  454. if (sameSign(k0, k3) && !rootFindingLemma(k0, k1, k2, k3))
  455. return false;
  456. // inside test
  457. return signDetermination2(k0, k1, k2, k3, face, node, dt);
  458. }
  459. else
  460. {
  461. // Case c:
  462. if (sameSign(k0, k3))
  463. return false;
  464. // inside test
  465. return signDetermination1(k0, k1, k2, k3, face, node, dt);
  466. }
  467. return false;
  468. }
  469. static SIMD_FORCE_INLINE bool conservativeCulling(const btScalar& k0, const btScalar& k1, const btScalar& k2, const btScalar& k3, const btScalar& mrg)
  470. {
  471. if (k0 > mrg && k1 > mrg && k2 > mrg && k3 > mrg)
  472. return true;
  473. if (k0 < -mrg && k1 < -mrg && k2 < -mrg && k3 < -mrg)
  474. return true;
  475. return false;
  476. }
  477. static SIMD_FORCE_INLINE bool bernsteinVFTest(const btScalar& k0, const btScalar& k1, const btScalar& k2, const btScalar& k3, const btScalar& mrg, const btSoftBody::Face* face, const btSoftBody::Node* node, const btScalar& dt)
  478. {
  479. if (conservativeCulling(k0, k1, k2, k3, mrg))
  480. return false;
  481. return coplanarAndInsideTest(k0, k1, k2, k3, face, node, dt);
  482. }
  483. static SIMD_FORCE_INLINE void deCasteljau(const btScalar& k0, const btScalar& k1, const btScalar& k2, const btScalar& k3, const btScalar& t0, btScalar& k10, btScalar& k20, btScalar& k30, btScalar& k21, btScalar& k12)
  484. {
  485. k10 = k0 * (1.0 - t0) + k1 * t0;
  486. btScalar k11 = k1 * (1.0 - t0) + k2 * t0;
  487. k12 = k2 * (1.0 - t0) + k3 * t0;
  488. k20 = k10 * (1.0 - t0) + k11 * t0;
  489. k21 = k11 * (1.0 - t0) + k12 * t0;
  490. k30 = k20 * (1.0 - t0) + k21 * t0;
  491. }
  492. static SIMD_FORCE_INLINE bool bernsteinVFTest(const btSoftBody::Face* face, const btSoftBody::Node* node, const btScalar& dt, const btScalar& mrg)
  493. {
  494. btScalar k0, k1, k2, k3;
  495. getBernsteinCoeff(face, node, dt, k0, k1, k2, k3);
  496. if (conservativeCulling(k0, k1, k2, k3, mrg))
  497. return false;
  498. return true;
  499. if (diffSign(k2 - 2.0 * k1 + k0, k3 - 2.0 * k2 + k1))
  500. {
  501. btScalar k10, k20, k30, k21, k12;
  502. btScalar t0 = (k2 - 2.0 * k1 + k0) / (k0 - 3.0 * k1 + 3.0 * k2 - k3);
  503. deCasteljau(k0, k1, k2, k3, t0, k10, k20, k30, k21, k12);
  504. return bernsteinVFTest(k0, k10, k20, k30, mrg, face, node, dt) || bernsteinVFTest(k30, k21, k12, k3, mrg, face, node, dt);
  505. }
  506. return coplanarAndInsideTest(k0, k1, k2, k3, face, node, dt);
  507. }
  508. static SIMD_FORCE_INLINE bool continuousCollisionDetection(const btSoftBody::Face* face, const btSoftBody::Node* node, const btScalar& dt, const btScalar& mrg, btVector3& bary)
  509. {
  510. if (hasSeparatingPlane(face, node, dt))
  511. return false;
  512. btVector3 x21 = face->m_n[1]->m_x - face->m_n[0]->m_x;
  513. btVector3 x31 = face->m_n[2]->m_x - face->m_n[0]->m_x;
  514. btVector3 x41 = node->m_x - face->m_n[0]->m_x;
  515. btVector3 v21 = face->m_n[1]->m_v - face->m_n[0]->m_v;
  516. btVector3 v31 = face->m_n[2]->m_v - face->m_n[0]->m_v;
  517. btVector3 v41 = node->m_v - face->m_n[0]->m_v;
  518. btVector3 a = x21.cross(x31);
  519. btVector3 b = x21.cross(v31) + v21.cross(x31);
  520. btVector3 c = v21.cross(v31);
  521. btVector3 d = x41;
  522. btVector3 e = v41;
  523. btScalar a0 = a.dot(d);
  524. btScalar a1 = a.dot(e) + b.dot(d);
  525. btScalar a2 = c.dot(d) + b.dot(e);
  526. btScalar a3 = c.dot(e);
  527. btScalar eps = SAFE_EPSILON;
  528. int num_roots = 0;
  529. btScalar roots[3];
  530. if (std::abs(a3) < eps)
  531. {
  532. // cubic term is zero
  533. if (std::abs(a2) < eps)
  534. {
  535. if (std::abs(a1) < eps)
  536. {
  537. if (std::abs(a0) < eps)
  538. {
  539. num_roots = 2;
  540. roots[0] = 0;
  541. roots[1] = dt;
  542. }
  543. }
  544. else
  545. {
  546. num_roots = 1;
  547. roots[0] = -a0 / a1;
  548. }
  549. }
  550. else
  551. {
  552. num_roots = SolveP2(roots, a1 / a2, a0 / a2);
  553. }
  554. }
  555. else
  556. {
  557. num_roots = SolveP3(roots, a2 / a3, a1 / a3, a0 / a3);
  558. }
  559. // std::sort(roots, roots+num_roots);
  560. if (num_roots > 1)
  561. {
  562. if (roots[0] > roots[1])
  563. btSwap(roots[0], roots[1]);
  564. }
  565. if (num_roots > 2)
  566. {
  567. if (roots[0] > roots[2])
  568. btSwap(roots[0], roots[2]);
  569. if (roots[1] > roots[2])
  570. btSwap(roots[1], roots[2]);
  571. }
  572. for (int r = 0; r < num_roots; ++r)
  573. {
  574. double root = roots[r];
  575. if (root <= 0)
  576. continue;
  577. if (root > dt + SIMD_EPSILON)
  578. return false;
  579. btVector3 x1 = face->m_n[0]->m_x + root * face->m_n[0]->m_v;
  580. btVector3 x2 = face->m_n[1]->m_x + root * face->m_n[1]->m_v;
  581. btVector3 x3 = face->m_n[2]->m_x + root * face->m_n[2]->m_v;
  582. btVector3 x4 = node->m_x + root * node->m_v;
  583. btVector3 normal = (x2 - x1).cross(x3 - x1);
  584. normal.safeNormalize();
  585. if (proximityTest(x1, x2, x3, x4, normal, mrg, bary))
  586. return true;
  587. }
  588. return false;
  589. }
  590. static SIMD_FORCE_INLINE bool bernsteinCCD(const btSoftBody::Face* face, const btSoftBody::Node* node, const btScalar& dt, const btScalar& mrg, btVector3& bary)
  591. {
  592. if (!bernsteinVFTest(face, node, dt, mrg))
  593. return false;
  594. if (!continuousCollisionDetection(face, node, dt, 1e-6, bary))
  595. return false;
  596. return true;
  597. }
  598. //
  599. // btSymMatrix
  600. //
  601. template <typename T>
  602. struct btSymMatrix
  603. {
  604. btSymMatrix() : dim(0) {}
  605. btSymMatrix(int n, const T& init = T()) { resize(n, init); }
  606. void resize(int n, const T& init = T())
  607. {
  608. dim = n;
  609. store.resize((n * (n + 1)) / 2, init);
  610. }
  611. int index(int c, int r) const
  612. {
  613. if (c > r) btSwap(c, r);
  614. btAssert(r < dim);
  615. return ((r * (r + 1)) / 2 + c);
  616. }
  617. T& operator()(int c, int r) { return (store[index(c, r)]); }
  618. const T& operator()(int c, int r) const { return (store[index(c, r)]); }
  619. btAlignedObjectArray<T> store;
  620. int dim;
  621. };
  622. //
  623. // btSoftBodyCollisionShape
  624. //
  625. class btSoftBodyCollisionShape : public btConcaveShape
  626. {
  627. public:
  628. btSoftBody* m_body;
  629. btSoftBodyCollisionShape(btSoftBody* backptr)
  630. {
  631. m_shapeType = SOFTBODY_SHAPE_PROXYTYPE;
  632. m_body = backptr;
  633. }
  634. virtual ~btSoftBodyCollisionShape()
  635. {
  636. }
  637. void processAllTriangles(btTriangleCallback* /*callback*/, const btVector3& /*aabbMin*/, const btVector3& /*aabbMax*/) const
  638. {
  639. //not yet
  640. btAssert(0);
  641. }
  642. ///getAabb returns the axis aligned bounding box in the coordinate frame of the given transform t.
  643. virtual void getAabb(const btTransform& t, btVector3& aabbMin, btVector3& aabbMax) const
  644. {
  645. /* t is usually identity, except when colliding against btCompoundShape. See Issue 512 */
  646. const btVector3 mins = m_body->m_bounds[0];
  647. const btVector3 maxs = m_body->m_bounds[1];
  648. const btVector3 crns[] = {t * btVector3(mins.x(), mins.y(), mins.z()),
  649. t * btVector3(maxs.x(), mins.y(), mins.z()),
  650. t * btVector3(maxs.x(), maxs.y(), mins.z()),
  651. t * btVector3(mins.x(), maxs.y(), mins.z()),
  652. t * btVector3(mins.x(), mins.y(), maxs.z()),
  653. t * btVector3(maxs.x(), mins.y(), maxs.z()),
  654. t * btVector3(maxs.x(), maxs.y(), maxs.z()),
  655. t * btVector3(mins.x(), maxs.y(), maxs.z())};
  656. aabbMin = aabbMax = crns[0];
  657. for (int i = 1; i < 8; ++i)
  658. {
  659. aabbMin.setMin(crns[i]);
  660. aabbMax.setMax(crns[i]);
  661. }
  662. }
  663. virtual void setLocalScaling(const btVector3& /*scaling*/)
  664. {
  665. ///na
  666. }
  667. virtual const btVector3& getLocalScaling() const
  668. {
  669. static const btVector3 dummy(1, 1, 1);
  670. return dummy;
  671. }
  672. virtual void calculateLocalInertia(btScalar /*mass*/, btVector3& /*inertia*/) const
  673. {
  674. ///not yet
  675. btAssert(0);
  676. }
  677. virtual const char* getName() const
  678. {
  679. return "SoftBody";
  680. }
  681. };
  682. //
  683. // btSoftClusterCollisionShape
  684. //
  685. class btSoftClusterCollisionShape : public btConvexInternalShape
  686. {
  687. public:
  688. const btSoftBody::Cluster* m_cluster;
  689. btSoftClusterCollisionShape(const btSoftBody::Cluster* cluster) : m_cluster(cluster) { setMargin(0); }
  690. virtual btVector3 localGetSupportingVertex(const btVector3& vec) const
  691. {
  692. btSoftBody::Node* const* n = &m_cluster->m_nodes[0];
  693. btScalar d = btDot(vec, n[0]->m_x);
  694. int j = 0;
  695. for (int i = 1, ni = m_cluster->m_nodes.size(); i < ni; ++i)
  696. {
  697. const btScalar k = btDot(vec, n[i]->m_x);
  698. if (k > d)
  699. {
  700. d = k;
  701. j = i;
  702. }
  703. }
  704. return (n[j]->m_x);
  705. }
  706. virtual btVector3 localGetSupportingVertexWithoutMargin(const btVector3& vec) const
  707. {
  708. return (localGetSupportingVertex(vec));
  709. }
  710. //notice that the vectors should be unit length
  711. virtual void batchedUnitVectorGetSupportingVertexWithoutMargin(const btVector3* vectors, btVector3* supportVerticesOut, int numVectors) const
  712. {
  713. }
  714. virtual void calculateLocalInertia(btScalar mass, btVector3& inertia) const
  715. {
  716. }
  717. virtual void getAabb(const btTransform& t, btVector3& aabbMin, btVector3& aabbMax) const
  718. {
  719. }
  720. virtual int getShapeType() const { return SOFTBODY_SHAPE_PROXYTYPE; }
  721. //debugging
  722. virtual const char* getName() const { return "SOFTCLUSTER"; }
  723. virtual void setMargin(btScalar margin)
  724. {
  725. btConvexInternalShape::setMargin(margin);
  726. }
  727. virtual btScalar getMargin() const
  728. {
  729. return btConvexInternalShape::getMargin();
  730. }
  731. };
  732. //
  733. // Inline's
  734. //
  735. //
  736. template <typename T>
  737. static inline void ZeroInitialize(T& value)
  738. {
  739. memset(&value, 0, sizeof(T));
  740. }
  741. //
  742. template <typename T>
  743. static inline bool CompLess(const T& a, const T& b)
  744. {
  745. return (a < b);
  746. }
  747. //
  748. template <typename T>
  749. static inline bool CompGreater(const T& a, const T& b)
  750. {
  751. return (a > b);
  752. }
  753. //
  754. template <typename T>
  755. static inline T Lerp(const T& a, const T& b, btScalar t)
  756. {
  757. return (a + (b - a) * t);
  758. }
  759. //
  760. template <typename T>
  761. static inline T InvLerp(const T& a, const T& b, btScalar t)
  762. {
  763. return ((b + a * t - b * t) / (a * b));
  764. }
  765. //
  766. static inline btMatrix3x3 Lerp(const btMatrix3x3& a,
  767. const btMatrix3x3& b,
  768. btScalar t)
  769. {
  770. btMatrix3x3 r;
  771. r[0] = Lerp(a[0], b[0], t);
  772. r[1] = Lerp(a[1], b[1], t);
  773. r[2] = Lerp(a[2], b[2], t);
  774. return (r);
  775. }
  776. //
  777. static inline btVector3 Clamp(const btVector3& v, btScalar maxlength)
  778. {
  779. const btScalar sql = v.length2();
  780. if (sql > (maxlength * maxlength))
  781. return ((v * maxlength) / btSqrt(sql));
  782. else
  783. return (v);
  784. }
  785. //
  786. template <typename T>
  787. static inline T Clamp(const T& x, const T& l, const T& h)
  788. {
  789. return (x < l ? l : x > h ? h : x);
  790. }
  791. //
  792. template <typename T>
  793. static inline T Sq(const T& x)
  794. {
  795. return (x * x);
  796. }
  797. //
  798. template <typename T>
  799. static inline T Cube(const T& x)
  800. {
  801. return (x * x * x);
  802. }
  803. //
  804. template <typename T>
  805. static inline T Sign(const T& x)
  806. {
  807. return ((T)(x < 0 ? -1 : +1));
  808. }
  809. //
  810. template <typename T>
  811. static inline bool SameSign(const T& x, const T& y)
  812. {
  813. return ((x * y) > 0);
  814. }
  815. //
  816. static inline btScalar ClusterMetric(const btVector3& x, const btVector3& y)
  817. {
  818. const btVector3 d = x - y;
  819. return (btFabs(d[0]) + btFabs(d[1]) + btFabs(d[2]));
  820. }
  821. //
  822. static inline btMatrix3x3 ScaleAlongAxis(const btVector3& a, btScalar s)
  823. {
  824. const btScalar xx = a.x() * a.x();
  825. const btScalar yy = a.y() * a.y();
  826. const btScalar zz = a.z() * a.z();
  827. const btScalar xy = a.x() * a.y();
  828. const btScalar yz = a.y() * a.z();
  829. const btScalar zx = a.z() * a.x();
  830. btMatrix3x3 m;
  831. m[0] = btVector3(1 - xx + xx * s, xy * s - xy, zx * s - zx);
  832. m[1] = btVector3(xy * s - xy, 1 - yy + yy * s, yz * s - yz);
  833. m[2] = btVector3(zx * s - zx, yz * s - yz, 1 - zz + zz * s);
  834. return (m);
  835. }
  836. //
  837. static inline btMatrix3x3 Cross(const btVector3& v)
  838. {
  839. btMatrix3x3 m;
  840. m[0] = btVector3(0, -v.z(), +v.y());
  841. m[1] = btVector3(+v.z(), 0, -v.x());
  842. m[2] = btVector3(-v.y(), +v.x(), 0);
  843. return (m);
  844. }
  845. //
  846. static inline btMatrix3x3 Diagonal(btScalar x)
  847. {
  848. btMatrix3x3 m;
  849. m[0] = btVector3(x, 0, 0);
  850. m[1] = btVector3(0, x, 0);
  851. m[2] = btVector3(0, 0, x);
  852. return (m);
  853. }
  854. static inline btMatrix3x3 Diagonal(const btVector3& v)
  855. {
  856. btMatrix3x3 m;
  857. m[0] = btVector3(v.getX(), 0, 0);
  858. m[1] = btVector3(0, v.getY(), 0);
  859. m[2] = btVector3(0, 0, v.getZ());
  860. return (m);
  861. }
  862. static inline btScalar Dot(const btScalar* a, const btScalar* b, int ndof)
  863. {
  864. btScalar result = 0;
  865. for (int i = 0; i < ndof; ++i)
  866. result += a[i] * b[i];
  867. return result;
  868. }
  869. static inline btMatrix3x3 OuterProduct(const btScalar* v1, const btScalar* v2, const btScalar* v3,
  870. const btScalar* u1, const btScalar* u2, const btScalar* u3, int ndof)
  871. {
  872. btMatrix3x3 m;
  873. btScalar a11 = Dot(v1, u1, ndof);
  874. btScalar a12 = Dot(v1, u2, ndof);
  875. btScalar a13 = Dot(v1, u3, ndof);
  876. btScalar a21 = Dot(v2, u1, ndof);
  877. btScalar a22 = Dot(v2, u2, ndof);
  878. btScalar a23 = Dot(v2, u3, ndof);
  879. btScalar a31 = Dot(v3, u1, ndof);
  880. btScalar a32 = Dot(v3, u2, ndof);
  881. btScalar a33 = Dot(v3, u3, ndof);
  882. m[0] = btVector3(a11, a12, a13);
  883. m[1] = btVector3(a21, a22, a23);
  884. m[2] = btVector3(a31, a32, a33);
  885. return (m);
  886. }
  887. static inline btMatrix3x3 OuterProduct(const btVector3& v1, const btVector3& v2)
  888. {
  889. btMatrix3x3 m;
  890. btScalar a11 = v1[0] * v2[0];
  891. btScalar a12 = v1[0] * v2[1];
  892. btScalar a13 = v1[0] * v2[2];
  893. btScalar a21 = v1[1] * v2[0];
  894. btScalar a22 = v1[1] * v2[1];
  895. btScalar a23 = v1[1] * v2[2];
  896. btScalar a31 = v1[2] * v2[0];
  897. btScalar a32 = v1[2] * v2[1];
  898. btScalar a33 = v1[2] * v2[2];
  899. m[0] = btVector3(a11, a12, a13);
  900. m[1] = btVector3(a21, a22, a23);
  901. m[2] = btVector3(a31, a32, a33);
  902. return (m);
  903. }
  904. //
  905. static inline btMatrix3x3 Add(const btMatrix3x3& a,
  906. const btMatrix3x3& b)
  907. {
  908. btMatrix3x3 r;
  909. for (int i = 0; i < 3; ++i) r[i] = a[i] + b[i];
  910. return (r);
  911. }
  912. //
  913. static inline btMatrix3x3 Sub(const btMatrix3x3& a,
  914. const btMatrix3x3& b)
  915. {
  916. btMatrix3x3 r;
  917. for (int i = 0; i < 3; ++i) r[i] = a[i] - b[i];
  918. return (r);
  919. }
  920. //
  921. static inline btMatrix3x3 Mul(const btMatrix3x3& a,
  922. btScalar b)
  923. {
  924. btMatrix3x3 r;
  925. for (int i = 0; i < 3; ++i) r[i] = a[i] * b;
  926. return (r);
  927. }
  928. //
  929. static inline void Orthogonalize(btMatrix3x3& m)
  930. {
  931. m[2] = btCross(m[0], m[1]).normalized();
  932. m[1] = btCross(m[2], m[0]).normalized();
  933. m[0] = btCross(m[1], m[2]).normalized();
  934. }
  935. //
  936. static inline btMatrix3x3 MassMatrix(btScalar im, const btMatrix3x3& iwi, const btVector3& r)
  937. {
  938. const btMatrix3x3 cr = Cross(r);
  939. return (Sub(Diagonal(im), cr * iwi * cr));
  940. }
  941. //
  942. static inline btMatrix3x3 ImpulseMatrix(btScalar dt,
  943. btScalar ima,
  944. btScalar imb,
  945. const btMatrix3x3& iwi,
  946. const btVector3& r)
  947. {
  948. return (Diagonal(1 / dt) * Add(Diagonal(ima), MassMatrix(imb, iwi, r)).inverse());
  949. }
  950. //
  951. static inline btMatrix3x3 ImpulseMatrix(btScalar dt,
  952. const btMatrix3x3& effective_mass_inv,
  953. btScalar imb,
  954. const btMatrix3x3& iwi,
  955. const btVector3& r)
  956. {
  957. return (Diagonal(1 / dt) * Add(effective_mass_inv, MassMatrix(imb, iwi, r)).inverse());
  958. // btMatrix3x3 iimb = MassMatrix(imb, iwi, r);
  959. // if (iimb.determinant() == 0)
  960. // return effective_mass_inv.inverse();
  961. // return effective_mass_inv.inverse() * Add(effective_mass_inv.inverse(), iimb.inverse()).inverse() * iimb.inverse();
  962. }
  963. //
  964. static inline btMatrix3x3 ImpulseMatrix(btScalar ima, const btMatrix3x3& iia, const btVector3& ra,
  965. btScalar imb, const btMatrix3x3& iib, const btVector3& rb)
  966. {
  967. return (Add(MassMatrix(ima, iia, ra), MassMatrix(imb, iib, rb)).inverse());
  968. }
  969. //
  970. static inline btMatrix3x3 AngularImpulseMatrix(const btMatrix3x3& iia,
  971. const btMatrix3x3& iib)
  972. {
  973. return (Add(iia, iib).inverse());
  974. }
  975. //
  976. static inline btVector3 ProjectOnAxis(const btVector3& v,
  977. const btVector3& a)
  978. {
  979. return (a * btDot(v, a));
  980. }
  981. //
  982. static inline btVector3 ProjectOnPlane(const btVector3& v,
  983. const btVector3& a)
  984. {
  985. return (v - ProjectOnAxis(v, a));
  986. }
  987. //
  988. static inline void ProjectOrigin(const btVector3& a,
  989. const btVector3& b,
  990. btVector3& prj,
  991. btScalar& sqd)
  992. {
  993. const btVector3 d = b - a;
  994. const btScalar m2 = d.length2();
  995. if (m2 > SIMD_EPSILON)
  996. {
  997. const btScalar t = Clamp<btScalar>(-btDot(a, d) / m2, 0, 1);
  998. const btVector3 p = a + d * t;
  999. const btScalar l2 = p.length2();
  1000. if (l2 < sqd)
  1001. {
  1002. prj = p;
  1003. sqd = l2;
  1004. }
  1005. }
  1006. }
  1007. //
  1008. static inline void ProjectOrigin(const btVector3& a,
  1009. const btVector3& b,
  1010. const btVector3& c,
  1011. btVector3& prj,
  1012. btScalar& sqd)
  1013. {
  1014. const btVector3& q = btCross(b - a, c - a);
  1015. const btScalar m2 = q.length2();
  1016. if (m2 > SIMD_EPSILON)
  1017. {
  1018. const btVector3 n = q / btSqrt(m2);
  1019. const btScalar k = btDot(a, n);
  1020. const btScalar k2 = k * k;
  1021. if (k2 < sqd)
  1022. {
  1023. const btVector3 p = n * k;
  1024. if ((btDot(btCross(a - p, b - p), q) > 0) &&
  1025. (btDot(btCross(b - p, c - p), q) > 0) &&
  1026. (btDot(btCross(c - p, a - p), q) > 0))
  1027. {
  1028. prj = p;
  1029. sqd = k2;
  1030. }
  1031. else
  1032. {
  1033. ProjectOrigin(a, b, prj, sqd);
  1034. ProjectOrigin(b, c, prj, sqd);
  1035. ProjectOrigin(c, a, prj, sqd);
  1036. }
  1037. }
  1038. }
  1039. }
  1040. //
  1041. static inline bool rayIntersectsTriangle(const btVector3& origin, const btVector3& dir, const btVector3& v0, const btVector3& v1, const btVector3& v2, btScalar& t)
  1042. {
  1043. btScalar a, f, u, v;
  1044. btVector3 e1 = v1 - v0;
  1045. btVector3 e2 = v2 - v0;
  1046. btVector3 h = dir.cross(e2);
  1047. a = e1.dot(h);
  1048. if (a > -0.00001 && a < 0.00001)
  1049. return (false);
  1050. f = btScalar(1) / a;
  1051. btVector3 s = origin - v0;
  1052. u = f * s.dot(h);
  1053. if (u < 0.0 || u > 1.0)
  1054. return (false);
  1055. btVector3 q = s.cross(e1);
  1056. v = f * dir.dot(q);
  1057. if (v < 0.0 || u + v > 1.0)
  1058. return (false);
  1059. // at this stage we can compute t to find out where
  1060. // the intersection point is on the line
  1061. t = f * e2.dot(q);
  1062. if (t > 0) // ray intersection
  1063. return (true);
  1064. else // this means that there is a line intersection
  1065. // but not a ray intersection
  1066. return (false);
  1067. }
  1068. static inline bool lineIntersectsTriangle(const btVector3& rayStart, const btVector3& rayEnd, const btVector3& p1, const btVector3& p2, const btVector3& p3, btVector3& sect, btVector3& normal)
  1069. {
  1070. btVector3 dir = rayEnd - rayStart;
  1071. btScalar dir_norm = dir.norm();
  1072. if (dir_norm < SIMD_EPSILON)
  1073. return false;
  1074. dir.normalize();
  1075. btScalar t;
  1076. bool ret = rayIntersectsTriangle(rayStart, dir, p1, p2, p3, t);
  1077. if (ret)
  1078. {
  1079. if (t <= dir_norm)
  1080. {
  1081. sect = rayStart + dir * t;
  1082. }
  1083. else
  1084. {
  1085. ret = false;
  1086. }
  1087. }
  1088. if (ret)
  1089. {
  1090. btVector3 n = (p3 - p1).cross(p2 - p1);
  1091. n.safeNormalize();
  1092. if (n.dot(dir) < 0)
  1093. normal = n;
  1094. else
  1095. normal = -n;
  1096. }
  1097. return ret;
  1098. }
  1099. //
  1100. template <typename T>
  1101. static inline T BaryEval(const T& a,
  1102. const T& b,
  1103. const T& c,
  1104. const btVector3& coord)
  1105. {
  1106. return (a * coord.x() + b * coord.y() + c * coord.z());
  1107. }
  1108. //
  1109. static inline btVector3 BaryCoord(const btVector3& a,
  1110. const btVector3& b,
  1111. const btVector3& c,
  1112. const btVector3& p)
  1113. {
  1114. const btScalar w[] = {btCross(a - p, b - p).length(),
  1115. btCross(b - p, c - p).length(),
  1116. btCross(c - p, a - p).length()};
  1117. const btScalar isum = 1 / (w[0] + w[1] + w[2]);
  1118. return (btVector3(w[1] * isum, w[2] * isum, w[0] * isum));
  1119. }
  1120. //
  1121. inline static btScalar ImplicitSolve(btSoftBody::ImplicitFn* fn,
  1122. const btVector3& a,
  1123. const btVector3& b,
  1124. const btScalar accuracy,
  1125. const int maxiterations = 256)
  1126. {
  1127. btScalar span[2] = {0, 1};
  1128. btScalar values[2] = {fn->Eval(a), fn->Eval(b)};
  1129. if (values[0] > values[1])
  1130. {
  1131. btSwap(span[0], span[1]);
  1132. btSwap(values[0], values[1]);
  1133. }
  1134. if (values[0] > -accuracy) return (-1);
  1135. if (values[1] < +accuracy) return (-1);
  1136. for (int i = 0; i < maxiterations; ++i)
  1137. {
  1138. const btScalar t = Lerp(span[0], span[1], values[0] / (values[0] - values[1]));
  1139. const btScalar v = fn->Eval(Lerp(a, b, t));
  1140. if ((t <= 0) || (t >= 1)) break;
  1141. if (btFabs(v) < accuracy) return (t);
  1142. if (v < 0)
  1143. {
  1144. span[0] = t;
  1145. values[0] = v;
  1146. }
  1147. else
  1148. {
  1149. span[1] = t;
  1150. values[1] = v;
  1151. }
  1152. }
  1153. return (-1);
  1154. }
  1155. inline static void EvaluateMedium(const btSoftBodyWorldInfo* wfi,
  1156. const btVector3& x,
  1157. btSoftBody::sMedium& medium)
  1158. {
  1159. medium.m_velocity = btVector3(0, 0, 0);
  1160. medium.m_pressure = 0;
  1161. medium.m_density = wfi->air_density;
  1162. if (wfi->water_density > 0)
  1163. {
  1164. const btScalar depth = -(btDot(x, wfi->water_normal) + wfi->water_offset);
  1165. if (depth > 0)
  1166. {
  1167. medium.m_density = wfi->water_density;
  1168. medium.m_pressure = depth * wfi->water_density * wfi->m_gravity.length();
  1169. }
  1170. }
  1171. }
  1172. //
  1173. static inline btVector3 NormalizeAny(const btVector3& v)
  1174. {
  1175. const btScalar l = v.length();
  1176. if (l > SIMD_EPSILON)
  1177. return (v / l);
  1178. else
  1179. return (btVector3(0, 0, 0));
  1180. }
  1181. //
  1182. static inline btDbvtVolume VolumeOf(const btSoftBody::Face& f,
  1183. btScalar margin)
  1184. {
  1185. const btVector3* pts[] = {&f.m_n[0]->m_x,
  1186. &f.m_n[1]->m_x,
  1187. &f.m_n[2]->m_x};
  1188. btDbvtVolume vol = btDbvtVolume::FromPoints(pts, 3);
  1189. vol.Expand(btVector3(margin, margin, margin));
  1190. return (vol);
  1191. }
  1192. //
  1193. static inline btVector3 CenterOf(const btSoftBody::Face& f)
  1194. {
  1195. return ((f.m_n[0]->m_x + f.m_n[1]->m_x + f.m_n[2]->m_x) / 3);
  1196. }
  1197. //
  1198. static inline btScalar AreaOf(const btVector3& x0,
  1199. const btVector3& x1,
  1200. const btVector3& x2)
  1201. {
  1202. const btVector3 a = x1 - x0;
  1203. const btVector3 b = x2 - x0;
  1204. const btVector3 cr = btCross(a, b);
  1205. const btScalar area = cr.length();
  1206. return (area);
  1207. }
  1208. //
  1209. static inline btScalar VolumeOf(const btVector3& x0,
  1210. const btVector3& x1,
  1211. const btVector3& x2,
  1212. const btVector3& x3)
  1213. {
  1214. const btVector3 a = x1 - x0;
  1215. const btVector3 b = x2 - x0;
  1216. const btVector3 c = x3 - x0;
  1217. return (btDot(a, btCross(b, c)));
  1218. }
  1219. //
  1220. //
  1221. static inline void ApplyClampedForce(btSoftBody::Node& n,
  1222. const btVector3& f,
  1223. btScalar dt)
  1224. {
  1225. const btScalar dtim = dt * n.m_im;
  1226. if ((f * dtim).length2() > n.m_v.length2())
  1227. { /* Clamp */
  1228. n.m_f -= ProjectOnAxis(n.m_v, f.normalized()) / dtim;
  1229. }
  1230. else
  1231. { /* Apply */
  1232. n.m_f += f;
  1233. }
  1234. }
  1235. //
  1236. static inline int MatchEdge(const btSoftBody::Node* a,
  1237. const btSoftBody::Node* b,
  1238. const btSoftBody::Node* ma,
  1239. const btSoftBody::Node* mb)
  1240. {
  1241. if ((a == ma) && (b == mb)) return (0);
  1242. if ((a == mb) && (b == ma)) return (1);
  1243. return (-1);
  1244. }
  1245. //
  1246. // btEigen : Extract eigen system,
  1247. // straitforward implementation of http://math.fullerton.edu/mathews/n2003/JacobiMethodMod.html
  1248. // outputs are NOT sorted.
  1249. //
  1250. struct btEigen
  1251. {
  1252. static int system(btMatrix3x3& a, btMatrix3x3* vectors, btVector3* values = 0)
  1253. {
  1254. static const int maxiterations = 16;
  1255. static const btScalar accuracy = (btScalar)0.0001;
  1256. btMatrix3x3& v = *vectors;
  1257. int iterations = 0;
  1258. vectors->setIdentity();
  1259. do
  1260. {
  1261. int p = 0, q = 1;
  1262. if (btFabs(a[p][q]) < btFabs(a[0][2]))
  1263. {
  1264. p = 0;
  1265. q = 2;
  1266. }
  1267. if (btFabs(a[p][q]) < btFabs(a[1][2]))
  1268. {
  1269. p = 1;
  1270. q = 2;
  1271. }
  1272. if (btFabs(a[p][q]) > accuracy)
  1273. {
  1274. const btScalar w = (a[q][q] - a[p][p]) / (2 * a[p][q]);
  1275. const btScalar z = btFabs(w);
  1276. const btScalar t = w / (z * (btSqrt(1 + w * w) + z));
  1277. if (t == t) /* [WARNING] let hope that one does not get thrown aways by some compilers... */
  1278. {
  1279. const btScalar c = 1 / btSqrt(t * t + 1);
  1280. const btScalar s = c * t;
  1281. mulPQ(a, c, s, p, q);
  1282. mulTPQ(a, c, s, p, q);
  1283. mulPQ(v, c, s, p, q);
  1284. }
  1285. else
  1286. break;
  1287. }
  1288. else
  1289. break;
  1290. } while ((++iterations) < maxiterations);
  1291. if (values)
  1292. {
  1293. *values = btVector3(a[0][0], a[1][1], a[2][2]);
  1294. }
  1295. return (iterations);
  1296. }
  1297. private:
  1298. static inline void mulTPQ(btMatrix3x3& a, btScalar c, btScalar s, int p, int q)
  1299. {
  1300. const btScalar m[2][3] = {{a[p][0], a[p][1], a[p][2]},
  1301. {a[q][0], a[q][1], a[q][2]}};
  1302. int i;
  1303. for (i = 0; i < 3; ++i) a[p][i] = c * m[0][i] - s * m[1][i];
  1304. for (i = 0; i < 3; ++i) a[q][i] = c * m[1][i] + s * m[0][i];
  1305. }
  1306. static inline void mulPQ(btMatrix3x3& a, btScalar c, btScalar s, int p, int q)
  1307. {
  1308. const btScalar m[2][3] = {{a[0][p], a[1][p], a[2][p]},
  1309. {a[0][q], a[1][q], a[2][q]}};
  1310. int i;
  1311. for (i = 0; i < 3; ++i) a[i][p] = c * m[0][i] - s * m[1][i];
  1312. for (i = 0; i < 3; ++i) a[i][q] = c * m[1][i] + s * m[0][i];
  1313. }
  1314. };
  1315. //
  1316. // Polar decomposition,
  1317. // "Computing the Polar Decomposition with Applications", Nicholas J. Higham, 1986.
  1318. //
  1319. static inline int PolarDecompose(const btMatrix3x3& m, btMatrix3x3& q, btMatrix3x3& s)
  1320. {
  1321. static const btPolarDecomposition polar;
  1322. return polar.decompose(m, q, s);
  1323. }
  1324. //
  1325. // btSoftColliders
  1326. //
  1327. struct btSoftColliders
  1328. {
  1329. //
  1330. // ClusterBase
  1331. //
  1332. struct ClusterBase : btDbvt::ICollide
  1333. {
  1334. btScalar erp;
  1335. btScalar idt;
  1336. btScalar m_margin;
  1337. btScalar friction;
  1338. btScalar threshold;
  1339. ClusterBase()
  1340. {
  1341. erp = (btScalar)1;
  1342. idt = 0;
  1343. m_margin = 0;
  1344. friction = 0;
  1345. threshold = (btScalar)0;
  1346. }
  1347. bool SolveContact(const btGjkEpaSolver2::sResults& res,
  1348. btSoftBody::Body ba, const btSoftBody::Body bb,
  1349. btSoftBody::CJoint& joint)
  1350. {
  1351. if (res.distance < m_margin)
  1352. {
  1353. btVector3 norm = res.normal;
  1354. norm.normalize(); //is it necessary?
  1355. const btVector3 ra = res.witnesses[0] - ba.xform().getOrigin();
  1356. const btVector3 rb = res.witnesses[1] - bb.xform().getOrigin();
  1357. const btVector3 va = ba.velocity(ra);
  1358. const btVector3 vb = bb.velocity(rb);
  1359. const btVector3 vrel = va - vb;
  1360. const btScalar rvac = btDot(vrel, norm);
  1361. btScalar depth = res.distance - m_margin;
  1362. // printf("depth=%f\n",depth);
  1363. const btVector3 iv = norm * rvac;
  1364. const btVector3 fv = vrel - iv;
  1365. joint.m_bodies[0] = ba;
  1366. joint.m_bodies[1] = bb;
  1367. joint.m_refs[0] = ra * ba.xform().getBasis();
  1368. joint.m_refs[1] = rb * bb.xform().getBasis();
  1369. joint.m_rpos[0] = ra;
  1370. joint.m_rpos[1] = rb;
  1371. joint.m_cfm = 1;
  1372. joint.m_erp = 1;
  1373. joint.m_life = 0;
  1374. joint.m_maxlife = 0;
  1375. joint.m_split = 1;
  1376. joint.m_drift = depth * norm;
  1377. joint.m_normal = norm;
  1378. // printf("normal=%f,%f,%f\n",res.normal.getX(),res.normal.getY(),res.normal.getZ());
  1379. joint.m_delete = false;
  1380. joint.m_friction = fv.length2() < (rvac * friction * rvac * friction) ? 1 : friction;
  1381. joint.m_massmatrix = ImpulseMatrix(ba.invMass(), ba.invWorldInertia(), joint.m_rpos[0],
  1382. bb.invMass(), bb.invWorldInertia(), joint.m_rpos[1]);
  1383. return (true);
  1384. }
  1385. return (false);
  1386. }
  1387. };
  1388. //
  1389. // CollideCL_RS
  1390. //
  1391. struct CollideCL_RS : ClusterBase
  1392. {
  1393. btSoftBody* psb;
  1394. const btCollisionObjectWrapper* m_colObjWrap;
  1395. void Process(const btDbvtNode* leaf)
  1396. {
  1397. btSoftBody::Cluster* cluster = (btSoftBody::Cluster*)leaf->data;
  1398. btSoftClusterCollisionShape cshape(cluster);
  1399. const btConvexShape* rshape = (const btConvexShape*)m_colObjWrap->getCollisionShape();
  1400. ///don't collide an anchored cluster with a static/kinematic object
  1401. if (m_colObjWrap->getCollisionObject()->isStaticOrKinematicObject() && cluster->m_containsAnchor)
  1402. return;
  1403. btGjkEpaSolver2::sResults res;
  1404. if (btGjkEpaSolver2::SignedDistance(&cshape, btTransform::getIdentity(),
  1405. rshape, m_colObjWrap->getWorldTransform(),
  1406. btVector3(1, 0, 0), res))
  1407. {
  1408. btSoftBody::CJoint joint;
  1409. if (SolveContact(res, cluster, m_colObjWrap->getCollisionObject(), joint)) //prb,joint))
  1410. {
  1411. btSoftBody::CJoint* pj = new (btAlignedAlloc(sizeof(btSoftBody::CJoint), 16)) btSoftBody::CJoint();
  1412. *pj = joint;
  1413. psb->m_joints.push_back(pj);
  1414. if (m_colObjWrap->getCollisionObject()->isStaticOrKinematicObject())
  1415. {
  1416. pj->m_erp *= psb->m_cfg.kSKHR_CL;
  1417. pj->m_split *= psb->m_cfg.kSK_SPLT_CL;
  1418. }
  1419. else
  1420. {
  1421. pj->m_erp *= psb->m_cfg.kSRHR_CL;
  1422. pj->m_split *= psb->m_cfg.kSR_SPLT_CL;
  1423. }
  1424. }
  1425. }
  1426. }
  1427. void ProcessColObj(btSoftBody* ps, const btCollisionObjectWrapper* colObWrap)
  1428. {
  1429. psb = ps;
  1430. m_colObjWrap = colObWrap;
  1431. idt = ps->m_sst.isdt;
  1432. m_margin = m_colObjWrap->getCollisionShape()->getMargin() + psb->getCollisionShape()->getMargin();
  1433. ///Bullet rigid body uses multiply instead of minimum to determine combined friction. Some customization would be useful.
  1434. friction = btMin(psb->m_cfg.kDF, m_colObjWrap->getCollisionObject()->getFriction());
  1435. btVector3 mins;
  1436. btVector3 maxs;
  1437. ATTRIBUTE_ALIGNED16(btDbvtVolume)
  1438. volume;
  1439. colObWrap->getCollisionShape()->getAabb(colObWrap->getWorldTransform(), mins, maxs);
  1440. volume = btDbvtVolume::FromMM(mins, maxs);
  1441. volume.Expand(btVector3(1, 1, 1) * m_margin);
  1442. ps->m_cdbvt.collideTV(ps->m_cdbvt.m_root, volume, *this);
  1443. }
  1444. };
  1445. //
  1446. // CollideCL_SS
  1447. //
  1448. struct CollideCL_SS : ClusterBase
  1449. {
  1450. btSoftBody* bodies[2];
  1451. void Process(const btDbvtNode* la, const btDbvtNode* lb)
  1452. {
  1453. btSoftBody::Cluster* cla = (btSoftBody::Cluster*)la->data;
  1454. btSoftBody::Cluster* clb = (btSoftBody::Cluster*)lb->data;
  1455. bool connected = false;
  1456. if ((bodies[0] == bodies[1]) && (bodies[0]->m_clusterConnectivity.size()))
  1457. {
  1458. connected = bodies[0]->m_clusterConnectivity[cla->m_clusterIndex + bodies[0]->m_clusters.size() * clb->m_clusterIndex];
  1459. }
  1460. if (!connected)
  1461. {
  1462. btSoftClusterCollisionShape csa(cla);
  1463. btSoftClusterCollisionShape csb(clb);
  1464. btGjkEpaSolver2::sResults res;
  1465. if (btGjkEpaSolver2::SignedDistance(&csa, btTransform::getIdentity(),
  1466. &csb, btTransform::getIdentity(),
  1467. cla->m_com - clb->m_com, res))
  1468. {
  1469. btSoftBody::CJoint joint;
  1470. if (SolveContact(res, cla, clb, joint))
  1471. {
  1472. btSoftBody::CJoint* pj = new (btAlignedAlloc(sizeof(btSoftBody::CJoint), 16)) btSoftBody::CJoint();
  1473. *pj = joint;
  1474. bodies[0]->m_joints.push_back(pj);
  1475. pj->m_erp *= btMax(bodies[0]->m_cfg.kSSHR_CL, bodies[1]->m_cfg.kSSHR_CL);
  1476. pj->m_split *= (bodies[0]->m_cfg.kSS_SPLT_CL + bodies[1]->m_cfg.kSS_SPLT_CL) / 2;
  1477. }
  1478. }
  1479. }
  1480. else
  1481. {
  1482. static int count = 0;
  1483. count++;
  1484. //printf("count=%d\n",count);
  1485. }
  1486. }
  1487. void ProcessSoftSoft(btSoftBody* psa, btSoftBody* psb)
  1488. {
  1489. idt = psa->m_sst.isdt;
  1490. //m_margin = (psa->getCollisionShape()->getMargin()+psb->getCollisionShape()->getMargin())/2;
  1491. m_margin = (psa->getCollisionShape()->getMargin() + psb->getCollisionShape()->getMargin());
  1492. friction = btMin(psa->m_cfg.kDF, psb->m_cfg.kDF);
  1493. bodies[0] = psa;
  1494. bodies[1] = psb;
  1495. psa->m_cdbvt.collideTT(psa->m_cdbvt.m_root, psb->m_cdbvt.m_root, *this);
  1496. }
  1497. };
  1498. //
  1499. // CollideSDF_RS
  1500. //
  1501. struct CollideSDF_RS : btDbvt::ICollide
  1502. {
  1503. void Process(const btDbvtNode* leaf)
  1504. {
  1505. btSoftBody::Node* node = (btSoftBody::Node*)leaf->data;
  1506. DoNode(*node);
  1507. }
  1508. void DoNode(btSoftBody::Node& n) const
  1509. {
  1510. const btScalar m = n.m_im > 0 ? dynmargin : stamargin;
  1511. btSoftBody::RContact c;
  1512. if ((!n.m_battach) &&
  1513. psb->checkContact(m_colObj1Wrap, n.m_x, m, c.m_cti))
  1514. {
  1515. const btScalar ima = n.m_im;
  1516. const btScalar imb = m_rigidBody ? m_rigidBody->getInvMass() : 0.f;
  1517. const btScalar ms = ima + imb;
  1518. if (ms > 0)
  1519. {
  1520. const btTransform& wtr = m_rigidBody ? m_rigidBody->getWorldTransform() : m_colObj1Wrap->getCollisionObject()->getWorldTransform();
  1521. static const btMatrix3x3 iwiStatic(0, 0, 0, 0, 0, 0, 0, 0, 0);
  1522. const btMatrix3x3& iwi = m_rigidBody ? m_rigidBody->getInvInertiaTensorWorld() : iwiStatic;
  1523. const btVector3 ra = n.m_x - wtr.getOrigin();
  1524. const btVector3 va = m_rigidBody ? m_rigidBody->getVelocityInLocalPoint(ra) * psb->m_sst.sdt : btVector3(0, 0, 0);
  1525. const btVector3 vb = n.m_x - n.m_q;
  1526. const btVector3 vr = vb - va;
  1527. const btScalar dn = btDot(vr, c.m_cti.m_normal);
  1528. const btVector3 fv = vr - c.m_cti.m_normal * dn;
  1529. const btScalar fc = psb->m_cfg.kDF * m_colObj1Wrap->getCollisionObject()->getFriction();
  1530. c.m_node = &n;
  1531. c.m_c0 = ImpulseMatrix(psb->m_sst.sdt, ima, imb, iwi, ra);
  1532. c.m_c1 = ra;
  1533. c.m_c2 = ima * psb->m_sst.sdt;
  1534. c.m_c3 = fv.length2() < (dn * fc * dn * fc) ? 0 : 1 - fc;
  1535. c.m_c4 = m_colObj1Wrap->getCollisionObject()->isStaticOrKinematicObject() ? psb->m_cfg.kKHR : psb->m_cfg.kCHR;
  1536. psb->m_rcontacts.push_back(c);
  1537. if (m_rigidBody)
  1538. m_rigidBody->activate();
  1539. }
  1540. }
  1541. }
  1542. btSoftBody* psb;
  1543. const btCollisionObjectWrapper* m_colObj1Wrap;
  1544. btRigidBody* m_rigidBody;
  1545. btScalar dynmargin;
  1546. btScalar stamargin;
  1547. };
  1548. //
  1549. // CollideSDF_RD
  1550. //
  1551. struct CollideSDF_RD : btDbvt::ICollide
  1552. {
  1553. void Process(const btDbvtNode* leaf)
  1554. {
  1555. btSoftBody::Node* node = (btSoftBody::Node*)leaf->data;
  1556. DoNode(*node);
  1557. }
  1558. void DoNode(btSoftBody::Node& n) const
  1559. {
  1560. const btScalar m = n.m_im > 0 ? dynmargin : stamargin;
  1561. btSoftBody::DeformableNodeRigidContact c;
  1562. if (!n.m_battach)
  1563. {
  1564. // check for collision at x_{n+1}^*
  1565. if (psb->checkDeformableContact(m_colObj1Wrap, n.m_q, m, c.m_cti, /*predict = */ true))
  1566. {
  1567. const btScalar ima = n.m_im;
  1568. // todo: collision between multibody and fixed deformable node will be missed.
  1569. const btScalar imb = m_rigidBody ? m_rigidBody->getInvMass() : 0.f;
  1570. const btScalar ms = ima + imb;
  1571. if (ms > 0)
  1572. {
  1573. // resolve contact at x_n
  1574. psb->checkDeformableContact(m_colObj1Wrap, n.m_x, m, c.m_cti, /*predict = */ false);
  1575. btSoftBody::sCti& cti = c.m_cti;
  1576. c.m_node = &n;
  1577. const btScalar fc = psb->m_cfg.kDF * m_colObj1Wrap->getCollisionObject()->getFriction();
  1578. c.m_c2 = ima;
  1579. c.m_c3 = fc;
  1580. c.m_c4 = m_colObj1Wrap->getCollisionObject()->isStaticOrKinematicObject() ? psb->m_cfg.kKHR : psb->m_cfg.kCHR;
  1581. c.m_c5 = n.m_effectiveMass_inv;
  1582. if (cti.m_colObj->getInternalType() == btCollisionObject::CO_RIGID_BODY)
  1583. {
  1584. const btTransform& wtr = m_rigidBody ? m_rigidBody->getWorldTransform() : m_colObj1Wrap->getCollisionObject()->getWorldTransform();
  1585. static const btMatrix3x3 iwiStatic(0, 0, 0, 0, 0, 0, 0, 0, 0);
  1586. const btMatrix3x3& iwi = m_rigidBody ? m_rigidBody->getInvInertiaTensorWorld() : iwiStatic;
  1587. const btVector3 ra = n.m_x - wtr.getOrigin();
  1588. c.m_c0 = ImpulseMatrix(1, n.m_effectiveMass_inv, imb, iwi, ra);
  1589. // c.m_c0 = ImpulseMatrix(1, ima, imb, iwi, ra);
  1590. c.m_c1 = ra;
  1591. }
  1592. else if (cti.m_colObj->getInternalType() == btCollisionObject::CO_FEATHERSTONE_LINK)
  1593. {
  1594. btMultiBodyLinkCollider* multibodyLinkCol = (btMultiBodyLinkCollider*)btMultiBodyLinkCollider::upcast(cti.m_colObj);
  1595. if (multibodyLinkCol)
  1596. {
  1597. btVector3 normal = cti.m_normal;
  1598. btVector3 t1 = generateUnitOrthogonalVector(normal);
  1599. btVector3 t2 = btCross(normal, t1);
  1600. btMultiBodyJacobianData jacobianData_normal, jacobianData_t1, jacobianData_t2;
  1601. findJacobian(multibodyLinkCol, jacobianData_normal, c.m_node->m_x, normal);
  1602. findJacobian(multibodyLinkCol, jacobianData_t1, c.m_node->m_x, t1);
  1603. findJacobian(multibodyLinkCol, jacobianData_t2, c.m_node->m_x, t2);
  1604. btScalar* J_n = &jacobianData_normal.m_jacobians[0];
  1605. btScalar* J_t1 = &jacobianData_t1.m_jacobians[0];
  1606. btScalar* J_t2 = &jacobianData_t2.m_jacobians[0];
  1607. btScalar* u_n = &jacobianData_normal.m_deltaVelocitiesUnitImpulse[0];
  1608. btScalar* u_t1 = &jacobianData_t1.m_deltaVelocitiesUnitImpulse[0];
  1609. btScalar* u_t2 = &jacobianData_t2.m_deltaVelocitiesUnitImpulse[0];
  1610. btMatrix3x3 rot(normal.getX(), normal.getY(), normal.getZ(),
  1611. t1.getX(), t1.getY(), t1.getZ(),
  1612. t2.getX(), t2.getY(), t2.getZ()); // world frame to local frame
  1613. const int ndof = multibodyLinkCol->m_multiBody->getNumDofs() + 6;
  1614. btMatrix3x3 local_impulse_matrix = (n.m_effectiveMass_inv + OuterProduct(J_n, J_t1, J_t2, u_n, u_t1, u_t2, ndof)).inverse();
  1615. c.m_c0 = rot.transpose() * local_impulse_matrix * rot;
  1616. c.jacobianData_normal = jacobianData_normal;
  1617. c.jacobianData_t1 = jacobianData_t1;
  1618. c.jacobianData_t2 = jacobianData_t2;
  1619. c.t1 = t1;
  1620. c.t2 = t2;
  1621. }
  1622. }
  1623. psb->m_nodeRigidContacts.push_back(c);
  1624. }
  1625. }
  1626. }
  1627. }
  1628. btSoftBody* psb;
  1629. const btCollisionObjectWrapper* m_colObj1Wrap;
  1630. btRigidBody* m_rigidBody;
  1631. btScalar dynmargin;
  1632. btScalar stamargin;
  1633. };
  1634. //
  1635. // CollideSDF_RDF
  1636. //
  1637. struct CollideSDF_RDF : btDbvt::ICollide
  1638. {
  1639. void Process(const btDbvtNode* leaf)
  1640. {
  1641. btSoftBody::Face* face = (btSoftBody::Face*)leaf->data;
  1642. DoNode(*face);
  1643. }
  1644. void DoNode(btSoftBody::Face& f) const
  1645. {
  1646. btSoftBody::Node* n0 = f.m_n[0];
  1647. btSoftBody::Node* n1 = f.m_n[1];
  1648. btSoftBody::Node* n2 = f.m_n[2];
  1649. const btScalar m = (n0->m_im > 0 && n1->m_im > 0 && n2->m_im > 0) ? dynmargin : stamargin;
  1650. btSoftBody::DeformableFaceRigidContact c;
  1651. btVector3 contact_point;
  1652. btVector3 bary;
  1653. if (psb->checkDeformableFaceContact(m_colObj1Wrap, f, contact_point, bary, m, c.m_cti, true))
  1654. {
  1655. btScalar ima = n0->m_im + n1->m_im + n2->m_im;
  1656. const btScalar imb = m_rigidBody ? m_rigidBody->getInvMass() : 0.f;
  1657. // todo: collision between multibody and fixed deformable face will be missed.
  1658. const btScalar ms = ima + imb;
  1659. if (ms > 0)
  1660. {
  1661. // resolve contact at x_n
  1662. // psb->checkDeformableFaceContact(m_colObj1Wrap, f, contact_point, bary, m, c.m_cti, /*predict = */ false);
  1663. btSoftBody::sCti& cti = c.m_cti;
  1664. c.m_contactPoint = contact_point;
  1665. c.m_bary = bary;
  1666. // todo xuchenhan@: this is assuming mass of all vertices are the same. Need to modify if mass are different for distinct vertices
  1667. c.m_weights = btScalar(2) / (btScalar(1) + bary.length2()) * bary;
  1668. c.m_face = &f;
  1669. // friction is handled by the nodes to prevent sticking
  1670. // const btScalar fc = 0;
  1671. const btScalar fc = psb->m_cfg.kDF * m_colObj1Wrap->getCollisionObject()->getFriction();
  1672. // the effective inverse mass of the face as in https://graphics.stanford.edu/papers/cloth-sig02/cloth.pdf
  1673. ima = bary.getX() * c.m_weights.getX() * n0->m_im + bary.getY() * c.m_weights.getY() * n1->m_im + bary.getZ() * c.m_weights.getZ() * n2->m_im;
  1674. c.m_c2 = ima;
  1675. c.m_c3 = fc;
  1676. c.m_c4 = m_colObj1Wrap->getCollisionObject()->isStaticOrKinematicObject() ? psb->m_cfg.kKHR : psb->m_cfg.kCHR;
  1677. c.m_c5 = Diagonal(ima);
  1678. if (cti.m_colObj->getInternalType() == btCollisionObject::CO_RIGID_BODY)
  1679. {
  1680. const btTransform& wtr = m_rigidBody ? m_rigidBody->getWorldTransform() : m_colObj1Wrap->getCollisionObject()->getWorldTransform();
  1681. static const btMatrix3x3 iwiStatic(0, 0, 0, 0, 0, 0, 0, 0, 0);
  1682. const btMatrix3x3& iwi = m_rigidBody ? m_rigidBody->getInvInertiaTensorWorld() : iwiStatic;
  1683. const btVector3 ra = contact_point - wtr.getOrigin();
  1684. // we do not scale the impulse matrix by dt
  1685. c.m_c0 = ImpulseMatrix(1, ima, imb, iwi, ra);
  1686. c.m_c1 = ra;
  1687. }
  1688. else if (cti.m_colObj->getInternalType() == btCollisionObject::CO_FEATHERSTONE_LINK)
  1689. {
  1690. btMultiBodyLinkCollider* multibodyLinkCol = (btMultiBodyLinkCollider*)btMultiBodyLinkCollider::upcast(cti.m_colObj);
  1691. if (multibodyLinkCol)
  1692. {
  1693. btVector3 normal = cti.m_normal;
  1694. btVector3 t1 = generateUnitOrthogonalVector(normal);
  1695. btVector3 t2 = btCross(normal, t1);
  1696. btMultiBodyJacobianData jacobianData_normal, jacobianData_t1, jacobianData_t2;
  1697. findJacobian(multibodyLinkCol, jacobianData_normal, contact_point, normal);
  1698. findJacobian(multibodyLinkCol, jacobianData_t1, contact_point, t1);
  1699. findJacobian(multibodyLinkCol, jacobianData_t2, contact_point, t2);
  1700. btScalar* J_n = &jacobianData_normal.m_jacobians[0];
  1701. btScalar* J_t1 = &jacobianData_t1.m_jacobians[0];
  1702. btScalar* J_t2 = &jacobianData_t2.m_jacobians[0];
  1703. btScalar* u_n = &jacobianData_normal.m_deltaVelocitiesUnitImpulse[0];
  1704. btScalar* u_t1 = &jacobianData_t1.m_deltaVelocitiesUnitImpulse[0];
  1705. btScalar* u_t2 = &jacobianData_t2.m_deltaVelocitiesUnitImpulse[0];
  1706. btMatrix3x3 rot(normal.getX(), normal.getY(), normal.getZ(),
  1707. t1.getX(), t1.getY(), t1.getZ(),
  1708. t2.getX(), t2.getY(), t2.getZ()); // world frame to local frame
  1709. const int ndof = multibodyLinkCol->m_multiBody->getNumDofs() + 6;
  1710. btMatrix3x3 local_impulse_matrix = (Diagonal(ima) + OuterProduct(J_n, J_t1, J_t2, u_n, u_t1, u_t2, ndof)).inverse();
  1711. c.m_c0 = rot.transpose() * local_impulse_matrix * rot;
  1712. c.jacobianData_normal = jacobianData_normal;
  1713. c.jacobianData_t1 = jacobianData_t1;
  1714. c.jacobianData_t2 = jacobianData_t2;
  1715. c.t1 = t1;
  1716. c.t2 = t2;
  1717. }
  1718. }
  1719. psb->m_faceRigidContacts.push_back(c);
  1720. }
  1721. }
  1722. // Set caching barycenters to be false after collision detection.
  1723. // Only turn on when contact is static.
  1724. f.m_pcontact[3] = 0;
  1725. }
  1726. btSoftBody* psb;
  1727. const btCollisionObjectWrapper* m_colObj1Wrap;
  1728. btRigidBody* m_rigidBody;
  1729. btScalar dynmargin;
  1730. btScalar stamargin;
  1731. };
  1732. //
  1733. // CollideVF_SS
  1734. //
  1735. struct CollideVF_SS : btDbvt::ICollide
  1736. {
  1737. void Process(const btDbvtNode* lnode,
  1738. const btDbvtNode* lface)
  1739. {
  1740. btSoftBody::Node* node = (btSoftBody::Node*)lnode->data;
  1741. btSoftBody::Face* face = (btSoftBody::Face*)lface->data;
  1742. for (int i = 0; i < 3; ++i)
  1743. {
  1744. if (face->m_n[i] == node)
  1745. continue;
  1746. }
  1747. btVector3 o = node->m_x;
  1748. btVector3 p;
  1749. btScalar d = SIMD_INFINITY;
  1750. ProjectOrigin(face->m_n[0]->m_x - o,
  1751. face->m_n[1]->m_x - o,
  1752. face->m_n[2]->m_x - o,
  1753. p, d);
  1754. const btScalar m = mrg + (o - node->m_q).length() * 2;
  1755. if (d < (m * m))
  1756. {
  1757. const btSoftBody::Node* n[] = {face->m_n[0], face->m_n[1], face->m_n[2]};
  1758. const btVector3 w = BaryCoord(n[0]->m_x, n[1]->m_x, n[2]->m_x, p + o);
  1759. const btScalar ma = node->m_im;
  1760. btScalar mb = BaryEval(n[0]->m_im, n[1]->m_im, n[2]->m_im, w);
  1761. if ((n[0]->m_im <= 0) ||
  1762. (n[1]->m_im <= 0) ||
  1763. (n[2]->m_im <= 0))
  1764. {
  1765. mb = 0;
  1766. }
  1767. const btScalar ms = ma + mb;
  1768. if (ms > 0)
  1769. {
  1770. btSoftBody::SContact c;
  1771. c.m_normal = p / -btSqrt(d);
  1772. c.m_margin = m;
  1773. c.m_node = node;
  1774. c.m_face = face;
  1775. c.m_weights = w;
  1776. c.m_friction = btMax(psb[0]->m_cfg.kDF, psb[1]->m_cfg.kDF);
  1777. c.m_cfm[0] = ma / ms * psb[0]->m_cfg.kSHR;
  1778. c.m_cfm[1] = mb / ms * psb[1]->m_cfg.kSHR;
  1779. psb[0]->m_scontacts.push_back(c);
  1780. }
  1781. }
  1782. }
  1783. btSoftBody* psb[2];
  1784. btScalar mrg;
  1785. };
  1786. //
  1787. // CollideVF_DD
  1788. //
  1789. struct CollideVF_DD : btDbvt::ICollide
  1790. {
  1791. void Process(const btDbvtNode* lnode,
  1792. const btDbvtNode* lface)
  1793. {
  1794. btSoftBody::Node* node = (btSoftBody::Node*)lnode->data;
  1795. btSoftBody::Face* face = (btSoftBody::Face*)lface->data;
  1796. btVector3 bary;
  1797. if (proximityTest(face->m_n[0]->m_x, face->m_n[1]->m_x, face->m_n[2]->m_x, node->m_x, face->m_normal, mrg, bary))
  1798. {
  1799. const btSoftBody::Node* n[] = {face->m_n[0], face->m_n[1], face->m_n[2]};
  1800. const btVector3 w = bary;
  1801. const btScalar ma = node->m_im;
  1802. btScalar mb = BaryEval(n[0]->m_im, n[1]->m_im, n[2]->m_im, w);
  1803. if ((n[0]->m_im <= 0) ||
  1804. (n[1]->m_im <= 0) ||
  1805. (n[2]->m_im <= 0))
  1806. {
  1807. mb = 0;
  1808. }
  1809. const btScalar ms = ma + mb;
  1810. if (ms > 0)
  1811. {
  1812. btSoftBody::DeformableFaceNodeContact c;
  1813. c.m_normal = face->m_normal;
  1814. if (!useFaceNormal && c.m_normal.dot(node->m_x - face->m_n[2]->m_x) < 0)
  1815. c.m_normal = -face->m_normal;
  1816. c.m_margin = mrg;
  1817. c.m_node = node;
  1818. c.m_face = face;
  1819. c.m_bary = w;
  1820. c.m_friction = psb[0]->m_cfg.kDF * psb[1]->m_cfg.kDF;
  1821. psb[0]->m_faceNodeContacts.push_back(c);
  1822. }
  1823. }
  1824. }
  1825. btSoftBody* psb[2];
  1826. btScalar mrg;
  1827. bool useFaceNormal;
  1828. };
  1829. //
  1830. // CollideFF_DD
  1831. //
  1832. struct CollideFF_DD : btDbvt::ICollide
  1833. {
  1834. void Process(const btDbvntNode* lface1,
  1835. const btDbvntNode* lface2)
  1836. {
  1837. btSoftBody::Face* f1 = (btSoftBody::Face*)lface1->data;
  1838. btSoftBody::Face* f2 = (btSoftBody::Face*)lface2->data;
  1839. if (f1 != f2)
  1840. {
  1841. Repel(f1, f2);
  1842. Repel(f2, f1);
  1843. }
  1844. }
  1845. void Repel(btSoftBody::Face* f1, btSoftBody::Face* f2)
  1846. {
  1847. //#define REPEL_NEIGHBOR 1
  1848. #ifndef REPEL_NEIGHBOR
  1849. for (int node_id = 0; node_id < 3; ++node_id)
  1850. {
  1851. btSoftBody::Node* node = f1->m_n[node_id];
  1852. for (int i = 0; i < 3; ++i)
  1853. {
  1854. if (f2->m_n[i] == node)
  1855. return;
  1856. }
  1857. }
  1858. #endif
  1859. bool skip = false;
  1860. for (int node_id = 0; node_id < 3; ++node_id)
  1861. {
  1862. btSoftBody::Node* node = f1->m_n[node_id];
  1863. #ifdef REPEL_NEIGHBOR
  1864. for (int i = 0; i < 3; ++i)
  1865. {
  1866. if (f2->m_n[i] == node)
  1867. {
  1868. skip = true;
  1869. break;
  1870. }
  1871. }
  1872. if (skip)
  1873. {
  1874. skip = false;
  1875. continue;
  1876. }
  1877. #endif
  1878. btSoftBody::Face* face = f2;
  1879. btVector3 bary;
  1880. if (!proximityTest(face->m_n[0]->m_x, face->m_n[1]->m_x, face->m_n[2]->m_x, node->m_x, face->m_normal, mrg, bary))
  1881. continue;
  1882. btSoftBody::DeformableFaceNodeContact c;
  1883. c.m_normal = face->m_normal;
  1884. if (!useFaceNormal && c.m_normal.dot(node->m_x - face->m_n[2]->m_x) < 0)
  1885. c.m_normal = -face->m_normal;
  1886. c.m_margin = mrg;
  1887. c.m_node = node;
  1888. c.m_face = face;
  1889. c.m_bary = bary;
  1890. c.m_friction = psb[0]->m_cfg.kDF * psb[1]->m_cfg.kDF;
  1891. psb[0]->m_faceNodeContacts.push_back(c);
  1892. }
  1893. }
  1894. btSoftBody* psb[2];
  1895. btScalar mrg;
  1896. bool useFaceNormal;
  1897. };
  1898. struct CollideCCD : btDbvt::ICollide
  1899. {
  1900. void Process(const btDbvtNode* lnode,
  1901. const btDbvtNode* lface)
  1902. {
  1903. btSoftBody::Node* node = (btSoftBody::Node*)lnode->data;
  1904. btSoftBody::Face* face = (btSoftBody::Face*)lface->data;
  1905. btVector3 bary;
  1906. if (bernsteinCCD(face, node, dt, SAFE_EPSILON, bary))
  1907. {
  1908. btSoftBody::DeformableFaceNodeContact c;
  1909. c.m_normal = face->m_normal;
  1910. if (!useFaceNormal && c.m_normal.dot(node->m_x - face->m_n[2]->m_x) < 0)
  1911. c.m_normal = -face->m_normal;
  1912. c.m_node = node;
  1913. c.m_face = face;
  1914. c.m_bary = bary;
  1915. c.m_friction = psb[0]->m_cfg.kDF * psb[1]->m_cfg.kDF;
  1916. psb[0]->m_faceNodeContacts.push_back(c);
  1917. }
  1918. }
  1919. void Process(const btDbvntNode* lface1,
  1920. const btDbvntNode* lface2)
  1921. {
  1922. btSoftBody::Face* f1 = (btSoftBody::Face*)lface1->data;
  1923. btSoftBody::Face* f2 = (btSoftBody::Face*)lface2->data;
  1924. if (f1 != f2)
  1925. {
  1926. Repel(f1, f2);
  1927. Repel(f2, f1);
  1928. }
  1929. }
  1930. void Repel(btSoftBody::Face* f1, btSoftBody::Face* f2)
  1931. {
  1932. //#define REPEL_NEIGHBOR 1
  1933. #ifndef REPEL_NEIGHBOR
  1934. for (int node_id = 0; node_id < 3; ++node_id)
  1935. {
  1936. btSoftBody::Node* node = f1->m_n[node_id];
  1937. for (int i = 0; i < 3; ++i)
  1938. {
  1939. if (f2->m_n[i] == node)
  1940. return;
  1941. }
  1942. }
  1943. #endif
  1944. bool skip = false;
  1945. for (int node_id = 0; node_id < 3; ++node_id)
  1946. {
  1947. btSoftBody::Node* node = f1->m_n[node_id];
  1948. #ifdef REPEL_NEIGHBOR
  1949. for (int i = 0; i < 3; ++i)
  1950. {
  1951. if (f2->m_n[i] == node)
  1952. {
  1953. skip = true;
  1954. break;
  1955. }
  1956. }
  1957. if (skip)
  1958. {
  1959. skip = false;
  1960. continue;
  1961. }
  1962. #endif
  1963. btSoftBody::Face* face = f2;
  1964. btVector3 bary;
  1965. if (bernsteinCCD(face, node, dt, SAFE_EPSILON, bary))
  1966. {
  1967. btSoftBody::DeformableFaceNodeContact c;
  1968. c.m_normal = face->m_normal;
  1969. if (!useFaceNormal && c.m_normal.dot(node->m_x - face->m_n[2]->m_x) < 0)
  1970. c.m_normal = -face->m_normal;
  1971. c.m_node = node;
  1972. c.m_face = face;
  1973. c.m_bary = bary;
  1974. c.m_friction = psb[0]->m_cfg.kDF * psb[1]->m_cfg.kDF;
  1975. psb[0]->m_faceNodeContacts.push_back(c);
  1976. }
  1977. }
  1978. }
  1979. btSoftBody* psb[2];
  1980. btScalar dt, mrg;
  1981. bool useFaceNormal;
  1982. };
  1983. };
  1984. #endif //_BT_SOFT_BODY_INTERNALS_H