inmath ~simd

Inochi2D Math Library (fork of gl3n)


To use this package, run the following command in your project's root directory:

Manual usage
Put the following dependency into your project's dependences section:

Inochi2D Math

inmath is a fork of gl3n meant for use within Inochi2D, containing modifications specific to Inochi2D. inmath provides all the math you need to work with OpenGL. Currently inmath supports:

  • linear algebra
  • vectors
  • matrices
  • quaternions
  • geometry
  • axis aligned bounding boxes
  • planes
  • frustum (use it with care, not a 100% tested)
  • interpolation
  • linear interpolation (lerp)
  • spherical linear interpolation (slerp)
  • hermite interpolation
  • catmull rom interpolation
  • noise
  • opensimplex2 noise generation
  • colors - hsv to rgb and rgb to hsv conversion
  • nearly all GLSL defined functions (according to spec 4.1)
  • the power of D, e.g. dynamic swizzling, templated types (vectors, matrices, quaternions), impressive constructors and more!

inmath is slightly different from gl3n in the following ways

  • No unexpected side effects
  • No unexpected casts
  • Vector multiplication is not dot product.
    • Multiplying vectors does pair-wise multiplication instead.
  • inmath uses camelCase for the naming of things
  • inmath simplifies parts of gl3n by removing excessive use of aliases.

License

inmath, like gl3n is MIT licensed, which allows you to use it everywhere you want it.

Installation

You can use inmath in your project via the dub package database.

Examples

vec4 v4 = vec4(1.0f, vec3(2.0f, 3.0f, 4.0f));
vec4 v4_2 = vec4(1.0f, vec4(1.0f, 2.0f, 3.0f, 4.0f).xyz); // "dynamic" swizzling with opDispatch
vec4 v4_3 = v4_2.xxyz; // opDispatch returns a static array which you can pass directly to the ctor of a vector!

vec3 v3 = my_3dvec.rgb;
vec3 foo = v4.xyzzzwzyyxw.xyz // not useful but possible!

mat4 m4fv = mat4.translation(-0.5f, -0.54f, 0.42f).rotateX(PI).rotateZ(PI/2);
glUniformMatrix4fv(location, 1, GL_TRUE, m4fv.ptr); // yes they are row major!

alias Matrix!(double, 4, 4) mat4d;
mat4d projection;
glGetDoublev(GL_PROJECTION_MATRIX, projection.ptr);

mat3 inv_view = view.rotation;
mat3 inv_view = mat3(view);

mat4 m4 = mat4(vec4(1.0f, 2.0f, 3.0f, 4.0f), 5.0f, 6.0f, 7.0f, 8.0f, vec4(...) ...); 
    void strafeLeft(float delta) { // A
        vec3 vcross = cross(up, forward).normalized;
        _position = _position + vcross.dot(delta);
    }

    void strafeRight(float delta) { // D
        vec3 vcross = cross(up, forward).normalized;
        _position = _position - vcross.dot(delta);
    }
Authors:
  • David Herberth
  • Inochi2D Project
Dependencies:
intel-intrinsics, silly
Versions:
1.3.0 2024-Sep-11
1.2.1 2024-Jun-08
1.2.0 2024-Jun-08
1.1.1 2024-May-19
1.1.0 2024-May-16
Show all 16 versions
Download Stats:
  • 22 downloads today

  • 144 downloads this week

  • 662 downloads this month

  • 15902 downloads total

Score:
3.0
Short URL:
inmath.dub.pm