| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139 | = Math Cheat Sheet:revnumber: 2.0:revdate: 2020/07/13== Formulas[NOTE]====Typically you have to string these formulas together. Look in the table for what you want, and what you have. If the two are not the same line, than you need conversion steps inbetween. E.g. if you have an angle in degrees, but the formula expects radians: 1) convert degrees to radians, 2) use the radians formula on the result.====[cols="3", options="header"]|===a|I have…a|I want…a|Formulaa|normalized direction and length +n1,d1a|a vector that goes that far in that direction +new direction vector v0a|v0 = n1.mult(d1)a|point and direction vector +p1,v1a|to move the point +new point p0a|p0 = p1.add(v1)a| direction, position and distance +v1,p1,dista|Position at distance +p2a|v1.normalzeLocal() +scaledDir = v1.mult(dist) +p2 = p1.add(scaledDir)a|two direction vectors or normals +v1,v2a|to combine both directions +new direction vector v0a|v0 = v1.add(v2)a|two points +p1, p2a|distance between two points +new scalar d0a|d0 = p1.subtract(p2).length() +d0 = p1.distance(p2)a|two points +p1, p2a|the direction from p2 to p1 +new direction vector v0a|v0 = p1.substract(p2)a|two points, a fraction +p1, p2, h=0.5fa|the point "`halfway`" (h=0.5f) between the two points +new interpolated point p0a|p0 = FastMath.interpolateLinear(h,p1,p2)a|a direction vector, an up vector +v, upa|A rotation around this up axis towards this direction +new Quaternion qa|Quaternion q = new Quaternion(); +q.lookAt(v,up)|===[cols="3", options="header"]|===a|I have…a|I want…a|Formulaa|angle in degrees +aa| to convert angle a from degrees to radians +new float angle phia|phi = a / 180 * FastMath.PI; +OR +phi=a.mult(FastMath.DEG_TO_RAD);a|angle in radians +phia| to convert angle phi from radians to degrees +new float angle aa|a = phi * 180 / FastMath.PIa|radian angle and x axis +phi, xa|to rotate around x axis +new quaternion q0a|q0.fromAngleAxis( phi, Vector3f.UNIT_X )a|radian angle and y axis +phi, ya|to rotate around y axis +new quaternion q0a|q0.fromAngleAxis( phi, Vector3f.UNIT_Y )a|radian angle and z axis +phi, za|to rotate around z axis +new quaternion q0a|q0.fromAngleAxis( phi, Vector3f.UNIT_Z )a|several quaternions +q1, q2, q3a|to combine rotations, in that order +new quaternion q0a|q0 = q1.mult(q2).mult(q3)a|point and quaternion +p1, q1a|to rotate the point around origin +new point p0a|p0 = q1.mult(p1)a|angle in radians and radius +phi,ra|to arrange or move objects horizontally in a circle (with y=0) +x and z coordinatesa|float x = FastMath.cos(phi)*r; +float z = FastMath.sin(phi)*r;|===== Local vs Non-local methods?*  Non-local method creates new object as return value, v remains unchanged. +`v2 = v.mult(); v2 = v.add(); v2 = v.subtract();` etc*  Local method changes v directly! +`v.multLocal(); v.addLocal(); v.subtractLocal();` etc
 |