Project

General

Profile

« Previous | Next » 

Revision 309ba6ea

Added by Leszek Koltunski 3 months ago

major speedup of SolvedObject

View differences:

src/main/java/org/distorted/library/helpers/QuatHelper.java
143 143
    ret[3] = rw*qw - rz*qz - ry*qy - rx*qx;
144 144
    }
145 145

  
146
///////////////////////////////////////////////////////////////////////////////////////////////////
147
// ret = (qx,qy,qz,qw)*(rx,ry,rz,rw)
148

  
149
  private static void quatMultiply( float[] ret, int index, float qx, float qy, float qz, float qw, float rx, float ry, float rz, float rw )
150
    {
151
    ret[index  ] = rw*qx - rz*qy + ry*qz + rx*qw;
152
    ret[index+1] = rw*qy + rz*qx + ry*qw - rx*qz;
153
    ret[index+2] = rw*qz + rz*qw - ry*qx + rx*qy;
154
    ret[index+3] = rw*qw - rz*qz - ry*qy - rx*qx;
155
    }
156

  
146 157
///////////////////////////////////////////////////////////////////////////////////////////////////
147 158
// rotate 'vector' by quat  ( i.e. return quat*vector*(quat^-1) )
148 159

  
......
189 200
    quatMultiply(output,tmp[0],tmp[1],tmp[2],tmp[3],-qx,-qy,-qz,qw);
190 201
    }
191 202

  
203
///////////////////////////////////////////////////////////////////////////////////////////////////
204
// rotate (x1,x2,x3,x4) by quat  ( i.e. return quat*vector*(quat^-1) )
205

  
206
  public static void rotateVectorByQuat(float[] output, int index, float x, float y, float z, float w, Static4D quat)
207
    {
208
    float[] tmp = new float[4];
209

  
210
    float qx = quat.get0();
211
    float qy = quat.get1();
212
    float qz = quat.get2();
213
    float qw = quat.get3();
214

  
215
    quatMultiply(tmp,qx,qy,qz,qw,x,y,z,w);
216
    quatMultiply(output,index,tmp[0],tmp[1],tmp[2],tmp[3],-qx,-qy,-qz,qw);
217
    }
218

  
192 219
///////////////////////////////////////////////////////////////////////////////////////////////////
193 220
// rotate (x1,x2,x3,x4) by quat  ( i.e. return quat*vector*(quat^-1) )
194 221

  
......
205 232
    quatMultiply(output,tmp[0],tmp[1],tmp[2],tmp[3],-qx,-qy,-qz,qw);
206 233
    }
207 234

  
235
///////////////////////////////////////////////////////////////////////////////////////////////////
236
// rotate (x1,x2,x3,x4) by quat  ( i.e. return quat*vector*(quat^-1) )
237

  
238
  public static void rotateVectorByQuat(float[] output, int index, float x, float y, float z, float w, float[] quat)
239
    {
240
    float[] tmp = new float[4];
241

  
242
    float qx = quat[0];
243
    float qy = quat[1];
244
    float qz = quat[2];
245
    float qw = quat[3];
246

  
247
    quatMultiply(tmp,qx,qy,qz,qw,x,y,z,w);
248
    quatMultiply(output,index,tmp[0],tmp[1],tmp[2],tmp[3],-qx,-qy,-qz,qw);
249
    }
250

  
208 251
///////////////////////////////////////////////////////////////////////////////////////////////////
209 252
// rotate vec by quat ( i.e. return quat*vector*(quat^-1) )
210 253

  

Also available in: Unified diff