23#ifndef BJ_PHYSICS_2D_H
24#define BJ_PHYSICS_2D_H
General-purpose definitions for Banjo API.
#define BANJO_EXPORT
Definition api.h:139
#define BJ_RESTRICT
BJ_RESTRICT expands to the appropriate restrict qualifier per toolchain.
Definition api.h:183
struct bj_vec2_t bj_vec2
Definition vec.h:30
float bj_real
Selected real type for float configuration.
Definition math.h:51
bj_vec2 velocity
Definition physics_2d.h:80
bj_real value
Definition physics_2d.h:227
bj_real torque
Definition physics_2d.h:230
bj_real inverse_mass
Definition physics_2d.h:84
bj_real acceleration
Definition physics_2d.h:229
bj_real velocity
Definition physics_2d.h:228
bj_real damping
Definition physics_2d.h:83
bj_vec2 position
Definition physics_2d.h:79
struct bj_angular_2d_t angular
Definition physics_2d.h:270
bj_vec2 forces
Definition physics_2d.h:82
bj_vec2 acceleration
Definition physics_2d.h:81
bj_real inverse_inertia
Definition physics_2d.h:232
struct bj_particle_2d_t particle
Definition physics_2d.h:269
bj_real damping
Definition physics_2d.h:231
void bj_apply_angular_torque_2d(bj_angular_2d *angular, bj_real torque)
Add torque to the angular accumulator.
void bj_apply_point_gravity_2d(bj_particle_2d *restrict p_particle_from, const bj_particle_2d *restrict p_particle_to, const bj_real gravity_factor)
Apply point gravity from one particle to another.
bj_vec2 bj_compute_kinematics_velocity_2d(bj_vec2 velocity, bj_vec2 acceleration, bj_real time)
Integrate constant-acceleration 2D kinematics: velocity at time t.
void bj_step_rigid_body_2d(bj_rigid_body_2d *body, double delta_time)
Step rigid body linear and angular states.
void bj_apply_gravity_2d(bj_particle_2d *p_particle, bj_real gravity)
Apply constant downward gravity in world space to a particle.
void bj_apply_particle_force_2d(bj_particle_2d *p_particle, const bj_vec2 force)
Add a force to a particle's accumulator.
void bj_step_particle_2d(bj_particle_2d *p_particle, bj_real dt)
Semi-implicit Euler step for a particle.
void bj_apply_rigidbody_force_2d(bj_rigid_body_2d *body, const bj_vec2 force)
Apply a world-space force at the center of mass.
struct bj_rigid_body_2d_t bj_rigid_body_2d
Definition physics_2d.h:272
struct bj_particle_2d_t bj_particle_2d
Definition physics_2d.h:86
void bj_step_angular_2d(bj_angular_2d *angular, double delta_time)
Semi-implicit Euler step for angular motion.
bj_vec2 bj_compute_particle_drag_force_2d(bj_vec2 vel, const bj_real k1, const bj_real k2)
Compute drag force for a velocity.
struct bj_angular_2d_t bj_angular_2d
Definition physics_2d.h:234
void bj_apply_point_gravity_softened_2d(bj_particle_2d *restrict p_particle_from, const bj_particle_2d *restrict p_particle_to, const bj_real gravity_factor, const bj_real epsilon)
Apply softened point gravity to avoid singularities at small r.
bj_real bj_compute_particle_drag_coefficient_2d(const bj_vec2 vel, const bj_real k1, const bj_real k2)
Return scalar drag coefficient for a velocity.
void bj_apply_drag_2d(bj_particle_2d *p_particle, bj_real k1, bj_real k2)
Apply quadratic + linear drag to a particle's accumulator.
bj_vec2 bj_compute_kinematics_2d(bj_vec2 position, bj_vec2 velocity, bj_vec2 acceleration, bj_real time)
Integrate constant-acceleration 2D kinematics: position at time t.
Angular.
Definition physics_2d.h:226
2D point mass state and physical properties.
Definition physics_2d.h:78
Rigid body with translational and angular components.
Definition physics_2d.h:268
C99 math shim with bj_real precision type and scalar utilities.