Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

Changeset 5428 in orxonox.OLD for trunk/src/lib/collision_detection


Ignore:
Timestamp:
Oct 24, 2005, 7:07:00 PM (19 years ago)
Author:
patrick
Message:

orxonox/trunk: fixed a bug in the CD engine

Location:
trunk/src/lib/collision_detection
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/lib/collision_detection/lin_alg.h

    r5398 r5428  
    2424void JacobI(float **A,int N,float *D, float **V, int *NROT) {
    2525float  *B, *Z;
    26 double  c,g,h,s,sm,t,tau,theta,tresh;
    27 int     i,j,ip,iq;
    28 
    29 // void *vmblock1 = NULL;
     26double  c=0.0f, g=0.0f, h=0.0f, s=0.0f, sm=0.0f, t=0.0f, tau=0.0f, theta=0.0f, tresh=0.0f;
     27int     i=0,j=0,ip=0,iq=0;
    3028
    3129  //allocate vectors B, Z
    32   //vmblock1 = vminit();
     30
    3331  B = (float *) calloc(100, 32);
    3432  Z = (float *) calloc(100, 32);
    3533
    36   for (ip=1; ip<=N; ip++) {  //initialize V to identity matrix
     34  for(ip=1; ip<=N; ip++) {  //initialize V to identity matrix
    3735    for (iq=1; iq<=N; iq++)  V[ip][iq]=0;
    3836    V[ip][ip]=1;
     
    118116  } //end of main i loop
    119117//  printf("\n 50 iterations !\n");
     118  free(B);
     119  free(Z);
    120120  return;  //too many iterations
    121121}
  • trunk/src/lib/collision_detection/obb_tree_node.cc

    r5210 r5428  
    160160{
    161161  float     facelet[length];                         //!< surface area of the i'th triangle of the convex hull
    162   float     face;                                    //!< surface area of the entire convex hull
     162  float     face = 0.0f;                             //!< surface area of the entire convex hull
    163163  Vector    centroid[length];                        //!< centroid of the i'th convex hull
    164164  Vector    center;                                  //!< the center of the entire hull
     
    175175  {
    176176    /* fist compute all the convex hull face/facelets and centroids */
    177     for(int i = 0; i+3 < length ; i+=3)          /* FIX-ME-QUICK: hops of 3, array indiscontinuity*/
     177    for( int i = 0; i+3 < length ; i+=3)          /* FIX-ME-QUICK: hops of 3, array indiscontinuity*/
    178178    {
    179179      p = verticesList[i];
     
    199199
    200200    /* now calculate the covariance matrix - if not written in three for-loops, it would compute faster: minor */
    201     for(int j = 0; j < 3; ++j)
    202     {
    203       for(int k = 0; k < 3; ++k)
     201    for( int j = 0; j < 3; ++j)
     202    {
     203      for( int k = 0; k < 3; ++k)
    204204      {
    205         for(int i = 0; i < length; i+=3)
     205        for( int i = 0; i + 3 < length; i+=3)
    206206        {
    207207          p = verticesList[i];
     
    218218  else if( mode == 1)
    219219  {
    220     for( int i = 0; i < length; i+=3)          /* FIX-ME-QUICK: hops of 3, array indiscontinuity*/
     220    for( int i = 0; i + 3 < length; i+=3)          /* FIX-ME-QUICK: hops of 3, array indiscontinuity*/
    221221    {
    222222      p = verticesList[i];
     
    233233      for( int k = 0; k < 3; ++k)
    234234      {
    235         for( int i = 0; i < length; i+=3)
     235        for( int i = 0; i + 3 < length; i+=3)
    236236        {
    237237          p = verticesList[i];
     
    249249  {
    250250    /* fist compute all the convex hull face/facelets and centroids */
    251     for(int i = 0; i < length; i+=3)          /* FIX-ME-QUICK: hops of 3, array indiscontinuity*/
     251    for(int i = 0; i + 3 < length; i+=3)          /* FIX-ME-QUICK: hops of 3, array indiscontinuity*/
    252252    {
    253253      p = verticesList[i];
     
    275275      for( int k = 0; k < 3; ++k)
    276276      {
    277         for( int i = 0; i < length; i+=3)
     277        for( int i = 0; i + 3 < length; i+=3)
    278278        {
    279279          p = verticesList[i];
     
    300300      for( int k = 0; k < 3; ++k)
    301301      {
    302         for( int i = 0; i < length; i+=3)
     302        for( int i = 0; i + 3 < length; i+=3)
    303303        {
    304304          p = verticesList[i];
Note: See TracChangeset for help on using the changeset viewer.