Overloaded basic math funcs (double and float variants). Use real_t rather than float or double in generic functions (core/math) whenever possible.

Also inlined some more math functions.
This commit is contained in:
Ferenc Arn 2017-01-14 14:35:39 -06:00
parent d13f2f9e25
commit 6f4f9aa6de
50 changed files with 543 additions and 615 deletions

View File

@ -39,7 +39,7 @@ int AStar::get_available_point_id() const {
return points.back()->key()+1; return points.back()->key()+1;
} }
void AStar::add_point(int p_id, const Vector3 &p_pos, float p_weight_scale) { void AStar::add_point(int p_id, const Vector3 &p_pos, real_t p_weight_scale) {
ERR_FAIL_COND(p_id<0); ERR_FAIL_COND(p_id<0);
if (!points.has(p_id)) { if (!points.has(p_id)) {
Point *pt = memnew( Point ); Point *pt = memnew( Point );
@ -62,7 +62,7 @@ Vector3 AStar::get_point_pos(int p_id) const{
return points[p_id]->pos; return points[p_id]->pos;
} }
float AStar::get_point_weight_scale(int p_id) const{ real_t AStar::get_point_weight_scale(int p_id) const{
ERR_FAIL_COND_V(!points.has(p_id),0); ERR_FAIL_COND_V(!points.has(p_id),0);
@ -145,11 +145,11 @@ void AStar::clear(){
int AStar::get_closest_point(const Vector3& p_point) const{ int AStar::get_closest_point(const Vector3& p_point) const{
int closest_id=-1; int closest_id=-1;
float closest_dist=1e20; real_t closest_dist=1e20;
for (const Map<int,Point*>::Element *E=points.front();E;E=E->next()) { for (const Map<int,Point*>::Element *E=points.front();E;E=E->next()) {
float d = p_point.distance_squared_to(E->get()->pos); real_t d = p_point.distance_squared_to(E->get()->pos);
if (closest_id<0 || d<closest_dist) { if (closest_id<0 || d<closest_dist) {
closest_dist=d; closest_dist=d;
closest_id=E->key(); closest_id=E->key();
@ -162,7 +162,7 @@ int AStar::get_closest_point(const Vector3& p_point) const{
} }
Vector3 AStar::get_closest_pos_in_segment(const Vector3& p_point) const { Vector3 AStar::get_closest_pos_in_segment(const Vector3& p_point) const {
float closest_dist = 1e20; real_t closest_dist = 1e20;
bool found=false; bool found=false;
Vector3 closest_point; Vector3 closest_point;
@ -175,7 +175,7 @@ Vector3 AStar::get_closest_pos_in_segment(const Vector3& p_point) const {
}; };
Vector3 p = Geometry::get_closest_point_to_segment(p_point,segment); Vector3 p = Geometry::get_closest_point_to_segment(p_point,segment);
float d = p_point.distance_squared_to(p); real_t d = p_point.distance_squared_to(p);
if (!found || d<closest_dist) { if (!found || d<closest_dist) {
closest_point=p; closest_point=p;
@ -220,14 +220,14 @@ bool AStar::_solve(Point* begin_point, Point* end_point) {
//check open list //check open list
SelfList<Point> *least_cost_point=NULL; SelfList<Point> *least_cost_point=NULL;
float least_cost=1e30; real_t least_cost=1e30;
//this could be faster (cache previous results) //this could be faster (cache previous results)
for (SelfList<Point> *E=open_list.first();E;E=E->next()) { for (SelfList<Point> *E=open_list.first();E;E=E->next()) {
Point *p=E->self(); Point *p=E->self();
float cost=p->distance; real_t cost=p->distance;
cost+=p->pos.distance_to(end_point->pos); cost+=p->pos.distance_to(end_point->pos);
cost*=p->weight_scale; cost*=p->weight_scale;
@ -249,7 +249,7 @@ bool AStar::_solve(Point* begin_point, Point* end_point) {
Point* e=p->neighbours[i]; Point* e=p->neighbours[i];
float distance = p->pos.distance_to(e->pos) + p->distance; real_t distance = p->pos.distance_to(e->pos) + p->distance;
distance*=e->weight_scale; distance*=e->weight_scale;

View File

@ -48,14 +48,14 @@ class AStar: public Reference {
int id; int id;
Vector3 pos; Vector3 pos;
float weight_scale; real_t weight_scale;
uint64_t last_pass; uint64_t last_pass;
Vector<Point*> neighbours; Vector<Point*> neighbours;
//used for pathfinding //used for pathfinding
Point *prev_point; Point *prev_point;
float distance; real_t distance;
Point() : list(this) {} Point() : list(this) {}
}; };
@ -98,9 +98,9 @@ public:
int get_available_point_id() const; int get_available_point_id() const;
void add_point(int p_id,const Vector3& p_pos,float p_weight_scale=1); void add_point(int p_id,const Vector3& p_pos,real_t p_weight_scale=1);
Vector3 get_point_pos(int p_id) const; Vector3 get_point_pos(int p_id) const;
float get_point_weight_scale(int p_id) const; real_t get_point_weight_scale(int p_id) const;
void remove_point(int p_id); void remove_point(int p_id);
void connect_points(int p_id,int p_with_id); void connect_points(int p_id,int p_with_id);

View File

@ -87,8 +87,8 @@ int BSP_Tree::_get_points_inside(int p_node,const Vector3* p_points,int *p_indic
max+=p_center; max+=p_center;
min+=p_center; min+=p_center;
float dist_min = p.distance_to(min); real_t dist_min = p.distance_to(min);
float dist_max = p.distance_to(max); real_t dist_max = p.distance_to(max);
if ((dist_min * dist_max) < CMP_EPSILON ) { //intersection, test point by point if ((dist_min * dist_max) < CMP_EPSILON ) { //intersection, test point by point
@ -290,13 +290,13 @@ bool BSP_Tree::point_is_inside(const Vector3& p_point) const {
} }
static int _bsp_find_best_half_plane(const Face3* p_faces,const Vector<int>& p_indices,float p_tolerance) { static int _bsp_find_best_half_plane(const Face3* p_faces,const Vector<int>& p_indices,real_t p_tolerance) {
int ic = p_indices.size(); int ic = p_indices.size();
const int*indices=p_indices.ptr(); const int*indices=p_indices.ptr();
int best_plane = -1; int best_plane = -1;
float best_plane_cost = 1e20; real_t best_plane_cost = 1e20;
// Loop to find the polygon that best divides the set. // Loop to find the polygon that best divides the set.
@ -317,7 +317,7 @@ static int _bsp_find_best_half_plane(const Face3* p_faces,const Vector<int>& p_i
for(int k=0;k<3;k++) { for(int k=0;k<3;k++) {
float d = p.distance_to(g.vertex[j]); real_t d = p.distance_to(g.vertex[j]);
if (Math::abs(d)>p_tolerance) { if (Math::abs(d)>p_tolerance) {
@ -340,13 +340,13 @@ static int _bsp_find_best_half_plane(const Face3* p_faces,const Vector<int>& p_i
//double split_cost = num_spanning / (double) face_count; //real_t split_cost = num_spanning / (real_t) face_count;
double relation = Math::abs(num_over-num_under) / (double) ic; real_t relation = Math::abs(num_over-num_under) / (real_t) ic;
// being honest, i never found a way to add split cost to the mix in a meaninguful way // being honest, i never found a way to add split cost to the mix in a meaninguful way
// in this engine, also, will likely be ignored anyway // in this engine, also, will likely be ignored anyway
double plane_cost = /*split_cost +*/ relation; real_t plane_cost = /*split_cost +*/ relation;
//printf("plane %i, %i over, %i under, %i spanning, cost is %g\n",i,num_over,num_under,num_spanning,plane_cost); //printf("plane %i, %i over, %i under, %i spanning, cost is %g\n",i,num_over,num_under,num_spanning,plane_cost);
if (plane_cost<best_plane_cost) { if (plane_cost<best_plane_cost) {
@ -362,7 +362,7 @@ static int _bsp_find_best_half_plane(const Face3* p_faces,const Vector<int>& p_i
} }
static int _bsp_create_node(const Face3 *p_faces,const Vector<int>& p_indices,Vector<Plane> &p_planes, Vector<BSP_Tree::Node> &p_nodes,float p_tolerance) { static int _bsp_create_node(const Face3 *p_faces,const Vector<int>& p_indices,Vector<Plane> &p_planes, Vector<BSP_Tree::Node> &p_nodes,real_t p_tolerance) {
ERR_FAIL_COND_V( p_nodes.size() == BSP_Tree::MAX_NODES, -1 ); ERR_FAIL_COND_V( p_nodes.size() == BSP_Tree::MAX_NODES, -1 );
@ -400,7 +400,7 @@ static int _bsp_create_node(const Face3 *p_faces,const Vector<int>& p_indices,Ve
for(int j=0;j<3;j++) { for(int j=0;j<3;j++) {
float d = divisor_plane.distance_to(f.vertex[j]); real_t d = divisor_plane.distance_to(f.vertex[j]);
if (Math::abs(d)>p_tolerance) { if (Math::abs(d)>p_tolerance) {
if (d > 0) if (d > 0)
@ -473,7 +473,7 @@ BSP_Tree::operator Variant() const {
Dictionary d; Dictionary d;
d["error_radius"]=error_radius; d["error_radius"]=error_radius;
Vector<float> plane_values; Vector<real_t> plane_values;
plane_values.resize(planes.size()*4); plane_values.resize(planes.size()*4);
for(int i=0;i<planes.size();i++) { for(int i=0;i<planes.size();i++) {
@ -522,13 +522,13 @@ BSP_Tree::BSP_Tree(const Variant& p_variant) {
if (d["planes"].get_type()==Variant::POOL_REAL_ARRAY) { if (d["planes"].get_type()==Variant::POOL_REAL_ARRAY) {
PoolVector<float> src_planes=d["planes"]; PoolVector<real_t> src_planes=d["planes"];
int plane_count=src_planes.size(); int plane_count=src_planes.size();
ERR_FAIL_COND(plane_count%4); ERR_FAIL_COND(plane_count%4);
planes.resize(plane_count/4); planes.resize(plane_count/4);
if (plane_count) { if (plane_count) {
PoolVector<float>::Read r = src_planes.read(); PoolVector<real_t>::Read r = src_planes.read();
for(int i=0;i<plane_count/4;i++) { for(int i=0;i<plane_count/4;i++) {
planes[i].normal.x=r[i*4+0]; planes[i].normal.x=r[i*4+0];
@ -562,7 +562,7 @@ BSP_Tree::BSP_Tree(const Variant& p_variant) {
} }
BSP_Tree::BSP_Tree(const PoolVector<Face3>& p_faces,float p_error_radius) { BSP_Tree::BSP_Tree(const PoolVector<Face3>& p_faces,real_t p_error_radius) {
// compute aabb // compute aabb
@ -615,7 +615,7 @@ BSP_Tree::BSP_Tree(const PoolVector<Face3>& p_faces,float p_error_radius) {
error_radius=p_error_radius; error_radius=p_error_radius;
} }
BSP_Tree::BSP_Tree(const Vector<Node> &p_nodes, const Vector<Plane> &p_planes, const Rect3& p_aabb,float p_error_radius) { BSP_Tree::BSP_Tree(const Vector<Node> &p_nodes, const Vector<Plane> &p_planes, const Rect3& p_aabb,real_t p_error_radius) {
nodes=p_nodes; nodes=p_nodes;
planes=p_planes; planes=p_planes;

View File

@ -66,7 +66,7 @@ private:
Vector<Node> nodes; Vector<Node> nodes;
Vector<Plane> planes; Vector<Plane> planes;
Rect3 aabb; Rect3 aabb;
float error_radius; real_t error_radius;
int _get_points_inside(int p_node,const Vector3* p_points,int *p_indices, const Vector3& p_center,const Vector3& p_half_extents,int p_indices_count) const; int _get_points_inside(int p_node,const Vector3* p_points,int *p_indices, const Vector3& p_center,const Vector3& p_half_extents,int p_indices_count) const;
@ -91,8 +91,8 @@ public:
BSP_Tree(); BSP_Tree();
BSP_Tree(const Variant& p_variant); BSP_Tree(const Variant& p_variant);
BSP_Tree(const PoolVector<Face3>& p_faces,float p_error_radius=0); BSP_Tree(const PoolVector<Face3>& p_faces,real_t p_error_radius=0);
BSP_Tree(const Vector<Node> &p_nodes, const Vector<Plane> &p_planes, const Rect3& p_aabb,float p_error_radius=0); BSP_Tree(const Vector<Node> &p_nodes, const Vector<Plane> &p_planes, const Rect3& p_aabb,real_t p_error_radius=0);
~BSP_Tree(); ~BSP_Tree();
}; };
@ -110,7 +110,7 @@ bool BSP_Tree::_test_convex(const Node* p_nodes, const Plane* p_planes,int p_cur
const Plane& p=p_planes[n.plane]; const Plane& p=p_planes[n.plane];
float min,max; real_t min,max;
p_convex.project_range(p.normal,min,max); p_convex.project_range(p.normal,min,max);
bool go_under = min < p.d; bool go_under = min < p.d;

View File

@ -65,15 +65,15 @@ Plane CameraMatrix::xform4(const Plane& p_vec4) const {
return ret; return ret;
} }
void CameraMatrix::set_perspective(float p_fovy_degrees, float p_aspect, float p_z_near, float p_z_far,bool p_flip_fov) { void CameraMatrix::set_perspective(real_t p_fovy_degrees, real_t p_aspect, real_t p_z_near, real_t p_z_far,bool p_flip_fov) {
if (p_flip_fov) { if (p_flip_fov) {
p_fovy_degrees=get_fovy(p_fovy_degrees,1.0/p_aspect); p_fovy_degrees=get_fovy(p_fovy_degrees,1.0/p_aspect);
} }
float sine, cotangent, deltaZ; real_t sine, cotangent, deltaZ;
float radians = p_fovy_degrees / 2.0 * Math_PI / 180.0; real_t radians = p_fovy_degrees / 2.0 * Math_PI / 180.0;
deltaZ = p_z_far - p_z_near; deltaZ = p_z_far - p_z_near;
sine = Math::sin(radians); sine = Math::sin(radians);
@ -94,7 +94,7 @@ void CameraMatrix::set_perspective(float p_fovy_degrees, float p_aspect, float p
} }
void CameraMatrix::set_orthogonal(float p_left, float p_right, float p_bottom, float p_top, float p_znear, float p_zfar) { void CameraMatrix::set_orthogonal(real_t p_left, real_t p_right, real_t p_bottom, real_t p_top, real_t p_znear, real_t p_zfar) {
set_identity(); set_identity();
@ -109,7 +109,7 @@ void CameraMatrix::set_orthogonal(float p_left, float p_right, float p_bottom, f
} }
void CameraMatrix::set_orthogonal(float p_size, float p_aspect, float p_znear, float p_zfar,bool p_flip_fov) { void CameraMatrix::set_orthogonal(real_t p_size, real_t p_aspect, real_t p_znear, real_t p_zfar,bool p_flip_fov) {
if (!p_flip_fov) { if (!p_flip_fov) {
p_size*=p_aspect; p_size*=p_aspect;
@ -120,7 +120,7 @@ void CameraMatrix::set_orthogonal(float p_size, float p_aspect, float p_znear, f
void CameraMatrix::set_frustum(float p_left, float p_right, float p_bottom, float p_top, float p_near, float p_far) { void CameraMatrix::set_frustum(real_t p_left, real_t p_right, real_t p_bottom, real_t p_top, real_t p_near, real_t p_far) {
#if 0 #if 0
///@TODO, give a check to this. I'm not sure if it's working. ///@TODO, give a check to this. I'm not sure if it's working.
set_identity(); set_identity();
@ -134,14 +134,14 @@ void CameraMatrix::set_frustum(float p_left, float p_right, float p_bottom, floa
matrix[3][2]=-1; matrix[3][2]=-1;
matrix[3][3]=0; matrix[3][3]=0;
#else #else
float *te = &matrix[0][0]; real_t *te = &matrix[0][0];
float x = 2 * p_near / ( p_right - p_left ); real_t x = 2 * p_near / ( p_right - p_left );
float y = 2 * p_near / ( p_top - p_bottom ); real_t y = 2 * p_near / ( p_top - p_bottom );
float a = ( p_right + p_left ) / ( p_right - p_left ); real_t a = ( p_right + p_left ) / ( p_right - p_left );
float b = ( p_top + p_bottom ) / ( p_top - p_bottom ); real_t b = ( p_top + p_bottom ) / ( p_top - p_bottom );
float c = - ( p_far + p_near ) / ( p_far - p_near ); real_t c = - ( p_far + p_near ) / ( p_far - p_near );
float d = - 2 * p_far * p_near / ( p_far - p_near ); real_t d = - 2 * p_far * p_near / ( p_far - p_near );
te[0] = x; te[0] = x;
te[1] = 0; te[1] = 0;
@ -166,9 +166,9 @@ void CameraMatrix::set_frustum(float p_left, float p_right, float p_bottom, floa
float CameraMatrix::get_z_far() const { real_t CameraMatrix::get_z_far() const {
const float * matrix = (const float*)this->matrix; const real_t * matrix = (const real_t*)this->matrix;
Plane new_plane=Plane(matrix[ 3] - matrix[ 2], Plane new_plane=Plane(matrix[ 3] - matrix[ 2],
matrix[ 7] - matrix[ 6], matrix[ 7] - matrix[ 6],
matrix[11] - matrix[10], matrix[11] - matrix[10],
@ -179,9 +179,9 @@ float CameraMatrix::get_z_far() const {
return new_plane.d; return new_plane.d;
} }
float CameraMatrix::get_z_near() const { real_t CameraMatrix::get_z_near() const {
const float * matrix = (const float*)this->matrix; const real_t * matrix = (const real_t*)this->matrix;
Plane new_plane=Plane(matrix[ 3] + matrix[ 2], Plane new_plane=Plane(matrix[ 3] + matrix[ 2],
matrix[ 7] + matrix[ 6], matrix[ 7] + matrix[ 6],
matrix[11] + matrix[10], matrix[11] + matrix[10],
@ -191,9 +191,9 @@ float CameraMatrix::get_z_near() const {
return new_plane.d; return new_plane.d;
} }
void CameraMatrix::get_viewport_size(float& r_width, float& r_height) const { void CameraMatrix::get_viewport_size(real_t& r_width, real_t& r_height) const {
const float * matrix = (const float*)this->matrix; const real_t * matrix = (const real_t*)this->matrix;
///////--- Near Plane ---/////// ///////--- Near Plane ---///////
Plane near_plane=Plane(matrix[ 3] + matrix[ 2], Plane near_plane=Plane(matrix[ 3] + matrix[ 2],
matrix[ 7] + matrix[ 6], matrix[ 7] + matrix[ 6],
@ -223,7 +223,7 @@ void CameraMatrix::get_viewport_size(float& r_width, float& r_height) const {
bool CameraMatrix::get_endpoints(const Transform& p_transform, Vector3 *p_8points) const { bool CameraMatrix::get_endpoints(const Transform& p_transform, Vector3 *p_8points) const {
const float * matrix = (const float*)this->matrix; const real_t * matrix = (const real_t*)this->matrix;
///////--- Near Plane ---/////// ///////--- Near Plane ---///////
Plane near_plane=Plane(matrix[ 3] + matrix[ 2], Plane near_plane=Plane(matrix[ 3] + matrix[ 2],
@ -284,7 +284,7 @@ Vector<Plane> CameraMatrix::get_projection_planes(const Transform& p_transform)
Vector<Plane> planes; Vector<Plane> planes;
const float * matrix = (const float*)this->matrix; const real_t * matrix = (const real_t*)this->matrix;
Plane new_plane; Plane new_plane;
@ -377,9 +377,9 @@ void CameraMatrix::invert() {
int i,j,k; int i,j,k;
int pvt_i[4], pvt_j[4]; /* Locations of pivot matrix */ int pvt_i[4], pvt_j[4]; /* Locations of pivot matrix */
float pvt_val; /* Value of current pivot element */ real_t pvt_val; /* Value of current pivot element */
float hold; /* Temporary storage */ real_t hold; /* Temporary storage */
float determinat; /* Determinant */ real_t determinat; /* Determinant */
determinat = 1.0; determinat = 1.0;
for (k=0; k<4; k++) { for (k=0; k<4; k++) {
@ -492,7 +492,7 @@ CameraMatrix CameraMatrix::operator*(const CameraMatrix& p_matrix) const {
void CameraMatrix::set_light_bias() { void CameraMatrix::set_light_bias() {
float *m=&matrix[0][0]; real_t *m=&matrix[0][0];
m[0]=0.5, m[0]=0.5,
m[1]=0.0, m[1]=0.0,
@ -515,7 +515,7 @@ void CameraMatrix::set_light_bias() {
void CameraMatrix::set_light_atlas_rect(const Rect2& p_rect) { void CameraMatrix::set_light_atlas_rect(const Rect2& p_rect) {
float *m=&matrix[0][0]; real_t *m=&matrix[0][0];
m[0]=p_rect.size.width, m[0]=p_rect.size.width,
m[1]=0.0, m[1]=0.0,
@ -545,9 +545,9 @@ CameraMatrix::operator String() const {
return str; return str;
} }
float CameraMatrix::get_aspect() const { real_t CameraMatrix::get_aspect() const {
float w,h; real_t w,h;
get_viewport_size(w,h); get_viewport_size(w,h);
return w/h; return w/h;
} }
@ -561,8 +561,8 @@ int CameraMatrix::get_pixels_per_meter(int p_for_pixel_width) const {
} }
float CameraMatrix::get_fov() const { real_t CameraMatrix::get_fov() const {
const float * matrix = (const float*)this->matrix; const real_t * matrix = (const real_t*)this->matrix;
Plane right_plane=Plane(matrix[ 3] - matrix[ 0], Plane right_plane=Plane(matrix[ 3] - matrix[ 0],
matrix[ 7] - matrix[ 4], matrix[ 7] - matrix[ 4],
@ -613,7 +613,7 @@ void CameraMatrix::scale_translate_to_fit(const Rect3& p_aabb) {
CameraMatrix::operator Transform() const { CameraMatrix::operator Transform() const {
Transform tr; Transform tr;
const float *m=&matrix[0][0]; const real_t *m=&matrix[0][0];
tr.basis.elements[0][0]=m[0]; tr.basis.elements[0][0]=m[0];
tr.basis.elements[1][0]=m[1]; tr.basis.elements[1][0]=m[1];
@ -637,7 +637,7 @@ CameraMatrix::operator Transform() const {
CameraMatrix::CameraMatrix(const Transform& p_transform) { CameraMatrix::CameraMatrix(const Transform& p_transform) {
const Transform &tr = p_transform; const Transform &tr = p_transform;
float *m=&matrix[0][0]; real_t *m=&matrix[0][0];
m[0]=tr.basis.elements[0][0]; m[0]=tr.basis.elements[0][0];
m[1]=tr.basis.elements[1][0]; m[1]=tr.basis.elements[1][0];

View File

@ -48,32 +48,32 @@ struct CameraMatrix {
PLANE_BOTTOM PLANE_BOTTOM
}; };
float matrix[4][4]; real_t matrix[4][4];
void set_identity(); void set_identity();
void set_zero(); void set_zero();
void set_light_bias(); void set_light_bias();
void set_light_atlas_rect(const Rect2& p_rect); void set_light_atlas_rect(const Rect2& p_rect);
void set_perspective(float p_fovy_degrees, float p_aspect, float p_z_near, float p_z_far,bool p_flip_fov=false); void set_perspective(real_t p_fovy_degrees, real_t p_aspect, real_t p_z_near, real_t p_z_far,bool p_flip_fov=false);
void set_orthogonal(float p_left, float p_right, float p_bottom, float p_top, float p_znear, float p_zfar); void set_orthogonal(real_t p_left, real_t p_right, real_t p_bottom, real_t p_top, real_t p_znear, real_t p_zfar);
void set_orthogonal(float p_size, float p_aspect, float p_znear, float p_zfar,bool p_flip_fov=false); void set_orthogonal(real_t p_size, real_t p_aspect, real_t p_znear, real_t p_zfar,bool p_flip_fov=false);
void set_frustum(float p_left, float p_right, float p_bottom, float p_top, float p_near, float p_far); void set_frustum(real_t p_left, real_t p_right, real_t p_bottom, real_t p_top, real_t p_near, real_t p_far);
static float get_fovy(float p_fovx,float p_aspect) { static real_t get_fovy(real_t p_fovx,real_t p_aspect) {
return Math::rad2deg(Math::atan(p_aspect * Math::tan(Math::deg2rad(p_fovx) * 0.5))*2.0); return Math::rad2deg(Math::atan(p_aspect * Math::tan(Math::deg2rad(p_fovx) * 0.5))*2.0);
} }
float get_z_far() const; real_t get_z_far() const;
float get_z_near() const; real_t get_z_near() const;
float get_aspect() const; real_t get_aspect() const;
float get_fov() const; real_t get_fov() const;
Vector<Plane> get_projection_planes(const Transform& p_transform) const; Vector<Plane> get_projection_planes(const Transform& p_transform) const;
bool get_endpoints(const Transform& p_transform,Vector3 *p_8points) const; bool get_endpoints(const Transform& p_transform,Vector3 *p_8points) const;
void get_viewport_size(float& r_width, float& r_height) const; void get_viewport_size(real_t& r_width, real_t& r_height) const;
void invert(); void invert();
CameraMatrix inverse() const; CameraMatrix inverse() const;
@ -102,7 +102,7 @@ Vector3 CameraMatrix::xform(const Vector3& p_vec3) const {
ret.x = matrix[0][0] * p_vec3.x + matrix[1][0] * p_vec3.y + matrix[2][0] * p_vec3.z + matrix[3][0]; ret.x = matrix[0][0] * p_vec3.x + matrix[1][0] * p_vec3.y + matrix[2][0] * p_vec3.z + matrix[3][0];
ret.y = matrix[0][1] * p_vec3.x + matrix[1][1] * p_vec3.y + matrix[2][1] * p_vec3.z + matrix[3][1]; ret.y = matrix[0][1] * p_vec3.x + matrix[1][1] * p_vec3.y + matrix[2][1] * p_vec3.z + matrix[3][1];
ret.z = matrix[0][2] * p_vec3.x + matrix[1][2] * p_vec3.y + matrix[2][2] * p_vec3.z + matrix[3][2]; ret.z = matrix[0][2] * p_vec3.x + matrix[1][2] * p_vec3.y + matrix[2][2] * p_vec3.z + matrix[3][2];
float w = matrix[0][3] * p_vec3.x + matrix[1][3] * p_vec3.y + matrix[2][3] * p_vec3.z + matrix[3][3]; real_t w = matrix[0][3] * p_vec3.x + matrix[1][3] * p_vec3.y + matrix[2][3] * p_vec3.z + matrix[3][3];
return ret/w; return ret/w;
} }

View File

@ -168,8 +168,8 @@ Face3::Side Face3::get_side_of(const Face3& p_face,ClockDirection p_clock_dir) c
Vector3 Face3::get_random_point_inside() const { Vector3 Face3::get_random_point_inside() const {
float a=Math::random(0,1); real_t a=Math::random(0,1);
float b=Math::random(0,1); real_t b=Math::random(0,1);
if (a>b) { if (a>b) {
SWAP(a,b); SWAP(a,b);
} }
@ -215,9 +215,9 @@ bool Face3::intersects_aabb(const Rect3& p_aabb) const {
#define TEST_AXIS(m_ax)\ #define TEST_AXIS(m_ax)\
{\ {\
float aabb_min=p_aabb.pos.m_ax;\ real_t aabb_min=p_aabb.pos.m_ax;\
float aabb_max=p_aabb.pos.m_ax+p_aabb.size.m_ax;\ real_t aabb_max=p_aabb.pos.m_ax+p_aabb.size.m_ax;\
float tri_min,tri_max;\ real_t tri_min,tri_max;\
for (int i=0;i<3;i++) {\ for (int i=0;i<3;i++) {\
if (i==0 || vertex[i].m_ax > tri_max)\ if (i==0 || vertex[i].m_ax > tri_max)\
tri_max=vertex[i].m_ax;\ tri_max=vertex[i].m_ax;\
@ -255,7 +255,7 @@ bool Face3::intersects_aabb(const Rect3& p_aabb) const {
continue; // coplanar continue; // coplanar
axis.normalize(); axis.normalize();
float minA,maxA,minB,maxB; real_t minA,maxA,minB,maxB;
p_aabb.project_range_in_plane(Plane(axis,0),minA,maxA); p_aabb.project_range_in_plane(Plane(axis,0),minA,maxA);
project_range(axis,Transform(),minB,maxB); project_range(axis,Transform(),minB,maxB);
@ -272,12 +272,12 @@ Face3::operator String() const {
return String()+vertex[0]+", "+vertex[1]+", "+vertex[2]; return String()+vertex[0]+", "+vertex[1]+", "+vertex[2];
} }
void Face3::project_range(const Vector3& p_normal,const Transform& p_transform,float& r_min, float& r_max) const { void Face3::project_range(const Vector3& p_normal,const Transform& p_transform,real_t& r_min, real_t& r_max) const {
for (int i=0;i<3;i++) { for (int i=0;i<3;i++) {
Vector3 v=p_transform.xform(vertex[i]); Vector3 v=p_transform.xform(vertex[i]);
float d=p_normal.dot(v); real_t d=p_normal.dot(v);
if (i==0 || d > r_max) if (i==0 || d > r_max)
r_max=d; r_max=d;
@ -316,11 +316,11 @@ void Face3::get_support(const Vector3& p_normal,const Transform& p_transform,Vec
/** FIND SUPPORT VERTEX **/ /** FIND SUPPORT VERTEX **/
int vert_support_idx=-1; int vert_support_idx=-1;
float support_max; real_t support_max;
for (int i=0;i<3;i++) { for (int i=0;i<3;i++) {
float d=n.dot(vertex[i]); real_t d=n.dot(vertex[i]);
if (i==0 || d > support_max) { if (i==0 || d > support_max) {
support_max=d; support_max=d;
@ -336,7 +336,7 @@ void Face3::get_support(const Vector3& p_normal,const Transform& p_transform,Vec
continue; continue;
// check if edge is valid as a support // check if edge is valid as a support
float dot=(vertex[i]-vertex[(i+1)%3]).normalized().dot(n); real_t dot=(vertex[i]-vertex[(i+1)%3]).normalized().dot(n);
dot=ABS(dot); dot=ABS(dot);
if (dot < _EDGE_IS_VALID_SUPPORT_TRESHOLD) { if (dot < _EDGE_IS_VALID_SUPPORT_TRESHOLD) {
@ -362,15 +362,15 @@ Vector3 Face3::get_closest_point_to(const Vector3& p_point) const {
Vector3 edge1 = vertex[2] - vertex[0]; Vector3 edge1 = vertex[2] - vertex[0];
Vector3 v0 = vertex[0] - p_point; Vector3 v0 = vertex[0] - p_point;
float a = edge0.dot( edge0 ); real_t a = edge0.dot( edge0 );
float b = edge0.dot( edge1 ); real_t b = edge0.dot( edge1 );
float c = edge1.dot( edge1 ); real_t c = edge1.dot( edge1 );
float d = edge0.dot( v0 ); real_t d = edge0.dot( v0 );
float e = edge1.dot( v0 ); real_t e = edge1.dot( v0 );
float det = a*c - b*b; real_t det = a*c - b*b;
float s = b*e - c*d; real_t s = b*e - c*d;
float t = b*d - a*e; real_t t = b*d - a*e;
if ( s + t < det ) if ( s + t < det )
{ {
@ -402,7 +402,7 @@ Vector3 Face3::get_closest_point_to(const Vector3& p_point) const {
} }
else else
{ {
float invDet = 1.f / det; real_t invDet = 1.f / det;
s *= invDet; s *= invDet;
t *= invDet; t *= invDet;
} }
@ -411,12 +411,12 @@ Vector3 Face3::get_closest_point_to(const Vector3& p_point) const {
{ {
if ( s < 0.f ) if ( s < 0.f )
{ {
float tmp0 = b+d; real_t tmp0 = b+d;
float tmp1 = c+e; real_t tmp1 = c+e;
if ( tmp1 > tmp0 ) if ( tmp1 > tmp0 )
{ {
float numer = tmp1 - tmp0; real_t numer = tmp1 - tmp0;
float denom = a-2*b+c; real_t denom = a-2*b+c;
s = CLAMP( numer/denom, 0.f, 1.f ); s = CLAMP( numer/denom, 0.f, 1.f );
t = 1-s; t = 1-s;
} }
@ -430,8 +430,8 @@ Vector3 Face3::get_closest_point_to(const Vector3& p_point) const {
{ {
if ( a+d > b+e ) if ( a+d > b+e )
{ {
float numer = c+e-b-d; real_t numer = c+e-b-d;
float denom = a-2*b+c; real_t denom = a-2*b+c;
s = CLAMP( numer/denom, 0.f, 1.f ); s = CLAMP( numer/denom, 0.f, 1.f );
t = 1-s; t = 1-s;
} }
@ -443,8 +443,8 @@ Vector3 Face3::get_closest_point_to(const Vector3& p_point) const {
} }
else else
{ {
float numer = c+e-b-d; real_t numer = c+e-b-d;
float denom = a-2*b+c; real_t denom = a-2*b+c;
s = CLAMP( numer/denom, 0.f, 1.f ); s = CLAMP( numer/denom, 0.f, 1.f );
t = 1.f - s; t = 1.f - s;
} }

View File

@ -76,7 +76,7 @@ public:
ClockDirection get_clock_dir() const; ///< todo, test if this is returning the proper clockwisity ClockDirection get_clock_dir() const; ///< todo, test if this is returning the proper clockwisity
void get_support(const Vector3& p_normal,const Transform& p_transform,Vector3 *p_vertices,int* p_count,int p_max) const; void get_support(const Vector3& p_normal,const Transform& p_transform,Vector3 *p_vertices,int* p_count,int p_max) const;
void project_range(const Vector3& p_normal,const Transform& p_transform,float& r_min, float& r_max) const; void project_range(const Vector3& p_normal,const Transform& p_transform,real_t& r_min, real_t& r_max) const;
Rect3 get_aabb() const { Rect3 get_aabb() const {
@ -109,9 +109,9 @@ bool Face3::intersects_aabb2(const Rect3& p_aabb) const {
(perp.z>0) ? -half_extents.z : half_extents.z (perp.z>0) ? -half_extents.z : half_extents.z
); );
float d = perp.dot(vertex[0]); real_t d = perp.dot(vertex[0]);
float dist_a = perp.dot(ofs+sup)-d; real_t dist_a = perp.dot(ofs+sup)-d;
float dist_b = perp.dot(ofs-sup)-d; real_t dist_b = perp.dot(ofs-sup)-d;
if (dist_a*dist_b > 0) if (dist_a*dist_b > 0)
return false; //does not intersect the plane return false; //does not intersect the plane
@ -119,9 +119,9 @@ bool Face3::intersects_aabb2(const Rect3& p_aabb) const {
#define TEST_AXIS(m_ax)\ #define TEST_AXIS(m_ax)\
{\ {\
float aabb_min=p_aabb.pos.m_ax;\ real_t aabb_min=p_aabb.pos.m_ax;\
float aabb_max=p_aabb.pos.m_ax+p_aabb.size.m_ax;\ real_t aabb_max=p_aabb.pos.m_ax+p_aabb.size.m_ax;\
float tri_min,tri_max;\ real_t tri_min,tri_max;\
for (int i=0;i<3;i++) {\ for (int i=0;i<3;i++) {\
if (i==0 || vertex[i].m_ax > tri_max)\ if (i==0 || vertex[i].m_ax > tri_max)\
tri_max=vertex[i].m_ax;\ tri_max=vertex[i].m_ax;\
@ -236,16 +236,16 @@ bool Face3::intersects_aabb2(const Rect3& p_aabb) const {
(axis.z>0) ? -half_extents.z : half_extents.z (axis.z>0) ? -half_extents.z : half_extents.z
); );
float maxB = axis.dot(ofs+sup2); real_t maxB = axis.dot(ofs+sup2);
float minB = axis.dot(ofs-sup2); real_t minB = axis.dot(ofs-sup2);
if (minB>maxB) { if (minB>maxB) {
SWAP(maxB,minB); SWAP(maxB,minB);
} }
float minT=1e20,maxT=-1e20; real_t minT=1e20,maxT=-1e20;
for (int k=0;k<3;k++) { for (int k=0;k<3;k++) {
float d=axis.dot(vertex[k]); real_t d=axis.dot(vertex[k]);
if (d > maxT) if (d > maxT)
maxT=d; maxT=d;

View File

@ -580,7 +580,7 @@ static inline void _build_faces(uint8_t*** p_cell_status,int x,int y,int z,int l
} }
PoolVector< Face3 > Geometry::wrap_geometry( PoolVector< Face3 > p_array,float *p_error ) { PoolVector< Face3 > Geometry::wrap_geometry( PoolVector< Face3 > p_array,real_t *p_error ) {
#define _MIN_SIZE 1.0 #define _MIN_SIZE 1.0
#define _MAX_LENGTH 20 #define _MAX_LENGTH 20
@ -755,7 +755,7 @@ Geometry::MeshData Geometry::build_convex_mesh(const PoolVector<Plane> &p_planes
#define SUBPLANE_SIZE 1024.0 #define SUBPLANE_SIZE 1024.0
float subplane_size = 1024.0; // should compute this from the actual plane real_t subplane_size = 1024.0; // should compute this from the actual plane
for (int i=0;i<p_planes.size();i++) { for (int i=0;i<p_planes.size();i++) {
Plane p =p_planes[i]; Plane p =p_planes[i];
@ -910,7 +910,7 @@ PoolVector<Plane> Geometry::build_box_planes(const Vector3& p_extents) {
return planes; return planes;
} }
PoolVector<Plane> Geometry::build_cylinder_planes(float p_radius, float p_height, int p_sides, Vector3::Axis p_axis) { PoolVector<Plane> Geometry::build_cylinder_planes(real_t p_radius, real_t p_height, int p_sides, Vector3::Axis p_axis) {
PoolVector<Plane> planes; PoolVector<Plane> planes;
@ -933,7 +933,7 @@ PoolVector<Plane> Geometry::build_cylinder_planes(float p_radius, float p_height
} }
PoolVector<Plane> Geometry::build_sphere_planes(float p_radius, int p_lats,int p_lons, Vector3::Axis p_axis) { PoolVector<Plane> Geometry::build_sphere_planes(real_t p_radius, int p_lats,int p_lons, Vector3::Axis p_axis) {
PoolVector<Plane> planes; PoolVector<Plane> planes;
@ -957,7 +957,7 @@ PoolVector<Plane> Geometry::build_sphere_planes(float p_radius, int p_lats,int p
for (int j=1;j<=p_lats;j++) { for (int j=1;j<=p_lats;j++) {
//todo this is stupid, fix //todo this is stupid, fix
Vector3 angle = normal.linear_interpolate(axis,j/(float)p_lats).normalized(); Vector3 angle = normal.linear_interpolate(axis,j/(real_t)p_lats).normalized();
Vector3 pos = angle*p_radius; Vector3 pos = angle*p_radius;
planes.push_back( Plane( pos, angle ) ); planes.push_back( Plane( pos, angle ) );
planes.push_back( Plane( pos * axis_neg, angle * axis_neg) ); planes.push_back( Plane( pos * axis_neg, angle * axis_neg) );
@ -969,7 +969,7 @@ PoolVector<Plane> Geometry::build_sphere_planes(float p_radius, int p_lats,int p
} }
PoolVector<Plane> Geometry::build_capsule_planes(float p_radius, float p_height, int p_sides, int p_lats, Vector3::Axis p_axis) { PoolVector<Plane> Geometry::build_capsule_planes(real_t p_radius, real_t p_height, int p_sides, int p_lats, Vector3::Axis p_axis) {
PoolVector<Plane> planes; PoolVector<Plane> planes;
@ -991,7 +991,7 @@ PoolVector<Plane> Geometry::build_capsule_planes(float p_radius, float p_height,
for (int j=1;j<=p_lats;j++) { for (int j=1;j<=p_lats;j++) {
Vector3 angle = normal.linear_interpolate(axis,j/(float)p_lats).normalized(); Vector3 angle = normal.linear_interpolate(axis,j/(real_t)p_lats).normalized();
Vector3 pos = axis*p_height*0.5 + angle*p_radius; Vector3 pos = axis*p_height*0.5 + angle*p_radius;
planes.push_back( Plane( pos, angle ) ); planes.push_back( Plane( pos, angle ) );
planes.push_back( Plane( pos * axis_neg, angle * axis_neg) ); planes.push_back( Plane( pos * axis_neg, angle * axis_neg) );
@ -1108,13 +1108,13 @@ void Geometry::make_atlas(const Vector<Size2i>& p_rects,Vector<Point2i>& r_resul
//find the result with the best aspect ratio //find the result with the best aspect ratio
int best=-1; int best=-1;
float best_aspect=1e20; real_t best_aspect=1e20;
for(int i=0;i<results.size();i++) { for(int i=0;i<results.size();i++) {
float h = nearest_power_of_2(results[i].max_h); real_t h = nearest_power_of_2(results[i].max_h);
float w = nearest_power_of_2(results[i].max_w); real_t w = nearest_power_of_2(results[i].max_w);
float aspect = h>w ? h/w : w/h; real_t aspect = h>w ? h/w : w/h;
if (aspect < best_aspect) { if (aspect < best_aspect) {
best=i; best=i;
best_aspect=aspect; best_aspect=aspect;

View File

@ -48,15 +48,15 @@ public:
static float get_closest_points_between_segments( const Vector2& p1,const Vector2& q1, const Vector2& p2,const Vector2& q2, Vector2& c1, Vector2& c2) { static real_t get_closest_points_between_segments( const Vector2& p1,const Vector2& q1, const Vector2& p2,const Vector2& q2, Vector2& c1, Vector2& c2) {
Vector2 d1 = q1 - p1; // Direction vector of segment S1 Vector2 d1 = q1 - p1; // Direction vector of segment S1
Vector2 d2 = q2 - p2; // Direction vector of segment S2 Vector2 d2 = q2 - p2; // Direction vector of segment S2
Vector2 r = p1 - p2; Vector2 r = p1 - p2;
float a = d1.dot(d1); // Squared length of segment S1, always nonnegative real_t a = d1.dot(d1); // Squared length of segment S1, always nonnegative
float e = d2.dot(d2); // Squared length of segment S2, always nonnegative real_t e = d2.dot(d2); // Squared length of segment S2, always nonnegative
float f = d2.dot(r); real_t f = d2.dot(r);
float s,t; real_t s,t;
// Check if either or both segments degenerate into points // Check if either or both segments degenerate into points
if (a <= CMP_EPSILON && e <= CMP_EPSILON) { if (a <= CMP_EPSILON && e <= CMP_EPSILON) {
// Both segments degenerate into points // Both segments degenerate into points
@ -66,25 +66,25 @@ public:
} }
if (a <= CMP_EPSILON) { if (a <= CMP_EPSILON) {
// First segment degenerates into a point // First segment degenerates into a point
s = 0.0f; s = 0.0;
t = f / e; // s = 0 => t = (b*s + f) / e = f / e t = f / e; // s = 0 => t = (b*s + f) / e = f / e
t = CLAMP(t, 0.0f, 1.0f); t = CLAMP(t, 0.0, 1.0);
} else { } else {
float c = d1.dot(r); real_t c = d1.dot(r);
if (e <= CMP_EPSILON) { if (e <= CMP_EPSILON) {
// Second segment degenerates into a point // Second segment degenerates into a point
t = 0.0f; t = 0.0;
s = CLAMP(-c / a, 0.0f, 1.0f); // t = 0 => s = (b*t - c) / a = -c / a s = CLAMP(-c / a, 0.0, 1.0); // t = 0 => s = (b*t - c) / a = -c / a
} else { } else {
// The general nondegenerate case starts here // The general nondegenerate case starts here
float b = d1.dot(d2); real_t b = d1.dot(d2);
float denom = a*e-b*b; // Always nonnegative real_t denom = a*e-b*b; // Always nonnegative
// If segments not parallel, compute closest point on L1 to L2 and // If segments not parallel, compute closest point on L1 to L2 and
// clamp to segment S1. Else pick arbitrary s (here 0) // clamp to segment S1. Else pick arbitrary s (here 0)
if (denom != 0.0f) { if (denom != 0.0) {
s = CLAMP((b*f - c*e) / denom, 0.0f, 1.0f); s = CLAMP((b*f - c*e) / denom, 0.0, 1.0);
} else } else
s = 0.0f; s = 0.0;
// Compute point on L2 closest to S1(s) using // Compute point on L2 closest to S1(s) using
// t = Dot((P1 + D1*s) - P2,D2) / Dot(D2,D2) = (b*s + f) / e // t = Dot((P1 + D1*s) - P2,D2) / Dot(D2,D2) = (b*s + f) / e
t = (b*s + f) / e; t = (b*s + f) / e;
@ -92,12 +92,12 @@ public:
//If t in [0,1] done. Else clamp t, recompute s for the new value //If t in [0,1] done. Else clamp t, recompute s for the new value
// of t using s = Dot((P2 + D2*t) - P1,D1) / Dot(D1,D1)= (t*b - c) / a // of t using s = Dot((P2 + D2*t) - P1,D1) / Dot(D1,D1)= (t*b - c) / a
// and clamp s to [0, 1] // and clamp s to [0, 1]
if (t < 0.0f) { if (t < 0.0) {
t = 0.0f; t = 0.0;
s = CLAMP(-c / a, 0.0f, 1.0f); s = CLAMP(-c / a, 0.0, 1.0);
} else if (t > 1.0f) { } else if (t > 1.0) {
t = 1.0f; t = 1.0;
s = CLAMP((b - c) / a, 0.0f, 1.0f); s = CLAMP((b - c) / a, 0.0, 1.0);
} }
} }
} }
@ -113,8 +113,8 @@ public:
#define d_of(m,n,o,p) ( (m.x - n.x) * (o.x - p.x) + (m.y - n.y) * (o.y - p.y) + (m.z - n.z) * (o.z - p.z) ) #define d_of(m,n,o,p) ( (m.x - n.x) * (o.x - p.x) + (m.y - n.y) * (o.y - p.y) + (m.z - n.z) * (o.z - p.z) )
//caluclate the parpametric position on the 2 curves, mua and mub //caluclate the parpametric position on the 2 curves, mua and mub
float mua = ( d_of(p1,q1,q2,q1) * d_of(q2,q1,p2,p1) - d_of(p1,q1,p2,p1) * d_of(q2,q1,q2,q1) ) / ( d_of(p2,p1,p2,p1) * d_of(q2,q1,q2,q1) - d_of(q2,q1,p2,p1) * d_of(q2,q1,p2,p1) ); real_t mua = ( d_of(p1,q1,q2,q1) * d_of(q2,q1,p2,p1) - d_of(p1,q1,p2,p1) * d_of(q2,q1,q2,q1) ) / ( d_of(p2,p1,p2,p1) * d_of(q2,q1,q2,q1) - d_of(q2,q1,p2,p1) * d_of(q2,q1,p2,p1) );
float mub = ( d_of(p1,q1,q2,q1) + mua * d_of(q2,q1,p2,p1) ) / d_of(q2,q1,q2,q1); real_t mub = ( d_of(p1,q1,q2,q1) + mua * d_of(q2,q1,p2,p1) ) / d_of(q2,q1,q2,q1);
//clip the value between [0..1] constraining the solution to lie on the original curves //clip the value between [0..1] constraining the solution to lie on the original curves
if (mua < 0) mua = 0; if (mua < 0) mua = 0;
@ -125,7 +125,7 @@ public:
c2 = q1.linear_interpolate(q2,mub); c2 = q1.linear_interpolate(q2,mub);
} }
static float get_closest_distance_between_segments( const Vector3& p_from_a,const Vector3& p_to_a, const Vector3& p_from_b,const Vector3& p_to_b) { static real_t get_closest_distance_between_segments( const Vector3& p_from_a,const Vector3& p_to_a, const Vector3& p_from_b,const Vector3& p_to_b) {
Vector3 u = p_to_a - p_from_a; Vector3 u = p_to_a - p_from_a;
Vector3 v = p_to_b - p_from_b; Vector3 v = p_to_b - p_from_b;
Vector3 w = p_from_a - p_to_a; Vector3 w = p_from_a - p_to_a;
@ -273,22 +273,22 @@ public:
Vector3 sphere_pos=p_sphere_pos-p_from; Vector3 sphere_pos=p_sphere_pos-p_from;
Vector3 rel=(p_to-p_from); Vector3 rel=(p_to-p_from);
float rel_l=rel.length(); real_t rel_l=rel.length();
if (rel_l<CMP_EPSILON) if (rel_l<CMP_EPSILON)
return false; // both points are the same return false; // both points are the same
Vector3 normal=rel/rel_l; Vector3 normal=rel/rel_l;
float sphere_d=normal.dot(sphere_pos); real_t sphere_d=normal.dot(sphere_pos);
//Vector3 ray_closest=normal*sphere_d; //Vector3 ray_closest=normal*sphere_d;
float ray_distance=sphere_pos.distance_to(normal*sphere_d); real_t ray_distance=sphere_pos.distance_to(normal*sphere_d);
if (ray_distance>=p_sphere_radius) if (ray_distance>=p_sphere_radius)
return false; return false;
float inters_d2=p_sphere_radius*p_sphere_radius - ray_distance*ray_distance; real_t inters_d2=p_sphere_radius*p_sphere_radius - ray_distance*ray_distance;
float inters_d=sphere_d; real_t inters_d=sphere_d;
if (inters_d2>=CMP_EPSILON) if (inters_d2>=CMP_EPSILON)
inters_d-=Math::sqrt(inters_d2); inters_d-=Math::sqrt(inters_d2);
@ -307,17 +307,17 @@ public:
return true; return true;
} }
static inline bool segment_intersects_cylinder( const Vector3& p_from, const Vector3& p_to, float p_height,float p_radius,Vector3* r_res=0,Vector3 *r_norm=0) { static inline bool segment_intersects_cylinder( const Vector3& p_from, const Vector3& p_to, real_t p_height,real_t p_radius,Vector3* r_res=0,Vector3 *r_norm=0) {
Vector3 rel=(p_to-p_from); Vector3 rel=(p_to-p_from);
float rel_l=rel.length(); real_t rel_l=rel.length();
if (rel_l<CMP_EPSILON) if (rel_l<CMP_EPSILON)
return false; // both points are the same return false; // both points are the same
// first check if they are parallel // first check if they are parallel
Vector3 normal=(rel/rel_l); Vector3 normal=(rel/rel_l);
Vector3 crs = normal.cross(Vector3(0,0,1)); Vector3 crs = normal.cross(Vector3(0,0,1));
float crs_l=crs.length(); real_t crs_l=crs.length();
Vector3 z_dir; Vector3 z_dir;
@ -328,13 +328,13 @@ public:
z_dir=crs/crs_l; z_dir=crs/crs_l;
} }
float dist=z_dir.dot(p_from); real_t dist=z_dir.dot(p_from);
if (dist>=p_radius) if (dist>=p_radius)
return false; // too far away return false; // too far away
// convert to 2D // convert to 2D
float w2=p_radius*p_radius-dist*dist; real_t w2=p_radius*p_radius-dist*dist;
if (w2<CMP_EPSILON) if (w2<CMP_EPSILON)
return false; //avoid numerical error return false; //avoid numerical error
Size2 size(Math::sqrt(w2),p_height*0.5); Size2 size(Math::sqrt(w2),p_height*0.5);
@ -344,7 +344,7 @@ public:
Vector2 from2D(x_dir.dot(p_from),p_from.z); Vector2 from2D(x_dir.dot(p_from),p_from.z);
Vector2 to2D(x_dir.dot(p_to),p_to.z); Vector2 to2D(x_dir.dot(p_to),p_to.z);
float min=0,max=1; real_t min=0,max=1;
int axis=-1; int axis=-1;
@ -464,12 +464,12 @@ public:
Vector3 p=p_point-p_segment[0]; Vector3 p=p_point-p_segment[0];
Vector3 n=p_segment[1]-p_segment[0]; Vector3 n=p_segment[1]-p_segment[0];
float l =n.length(); real_t l =n.length();
if (l<1e-10) if (l<1e-10)
return p_segment[0]; // both points are the same, just give any return p_segment[0]; // both points are the same, just give any
n/=l; n/=l;
float d=n.dot(p); real_t d=n.dot(p);
if (d<=0.0) if (d<=0.0)
return p_segment[0]; // before first point return p_segment[0]; // before first point
@ -483,12 +483,12 @@ public:
Vector3 p=p_point-p_segment[0]; Vector3 p=p_point-p_segment[0];
Vector3 n=p_segment[1]-p_segment[0]; Vector3 n=p_segment[1]-p_segment[0];
float l =n.length(); real_t l =n.length();
if (l<1e-10) if (l<1e-10)
return p_segment[0]; // both points are the same, just give any return p_segment[0]; // both points are the same, just give any
n/=l; n/=l;
float d=n.dot(p); real_t d=n.dot(p);
return p_segment[0]+n*d; // inside return p_segment[0]+n*d; // inside
} }
@ -497,12 +497,12 @@ public:
Vector2 p=p_point-p_segment[0]; Vector2 p=p_point-p_segment[0];
Vector2 n=p_segment[1]-p_segment[0]; Vector2 n=p_segment[1]-p_segment[0];
float l =n.length(); real_t l =n.length();
if (l<1e-10) if (l<1e-10)
return p_segment[0]; // both points are the same, just give any return p_segment[0]; // both points are the same, just give any
n/=l; n/=l;
float d=n.dot(p); real_t d=n.dot(p);
if (d<=0.0) if (d<=0.0)
return p_segment[0]; // before first point return p_segment[0]; // before first point
@ -529,12 +529,12 @@ public:
Vector2 p=p_point-p_segment[0]; Vector2 p=p_point-p_segment[0];
Vector2 n=p_segment[1]-p_segment[0]; Vector2 n=p_segment[1]-p_segment[0];
float l =n.length(); real_t l =n.length();
if (l<1e-10) if (l<1e-10)
return p_segment[0]; // both points are the same, just give any return p_segment[0]; // both points are the same, just give any
n/=l; n/=l;
float d=n.dot(p); real_t d=n.dot(p);
return p_segment[0]+n*d; // inside return p_segment[0]+n*d; // inside
} }
@ -555,7 +555,7 @@ public:
if ((C.y<0 && D.y<0) || (C.y>=0 && D.y>=0)) if ((C.y<0 && D.y<0) || (C.y>=0 && D.y>=0))
return false; return false;
float ABpos=D.x+(C.x-D.x)*D.y/(D.y-C.y); real_t ABpos=D.x+(C.x-D.x)*D.y/(D.y-C.y);
// Fail if segment C-D crosses line A-B outside of segment A-B. // Fail if segment C-D crosses line A-B outside of segment A-B.
if (ABpos<0 || ABpos>1.0) if (ABpos<0 || ABpos>1.0)
@ -595,7 +595,7 @@ public:
static inline bool triangle_sphere_intersection_test(const Vector3 *p_triangle,const Vector3& p_normal,const Vector3& p_sphere_pos, real_t p_sphere_radius,Vector3& r_triangle_contact,Vector3& r_sphere_contact) { static inline bool triangle_sphere_intersection_test(const Vector3 *p_triangle,const Vector3& p_normal,const Vector3& p_sphere_pos, real_t p_sphere_radius,Vector3& r_triangle_contact,Vector3& r_sphere_contact) {
float d=p_normal.dot(p_sphere_pos)-p_normal.dot(p_triangle[0]); real_t d=p_normal.dot(p_sphere_pos)-p_normal.dot(p_triangle[0]);
if (d > p_sphere_radius || d < -p_sphere_radius) // not touching the plane of the face, return if (d > p_sphere_radius || d < -p_sphere_radius) // not touching the plane of the face, return
return false; return false;
@ -629,7 +629,7 @@ public:
Vector3 axis =n1.cross(n2).cross(n1); Vector3 axis =n1.cross(n2).cross(n1);
axis.normalize(); // ugh axis.normalize(); // ugh
float ad=axis.dot(n2); real_t ad=axis.dot(n2);
if (ABS(ad)>p_sphere_radius) { if (ABS(ad)>p_sphere_radius) {
// no chance with this edge, too far away // no chance with this edge, too far away
@ -639,7 +639,7 @@ public:
// check point within edge capsule cylinder // check point within edge capsule cylinder
/** 4th TEST INSIDE EDGE POINTS **/ /** 4th TEST INSIDE EDGE POINTS **/
float sphere_at = n1.dot(n2); real_t sphere_at = n1.dot(n2);
if (sphere_at>=0 && sphere_at<n1.dot(n1)) { if (sphere_at>=0 && sphere_at<n1.dot(n1)) {
@ -650,7 +650,7 @@ public:
return true; return true;
} }
float r2=p_sphere_radius*p_sphere_radius; real_t r2=p_sphere_radius*p_sphere_radius;
if (n2.length_squared()<r2) { if (n2.length_squared()<r2) {
@ -726,8 +726,8 @@ public:
int outside_count = 0; int outside_count = 0;
for (int a = 0; a < polygon.size(); a++) { for (int a = 0; a < polygon.size(); a++) {
//float p_plane.d = (*this) * polygon[a]; //real_t p_plane.d = (*this) * polygon[a];
float dist = p_plane.distance_to(polygon[a]); real_t dist = p_plane.distance_to(polygon[a]);
if (dist <-CMP_POINT_IN_PLANE_EPSILON) { if (dist <-CMP_POINT_IN_PLANE_EPSILON) {
location_cache[a] = LOC_INSIDE; location_cache[a] = LOC_INSIDE;
inside_count++; inside_count++;
@ -761,8 +761,8 @@ public:
const Vector3& v2 = polygon[index]; const Vector3& v2 = polygon[index];
Vector3 segment= v1 - v2; Vector3 segment= v1 - v2;
double den=p_plane.normal.dot( segment ); real_t den=p_plane.normal.dot( segment );
double dist=p_plane.distance_to( v1 ) / den; real_t dist=p_plane.distance_to( v1 ) / den;
dist=-dist; dist=-dist;
clipped.push_back( v1 + segment * dist ); clipped.push_back( v1 + segment * dist );
} }
@ -771,8 +771,8 @@ public:
if ((loc == LOC_INSIDE) && (location_cache[previous] == LOC_OUTSIDE)) { if ((loc == LOC_INSIDE) && (location_cache[previous] == LOC_OUTSIDE)) {
const Vector3& v2 = polygon[previous]; const Vector3& v2 = polygon[previous];
Vector3 segment= v1 - v2; Vector3 segment= v1 - v2;
double den=p_plane.normal.dot( segment ); real_t den=p_plane.normal.dot( segment );
double dist=p_plane.distance_to( v1 ) / den; real_t dist=p_plane.distance_to( v1 ) / den;
dist=-dist; dist=-dist;
clipped.push_back( v1 + segment * dist ); clipped.push_back( v1 + segment * dist );
} }
@ -808,7 +808,7 @@ public:
static PoolVector< PoolVector< Face3 > > separate_objects( PoolVector< Face3 > p_array ); static PoolVector< PoolVector< Face3 > > separate_objects( PoolVector< Face3 > p_array );
static PoolVector< Face3 > wrap_geometry( PoolVector< Face3 > p_array, float *p_error=NULL ); ///< create a "wrap" that encloses the given geometry static PoolVector< Face3 > wrap_geometry( PoolVector< Face3 > p_array, real_t *p_error=NULL ); ///< create a "wrap" that encloses the given geometry
struct MeshData { struct MeshData {
@ -884,9 +884,9 @@ public:
} }
static double vec2_cross(const Point2 &O, const Point2 &A, const Point2 &B) static real_t vec2_cross(const Point2 &O, const Point2 &A, const Point2 &B)
{ {
return (double)(A.x - O.x) * (B.y - O.y) - (double)(A.y - O.y) * (B.x - O.x); return (real_t)(A.x - O.x) * (B.y - O.y) - (real_t)(A.y - O.y) * (B.x - O.x);
} }
// Returns a list of points on the convex hull in counter-clockwise order. // Returns a list of points on the convex hull in counter-clockwise order.
@ -918,10 +918,10 @@ public:
} }
static MeshData build_convex_mesh(const PoolVector<Plane> &p_planes); static MeshData build_convex_mesh(const PoolVector<Plane> &p_planes);
static PoolVector<Plane> build_sphere_planes(float p_radius, int p_lats, int p_lons, Vector3::Axis p_axis=Vector3::AXIS_Z); static PoolVector<Plane> build_sphere_planes(real_t p_radius, int p_lats, int p_lons, Vector3::Axis p_axis=Vector3::AXIS_Z);
static PoolVector<Plane> build_box_planes(const Vector3& p_extents); static PoolVector<Plane> build_box_planes(const Vector3& p_extents);
static PoolVector<Plane> build_cylinder_planes(float p_radius, float p_height, int p_sides, Vector3::Axis p_axis=Vector3::AXIS_Z); static PoolVector<Plane> build_cylinder_planes(real_t p_radius, real_t p_height, int p_sides, Vector3::Axis p_axis=Vector3::AXIS_Z);
static PoolVector<Plane> build_capsule_planes(float p_radius, float p_height, int p_sides, int p_lats, Vector3::Axis p_axis=Vector3::AXIS_Z); static PoolVector<Plane> build_capsule_planes(real_t p_radius, real_t p_height, int p_sides, int p_lats, Vector3::Axis p_axis=Vector3::AXIS_Z);
static void make_atlas(const Vector<Size2i>& p_rects,Vector<Point2i>& r_result, Size2i& r_size); static void make_atlas(const Vector<Size2i>& p_rects,Vector<Point2i>& r_result, Size2i& r_size);

View File

@ -239,10 +239,10 @@ Vector2 Vector2::cubic_interpolate(const Vector2& p_b,const Vector2& p_pre_a, co
real_t t3 = t2 * t; real_t t3 = t2 * t;
Vector2 out; Vector2 out;
out = 0.5f * ( ( p1 * 2.0f) + out = 0.5 * ( ( p1 * 2.0) +
( -p0 + p2 ) * t + ( -p0 + p2 ) * t +
( 2.0f * p0 - 5.0f * p1 + 4 * p2 - p3 ) * t2 + ( 2.0 * p0 - 5.0 * p1 + 4 * p2 - p3 ) * t2 +
( -p0 + 3.0f * p1 - 3.0f * p2 + p3 ) * t3 ); ( -p0 + 3.0 * p1 - 3.0 * p2 + p3 ) * t3 );
return out; return out;
/* /*

View File

@ -63,35 +63,8 @@ uint32_t Math::rand() {
return pcg32_random_r(&default_pcg); return pcg32_random_r(&default_pcg);
} }
double Math::randf() {
return (double)rand() / (double)Math::RANDOM_MAX;
}
double Math::round(double p_val) {
if (p_val>=0) {
return ::floor(p_val+0.5);
} else {
p_val=-p_val;
return -::floor(p_val+0.5);
}
}
double Math::dectime(double p_value,double p_amount, double p_step) {
float sgn = p_value < 0 ? -1.0 : 1.0;
float val = absf(p_value);
val-=p_amount*p_step;
if (val<0.0)
val=0.0;
return val*sgn;
}
int Math::step_decimals(double p_step) { int Math::step_decimals(double p_step) {
static const int maxn=9; static const int maxn=9;
static const double sd[maxn]={ static const double sd[maxn]={
0.9999, // somehow compensate for floating point error 0.9999, // somehow compensate for floating point error
@ -105,7 +78,7 @@ int Math::step_decimals(double p_step) {
0.000000009999 0.000000009999
}; };
double as=absf(p_step); double as=Math::abs(p_step);
for(int i=0;i<maxn;i++) { for(int i=0;i<maxn;i++) {
if (as>=sd[i]) { if (as>=sd[i]) {
return i; return i;
@ -115,8 +88,16 @@ int Math::step_decimals(double p_step) {
return maxn; return maxn;
} }
double Math::ease(double p_x, double p_c) { double Math::dectime(double p_value,double p_amount, double p_step) {
double sgn = p_value < 0 ? -1.0 : 1.0;
double val = Math::abs(p_value);
val-=p_amount*p_step;
if (val<0.0)
val=0.0;
return val*sgn;
}
double Math::ease(double p_x, double p_c) {
if (p_x<0) if (p_x<0)
p_x=0; p_x=0;
else if (p_x>1.0) else if (p_x>1.0)
@ -137,20 +118,16 @@ double Math::ease(double p_x, double p_c) {
} }
} else } else
return 0; // no ease (raw) return 0; // no ease (raw)
} }
double Math::stepify(double p_value,double p_step) { double Math::stepify(double p_value,double p_step) {
if (p_step!=0) { if (p_step!=0) {
p_value=Math::floor( p_value / p_step + 0.5 ) * p_step;
p_value=floor( p_value / p_step + 0.5 ) * p_step;
} }
return p_value; return p_value;
} }
uint32_t Math::larger_prime(uint32_t p_val) { uint32_t Math::larger_prime(uint32_t p_val) {
static const uint32_t primes[] = { static const uint32_t primes[] = {
@ -199,22 +176,15 @@ uint32_t Math::larger_prime(uint32_t p_val) {
} }
double Math::random(double from, double to) { double Math::random(double from, double to) {
unsigned int r = Math::rand(); unsigned int r = Math::rand();
double ret = (double)r/(double)RANDOM_MAX; double ret = (double)r/(double)RANDOM_MAX;
return (ret)*(to-from) + from; return (ret)*(to-from) + from;
} }
double Math::pow(double x, double y) { float Math::random(float from, float to) {
unsigned int r = Math::rand();
return ::pow(x,y); float ret = (float)r/(float)RANDOM_MAX;
return (ret)*(to-from) + from;
} }
double Math::log(double x) {
return ::log(x);
}
double Math::exp(double x) {
return ::exp(x);
}

View File

@ -39,6 +39,7 @@
#define Math_PI 3.14159265358979323846 #define Math_PI 3.14159265358979323846
#define Math_SQRT12 0.7071067811865475244008443621048490 #define Math_SQRT12 0.7071067811865475244008443621048490
#define Math_LN2 0.693147180559945309417
class Math { class Math {
@ -52,149 +53,122 @@ public:
}; };
static _ALWAYS_INLINE_ double sin(double p_x) { static _ALWAYS_INLINE_ double sin(double p_x) { return ::sin(p_x); }
static _ALWAYS_INLINE_ float sin(float p_x) { return ::sinf(p_x); }
return ::sin(p_x); static _ALWAYS_INLINE_ double cos(double p_x) { return ::cos(p_x); }
static _ALWAYS_INLINE_ float cos(float p_x) { return ::cosf(p_x); }
} static _ALWAYS_INLINE_ double tan(double p_x) { return ::tan(p_x); }
static _ALWAYS_INLINE_ float tan(float p_x) { return ::tanf(p_x); }
static _ALWAYS_INLINE_ double cos(double p_x) { static _ALWAYS_INLINE_ double sinh(double p_x) { return ::sinh(p_x); }
static _ALWAYS_INLINE_ float sinh(float p_x) { return ::sinhf(p_x); }
return ::cos(p_x); static _ALWAYS_INLINE_ double cosh(double p_x) { return ::cosh(p_x); }
static _ALWAYS_INLINE_ float cosh(float p_x) { return ::coshf(p_x); }
} static _ALWAYS_INLINE_ double tanh(double p_x) { return ::tanh(p_x); }
static _ALWAYS_INLINE_ float tanh(float p_x) { return ::tanhf(p_x); }
static _ALWAYS_INLINE_ double tan(double p_x) { static _ALWAYS_INLINE_ double asin(double p_x) { return ::asin(p_x); }
static _ALWAYS_INLINE_ float asin(float p_x) { return ::asinf(p_x); }
return ::tan(p_x); static _ALWAYS_INLINE_ double acos(double p_x) { return ::acos(p_x); }
static _ALWAYS_INLINE_ float acos(float p_x) { return ::acosf(p_x); }
} static _ALWAYS_INLINE_ double atan(double p_x) { return ::atan(p_x); }
static _ALWAYS_INLINE_ double sinh(double p_x) { static _ALWAYS_INLINE_ float atan(float p_x) { return ::atanf(p_x); }
return ::sinh(p_x); static _ALWAYS_INLINE_ double atan2(double p_y, double p_x) { return ::atan2(p_y,p_x); }
} static _ALWAYS_INLINE_ float atan2(float p_y, float p_x) { return ::atan2f(p_y,p_x); }
static _ALWAYS_INLINE_ double cosh(double p_x) { static _ALWAYS_INLINE_ double sqrt(double p_x) { return ::sqrt(p_x); }
static _ALWAYS_INLINE_ float sqrt(float p_x) { return ::sqrtf(p_x); }
return ::cosh(p_x); static _ALWAYS_INLINE_ double fmod(double p_x,double p_y) { return ::fmod(p_x,p_y); }
} static _ALWAYS_INLINE_ float fmod(float p_x,float p_y) { return ::fmodf(p_x,p_y); }
static _ALWAYS_INLINE_ double tanh(double p_x) { static _ALWAYS_INLINE_ double floor(double p_x) { return ::floor(p_x); }
static _ALWAYS_INLINE_ float floor(float p_x) { return ::floorf(p_x); }
return ::tanh(p_x); static _ALWAYS_INLINE_ double ceil(double p_x) { return ::ceil(p_x); }
} static _ALWAYS_INLINE_ float ceil(float p_x) { return ::ceilf(p_x); }
static _ALWAYS_INLINE_ double pow(double p_x, double p_y) { return ::pow(p_x,p_y); }
static _ALWAYS_INLINE_ float pow(float p_x, float p_y) { return ::powf(p_x,p_y); }
static _ALWAYS_INLINE_ double asin(double p_x) { static _ALWAYS_INLINE_ double log(double p_x) { return ::log(p_x); }
static _ALWAYS_INLINE_ float log(float p_x) { return ::logf(p_x); }
return ::asin(p_x); static _ALWAYS_INLINE_ double exp(double p_x) { return ::exp(p_x); }
static _ALWAYS_INLINE_ float exp(float p_x) { return ::expf(p_x); }
} static _ALWAYS_INLINE_ bool is_nan(double p_val) { return (p_val!=p_val); }
static _ALWAYS_INLINE_ bool is_nan(float p_val) { return (p_val!=p_val); }
static _ALWAYS_INLINE_ double acos(double p_x) {
return ::acos(p_x);
}
static _ALWAYS_INLINE_ double atan(double p_x) {
return ::atan(p_x);
}
static _ALWAYS_INLINE_ double atan2(double p_y, double p_x) {
return ::atan2(p_y,p_x);
}
static _ALWAYS_INLINE_ double deg2rad(double p_y) {
return p_y*Math_PI/180.0;
}
static _ALWAYS_INLINE_ double rad2deg(double p_y) {
return p_y*180.0/Math_PI;
}
static _ALWAYS_INLINE_ double sqrt(double p_x) {
return ::sqrt(p_x);
}
static _ALWAYS_INLINE_ double fmod(double p_x,double p_y) {
return ::fmod(p_x,p_y);
}
static _ALWAYS_INLINE_ double fposmod(double p_x,double p_y) {
if (p_x>=0) {
return fmod(p_x,p_y);
} else {
return p_y-fmod(-p_x,p_y);
}
}
static _ALWAYS_INLINE_ double floor(double p_x) {
return ::floor(p_x);
}
static _ALWAYS_INLINE_ double ceil(double p_x) {
return ::ceil(p_x);
}
static uint32_t rand_from_seed(uint64_t *seed);
static double ease(double p_x, double p_c);
static int step_decimals(double p_step);
static double stepify(double p_value,double p_step);
static void seed(uint64_t x=0);
static void randomize();
static uint32_t larger_prime(uint32_t p_val);
static double dectime(double p_value,double p_amount, double p_step);
static inline double linear2db(double p_linear) {
return Math::log( p_linear ) * 8.6858896380650365530225783783321;
}
static inline double db2linear(double p_db) {
return Math::exp( p_db * 0.11512925464970228420089957273422 );
}
static _ALWAYS_INLINE_ bool is_nan(double p_val) {
return (p_val!=p_val);
}
static _ALWAYS_INLINE_ bool is_inf(double p_val) { static _ALWAYS_INLINE_ bool is_inf(double p_val) {
#ifdef _MSC_VER #ifdef _MSC_VER
return !_finite(p_val); return !_finite(p_val);
#else #else
return isinf(p_val); return isinf(p_val);
#endif #endif
} }
static _ALWAYS_INLINE_ bool is_inf(float p_val) {
#ifdef _MSC_VER
return !_finite(p_val);
#else
return isinf(p_val);
#endif
}
static _ALWAYS_INLINE_ double abs(double g) { return absd(g); }
static _ALWAYS_INLINE_ float abs(float g) { return absf(g); }
static _ALWAYS_INLINE_ int abs(int g) { return g > 0 ? g : -g; }
static _ALWAYS_INLINE_ double fposmod(double p_x,double p_y) { return (p_x>=0) ? Math::fmod(p_x,p_y) : p_y-Math::fmod(-p_x,p_y); }
static _ALWAYS_INLINE_ float fposmod(float p_x,float p_y) { return (p_x>=0) ? Math::fmod(p_x,p_y) : p_y-Math::fmod(-p_x,p_y); }
static _ALWAYS_INLINE_ double deg2rad(double p_y) { return p_y*Math_PI/180.0; }
static _ALWAYS_INLINE_ float deg2rad(float p_y) { return p_y*Math_PI/180.0; }
static _ALWAYS_INLINE_ double rad2deg(double p_y) { return p_y*180.0/Math_PI; }
static _ALWAYS_INLINE_ float rad2deg(float p_y) { return p_y*180.0/Math_PI; }
static _ALWAYS_INLINE_ double lerp(double a, double b, double c) { return a+(b-a)*c; }
static _ALWAYS_INLINE_ float lerp(float a, float b, float c) { return a+(b-a)*c; }
static _ALWAYS_INLINE_ double linear2db(double p_linear) { return Math::log( p_linear ) * 8.6858896380650365530225783783321; }
static _ALWAYS_INLINE_ float linear2db(float p_linear) { return Math::log( p_linear ) * 8.6858896380650365530225783783321; }
static _ALWAYS_INLINE_ double db2linear(double p_db) { return Math::exp( p_db * 0.11512925464970228420089957273422 ); }
static _ALWAYS_INLINE_ float db2linear(float p_db) { return Math::exp( p_db * 0.11512925464970228420089957273422 ); }
static _ALWAYS_INLINE_ double round(double p_val) { return (p_val>=0) ? Math::floor(p_val+0.5) : -Math::floor(-p_val+0.5); }
static _ALWAYS_INLINE_ float round(float p_val) { return (p_val>=0) ? Math::floor(p_val+0.5) : -Math::floor(-p_val+0.5); }
// double only, as these functions are mainly used by the editor and not performance-critical,
static double ease(double p_x, double p_c);
static int step_decimals(double p_step);
static double stepify(double p_value,double p_step);
static double dectime(double p_value,double p_amount, double p_step);
static uint32_t larger_prime(uint32_t p_val);
static void seed(uint64_t x=0);
static void randomize();
static uint32_t rand_from_seed(uint64_t *seed);
static uint32_t rand(); static uint32_t rand();
static double randf(); static _ALWAYS_INLINE_ double randf() { return (double)rand() / (double)Math::RANDOM_MAX; }
static _ALWAYS_INLINE_ float randd() { return (float)rand() / (float)Math::RANDOM_MAX; }
static double round(double p_val);
static double random(double from, double to); static double random(double from, double to);
static float random(float from, float to);
static real_t random(int from, int to) { return (real_t)random((real_t)from, (real_t)to); }
static _FORCE_INLINE_ bool isequal_approx(real_t a, real_t b) {
static _ALWAYS_INLINE_ bool isequal_approx(real_t a, real_t b) {
// TODO: Comparing floats for approximate-equality is non-trivial. // TODO: Comparing floats for approximate-equality is non-trivial.
// Using epsilon should cover the typical cases in Godot (where a == b is used to compare two reals), such as matrix and vector comparison operators. // Using epsilon should cover the typical cases in Godot (where a == b is used to compare two reals), such as matrix and vector comparison operators.
// A proper implementation in terms of ULPs should eventually replace the contents of this function. // A proper implementation in terms of ULPs should eventually replace the contents of this function.
@ -204,18 +178,7 @@ public:
} }
static _FORCE_INLINE_ real_t abs(real_t g) { static _ALWAYS_INLINE_ float absf(float g) {
#ifdef REAL_T_IS_DOUBLE
return absd(g);
#else
return absf(g);
#endif
}
static _FORCE_INLINE_ float absf(float g) {
union { union {
float f; float f;
@ -227,7 +190,7 @@ public:
return u.f; return u.f;
} }
static _FORCE_INLINE_ double absd(double g) { static _ALWAYS_INLINE_ double absd(double g) {
union { union {
double d; double d;
@ -239,12 +202,12 @@ public:
} }
//this function should be as fast as possible and rounding mode should not matter //this function should be as fast as possible and rounding mode should not matter
static _FORCE_INLINE_ int fast_ftoi(float a) { static _ALWAYS_INLINE_ int fast_ftoi(float a) {
static int b; static int b;
#if (defined(_WIN32_WINNT) && _WIN32_WINNT >= 0x0603) || WINAPI_FAMILY == WINAPI_FAMILY_PHONE_APP // windows 8 phone? #if (defined(_WIN32_WINNT) && _WIN32_WINNT >= 0x0603) || WINAPI_FAMILY == WINAPI_FAMILY_PHONE_APP // windows 8 phone?
b = (int)((a>0.0f) ? (a + 0.5f):(a -0.5f)); b = (int)((a>0.0) ? (a + 0.5):(a -0.5));
#elif defined(_MSC_VER) && _MSC_VER < 1800 #elif defined(_MSC_VER) && _MSC_VER < 1800
__asm fld a __asm fld a
@ -267,23 +230,16 @@ public:
#if defined(__GNUC__) #if defined(__GNUC__)
static _FORCE_INLINE_ int64_t dtoll(double p_double) { return (int64_t)p_double; } ///@TODO OPTIMIZE static _ALWAYS_INLINE_ int64_t dtoll(double p_double) { return (int64_t)p_double; } ///@TODO OPTIMIZE
static _ALWAYS_INLINE_ int64_t dtoll(float p_float) { return (int64_t)p_float; } ///@TODO OPTIMIZE and rename
#else #else
static _FORCE_INLINE_ int64_t dtoll(double p_double) { return (int64_t)p_double; } ///@TODO OPTIMIZE static _ALWAYS_INLINE_ int64_t dtoll(double p_double) { return (int64_t)p_double; } ///@TODO OPTIMIZE
static _ALWAYS_INLINE_ int64_t dtoll(float p_float) { return (int64_t)p_float; } ///@TODO OPTIMIZE and rename
#endif #endif
static _FORCE_INLINE_ float lerp(float a, float b, float c) {
return a+(b-a)*c; static _ALWAYS_INLINE_ uint32_t halfbits_to_floatbits(uint16_t h)
}
static double pow(double x, double y);
static double log(double x);
static double exp(double x);
static _FORCE_INLINE_ uint32_t halfbits_to_floatbits(uint16_t h)
{ {
uint16_t h_exp, h_sig; uint16_t h_exp, h_sig;
uint32_t f_sgn, f_exp, f_sig; uint32_t f_sgn, f_exp, f_sig;
@ -315,7 +271,7 @@ public:
} }
} }
static _FORCE_INLINE_ float halfptr_to_float(const uint16_t *h) { static _ALWAYS_INLINE_ float halfptr_to_float(const uint16_t *h) {
union { union {
uint32_t u32; uint32_t u32;
@ -326,7 +282,7 @@ public:
return u.f32; return u.f32;
} }
static _FORCE_INLINE_ uint16_t make_half_float(float f) { static _ALWAYS_INLINE_ uint16_t make_half_float(float f) {
union { union {
float fv; float fv;

View File

@ -504,9 +504,9 @@ void Basis::get_axis_and_angle(Vector3 &r_axis,real_t& r_angle) const {
ERR_FAIL_COND(is_rotation() == false); ERR_FAIL_COND(is_rotation() == false);
double angle,x,y,z; // variables for result real_t angle,x,y,z; // variables for result
double epsilon = 0.01; // margin to allow for rounding errors real_t epsilon = 0.01; // margin to allow for rounding errors
double epsilon2 = 0.1; // margin to distinguish between 0 and 180 degrees real_t epsilon2 = 0.1; // margin to distinguish between 0 and 180 degrees
if ( (Math::abs(elements[1][0]-elements[0][1])< epsilon) if ( (Math::abs(elements[1][0]-elements[0][1])< epsilon)
&& (Math::abs(elements[2][0]-elements[0][2])< epsilon) && (Math::abs(elements[2][0]-elements[0][2])< epsilon)
@ -525,12 +525,12 @@ void Basis::get_axis_and_angle(Vector3 &r_axis,real_t& r_angle) const {
} }
// otherwise this singularity is angle = 180 // otherwise this singularity is angle = 180
angle = Math_PI; angle = Math_PI;
double xx = (elements[0][0]+1)/2; real_t xx = (elements[0][0]+1)/2;
double yy = (elements[1][1]+1)/2; real_t yy = (elements[1][1]+1)/2;
double zz = (elements[2][2]+1)/2; real_t zz = (elements[2][2]+1)/2;
double xy = (elements[1][0]+elements[0][1])/4; real_t xy = (elements[1][0]+elements[0][1])/4;
double xz = (elements[2][0]+elements[0][2])/4; real_t xz = (elements[2][0]+elements[0][2])/4;
double yz = (elements[2][1]+elements[1][2])/4; real_t yz = (elements[2][1]+elements[1][2])/4;
if ((xx > yy) && (xx > zz)) { // elements[0][0] is the largest diagonal term if ((xx > yy) && (xx > zz)) { // elements[0][0] is the largest diagonal term
if (xx< epsilon) { if (xx< epsilon) {
x = 0; x = 0;
@ -567,7 +567,7 @@ void Basis::get_axis_and_angle(Vector3 &r_axis,real_t& r_angle) const {
return; return;
} }
// as we have reached here there are no singularities so we can handle normally // as we have reached here there are no singularities so we can handle normally
double s = Math::sqrt((elements[1][2] - elements[2][1])*(elements[1][2] - elements[2][1]) real_t s = Math::sqrt((elements[1][2] - elements[2][1])*(elements[1][2] - elements[2][1])
+(elements[2][0] - elements[0][2])*(elements[2][0] - elements[0][2]) +(elements[2][0] - elements[0][2])*(elements[2][0] - elements[0][2])
+(elements[0][1] - elements[1][0])*(elements[0][1] - elements[1][0])); // s=|axis||sin(angle)|, used to normalise +(elements[0][1] - elements[1][0])*(elements[0][1] - elements[1][0])); // s=|axis||sin(angle)|, used to normalise

View File

@ -435,7 +435,7 @@ int Octree<T,use_pairs,AL>::get_subindex(OctreeElementID p_id) const {
template<class T,bool use_pairs,class AL> template<class T,bool use_pairs,class AL>
void Octree<T,use_pairs,AL>::_insert_element(Element *p_element,Octant *p_octant) { void Octree<T,use_pairs,AL>::_insert_element(Element *p_element,Octant *p_octant) {
float element_size = p_element->aabb.get_longest_axis_size() * 1.01; // avoid precision issues real_t element_size = p_element->aabb.get_longest_axis_size() * 1.01; // avoid precision issues
if (p_octant->aabb.size.x/OCTREE_DIVISOR < element_size) { if (p_octant->aabb.size.x/OCTREE_DIVISOR < element_size) {
//if (p_octant->aabb.size.x*0.5 < element_size) { //if (p_octant->aabb.size.x*0.5 < element_size) {

View File

@ -99,7 +99,7 @@ real_t Plane::distance_to(const Vector3 &p_point) const {
bool Plane::has_point(const Vector3 &p_point,real_t _epsilon) const { bool Plane::has_point(const Vector3 &p_point,real_t _epsilon) const {
float dist=normal.dot(p_point) - d; real_t dist=normal.dot(p_point) - d;
dist=ABS(dist); dist=ABS(dist);
return ( dist <= _epsilon); return ( dist <= _epsilon);

View File

@ -124,8 +124,8 @@ Quat Quat::slerp(const Quat& q, const real_t& t) const {
// Standard case (slerp) // Standard case (slerp)
real_t sine = Math::sqrt(1 - cosine*cosine); real_t sine = Math::sqrt(1 - cosine*cosine);
real_t angle = Math::atan2(sine, cosine); real_t angle = Math::atan2(sine, cosine);
real_t inv_sine = 1.0f / sine; real_t inv_sine = 1.0 / sine;
real_t coeff_0 = Math::sin((1.0f - t) * angle) * inv_sine; real_t coeff_0 = Math::sin((1.0 - t) * angle) * inv_sine;
real_t coeff_1 = Math::sin(t * angle) * inv_sine; real_t coeff_1 = Math::sin(t * angle) * inv_sine;
Quat ret= src * coeff_0 + dst * coeff_1; Quat ret= src * coeff_0 + dst * coeff_1;
@ -137,7 +137,7 @@ Quat Quat::slerp(const Quat& q, const real_t& t) const {
// 2. "rkP" and "q" are almost invedste of each other (cosine ~= -1), there // 2. "rkP" and "q" are almost invedste of each other (cosine ~= -1), there
// are an infinite number of possibilities interpolation. but we haven't // are an infinite number of possibilities interpolation. but we haven't
// have method to fix this case, so just use linear interpolation here. // have method to fix this case, so just use linear interpolation here.
Quat ret = src * (1.0f - t) + dst *t; Quat ret = src * (1.0 - t) + dst *t;
// taking the complement requires renormalisation // taking the complement requires renormalisation
ret.normalize(); ret.normalize();
return ret; return ret;
@ -194,14 +194,14 @@ Quat Quat::slerpni(const Quat& q, const real_t& t) const {
const Quat &from = *this; const Quat &from = *this;
float dot = from.dot(q); real_t dot = from.dot(q);
if (Math::absf(dot) > 0.9999f) return from; if (Math::absf(dot) > 0.9999) return from;
float theta = Math::acos(dot), real_t theta = Math::acos(dot),
sinT = 1.0f / Math::sin(theta), sinT = 1.0 / Math::sin(theta),
newFactor = Math::sin(t * theta) * sinT, newFactor = Math::sin(t * theta) * sinT,
invFactor = Math::sin((1.0f - t) * theta) * sinT; invFactor = Math::sin((1.0 - t) * theta) * sinT;
return Quat(invFactor * from.x + newFactor * q.x, return Quat(invFactor * from.x + newFactor * q.x,
invFactor * from.y + newFactor * q.y, invFactor * from.y + newFactor * q.y,
@ -259,7 +259,7 @@ Quat Quat::slerpni(const Quat& q, const real_t& t) const {
Quat Quat::cubic_slerp(const Quat& q, const Quat& prep, const Quat& postq,const real_t& t) const { Quat Quat::cubic_slerp(const Quat& q, const Quat& prep, const Quat& postq,const real_t& t) const {
//the only way to do slerp :| //the only way to do slerp :|
float t2 = (1.0-t)*t*2; real_t t2 = (1.0-t)*t*2;
Quat sp = this->slerp(q,t); Quat sp = this->slerp(q,t);
Quat sq = prep.slerpni(postq,t); Quat sq = prep.slerpni(postq,t);
return sp.slerpni(sq,t2); return sp.slerpni(sq,t2);

View File

@ -119,8 +119,8 @@ public:
w=0; w=0;
} else { } else {
real_t s = Math::sqrt((1.0f + d) * 2.0f); real_t s = Math::sqrt((1.0 + d) * 2.0);
real_t rs = 1.0f / s; real_t rs = 1.0 / s;
x=c.x*rs; x=c.x*rs;
y=c.y*rs; y=c.y*rs;

View File

@ -86,7 +86,7 @@ Error QuickHull::build(const Vector<Vector3>& p_points, Geometry::MeshData &r_me
if (!valid_points[i]) if (!valid_points[i])
continue; continue;
float d = p_points[i][longest_axis]; real_t d = p_points[i][longest_axis];
if (i==0 || d < min) { if (i==0 || d < min) {
simplex[0]=i; simplex[0]=i;
@ -105,7 +105,7 @@ Error QuickHull::build(const Vector<Vector3>& p_points, Geometry::MeshData &r_me
{ {
float maxd; real_t maxd;
Vector3 rel12 = p_points[simplex[0]] - p_points[simplex[1]]; Vector3 rel12 = p_points[simplex[0]] - p_points[simplex[1]];
for(int i=0;i<p_points.size();i++) { for(int i=0;i<p_points.size();i++) {
@ -127,7 +127,7 @@ Error QuickHull::build(const Vector<Vector3>& p_points, Geometry::MeshData &r_me
//fourth vertex is the one most further away from the plane //fourth vertex is the one most further away from the plane
{ {
float maxd; real_t maxd;
Plane p(p_points[simplex[0]],p_points[simplex[1]],p_points[simplex[2]]); Plane p(p_points[simplex[0]],p_points[simplex[1]],p_points[simplex[2]]);
for(int i=0;i<p_points.size();i++) { for(int i=0;i<p_points.size();i++) {

View File

@ -30,7 +30,7 @@
#include "print_string.h" #include "print_string.h"
float Rect3::get_area() const { real_t Rect3::get_area() const {
return size.x*size.y*size.z; return size.x*size.y*size.z;
@ -114,8 +114,8 @@ bool Rect3::intersects_ray(const Vector3& p_from, const Vector3& p_dir,Vector3*
Vector3 c1, c2; Vector3 c1, c2;
Vector3 end = pos+size; Vector3 end = pos+size;
float near=-1e20; real_t near=-1e20;
float far=1e20; real_t far=1e20;
int axis=0; int axis=0;
for (int i=0;i<3;i++){ for (int i=0;i<3;i++){
@ -159,7 +159,7 @@ bool Rect3::intersects_segment(const Vector3& p_from, const Vector3& p_to,Vector
real_t min=0,max=1; real_t min=0,max=1;
int axis=0; int axis=0;
float sign=0; real_t sign=0;
for(int i=0;i<3;i++) { for(int i=0;i<3;i++) {
real_t seg_from=p_from[i]; real_t seg_from=p_from[i];
@ -167,7 +167,7 @@ bool Rect3::intersects_segment(const Vector3& p_from, const Vector3& p_to,Vector
real_t box_begin=pos[i]; real_t box_begin=pos[i];
real_t box_end=box_begin+size[i]; real_t box_end=box_begin+size[i];
real_t cmin,cmax; real_t cmin,cmax;
float csign; real_t csign;
if (seg_from < seg_to) { if (seg_from < seg_to) {

View File

@ -33,6 +33,8 @@
#include "vector3.h" #include "vector3.h"
#include "plane.h" #include "plane.h"
#include "math_defs.h"
/** /**
* AABB / AABB (Axis Aligned Bounding Box) * AABB / AABB (Axis Aligned Bounding Box)
* This is implemented by a point (pos) and the box size * This is implemented by a point (pos) and the box size
@ -45,7 +47,7 @@ public:
Vector3 pos; Vector3 pos;
Vector3 size; Vector3 size;
float get_area() const; /// get area real_t get_area() const; /// get area
_FORCE_INLINE_ bool has_no_area() const { _FORCE_INLINE_ bool has_no_area() const {
return (size.x<=CMP_EPSILON || size.y<=CMP_EPSILON || size.z<=CMP_EPSILON); return (size.x<=CMP_EPSILON || size.y<=CMP_EPSILON || size.z<=CMP_EPSILON);
@ -74,7 +76,7 @@ public:
Rect3 intersection(const Rect3& p_aabb) const; ///get box where two intersect, empty if no intersection occurs Rect3 intersection(const Rect3& p_aabb) const; ///get box where two intersect, empty if no intersection occurs
bool intersects_segment(const Vector3& p_from, const Vector3& p_to,Vector3* r_clip=NULL,Vector3* r_normal=NULL) const; bool intersects_segment(const Vector3& p_from, const Vector3& p_to,Vector3* r_clip=NULL,Vector3* r_normal=NULL) const;
bool intersects_ray(const Vector3& p_from, const Vector3& p_dir,Vector3* r_clip=NULL,Vector3* r_normal=NULL) const; bool intersects_ray(const Vector3& p_from, const Vector3& p_dir,Vector3* r_clip=NULL,Vector3* r_normal=NULL) const;
_FORCE_INLINE_ bool smits_intersect_ray(const Vector3 &from,const Vector3& p_dir, float t0, float t1) const; _FORCE_INLINE_ bool smits_intersect_ray(const Vector3 &from,const Vector3& p_dir, real_t t0, real_t t1) const;
_FORCE_INLINE_ bool intersects_convex_shape(const Plane *p_plane, int p_plane_count) const; _FORCE_INLINE_ bool intersects_convex_shape(const Plane *p_plane, int p_plane_count) const;
bool intersects_plane(const Plane &p_plane) const; bool intersects_plane(const Plane &p_plane) const;
@ -98,7 +100,7 @@ public:
_FORCE_INLINE_ Vector3 get_endpoint(int p_point) const; _FORCE_INLINE_ Vector3 get_endpoint(int p_point) const;
Rect3 expand(const Vector3& p_vector) const; Rect3 expand(const Vector3& p_vector) const;
_FORCE_INLINE_ void project_range_in_plane(const Plane& p_plane,float &r_min,float& r_max) const; _FORCE_INLINE_ void project_range_in_plane(const Plane& p_plane,real_t &r_min,real_t& r_max) const;
_FORCE_INLINE_ void expand_to(const Vector3& p_vector); /** expand to contain a point if necesary */ _FORCE_INLINE_ void expand_to(const Vector3& p_vector); /** expand to contain a point if necesary */
operator String() const; operator String() const;
@ -293,13 +295,13 @@ inline void Rect3::expand_to(const Vector3& p_vector) {
size=end-begin; size=end-begin;
} }
void Rect3::project_range_in_plane(const Plane& p_plane,float &r_min,float& r_max) const { void Rect3::project_range_in_plane(const Plane& p_plane,real_t &r_min,real_t& r_max) const {
Vector3 half_extents( size.x * 0.5, size.y * 0.5, size.z * 0.5 ); Vector3 half_extents( size.x * 0.5, size.y * 0.5, size.z * 0.5 );
Vector3 center( pos.x + half_extents.x, pos.y + half_extents.y, pos.z + half_extents.z ); Vector3 center( pos.x + half_extents.x, pos.y + half_extents.y, pos.z + half_extents.z );
float length = p_plane.normal.abs().dot(half_extents); real_t length = p_plane.normal.abs().dot(half_extents);
float distance = p_plane.distance_to( center ); real_t distance = p_plane.distance_to( center );
r_min = distance - length; r_min = distance - length;
r_max = distance + length; r_max = distance + length;
} }
@ -334,14 +336,14 @@ inline real_t Rect3::get_shortest_axis_size() const {
return max_size; return max_size;
} }
bool Rect3::smits_intersect_ray(const Vector3 &from,const Vector3& dir, float t0, float t1) const { bool Rect3::smits_intersect_ray(const Vector3 &from,const Vector3& dir, real_t t0, real_t t1) const {
float divx=1.0/dir.x; real_t divx=1.0/dir.x;
float divy=1.0/dir.y; real_t divy=1.0/dir.y;
float divz=1.0/dir.z; real_t divz=1.0/dir.z;
Vector3 upbound=pos+size; Vector3 upbound=pos+size;
float tmin, tmax, tymin, tymax, tzmin, tzmax; real_t tmin, tmax, tymin, tymax, tzmin, tzmax;
if (dir.x >= 0) { if (dir.x >= 0) {
tmin = (pos.x - from.x) * divx; tmin = (pos.x - from.x) * divx;
tmax = (upbound.x - from.x) * divx; tmax = (upbound.x - from.x) * divx;

View File

@ -340,7 +340,7 @@ bool TriangleMesh::intersect_segment(const Vector3& p_begin,const Vector3& p_end
if (f3.intersects_segment(p_begin,p_end,&res)) { if (f3.intersects_segment(p_begin,p_end,&res)) {
float nd = n.dot(res); real_t nd = n.dot(res);
if (nd<d) { if (nd<d) {
d=nd; d=nd;
@ -462,7 +462,7 @@ bool TriangleMesh::intersect_ray(const Vector3& p_begin,const Vector3& p_dir,Vec
if (f3.intersects_ray(p_begin,p_dir,&res)) { if (f3.intersects_ray(p_begin,p_dir,&res)) {
float nd = n.dot(res); real_t nd = n.dot(res);
if (nd<d) { if (nd<d) {
d=nd; d=nd;

View File

@ -28,19 +28,19 @@
/*************************************************************************/ /*************************************************************************/
#include "triangulate.h" #include "triangulate.h"
float Triangulate::get_area(const Vector<Vector2> &contour) real_t Triangulate::get_area(const Vector<Vector2> &contour)
{ {
int n = contour.size(); int n = contour.size();
const Vector2 *c=&contour[0]; const Vector2 *c=&contour[0];
float A=0.0f; real_t A=0.0;
for(int p=n-1,q=0; q<n; p=q++) for(int p=n-1,q=0; q<n; p=q++)
{ {
A+= c[p].cross(c[q]); A+= c[p].cross(c[q]);
} }
return A*0.5f; return A*0.5;
} }
/* /*
@ -48,14 +48,14 @@ float Triangulate::get_area(const Vector<Vector2> &contour)
defined by A, B, C. defined by A, B, C.
*/ */
bool Triangulate::is_inside_triangle(float Ax, float Ay, bool Triangulate::is_inside_triangle(real_t Ax, real_t Ay,
float Bx, float By, real_t Bx, real_t By,
float Cx, float Cy, real_t Cx, real_t Cy,
float Px, float Py) real_t Px, real_t Py)
{ {
float ax, ay, bx, by, cx, cy, apx, apy, bpx, bpy, cpx, cpy; real_t ax, ay, bx, by, cx, cy, apx, apy, bpx, bpy, cpx, cpy;
float cCROSSap, bCROSScp, aCROSSbp; real_t cCROSSap, bCROSScp, aCROSSbp;
ax = Cx - Bx; ay = Cy - By; ax = Cx - Bx; ay = Cy - By;
bx = Ax - Cx; by = Ay - Cy; bx = Ax - Cx; by = Ay - Cy;
@ -68,13 +68,13 @@ bool Triangulate::is_inside_triangle(float Ax, float Ay,
cCROSSap = cx*apy - cy*apx; cCROSSap = cx*apy - cy*apx;
bCROSScp = bx*cpy - by*cpx; bCROSScp = bx*cpy - by*cpx;
return ((aCROSSbp >= 0.0f) && (bCROSScp >= 0.0f) && (cCROSSap >= 0.0f)); return ((aCROSSbp >= 0.0) && (bCROSScp >= 0.0) && (cCROSSap >= 0.0));
}; };
bool Triangulate::snip(const Vector<Vector2> &p_contour,int u,int v,int w,int n,const Vector<int>& V) bool Triangulate::snip(const Vector<Vector2> &p_contour,int u,int v,int w,int n,const Vector<int>& V)
{ {
int p; int p;
float Ax, Ay, Bx, By, Cx, Cy, Px, Py; real_t Ax, Ay, Bx, By, Cx, Cy, Px, Py;
const Vector2 *contour=&p_contour[0]; const Vector2 *contour=&p_contour[0];
Ax = contour[V[u]].x; Ax = contour[V[u]].x;
@ -112,7 +112,7 @@ bool Triangulate::triangulate(const Vector<Vector2> &contour,Vector<int> &result
/* we want a counter-clockwise polygon in V */ /* we want a counter-clockwise polygon in V */
if ( 0.0f < get_area(contour) ) if ( 0.0 < get_area(contour) )
for (int v=0; v<n; v++) V[v] = v; for (int v=0; v<n; v++) V[v] = v;
else else
for(int v=0; v<n; v++) V[v] = (n-1)-v; for(int v=0; v<n; v++) V[v] = (n-1)-v;

View File

@ -45,14 +45,14 @@ public:
static bool triangulate(const Vector< Vector2 > &contour, Vector<int> &result); static bool triangulate(const Vector< Vector2 > &contour, Vector<int> &result);
// compute area of a contour/polygon // compute area of a contour/polygon
static float get_area(const Vector< Vector2 > &contour); static real_t get_area(const Vector< Vector2 > &contour);
// decide if point Px/Py is inside triangle defined by // decide if point Px/Py is inside triangle defined by
// (Ax,Ay) (Bx,By) (Cx,Cy) // (Ax,Ay) (Bx,By) (Cx,Cy)
static bool is_inside_triangle(float Ax, float Ay, static bool is_inside_triangle(real_t Ax, real_t Ay,
float Bx, float By, real_t Bx, real_t By,
float Cx, float Cy, real_t Cx, real_t Cy,
float Px, float Py); real_t Px, real_t Py);
private: private:

View File

@ -30,12 +30,12 @@
#include "matrix3.h" #include "matrix3.h"
void Vector3::rotate(const Vector3& p_axis,float p_phi) { void Vector3::rotate(const Vector3& p_axis,real_t p_phi) {
*this=Basis(p_axis,p_phi).xform(*this); *this=Basis(p_axis,p_phi).xform(*this);
} }
Vector3 Vector3::rotated(const Vector3& p_axis,float p_phi) const { Vector3 Vector3::rotated(const Vector3& p_axis,real_t p_phi) const {
Vector3 r = *this; Vector3 r = *this;
r.rotate(p_axis,p_phi); r.rotate(p_axis,p_phi);
@ -63,13 +63,13 @@ int Vector3::max_axis() const {
} }
void Vector3::snap(float p_val) { void Vector3::snap(real_t p_val) {
x=Math::stepify(x,p_val); x=Math::stepify(x,p_val);
y=Math::stepify(y,p_val); y=Math::stepify(y,p_val);
z=Math::stepify(z,p_val); z=Math::stepify(z,p_val);
} }
Vector3 Vector3::snapped(float p_val) const { Vector3 Vector3::snapped(real_t p_val) const {
Vector3 v=*this; Vector3 v=*this;
v.snap(p_val); v.snap(p_val);
@ -77,7 +77,7 @@ Vector3 Vector3::snapped(float p_val) const {
} }
Vector3 Vector3::cubic_interpolaten(const Vector3& p_b,const Vector3& p_pre_a, const Vector3& p_post_b,float p_t) const { Vector3 Vector3::cubic_interpolaten(const Vector3& p_b,const Vector3& p_pre_a, const Vector3& p_post_b,real_t p_t) const {
Vector3 p0=p_pre_a; Vector3 p0=p_pre_a;
Vector3 p1=*this; Vector3 p1=*this;
@ -87,9 +87,9 @@ Vector3 Vector3::cubic_interpolaten(const Vector3& p_b,const Vector3& p_pre_a, c
{ {
//normalize //normalize
float ab = p0.distance_to(p1); real_t ab = p0.distance_to(p1);
float bc = p1.distance_to(p2); real_t bc = p1.distance_to(p2);
float cd = p2.distance_to(p3); real_t cd = p2.distance_to(p3);
if (ab>0) if (ab>0)
p0 = p1+(p0-p1)*(bc/ab); p0 = p1+(p0-p1)*(bc/ab);
@ -98,41 +98,41 @@ Vector3 Vector3::cubic_interpolaten(const Vector3& p_b,const Vector3& p_pre_a, c
} }
float t = p_t; real_t t = p_t;
float t2 = t * t; real_t t2 = t * t;
float t3 = t2 * t; real_t t3 = t2 * t;
Vector3 out; Vector3 out;
out = 0.5f * ( ( p1 * 2.0f) + out = 0.5 * ( ( p1 * 2.0) +
( -p0 + p2 ) * t + ( -p0 + p2 ) * t +
( 2.0f * p0 - 5.0f * p1 + 4 * p2 - p3 ) * t2 + ( 2.0 * p0 - 5.0 * p1 + 4 * p2 - p3 ) * t2 +
( -p0 + 3.0f * p1 - 3.0f * p2 + p3 ) * t3 ); ( -p0 + 3.0 * p1 - 3.0 * p2 + p3 ) * t3 );
return out; return out;
} }
Vector3 Vector3::cubic_interpolate(const Vector3& p_b,const Vector3& p_pre_a, const Vector3& p_post_b,float p_t) const { Vector3 Vector3::cubic_interpolate(const Vector3& p_b,const Vector3& p_pre_a, const Vector3& p_post_b,real_t p_t) const {
Vector3 p0=p_pre_a; Vector3 p0=p_pre_a;
Vector3 p1=*this; Vector3 p1=*this;
Vector3 p2=p_b; Vector3 p2=p_b;
Vector3 p3=p_post_b; Vector3 p3=p_post_b;
float t = p_t; real_t t = p_t;
float t2 = t * t; real_t t2 = t * t;
float t3 = t2 * t; real_t t3 = t2 * t;
Vector3 out; Vector3 out;
out = 0.5f * ( ( p1 * 2.0f) + out = 0.5 * ( ( p1 * 2.0) +
( -p0 + p2 ) * t + ( -p0 + p2 ) * t +
( 2.0f * p0 - 5.0f * p1 + 4 * p2 - p3 ) * t2 + ( 2.0 * p0 - 5.0 * p1 + 4 * p2 - p3 ) * t2 +
( -p0 + 3.0f * p1 - 3.0f * p2 + p3 ) * t3 ); ( -p0 + 3.0 * p1 - 3.0 * p2 + p3 ) * t3 );
return out; return out;
} }
#if 0 #if 0
Vector3 Vector3::cubic_interpolate(const Vector3& p_b,const Vector3& p_pre_a, const Vector3& p_post_b,float p_t) const { Vector3 Vector3::cubic_interpolate(const Vector3& p_b,const Vector3& p_pre_a, const Vector3& p_post_b,real_t p_t) const {
Vector3 p0=p_pre_a; Vector3 p0=p_pre_a;
Vector3 p1=*this; Vector3 p1=*this;
@ -141,9 +141,9 @@ Vector3 Vector3::cubic_interpolate(const Vector3& p_b,const Vector3& p_pre_a, co
if (true) { if (true) {
float ab = p0.distance_to(p1); real_t ab = p0.distance_to(p1);
float bc = p1.distance_to(p2); real_t bc = p1.distance_to(p2);
float cd = p2.distance_to(p3); real_t cd = p2.distance_to(p3);
//if (ab>bc) { //if (ab>bc) {
if (ab>0) if (ab>0)
@ -156,23 +156,23 @@ Vector3 Vector3::cubic_interpolate(const Vector3& p_b,const Vector3& p_pre_a, co
//} //}
} }
float t = p_t; real_t t = p_t;
float t2 = t * t; real_t t2 = t * t;
float t3 = t2 * t; real_t t3 = t2 * t;
Vector3 out; Vector3 out;
out.x = 0.5f * ( ( 2.0f * p1.x ) + out.x = 0.5 * ( ( 2.0 * p1.x ) +
( -p0.x + p2.x ) * t + ( -p0.x + p2.x ) * t +
( 2.0f * p0.x - 5.0f * p1.x + 4 * p2.x - p3.x ) * t2 + ( 2.0 * p0.x - 5.0 * p1.x + 4 * p2.x - p3.x ) * t2 +
( -p0.x + 3.0f * p1.x - 3.0f * p2.x + p3.x ) * t3 ); ( -p0.x + 3.0 * p1.x - 3.0 * p2.x + p3.x ) * t3 );
out.y = 0.5f * ( ( 2.0f * p1.y ) + out.y = 0.5 * ( ( 2.0 * p1.y ) +
( -p0.y + p2.y ) * t + ( -p0.y + p2.y ) * t +
( 2.0f * p0.y - 5.0f * p1.y + 4 * p2.y - p3.y ) * t2 + ( 2.0 * p0.y - 5.0 * p1.y + 4 * p2.y - p3.y ) * t2 +
( -p0.y + 3.0f * p1.y - 3.0f * p2.y + p3.y ) * t3 ); ( -p0.y + 3.0 * p1.y - 3.0 * p2.y + p3.y ) * t3 );
out.z = 0.5f * ( ( 2.0f * p1.z ) + out.z = 0.5 * ( ( 2.0 * p1.z ) +
( -p0.z + p2.z ) * t + ( -p0.z + p2.z ) * t +
( 2.0f * p0.z - 5.0f * p1.z + 4 * p2.z - p3.z ) * t2 + ( 2.0 * p0.z - 5.0 * p1.z + 4 * p2.z - p3.z ) * t2 +
( -p0.z + 3.0f * p1.z - 3.0f * p2.z + p3.z ) * t3 ); ( -p0.z + 3.0 * p1.z - 3.0 * p2.z + p3.z ) * t3 );
return out; return out;
} }
# endif # endif

View File

@ -79,17 +79,17 @@ struct Vector3 {
_FORCE_INLINE_ void zero(); _FORCE_INLINE_ void zero();
void snap(float p_val); void snap(real_t p_val);
Vector3 snapped(float p_val) const; Vector3 snapped(real_t p_val) const;
void rotate(const Vector3& p_axis,float p_phi); void rotate(const Vector3& p_axis,real_t p_phi);
Vector3 rotated(const Vector3& p_axis,float p_phi) const; Vector3 rotated(const Vector3& p_axis,real_t p_phi) const;
/* Static Methods between 2 vector3s */ /* Static Methods between 2 vector3s */
_FORCE_INLINE_ Vector3 linear_interpolate(const Vector3& p_b,float p_t) const; _FORCE_INLINE_ Vector3 linear_interpolate(const Vector3& p_b,real_t p_t) const;
Vector3 cubic_interpolate(const Vector3& p_b,const Vector3& p_pre_a, const Vector3& p_post_b,float p_t) const; Vector3 cubic_interpolate(const Vector3& p_b,const Vector3& p_pre_a, const Vector3& p_post_b,real_t p_t) const;
Vector3 cubic_interpolaten(const Vector3& p_b,const Vector3& p_pre_a, const Vector3& p_post_b,float p_t) const; Vector3 cubic_interpolaten(const Vector3& p_b,const Vector3& p_pre_a, const Vector3& p_post_b,real_t p_t) const;
_FORCE_INLINE_ Vector3 cross(const Vector3& p_b) const; _FORCE_INLINE_ Vector3 cross(const Vector3& p_b) const;
_FORCE_INLINE_ real_t dot(const Vector3& p_b) const; _FORCE_INLINE_ real_t dot(const Vector3& p_b) const;
@ -195,7 +195,7 @@ Vector3 Vector3::ceil() const {
return Vector3( Math::ceil(x), Math::ceil(y), Math::ceil(z) ); return Vector3( Math::ceil(x), Math::ceil(y), Math::ceil(z) );
} }
Vector3 Vector3::linear_interpolate(const Vector3& p_b,float p_t) const { Vector3 Vector3::linear_interpolate(const Vector3& p_b,real_t p_t) const {
return Vector3( return Vector3(
x+(p_t * (p_b.x-x)), x+(p_t * (p_b.x-x)),

View File

@ -166,7 +166,7 @@ void RasterizerSceneGLES3::shadow_atlas_set_quadrant_subdivision(RID p_atlas,int
subdiv<<=1; subdiv<<=1;
} }
subdiv=int(Math::sqrt(subdiv)); subdiv=int(Math::sqrt((float)subdiv));
//obtain the number that will be x*x //obtain the number that will be x*x
@ -568,7 +568,7 @@ void RasterizerSceneGLES3::reflection_atlas_set_subdivision(RID p_ref_atlas,int
subdiv<<=1; subdiv<<=1;
} }
subdiv=int(Math::sqrt(subdiv)); subdiv=int(Math::sqrt((float)subdiv));
if (reflection_atlas->subdiv==subdiv) if (reflection_atlas->subdiv==subdiv)
return; return;
@ -4567,7 +4567,7 @@ static _FORCE_INLINE_ Vector3 ImportanceSampleGGX(Vector2 Xi, float Roughness, V
// Compute distribution direction // Compute distribution direction
float Phi = 2.0f * Math_PI * Xi.x; float Phi = 2.0f * Math_PI * Xi.x;
float CosTheta = Math::sqrt((1.0f - Xi.y) / (1.0f + (a*a - 1.0f) * Xi.y)); float CosTheta = Math::sqrt((float)(1.0f - Xi.y) / (1.0f + (a*a - 1.0f) * Xi.y));
float SinTheta = Math::sqrt((float)Math::abs(1.0f - CosTheta * CosTheta)); float SinTheta = Math::sqrt((float)Math::abs(1.0f - CosTheta * CosTheta));
// Convert to spherical direction // Convert to spherical direction
@ -4615,7 +4615,7 @@ void RasterizerSceneGLES3::_generate_brdf() {
float NoV = float(i+1)/(brdf_size); //avoid storing nov0 float NoV = float(i+1)/(brdf_size); //avoid storing nov0
Vector3 V; Vector3 V;
V.x = Math::sqrt( 1.0 - NoV * NoV ); V.x = Math::sqrt( 1.0f - NoV * NoV );
V.y = 0.0; V.y = 0.0;
V.z = NoV; V.z = NoV;

View File

@ -5256,7 +5256,7 @@ void RasterizerStorageGLES3::update_particles() {
shaders.particles.set_uniform(ParticlesShaderGLES3::ORIGIN,particles->origin); shaders.particles.set_uniform(ParticlesShaderGLES3::ORIGIN,particles->origin);
float new_phase = Math::fmod(particles->phase+(frame.delta/particles->lifetime),1.0); float new_phase = Math::fmod((float)particles->phase+(frame.delta/particles->lifetime),(float)1.0);
shaders.particles.set_uniform(ParticlesShaderGLES3::SYSTEM_PHASE,new_phase); shaders.particles.set_uniform(ParticlesShaderGLES3::SYSTEM_PHASE,new_phase);
shaders.particles.set_uniform(ParticlesShaderGLES3::PREV_SYSTEM_PHASE,particles->phase); shaders.particles.set_uniform(ParticlesShaderGLES3::PREV_SYSTEM_PHASE,particles->phase);

View File

@ -159,85 +159,85 @@ void GDFunctions::call(Function p_func,const Variant **p_args,int p_arg_count,Va
case MATH_SIN: { case MATH_SIN: {
VALIDATE_ARG_COUNT(1); VALIDATE_ARG_COUNT(1);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
r_ret=Math::sin(*p_args[0]); r_ret=Math::sin((double)*p_args[0]);
} break; } break;
case MATH_COS: { case MATH_COS: {
VALIDATE_ARG_COUNT(1); VALIDATE_ARG_COUNT(1);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
r_ret=Math::cos(*p_args[0]); r_ret=Math::cos((double)*p_args[0]);
} break; } break;
case MATH_TAN: { case MATH_TAN: {
VALIDATE_ARG_COUNT(1); VALIDATE_ARG_COUNT(1);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
r_ret=Math::tan(*p_args[0]); r_ret=Math::tan((double)*p_args[0]);
} break; } break;
case MATH_SINH: { case MATH_SINH: {
VALIDATE_ARG_COUNT(1); VALIDATE_ARG_COUNT(1);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
r_ret=Math::sinh(*p_args[0]); r_ret=Math::sinh((double)*p_args[0]);
} break; } break;
case MATH_COSH: { case MATH_COSH: {
VALIDATE_ARG_COUNT(1); VALIDATE_ARG_COUNT(1);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
r_ret=Math::cosh(*p_args[0]); r_ret=Math::cosh((double)*p_args[0]);
} break; } break;
case MATH_TANH: { case MATH_TANH: {
VALIDATE_ARG_COUNT(1); VALIDATE_ARG_COUNT(1);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
r_ret=Math::tanh(*p_args[0]); r_ret=Math::tanh((double)*p_args[0]);
} break; } break;
case MATH_ASIN: { case MATH_ASIN: {
VALIDATE_ARG_COUNT(1); VALIDATE_ARG_COUNT(1);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
r_ret=Math::asin(*p_args[0]); r_ret=Math::asin((double)*p_args[0]);
} break; } break;
case MATH_ACOS: { case MATH_ACOS: {
VALIDATE_ARG_COUNT(1); VALIDATE_ARG_COUNT(1);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
r_ret=Math::acos(*p_args[0]); r_ret=Math::acos((double)*p_args[0]);
} break; } break;
case MATH_ATAN: { case MATH_ATAN: {
VALIDATE_ARG_COUNT(1); VALIDATE_ARG_COUNT(1);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
r_ret=Math::atan(*p_args[0]); r_ret=Math::atan((double)*p_args[0]);
} break; } break;
case MATH_ATAN2: { case MATH_ATAN2: {
VALIDATE_ARG_COUNT(2); VALIDATE_ARG_COUNT(2);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
VALIDATE_ARG_NUM(1); VALIDATE_ARG_NUM(1);
r_ret=Math::atan2(*p_args[0],*p_args[1]); r_ret=Math::atan2((double)*p_args[0],(double)*p_args[1]);
} break; } break;
case MATH_SQRT: { case MATH_SQRT: {
VALIDATE_ARG_COUNT(1); VALIDATE_ARG_COUNT(1);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
r_ret=Math::sqrt(*p_args[0]); r_ret=Math::sqrt((double)*p_args[0]);
} break; } break;
case MATH_FMOD: { case MATH_FMOD: {
VALIDATE_ARG_COUNT(2); VALIDATE_ARG_COUNT(2);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
VALIDATE_ARG_NUM(1); VALIDATE_ARG_NUM(1);
r_ret=Math::fmod(*p_args[0],*p_args[1]); r_ret=Math::fmod((double)*p_args[0],(double)*p_args[1]);
} break; } break;
case MATH_FPOSMOD: { case MATH_FPOSMOD: {
VALIDATE_ARG_COUNT(2); VALIDATE_ARG_COUNT(2);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
VALIDATE_ARG_NUM(1); VALIDATE_ARG_NUM(1);
r_ret=Math::fposmod(*p_args[0],*p_args[1]); r_ret=Math::fposmod((double)*p_args[0],(double)*p_args[1]);
} break; } break;
case MATH_FLOOR: { case MATH_FLOOR: {
VALIDATE_ARG_COUNT(1); VALIDATE_ARG_COUNT(1);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
r_ret=Math::floor(*p_args[0]); r_ret=Math::floor((double)*p_args[0]);
} break; } break;
case MATH_CEIL: { case MATH_CEIL: {
VALIDATE_ARG_COUNT(1); VALIDATE_ARG_COUNT(1);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
r_ret=Math::ceil(*p_args[0]); r_ret=Math::ceil((double)*p_args[0]);
} break; } break;
case MATH_ROUND: { case MATH_ROUND: {
VALIDATE_ARG_COUNT(1); VALIDATE_ARG_COUNT(1);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
r_ret=Math::round(*p_args[0]); r_ret=Math::round((double)*p_args[0]);
} break; } break;
case MATH_ABS: { case MATH_ABS: {
VALIDATE_ARG_COUNT(1); VALIDATE_ARG_COUNT(1);
@ -247,7 +247,7 @@ void GDFunctions::call(Function p_func,const Variant **p_args,int p_arg_count,Va
r_ret=ABS(i); r_ret=ABS(i);
} else if (p_args[0]->get_type()==Variant::REAL) { } else if (p_args[0]->get_type()==Variant::REAL) {
real_t r = *p_args[0]; double r = *p_args[0];
r_ret=Math::abs(r); r_ret=Math::abs(r);
} else { } else {
@ -279,58 +279,58 @@ void GDFunctions::call(Function p_func,const Variant **p_args,int p_arg_count,Va
VALIDATE_ARG_COUNT(2); VALIDATE_ARG_COUNT(2);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
VALIDATE_ARG_NUM(1); VALIDATE_ARG_NUM(1);
r_ret=Math::pow(*p_args[0],*p_args[1]); r_ret=Math::pow((double)*p_args[0],(double)*p_args[1]);
} break; } break;
case MATH_LOG: { case MATH_LOG: {
VALIDATE_ARG_COUNT(1); VALIDATE_ARG_COUNT(1);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
r_ret=Math::log(*p_args[0]); r_ret=Math::log((double)*p_args[0]);
} break; } break;
case MATH_EXP: { case MATH_EXP: {
VALIDATE_ARG_COUNT(1); VALIDATE_ARG_COUNT(1);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
r_ret=Math::exp(*p_args[0]); r_ret=Math::exp((double)*p_args[0]);
} break; } break;
case MATH_ISNAN: { case MATH_ISNAN: {
VALIDATE_ARG_COUNT(1); VALIDATE_ARG_COUNT(1);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
r_ret=Math::is_nan(*p_args[0]); r_ret=Math::is_nan((double)*p_args[0]);
} break; } break;
case MATH_ISINF: { case MATH_ISINF: {
VALIDATE_ARG_COUNT(1); VALIDATE_ARG_COUNT(1);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
r_ret=Math::is_inf(*p_args[0]); r_ret=Math::is_inf((double)*p_args[0]);
} break; } break;
case MATH_EASE: { case MATH_EASE: {
VALIDATE_ARG_COUNT(2); VALIDATE_ARG_COUNT(2);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
VALIDATE_ARG_NUM(1); VALIDATE_ARG_NUM(1);
r_ret=Math::ease(*p_args[0],*p_args[1]); r_ret=Math::ease((double)*p_args[0],(double)*p_args[1]);
} break; } break;
case MATH_DECIMALS: { case MATH_DECIMALS: {
VALIDATE_ARG_COUNT(1); VALIDATE_ARG_COUNT(1);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
r_ret=Math::step_decimals(*p_args[0]); r_ret=Math::step_decimals((double)*p_args[0]);
} break; } break;
case MATH_STEPIFY: { case MATH_STEPIFY: {
VALIDATE_ARG_COUNT(2); VALIDATE_ARG_COUNT(2);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
VALIDATE_ARG_NUM(1); VALIDATE_ARG_NUM(1);
r_ret=Math::stepify(*p_args[0],*p_args[1]); r_ret=Math::stepify((double)*p_args[0],(double)*p_args[1]);
} break; } break;
case MATH_LERP: { case MATH_LERP: {
VALIDATE_ARG_COUNT(3); VALIDATE_ARG_COUNT(3);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
VALIDATE_ARG_NUM(1); VALIDATE_ARG_NUM(1);
VALIDATE_ARG_NUM(2); VALIDATE_ARG_NUM(2);
r_ret=Math::lerp(*p_args[0],*p_args[1],*p_args[2]); r_ret=Math::lerp((double)*p_args[0],(double)*p_args[1],(double)*p_args[2]);
} break; } break;
case MATH_DECTIME: { case MATH_DECTIME: {
VALIDATE_ARG_COUNT(3); VALIDATE_ARG_COUNT(3);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
VALIDATE_ARG_NUM(1); VALIDATE_ARG_NUM(1);
VALIDATE_ARG_NUM(2); VALIDATE_ARG_NUM(2);
r_ret=Math::dectime(*p_args[0],*p_args[1],*p_args[2]); r_ret=Math::dectime((double)*p_args[0],(double)*p_args[1],(double)*p_args[2]);
} break; } break;
case MATH_RANDOMIZE: { case MATH_RANDOMIZE: {
Math::randomize(); Math::randomize();
@ -346,7 +346,7 @@ void GDFunctions::call(Function p_func,const Variant **p_args,int p_arg_count,Va
VALIDATE_ARG_COUNT(2); VALIDATE_ARG_COUNT(2);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
VALIDATE_ARG_NUM(1); VALIDATE_ARG_NUM(1);
r_ret=Math::random(*p_args[0],*p_args[1]); r_ret=Math::random((double)*p_args[0],(double)*p_args[1]);
} break; } break;
case MATH_SEED: { case MATH_SEED: {
VALIDATE_ARG_COUNT(1); VALIDATE_ARG_COUNT(1);
@ -369,22 +369,22 @@ void GDFunctions::call(Function p_func,const Variant **p_args,int p_arg_count,Va
case MATH_DEG2RAD: { case MATH_DEG2RAD: {
VALIDATE_ARG_COUNT(1); VALIDATE_ARG_COUNT(1);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
r_ret=Math::deg2rad(*p_args[0]); r_ret=Math::deg2rad((double)*p_args[0]);
} break; } break;
case MATH_RAD2DEG: { case MATH_RAD2DEG: {
VALIDATE_ARG_COUNT(1); VALIDATE_ARG_COUNT(1);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
r_ret=Math::rad2deg(*p_args[0]); r_ret=Math::rad2deg((double)*p_args[0]);
} break; } break;
case MATH_LINEAR2DB: { case MATH_LINEAR2DB: {
VALIDATE_ARG_COUNT(1); VALIDATE_ARG_COUNT(1);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
r_ret=Math::linear2db(*p_args[0]); r_ret=Math::linear2db((double)*p_args[0]);
} break; } break;
case MATH_DB2LINEAR: { case MATH_DB2LINEAR: {
VALIDATE_ARG_COUNT(1); VALIDATE_ARG_COUNT(1);
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
r_ret=Math::db2linear(*p_args[0]); r_ret=Math::db2linear((double)*p_args[0]);
} break; } break;
case LOGIC_MAX: { case LOGIC_MAX: {
VALIDATE_ARG_COUNT(2); VALIDATE_ARG_COUNT(2);

View File

@ -610,85 +610,85 @@ void VisualScriptBuiltinFunc::exec_func(BuiltinFunc p_func,const Variant** p_inp
case VisualScriptBuiltinFunc::MATH_SIN: { case VisualScriptBuiltinFunc::MATH_SIN: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
*r_return=Math::sin(*p_inputs[0]); *r_return=Math::sin((double)*p_inputs[0]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_COS: { case VisualScriptBuiltinFunc::MATH_COS: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
*r_return=Math::cos(*p_inputs[0]); *r_return=Math::cos((double)*p_inputs[0]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_TAN: { case VisualScriptBuiltinFunc::MATH_TAN: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
*r_return=Math::tan(*p_inputs[0]); *r_return=Math::tan((double)*p_inputs[0]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_SINH: { case VisualScriptBuiltinFunc::MATH_SINH: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
*r_return=Math::sinh(*p_inputs[0]); *r_return=Math::sinh((double)*p_inputs[0]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_COSH: { case VisualScriptBuiltinFunc::MATH_COSH: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
*r_return=Math::cosh(*p_inputs[0]); *r_return=Math::cosh((double)*p_inputs[0]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_TANH: { case VisualScriptBuiltinFunc::MATH_TANH: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
*r_return=Math::tanh(*p_inputs[0]); *r_return=Math::tanh((double)*p_inputs[0]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_ASIN: { case VisualScriptBuiltinFunc::MATH_ASIN: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
*r_return=Math::asin(*p_inputs[0]); *r_return=Math::asin((double)*p_inputs[0]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_ACOS: { case VisualScriptBuiltinFunc::MATH_ACOS: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
*r_return=Math::acos(*p_inputs[0]); *r_return=Math::acos((double)*p_inputs[0]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_ATAN: { case VisualScriptBuiltinFunc::MATH_ATAN: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
*r_return=Math::atan(*p_inputs[0]); *r_return=Math::atan((double)*p_inputs[0]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_ATAN2: { case VisualScriptBuiltinFunc::MATH_ATAN2: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
VALIDATE_ARG_NUM(1); VALIDATE_ARG_NUM(1);
*r_return=Math::atan2(*p_inputs[0],*p_inputs[1]); *r_return=Math::atan2((double)*p_inputs[0],(double)*p_inputs[1]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_SQRT: { case VisualScriptBuiltinFunc::MATH_SQRT: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
*r_return=Math::sqrt(*p_inputs[0]); *r_return=Math::sqrt((double)*p_inputs[0]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_FMOD: { case VisualScriptBuiltinFunc::MATH_FMOD: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
VALIDATE_ARG_NUM(1); VALIDATE_ARG_NUM(1);
*r_return=Math::fmod(*p_inputs[0],*p_inputs[1]); *r_return=Math::fmod((double)*p_inputs[0],(double)*p_inputs[1]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_FPOSMOD: { case VisualScriptBuiltinFunc::MATH_FPOSMOD: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
VALIDATE_ARG_NUM(1); VALIDATE_ARG_NUM(1);
*r_return=Math::fposmod(*p_inputs[0],*p_inputs[1]); *r_return=Math::fposmod((double)*p_inputs[0],(double)*p_inputs[1]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_FLOOR: { case VisualScriptBuiltinFunc::MATH_FLOOR: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
*r_return=Math::floor(*p_inputs[0]); *r_return=Math::floor((double)*p_inputs[0]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_CEIL: { case VisualScriptBuiltinFunc::MATH_CEIL: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
*r_return=Math::ceil(*p_inputs[0]); *r_return=Math::ceil((double)*p_inputs[0]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_ROUND: { case VisualScriptBuiltinFunc::MATH_ROUND: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
*r_return=Math::round(*p_inputs[0]); *r_return=Math::round((double)*p_inputs[0]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_ABS: { case VisualScriptBuiltinFunc::MATH_ABS: {
@ -730,58 +730,58 @@ void VisualScriptBuiltinFunc::exec_func(BuiltinFunc p_func,const Variant** p_inp
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
VALIDATE_ARG_NUM(1); VALIDATE_ARG_NUM(1);
*r_return=Math::pow(*p_inputs[0],*p_inputs[1]); *r_return=Math::pow((double)*p_inputs[0],(double)*p_inputs[1]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_LOG: { case VisualScriptBuiltinFunc::MATH_LOG: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
*r_return=Math::log(*p_inputs[0]); *r_return=Math::log((double)*p_inputs[0]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_EXP: { case VisualScriptBuiltinFunc::MATH_EXP: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
*r_return=Math::exp(*p_inputs[0]); *r_return=Math::exp((double)*p_inputs[0]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_ISNAN: { case VisualScriptBuiltinFunc::MATH_ISNAN: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
*r_return=Math::is_nan(*p_inputs[0]); *r_return=Math::is_nan((double)*p_inputs[0]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_ISINF: { case VisualScriptBuiltinFunc::MATH_ISINF: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
*r_return=Math::is_inf(*p_inputs[0]); *r_return=Math::is_inf((double)*p_inputs[0]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_EASE: { case VisualScriptBuiltinFunc::MATH_EASE: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
VALIDATE_ARG_NUM(1); VALIDATE_ARG_NUM(1);
*r_return=Math::ease(*p_inputs[0],*p_inputs[1]); *r_return=Math::ease((double)*p_inputs[0],(double)*p_inputs[1]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_DECIMALS: { case VisualScriptBuiltinFunc::MATH_DECIMALS: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
*r_return=Math::step_decimals(*p_inputs[0]); *r_return=Math::step_decimals((double)*p_inputs[0]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_STEPIFY: { case VisualScriptBuiltinFunc::MATH_STEPIFY: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
VALIDATE_ARG_NUM(1); VALIDATE_ARG_NUM(1);
*r_return=Math::stepify(*p_inputs[0],*p_inputs[1]); *r_return=Math::stepify((double)*p_inputs[0],(double)*p_inputs[1]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_LERP: { case VisualScriptBuiltinFunc::MATH_LERP: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
VALIDATE_ARG_NUM(1); VALIDATE_ARG_NUM(1);
VALIDATE_ARG_NUM(2); VALIDATE_ARG_NUM(2);
*r_return=Math::lerp(*p_inputs[0],*p_inputs[1],*p_inputs[2]); *r_return=Math::lerp((double)*p_inputs[0],(double)*p_inputs[1],(double)*p_inputs[2]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_DECTIME: { case VisualScriptBuiltinFunc::MATH_DECTIME: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
VALIDATE_ARG_NUM(1); VALIDATE_ARG_NUM(1);
VALIDATE_ARG_NUM(2); VALIDATE_ARG_NUM(2);
*r_return=Math::dectime(*p_inputs[0],*p_inputs[1],*p_inputs[2]); *r_return=Math::dectime((double)*p_inputs[0],(double)*p_inputs[1],(double)*p_inputs[2]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_RANDOMIZE: { case VisualScriptBuiltinFunc::MATH_RANDOMIZE: {
Math::randomize(); Math::randomize();
@ -797,7 +797,7 @@ void VisualScriptBuiltinFunc::exec_func(BuiltinFunc p_func,const Variant** p_inp
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
VALIDATE_ARG_NUM(1); VALIDATE_ARG_NUM(1);
*r_return=Math::random(*p_inputs[0],*p_inputs[1]); *r_return=Math::random((double)*p_inputs[0],(double)*p_inputs[1]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_SEED: { case VisualScriptBuiltinFunc::MATH_SEED: {
@ -820,22 +820,22 @@ void VisualScriptBuiltinFunc::exec_func(BuiltinFunc p_func,const Variant** p_inp
case VisualScriptBuiltinFunc::MATH_DEG2RAD: { case VisualScriptBuiltinFunc::MATH_DEG2RAD: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
*r_return=Math::deg2rad(*p_inputs[0]); *r_return=Math::deg2rad((double)*p_inputs[0]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_RAD2DEG: { case VisualScriptBuiltinFunc::MATH_RAD2DEG: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
*r_return=Math::rad2deg(*p_inputs[0]); *r_return=Math::rad2deg((double)*p_inputs[0]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_LINEAR2DB: { case VisualScriptBuiltinFunc::MATH_LINEAR2DB: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
*r_return=Math::linear2db(*p_inputs[0]); *r_return=Math::linear2db((double)*p_inputs[0]);
} break; } break;
case VisualScriptBuiltinFunc::MATH_DB2LINEAR: { case VisualScriptBuiltinFunc::MATH_DB2LINEAR: {
VALIDATE_ARG_NUM(0); VALIDATE_ARG_NUM(0);
*r_return=Math::db2linear(*p_inputs[0]); *r_return=Math::db2linear((double)*p_inputs[0]);
} break; } break;
case VisualScriptBuiltinFunc::LOGIC_MAX: { case VisualScriptBuiltinFunc::LOGIC_MAX: {

View File

@ -364,7 +364,7 @@ void Particles2D::_process_particles(float p_delta) {
p.rot=Math::deg2rad(param[PARAM_INITIAL_ANGLE]+param[PARAM_INITIAL_ANGLE]*randomness[PARAM_INITIAL_ANGLE]*_rand_from_seed(&rand_seed)); p.rot=Math::deg2rad(param[PARAM_INITIAL_ANGLE]+param[PARAM_INITIAL_ANGLE]*randomness[PARAM_INITIAL_ANGLE]*_rand_from_seed(&rand_seed));
active_count++; active_count++;
p.frame=Math::fmod(param[PARAM_ANIM_INITIAL_POS]+randomness[PARAM_ANIM_INITIAL_POS]*_rand_from_seed(&rand_seed),1.0); p.frame=Math::fmod(param[PARAM_ANIM_INITIAL_POS]+randomness[PARAM_ANIM_INITIAL_POS]*_rand_from_seed(&rand_seed),1.0f);
} else { } else {
@ -438,7 +438,7 @@ void Particles2D::_process_particles(float p_delta) {
p.pos+=p.velocity*frame_time; p.pos+=p.velocity*frame_time;
p.rot+=Math::lerp(param[PARAM_SPIN_VELOCITY],param[PARAM_SPIN_VELOCITY]*randomness[PARAM_SPIN_VELOCITY]*_rand_from_seed(&rand_seed),randomness[PARAM_SPIN_VELOCITY])*frame_time; p.rot+=Math::lerp(param[PARAM_SPIN_VELOCITY],param[PARAM_SPIN_VELOCITY]*randomness[PARAM_SPIN_VELOCITY]*_rand_from_seed(&rand_seed),randomness[PARAM_SPIN_VELOCITY])*frame_time;
float anim_spd=param[PARAM_ANIM_SPEED_SCALE]+param[PARAM_ANIM_SPEED_SCALE]*randomness[PARAM_ANIM_SPEED_SCALE]*_rand_from_seed(&rand_seed); float anim_spd=param[PARAM_ANIM_SPEED_SCALE]+param[PARAM_ANIM_SPEED_SCALE]*randomness[PARAM_ANIM_SPEED_SCALE]*_rand_from_seed(&rand_seed);
p.frame=Math::fposmod(p.frame+(frame_time/lifetime)*anim_spd,1.0); p.frame=Math::fposmod(p.frame+(frame_time/lifetime)*anim_spd,1.0f);
active_count++; active_count++;
@ -555,7 +555,7 @@ void Particles2D::_notification(int p_what) {
float a=color.a; float a=color.a;
//float preh=h; //float preh=h;
h+=huerot; h+=huerot;
h=Math::abs(Math::fposmod(h,1.0)); h=Math::abs(Math::fposmod(h,1.0f));
//print_line("rand: "+rtos(randomness[PARAM_HUE_VARIATION])+" rand: "+rtos(huerand)); //print_line("rand: "+rtos(randomness[PARAM_HUE_VARIATION])+" rand: "+rtos(huerand));
//print_line(itos(i)+":hue: "+rtos(preh)+" + "+rtos(huerot)+" = "+rtos(h)); //print_line(itos(i)+":hue: "+rtos(preh)+" + "+rtos(huerot)+" = "+rtos(h));
color.set_hsv(h,s,v); color.set_hsv(h,s,v);

View File

@ -1262,7 +1262,7 @@ Vector2 KinematicBody2D::move_and_slide(const Vector2& p_linear_velocity,const V
//all is a wall //all is a wall
move_and_slide_on_wall=true; move_and_slide_on_wall=true;
} else { } else {
if ( get_collision_normal().dot(p_floor_direction) > Math::cos(Math::deg2rad(45))) { //floor if ( get_collision_normal().dot(p_floor_direction) > Math::cos(Math::deg2rad((float)45))) { //floor
move_and_slide_on_floor=true; move_and_slide_on_floor=true;
@ -1272,7 +1272,7 @@ Vector2 KinematicBody2D::move_and_slide(const Vector2& p_linear_velocity,const V
revert_motion(); revert_motion();
return Vector2(); return Vector2();
} }
} else if ( get_collision_normal().dot(p_floor_direction) < Math::cos(Math::deg2rad(45))) { //ceiling } else if ( get_collision_normal().dot(p_floor_direction) < Math::cos(Math::deg2rad((float)45))) { //ceiling
move_and_slide_on_ceiling=true; move_and_slide_on_ceiling=true;
} else { } else {
move_and_slide_on_wall=true; move_and_slide_on_wall=true;

View File

@ -389,8 +389,8 @@ void BakedLight::_plot_face(int p_idx, int p_level, const Vector3 *p_vtx, const
Vector2 uv = get_uv(intersection,p_vtx,p_uv); Vector2 uv = get_uv(intersection,p_vtx,p_uv);
int uv_x = CLAMP(Math::fposmod(uv.x,1.0)*bake_texture_size,0,bake_texture_size-1); int uv_x = CLAMP(Math::fposmod(uv.x,1.0f)*bake_texture_size,0,bake_texture_size-1);
int uv_y = CLAMP(Math::fposmod(uv.y,1.0)*bake_texture_size,0,bake_texture_size-1); int uv_y = CLAMP(Math::fposmod(uv.y,1.0f)*bake_texture_size,0,bake_texture_size-1);
int ofs = uv_y*bake_texture_size+uv_x; int ofs = uv_y*bake_texture_size+uv_x;
albedo_accum.r+=p_material.albedo[ofs].r; albedo_accum.r+=p_material.albedo[ofs].r;
@ -415,8 +415,8 @@ void BakedLight::_plot_face(int p_idx, int p_level, const Vector3 *p_vtx, const
Vector2 uv = get_uv(inters,p_vtx,p_uv); Vector2 uv = get_uv(inters,p_vtx,p_uv);
int uv_x = CLAMP(Math::fposmod(uv.x,1.0)*bake_texture_size,0,bake_texture_size-1); int uv_x = CLAMP(Math::fposmod(uv.x,1.0f)*bake_texture_size,0,bake_texture_size-1);
int uv_y = CLAMP(Math::fposmod(uv.y,1.0)*bake_texture_size,0,bake_texture_size-1); int uv_y = CLAMP(Math::fposmod(uv.y,1.0f)*bake_texture_size,0,bake_texture_size-1);
int ofs = uv_y*bake_texture_size+uv_x; int ofs = uv_y*bake_texture_size+uv_x;

View File

@ -510,8 +510,8 @@ void GIProbe::_plot_face(int p_idx, int p_level,int p_x,int p_y,int p_z, const V
Vector2 uv = get_uv(intersection,p_vtx,p_uv); Vector2 uv = get_uv(intersection,p_vtx,p_uv);
int uv_x = CLAMP(Math::fposmod(uv.x,1.0)*bake_texture_size,0,bake_texture_size-1); int uv_x = CLAMP(Math::fposmod(uv.x,1.0f)*bake_texture_size,0,bake_texture_size-1);
int uv_y = CLAMP(Math::fposmod(uv.y,1.0)*bake_texture_size,0,bake_texture_size-1); int uv_y = CLAMP(Math::fposmod(uv.y,1.0f)*bake_texture_size,0,bake_texture_size-1);
int ofs = uv_y*bake_texture_size+uv_x; int ofs = uv_y*bake_texture_size+uv_x;
albedo_accum.r+=p_material.albedo[ofs].r; albedo_accum.r+=p_material.albedo[ofs].r;
@ -539,8 +539,8 @@ void GIProbe::_plot_face(int p_idx, int p_level,int p_x,int p_y,int p_z, const V
Vector2 uv = get_uv(inters,p_vtx,p_uv); Vector2 uv = get_uv(inters,p_vtx,p_uv);
int uv_x = CLAMP(Math::fposmod(uv.x,1.0)*bake_texture_size,0,bake_texture_size-1); int uv_x = CLAMP(Math::fposmod(uv.x,1.0f)*bake_texture_size,0,bake_texture_size-1);
int uv_y = CLAMP(Math::fposmod(uv.y,1.0)*bake_texture_size,0,bake_texture_size-1); int uv_y = CLAMP(Math::fposmod(uv.y,1.0f)*bake_texture_size,0,bake_texture_size-1);
int ofs = uv_y*bake_texture_size+uv_x; int ofs = uv_y*bake_texture_size+uv_x;

View File

@ -476,7 +476,7 @@ void AnimationPlayer::_animation_process_animation(AnimationData* p_anim,float p
} }
#endif #endif
static_cast<Node2D*>(pa->object)->set_rotation(Math::deg2rad(value)); static_cast<Node2D*>(pa->object)->set_rotation(Math::deg2rad((double)value));
} break; } break;
case SP_NODE2D_SCALE: { case SP_NODE2D_SCALE: {
#ifdef DEBUG_ENABLED #ifdef DEBUG_ENABLED
@ -690,7 +690,7 @@ void AnimationPlayer::_animation_update_transforms() {
} }
#endif #endif
static_cast<Node2D*>(pa->object)->set_rotation(Math::deg2rad(pa->value_accum)); static_cast<Node2D*>(pa->object)->set_rotation(Math::deg2rad((double)pa->value_accum));
} break; } break;
case SP_NODE2D_SCALE: { case SP_NODE2D_SCALE: {
#ifdef DEBUG_ENABLED #ifdef DEBUG_ENABLED

View File

@ -141,8 +141,8 @@ void Range::set_as_ratio(double p_value) {
if (shared->exp_ratio && get_min()>0) { if (shared->exp_ratio && get_min()>0) {
double exp_min = Math::log(get_min())/Math::log(2); double exp_min = Math::log(get_min())/Math::log((double)2);
double exp_max = Math::log(get_max())/Math::log(2); double exp_max = Math::log(get_max())/Math::log((double)2);
v = Math::pow(2,exp_min+(exp_max-exp_min)*p_value); v = Math::pow(2,exp_min+(exp_max-exp_min)*p_value);
} else { } else {
@ -160,9 +160,9 @@ double Range::get_as_ratio() const {
if (shared->exp_ratio && get_min()>0) { if (shared->exp_ratio && get_min()>0) {
double exp_min = Math::log(get_min())/Math::log(2); double exp_min = Math::log(get_min())/Math::log((double)2);
double exp_max = Math::log(get_max())/Math::log(2); double exp_max = Math::log(get_max())/Math::log((double)2);
double v = Math::log(get_value())/Math::log(2); double v = Math::log(get_value())/Math::log((double)2);
return (v - exp_min) / (exp_max - exp_min); return (v - exp_min) / (exp_max - exp_min);

View File

@ -162,7 +162,7 @@ void SpinBox::_gui_input(const InputEvent& p_event) {
if (drag.enabled) { if (drag.enabled) {
float diff_y = drag.mouse_pos.y - cpos.y; float diff_y = drag.mouse_pos.y - cpos.y;
diff_y=Math::pow(ABS(diff_y),1.8)*SGN(diff_y); diff_y=Math::pow(ABS(diff_y),1.8f)*SGN(diff_y);
diff_y*=0.1; diff_y*=0.1;
drag.mouse_pos=cpos; drag.mouse_pos=cpos;

View File

@ -943,7 +943,7 @@ void Tree::draw_item_rect(const TreeItem::Cell& p_cell,const Rect2i& p_rect,cons
bmsize.width=p_cell.icon_max_w; bmsize.width=p_cell.icon_max_w;
} }
p_cell.draw_icon(ci,rect.pos + Size2i(0,Math::floor((rect.size.y-bmsize.y)/2)),bmsize); p_cell.draw_icon(ci,rect.pos + Size2i(0,Math::floor((real_t)(rect.size.y-bmsize.y)/2)),bmsize);
rect.pos.x+=bmsize.x+cache.hseparation; rect.pos.x+=bmsize.x+cache.hseparation;
rect.size.x-=bmsize.x+cache.hseparation; rect.size.x-=bmsize.x+cache.hseparation;
@ -1173,7 +1173,7 @@ int Tree::draw_item(const Point2i& p_pos,const Point2& p_draw_ofs, const Size2&
Ref<Texture> checked = cache.checked; Ref<Texture> checked = cache.checked;
Ref<Texture> unchecked = cache.unchecked; Ref<Texture> unchecked = cache.unchecked;
Point2i check_ofs=item_rect.pos; Point2i check_ofs=item_rect.pos;
check_ofs.y+=Math::floor((item_rect.size.y-checked->get_height())/2); check_ofs.y+=Math::floor((real_t)(item_rect.size.y-checked->get_height())/2);
if (p_item->cells[i].checked) { if (p_item->cells[i].checked) {
@ -2321,7 +2321,7 @@ void Tree::_gui_input(InputEvent p_event) {
TreeItem::Cell &c=popup_edited_item->cells[popup_edited_item_col]; TreeItem::Cell &c=popup_edited_item->cells[popup_edited_item_col];
float diff_y = -b.relative_y; float diff_y = -b.relative_y;
diff_y=Math::pow(ABS(diff_y),1.8)*SGN(diff_y); diff_y=Math::pow(ABS(diff_y),1.8f)*SGN(diff_y);
diff_y*=0.1; diff_y*=0.1;
range_drag_base=CLAMP(range_drag_base + c.step * diff_y, c.min, c.max); range_drag_base=CLAMP(range_drag_base + c.step * diff_y, c.min, c.max);
popup_edited_item->set_range(popup_edited_item_col,range_drag_base); popup_edited_item->set_range(popup_edited_item_col,range_drag_base);

View File

@ -42,8 +42,8 @@ Vector<Vector3> CapsuleShape::_gen_debug_mesh_lines() {
Vector3 d(0,0,height*0.5); Vector3 d(0,0,height*0.5);
for(int i=0;i<360;i++) { for(int i=0;i<360;i++) {
float ra=Math::deg2rad(i); float ra=Math::deg2rad((float)i);
float rb=Math::deg2rad(i+1); float rb=Math::deg2rad((float)i+1);
Point2 a = Vector2(Math::sin(ra),Math::cos(ra))*radius; Point2 a = Vector2(Math::sin(ra),Math::cos(ra))*radius;
Point2 b = Vector2(Math::sin(rb),Math::cos(rb))*radius; Point2 b = Vector2(Math::sin(rb),Math::cos(rb))*radius;

View File

@ -498,7 +498,7 @@ Vector2 Curve2D::interpolatef(real_t p_findex) const {
else if (p_findex>=points.size()) else if (p_findex>=points.size())
p_findex=points.size(); p_findex=points.size();
return interpolate((int)p_findex,Math::fmod(p_findex,1.0)); return interpolate((int)p_findex,Math::fmod(p_findex,(real_t)1.0));
} }
@ -653,7 +653,7 @@ Vector2 Curve2D::interpolate_baked(float p_offset,bool p_cubic) const{
return r[bpc-1]; return r[bpc-1];
int idx = Math::floor((double)p_offset/(double)bake_interval); int idx = Math::floor((double)p_offset/(double)bake_interval);
float frac = Math::fmod(p_offset,bake_interval); float frac = Math::fmod(p_offset,(float)bake_interval);
if (idx>=bpc-1) { if (idx>=bpc-1) {
return r[bpc-1]; return r[bpc-1];
@ -974,7 +974,7 @@ Vector3 Curve3D::interpolatef(real_t p_findex) const {
else if (p_findex>=points.size()) else if (p_findex>=points.size())
p_findex=points.size(); p_findex=points.size();
return interpolate((int)p_findex,Math::fmod(p_findex,1.0)); return interpolate((int)p_findex,Math::fmod(p_findex,(real_t)1.0));
} }

View File

@ -37,8 +37,8 @@ Vector<Vector3> SphereShape::_gen_debug_mesh_lines() {
for(int i=0;i<=360;i++) { for(int i=0;i<=360;i++) {
float ra=Math::deg2rad(i); float ra=Math::deg2rad((float)i);
float rb=Math::deg2rad(i+1); float rb=Math::deg2rad((float)i+1);
Point2 a = Vector2(Math::sin(ra),Math::cos(ra))*r; Point2 a = Vector2(Math::sin(ra),Math::cos(ra))*r;
Point2 b = Vector2(Math::sin(rb),Math::cos(rb))*r; Point2 b = Vector2(Math::sin(rb),Math::cos(rb))*r;

View File

@ -142,9 +142,9 @@ void AudioFilterSW::prepare_coefficients(Coeffs *p_coeffs) {
//this one is extra tricky //this one is extra tricky
double hicutoff=resonance; double hicutoff=resonance;
double centercutoff = (cutoff+resonance)/2.0; double centercutoff = (cutoff+resonance)/2.0;
double bandwidth=(Math::log(centercutoff)-Math::log(hicutoff))/Math::log(2); double bandwidth=(Math::log(centercutoff)-Math::log(hicutoff))/Math::log((double)2);
omega=2.0*Math_PI*centercutoff/sampling_rate; omega=2.0*Math_PI*centercutoff/sampling_rate;
alpha = Math::sin(omega)*Math::sinh( Math::log(2)/2 * bandwidth * omega/Math::sin(omega) ); alpha = Math::sin(omega)*Math::sinh( Math::log((double)2)/2 * bandwidth * omega/Math::sin(omega) );
a0=1+alpha; a0=1+alpha;
p_coeffs->b0 = alpha; p_coeffs->b0 = alpha;

View File

@ -539,14 +539,14 @@ int BroadPhase2DHashGrid::cull_segment(const Vector2& p_from, const Vector2& p_t
Vector2 max; Vector2 max;
if (dir.x<0) if (dir.x<0)
max.x= (Math::floor(pos.x)*cell_size - p_from.x) / dir.x; max.x= (Math::floor((double)pos.x)*cell_size - p_from.x) / dir.x;
else else
max.x= (Math::floor(pos.x + 1)*cell_size - p_from.x) / dir.x; max.x= (Math::floor((double)pos.x + 1)*cell_size - p_from.x) / dir.x;
if (dir.y<0) if (dir.y<0)
max.y= (Math::floor(pos.y)*cell_size - p_from.y) / dir.y; max.y= (Math::floor((double)pos.y)*cell_size - p_from.y) / dir.y;
else else
max.y= (Math::floor(pos.y + 1)*cell_size - p_from.y) / dir.y; max.y= (Math::floor((double)pos.y + 1)*cell_size - p_from.y) / dir.y;
int cullcount=0; int cullcount=0;
_cull<false,true>(pos,Rect2(),p_from,p_to,p_results,p_max_results,p_result_indices,cullcount); _cull<false,true>(pos,Rect2(),p_from,p_to,p_results,p_max_results,p_result_indices,cullcount);

View File

@ -179,12 +179,12 @@ private:
bool sg = val < 0; bool sg = val < 0;
val = Math::absf(val); val = Math::absf(val);
val = Math::log(val)/Math::log(2); val = Math::log(val)/Math::log((float)2.0);
//logspace //logspace
val+=rel*0.05; val+=rel*0.05;
// //
val = Math::pow(2,val); val = Math::pow((float)2.0,val);
if (sg) if (sg)
val=-val; val=-val;
@ -1055,9 +1055,9 @@ float AnimationKeyEditor::_get_zoom_scale() const {
float zv = zoom->get_value(); float zv = zoom->get_value();
if (zv<1) { if (zv<1) {
zv = 1.0-zv; zv = 1.0-zv;
return Math::pow(1.0+zv,8.0)*100; return Math::pow(1.0f+zv,8.0f)*100;
} else { } else {
return 1.0/Math::pow(zv,8.0)*100; return 1.0/Math::pow(zv,8.0f)*100;
} }
} }
@ -1487,8 +1487,8 @@ void AnimationKeyEditor::_track_editor_draw() {
//draw the keys; //draw the keys;
int tt = animation->track_get_type(idx); int tt = animation->track_get_type(idx);
float key_vofs = Math::floor((h - type_icon[tt]->get_height())/2); float key_vofs = Math::floor((float)(h - type_icon[tt]->get_height())/2);
float key_hofs = -Math::floor(type_icon[tt]->get_height()/2); float key_hofs = -Math::floor((float)type_icon[tt]->get_height()/2);
int kc=animation->track_get_key_count(idx); int kc=animation->track_get_key_count(idx);
bool first=true; bool first=true;
@ -1592,8 +1592,8 @@ void AnimationKeyEditor::_track_editor_draw() {
continue; continue;
int y = h+i*h+sep; int y = h+i*h+sep;
float key_vofs = Math::floor((h - type_selected->get_height())/2); float key_vofs = Math::floor((float)(h - type_selected->get_height())/2);
float key_hofs = -Math::floor(type_selected->get_height()/2); float key_hofs = -Math::floor((float)type_selected->get_height()/2);
float time = animation->track_get_key_time(idx,E->key().key); float time = animation->track_get_key_time(idx,E->key().key);
float diff = time-from_t; float diff = time-from_t;

View File

@ -1473,7 +1473,7 @@ Ref<BitmapFont> EditorFontImportPlugin::generate_font(const Ref<ResourceImportMe
sum+=w2[ofs_l]; sum+=w2[ofs_l];
} }
wa[ofs]=Math::pow(float(sum/(r*2+1))/255.0,tr)*255.0; wa[ofs]=Math::pow(float(sum/(r*2+1))/255.0f,tr)*255.0f;
} }
} }

View File

@ -541,7 +541,7 @@ Error EditorSampleImportPlugin::import(const String& p_path, const Ref<ResourceI
int first=0; int first=0;
int last=(len*chans)-1; int last=(len*chans)-1;
bool found=false; bool found=false;
float limit = Math::db2linear(-30); float limit = Math::db2linear((float)-30);
for(int i=0;i<data.size();i++) { for(int i=0;i<data.size();i++) {
float amp = Math::abs(data[i]); float amp = Math::abs(data[i]);

View File

@ -216,7 +216,7 @@ void MultiMeshEditor::_populate() {
for(int i=0;i<instance_count;i++) { for(int i=0;i<instance_count;i++) {
float areapos = Math::random(0,area_accum); float areapos = Math::random(0.0f,area_accum);
Map<float,int>::Element *E = triangle_area_map.find_closest(areapos); Map<float,int>::Element *E = triangle_area_map.find_closest(areapos);
ERR_FAIL_COND(!E) ERR_FAIL_COND(!E)

View File

@ -1503,12 +1503,12 @@ void CustomPropertyEditor::_drag_easing(const InputEvent& p_ev) {
bool sg = val < 0; bool sg = val < 0;
val = Math::absf(val); val = Math::absf(val);
val = Math::log(val)/Math::log(2); val = Math::log(val)/Math::log((float)2.0);
//logspace //logspace
val+=rel*0.05; val+=rel*0.05;
// //
val = Math::pow(2,val); val = Math::pow(2.0f,val);
if (sg) if (sg)
val=-val; val=-val;

View File

@ -826,7 +826,7 @@ void ScriptEditorDebugger::_performance_draw() {
Ref<StyleBox> graph_sb = get_stylebox("normal","TextEdit"); Ref<StyleBox> graph_sb = get_stylebox("normal","TextEdit");
Ref<Font> graph_font = get_font("font","TextEdit"); Ref<Font> graph_font = get_font("font","TextEdit");
int cols = Math::ceil(Math::sqrt(which.size())); int cols = Math::ceil(Math::sqrt((float)which.size()));
int rows = (which.size()+1)/cols; int rows = (which.size()+1)/cols;
if (which.size()==1) if (which.size()==1)
rows=1; rows=1;

View File

@ -839,8 +839,8 @@ void LightSpatialGizmo::redraw() {
for(int i=0;i<=360;i++) { for(int i=0;i<=360;i++) {
float ra=Math::deg2rad(i); float ra=Math::deg2rad((float)i);
float rb=Math::deg2rad(i+1); float rb=Math::deg2rad((float)i+1);
Point2 a = Vector2(Math::sin(ra),Math::cos(ra))*r; Point2 a = Vector2(Math::sin(ra),Math::cos(ra))*r;
Point2 b = Vector2(Math::sin(rb),Math::cos(rb))*r; Point2 b = Vector2(Math::sin(rb),Math::cos(rb))*r;
@ -881,8 +881,8 @@ void LightSpatialGizmo::redraw() {
for(int i=0;i<360;i++) { for(int i=0;i<360;i++) {
float ra=Math::deg2rad(i); float ra=Math::deg2rad((float)i);
float rb=Math::deg2rad(i+1); float rb=Math::deg2rad((float)i+1);
Point2 a = Vector2(Math::sin(ra),Math::cos(ra))*w; Point2 a = Vector2(Math::sin(ra),Math::cos(ra))*w;
Point2 b = Vector2(Math::sin(rb),Math::cos(rb))*w; Point2 b = Vector2(Math::sin(rb),Math::cos(rb))*w;
@ -1519,8 +1519,8 @@ void VehicleWheelSpatialGizmo::redraw() {
const int skip=10; const int skip=10;
for(int i=0;i<=360;i+=skip) { for(int i=0;i<=360;i+=skip) {
float ra=Math::deg2rad(i); float ra=Math::deg2rad((float)i);
float rb=Math::deg2rad(i+skip); float rb=Math::deg2rad((float)i+skip);
Point2 a = Vector2(Math::sin(ra),Math::cos(ra))*r; Point2 a = Vector2(Math::sin(ra),Math::cos(ra))*r;
Point2 b = Vector2(Math::sin(rb),Math::cos(rb))*r; Point2 b = Vector2(Math::sin(rb),Math::cos(rb))*r;
@ -1826,8 +1826,8 @@ void CollisionShapeSpatialGizmo::redraw(){
for(int i=0;i<=360;i++) { for(int i=0;i<=360;i++) {
float ra=Math::deg2rad(i); float ra=Math::deg2rad((float)i);
float rb=Math::deg2rad(i+1); float rb=Math::deg2rad((float)i+1);
Point2 a = Vector2(Math::sin(ra),Math::cos(ra))*r; Point2 a = Vector2(Math::sin(ra),Math::cos(ra))*r;
Point2 b = Vector2(Math::sin(rb),Math::cos(rb))*r; Point2 b = Vector2(Math::sin(rb),Math::cos(rb))*r;
@ -1907,8 +1907,8 @@ void CollisionShapeSpatialGizmo::redraw(){
Vector3 d(0,0,height*0.5); Vector3 d(0,0,height*0.5);
for(int i=0;i<360;i++) { for(int i=0;i<360;i++) {
float ra=Math::deg2rad(i); float ra=Math::deg2rad((float)i);
float rb=Math::deg2rad(i+1); float rb=Math::deg2rad((float)i+1);
Point2 a = Vector2(Math::sin(ra),Math::cos(ra))*radius; Point2 a = Vector2(Math::sin(ra),Math::cos(ra))*radius;
Point2 b = Vector2(Math::sin(rb),Math::cos(rb))*radius; Point2 b = Vector2(Math::sin(rb),Math::cos(rb))*radius;
@ -2844,8 +2844,8 @@ void ConeTwistJointSpatialGizmo::redraw() {
//swing //swing
for(int i=0;i<360;i+=10) { for(int i=0;i<360;i+=10) {
float ra=Math::deg2rad(i); float ra=Math::deg2rad((float)i);
float rb=Math::deg2rad(i+10); float rb=Math::deg2rad((float)i+10);
Point2 a = Vector2(Math::sin(ra),Math::cos(ra))*w; Point2 a = Vector2(Math::sin(ra),Math::cos(ra))*w;
Point2 b = Vector2(Math::sin(rb),Math::cos(rb))*w; Point2 b = Vector2(Math::sin(rb),Math::cos(rb))*w;
@ -2876,8 +2876,8 @@ void ConeTwistJointSpatialGizmo::redraw() {
for(int i=0;i<int(ts);i+=5) { for(int i=0;i<int(ts);i+=5) {
float ra=Math::deg2rad(i); float ra=Math::deg2rad((float)i);
float rb=Math::deg2rad(i+5); float rb=Math::deg2rad((float)i+5);
float c = i/720.0; float c = i/720.0;
float cn = (i+5)/720.0; float cn = (i+5)/720.0;
Point2 a = Vector2(Math::sin(ra),Math::cos(ra))*w*c; Point2 a = Vector2(Math::sin(ra),Math::cos(ra))*w*c;