17 #ifndef BT_SOLVE_PROJECTED_GAUSS_SEIDEL_H    18 #define BT_SOLVE_PROJECTED_GAUSS_SEIDEL_H    32                 A.rowComputeNonZeroElements();
    37                 int i, j, numRows = A.rows();
    41                 for (
int k = 0; k <numIterations; k++)
    43                         for (i = 0; i <numRows; i++)
    48                                         for (
int h=0;h<A.m_rowNonZeroElements1[i].size();h++)
    50                                                 int j = A.m_rowNonZeroElements1[i][h];
    53                                                         delta += A(i,j) * x[j];
    58                                         for (j = 0; j <i; j++) 
    59                                                 delta += A(i,j) * x[j];
    60                                         for (j = i+1; j<numRows; j++) 
    61                                                 delta += A(i,j) * x[j];
    65                                 x [i] = (b [i] - delta) / aDiag;
    68                                 if (limitDependency[i]>=0)
    70                                         s = x[limitDependency[i]];
    86 #endif //BT_SOLVE_PROJECTED_GAUSS_SEIDEL_H virtual bool solveMLCP(const btMatrixXu &A, const btVectorXu &b, btVectorXu &x, const btVectorXu &lo, const btVectorXu &hi, const btAlignedObjectArray< int > &limitDependency, int numIterations, bool useSparsity=true)
original version written by Erwin Coumans, October 2013 
original version written by Erwin Coumans, October 2013