6 releases

new 0.4.0 Jan 15, 2025
0.2.0 Dec 18, 2024
0.1.4 Dec 16, 2024

#343 in Math

Download history 339/week @ 2024-12-13 36/week @ 2024-12-20 3/week @ 2024-12-27 48/week @ 2025-01-10

109 downloads per month
Used in ggmath_testing

MIT license

240KB
6.5K SLoC

*** UNFINISHED CRATE ***

GGMath - Generic Graphics Math

graphics-math crate with powerful generics that are truely zero-cost

  • simple API
use ggmath::vector::*;

fn main() {
  let _2_4_ = vec2!(2.0_f32, 4.0);
  let vec = vec4!(1.0, _2_4_, 3.0).xywz();

  assert_eq!(vec, vec4!(1.0, 2.0, 3.0, 4.0));
}
  • powerful generics
use ggmath::vector::{f32_aliases::*, *};

struct MyStruct<const N: usize, T: Scalar, A: VecAlignment> where ScalarCount<N>: VecLen {
  gg: Vector<N, T, A>,
  go: Vector<N, T, VecAligned>,
  og: FVec3,
  //oo: go back to Java
}
  • both column-major and row-major matricies
use ggmath::matrix::*;

fn example(row_major: Mat4R, column_major: Mat2x3C) {}
  • 0-cost abstraction - fully optimized with SIMD on current stable Rust

restrictions:

  • only supports static vectors (2, 3, 4) and matricies (2, 3, 4)x(2, 3, 4)
  • won't support const-contexts until const-traits are stablized

Scalar

The Scalar trait allows types to be put inside math types (vectors, matricies...)

The magic of this crate is that when you implement Scalar, you can override the implementation of Vector functions to make optimizations

  • All Vector functions that are possible to optimize can be overriden

Vector

the Vector struct is generic over:

  • <const N: usize> where ScalarCount<N>: VecLen - only 2, 3, and 4 are valid vector lengths
  • <T: Scalar> - f32? u8? isize? CustomF256?
  • <A: VecAlignment> - doesn't affect API, VecAligned is faster, VecPacked saves memory

don't want to be generic? use type aliases! Vec2<f32>/FVec2/IVec3/BVec4

Matrix

the Matrix struct is generic over:

  • <const C: usize> where ScalarCount<C>: VecLen - column count
  • <const R: usize> where ScalarCount<R>: VecLen - row count
  • <T: Scalar> - "f32? u8? isize? CustomF256?"
  • <A: VecAlignment> - a matrix is built of vectors...
  • <M: MatrixMajorAxis> - internally row-major or column major?

don't want to be generic? use Mat3C<f32>/FMat4x2RP

GPU integration

GGMath is built with GPU struct integration in mind.

when making Vertex structs, use VecPacked to save space

when making Uniform structs, use VecAligned which has size & alignment rules that uniforms require

Type Aliases

ggmath's type aliases have naming rules:

Vectors:

Vec'N'<T> -> Vector<'N', T, VecAligned> For example: Vec2<f32> -> Vector<2, f32, VecAligned>

Vec'N'P<T> -> Vector<'N', T, VecPacked> For example: Vec4P<f32> -> Vector<4, f32, VecPacked>

'T'Vec'N' -> Vector<'N', 'T', VecAligned> For example: FVec2 -> Vector<2, f32, VecAligned>

'T'Vec'N'P -> Vector<'N', 'T', VecPacked> For example: U8Vec3P -> Vector<3, u8, VecPacked>

Matricies

Mat'C'x'R'C<T> -> Matrix<'C', 'R', T, VecAligned, ColumnMajor> For example: Mat2x3C<f32> -> Matrix<2, 3, f32, VecAligned, ColumnMajor>

Mat'C'x'R'R<T> -> Matrix<'C', 'R', T, VecAligned, RowMajor> For example: Mat4x3R<bool> -> Matrix<4, 3, bool, VecAligned, RowMajor>

Mat'C'x'R'CP<T> -> Matrix<'C', 'R', T, VecPacked, ColumnMajor> For example: Mat3CP<f64> -> Matrix<3, 3, f64, VecPacked, ColumnMajor>

Mat'C'x'R'RP<T>, 'T'Mat'C'x'R'C...

Development Progress

API

Vector: almost stable and complete.

Matrix: only has layout manipulation so columns rows construction... but no matrix multiplication for example.

Quaternion: doesn't exist.

Rectangle: mostly complete.

Performance

No scalars are optimized yet so right now the performance is probably close to nalgebra's while the final performance will be identical to glam.

Tests

The crate isn't fully tested yet and the custom-scalar testing system ggmath_testing isn't as well.

Left To Do

  • finish ggmath_testing (tester for custom scalars)
  • add missing tests
  • add benchmarks
  • finish APIs
  • optimize scalars
  • add missing docs

Dependencies

~305–750KB
~18K SLoC