mirror of
https://gitlab.com/veloren/veloren.git
synced 2024-08-30 18:12:32 +00:00
Make changing Alt/Compute to f32 work again.
This commit is contained in:
parent
756cc0aab4
commit
64d19a80e3
@ -21,28 +21,9 @@ use std::{
|
|||||||
use vek::*;
|
use vek::*;
|
||||||
|
|
||||||
pub type Alt = f64;
|
pub type Alt = f64;
|
||||||
// pub type Altx8 = /*f64x8*/f32x8;
|
|
||||||
pub type Compute = f64;
|
pub type Compute = f64;
|
||||||
pub type Computex8 = [Compute; 8];
|
pub type Computex8 = [Compute; 8];
|
||||||
|
|
||||||
/* /// This is a fast approximation of powf. This should only be used when minor accuracy loss is acceptable.
|
|
||||||
#[inline(always)]
|
|
||||||
#[allow(unsafe_code)]
|
|
||||||
fn approx_powf(b: f32, e: f32) -> f32 {
|
|
||||||
unsafe {
|
|
||||||
let b = b as f64;
|
|
||||||
let e = e as f64;
|
|
||||||
union Swagger {
|
|
||||||
f: f64,
|
|
||||||
a: [i32; 2],
|
|
||||||
}
|
|
||||||
let mut b = Swagger { f: b };
|
|
||||||
b.a[1] = (e * (b.a[1] as f64 - 1072632447.0) + 1072632447.0) as i32;
|
|
||||||
b.a[0] = 0;
|
|
||||||
b.f as f32
|
|
||||||
}
|
|
||||||
} */
|
|
||||||
|
|
||||||
/// Compute the water flux at all chunks, given a list of chunk indices sorted by increasing
|
/// Compute the water flux at all chunks, given a list of chunk indices sorted by increasing
|
||||||
/// height.
|
/// height.
|
||||||
pub fn get_drainage(newh: &[u32], downhill: &[isize], _boundary_len: usize) -> Box<[f32]> {
|
pub fn get_drainage(newh: &[u32], downhill: &[isize], _boundary_len: usize) -> Box<[f32]> {
|
||||||
@ -579,7 +560,7 @@ fn get_max_slope(
|
|||||||
.map(|(posi, &z)| {
|
.map(|(posi, &z)| {
|
||||||
let wposf = uniform_idx_as_vec2(posi).map(|e| e as f64) * TerrainChunkSize::RECT_SIZE.map(|e| e as f64);
|
let wposf = uniform_idx_as_vec2(posi).map(|e| e as f64) * TerrainChunkSize::RECT_SIZE.map(|e| e as f64);
|
||||||
let height_scale = height_scale(posi);
|
let height_scale = height_scale(posi);
|
||||||
let wposz = z as f64 / height_scale;// * CONFIG.mountain_scale as f64;
|
let wposz = z as f64 / height_scale as f64;
|
||||||
// Normalized to be between 6 and and 54 degrees.
|
// Normalized to be between 6 and and 54 degrees.
|
||||||
let div_factor = /*32.0*//*16.0*//*64.0*//*256.0*//*8.0 / 4.0*//*8.0*/(2.0 * TerrainChunkSize::RECT_SIZE.x as f64) / 8.0/* * 8.0*//*1.0*//*4.0*//* * /*1.0*/16.0/* TerrainChunkSize::RECT_SIZE.x as f64 / 8.0 */*/;
|
let div_factor = /*32.0*//*16.0*//*64.0*//*256.0*//*8.0 / 4.0*//*8.0*/(2.0 * TerrainChunkSize::RECT_SIZE.x as f64) / 8.0/* * 8.0*//*1.0*//*4.0*//* * /*1.0*/16.0/* TerrainChunkSize::RECT_SIZE.x as f64 / 8.0 */*/;
|
||||||
let rock_strength = rock_strength_nz
|
let rock_strength = rock_strength_nz
|
||||||
@ -966,7 +947,7 @@ fn erode(
|
|||||||
// let posj = posj as usize;
|
// let posj = posj as usize;
|
||||||
let dxy = (uniform_idx_as_vec2(posi) - uniform_idx_as_vec2(posj)).map(|e| e as f64);
|
let dxy = (uniform_idx_as_vec2(posi) - uniform_idx_as_vec2(posj)).map(|e| e as f64);
|
||||||
let neighbor_distance = (neighbor_coef * dxy).magnitude();
|
let neighbor_distance = (neighbor_coef * dxy).magnitude();
|
||||||
let knew = (k * (p * chunk_area * (area[posi] as f64 * mwrec_i[kk] as f64)).powf(m) / neighbor_distance.powf(n)) as /*Compute*/SimdType;
|
let knew = (k * (p as f64 * chunk_area * (area[posi] as f64 * mwrec_i[kk] as f64)).powf(m) / neighbor_distance.powf(n)) as /*Compute*/SimdType;
|
||||||
// let knew = (k * (p * chunk_area * (area[posi] as f64 * mwrec_i.extract(kk) as f64)).powf(m) / neighbor_distance.powf(n)) as Compute;
|
// let knew = (k * (p * chunk_area * (area[posi] as f64 * mwrec_i.extract(kk) as f64)).powf(m) / neighbor_distance.powf(n)) as Compute;
|
||||||
k_tot[kk] = knew;
|
k_tot[kk] = knew;
|
||||||
// k_tot = k_tot.replace(kk, knew);
|
// k_tot = k_tot.replace(kk, knew);
|
||||||
@ -1004,7 +985,7 @@ fn erode(
|
|||||||
// let g_i = g(posi) as f64;
|
// let g_i = g(posi) as f64;
|
||||||
let n = n_f(posi);
|
let n = n_f(posi);
|
||||||
let g_i = if sed > sediment_thickness(n) {
|
let g_i = if sed > sediment_thickness(n) {
|
||||||
g_fs_mult_sed * g(posi) as f64
|
(g_fs_mult_sed * g(posi)) as f64
|
||||||
} else {
|
} else {
|
||||||
g(posi) as f64
|
g(posi) as f64
|
||||||
};
|
};
|
||||||
@ -1026,7 +1007,7 @@ fn erode(
|
|||||||
|
|
||||||
let mwrec_i = &mwrec[posi];
|
let mwrec_i = &mwrec[posi];
|
||||||
mrec_downhill(&mrec, posi).for_each(|(kk, posj)| {
|
mrec_downhill(&mrec, posi).for_each(|(kk, posj)| {
|
||||||
let mwrec_kk = mwrec_i[kk];
|
let mwrec_kk = mwrec_i[kk] as f64;
|
||||||
// let posj = posj as usize;
|
// let posj = posj as usize;
|
||||||
|
|
||||||
// Working equation:
|
// Working equation:
|
||||||
@ -1068,7 +1049,7 @@ fn erode(
|
|||||||
// (eliminating EΔt maintains the sign, but it's somewhat imprecise;
|
// (eliminating EΔt maintains the sign, but it's somewhat imprecise;
|
||||||
// we can address this later, e.g. by assigning a debris flow / fluvial erosion ratio).
|
// we can address this later, e.g. by assigning a debris flow / fluvial erosion ratio).
|
||||||
let chunk_neutral_area = /*10.0e6*//*1.0e6*/0.1e6/*0.01e6*//*100.0 * 100.0*/; // 1 km^2 * (1000 m / km)^2 = 1e6 m^2
|
let chunk_neutral_area = /*10.0e6*//*1.0e6*/0.1e6/*0.01e6*//*100.0 * 100.0*/; // 1 km^2 * (1000 m / km)^2 = 1e6 m^2
|
||||||
let k = (mwrec_kk * (uplift_i + max_uplift as f64 * g_i / p)) / (1.0 + k_da * (mwrec_kk * chunk_neutral_area).powf(q)) / max_slope.powf(q_);
|
let k = (mwrec_kk * (uplift_i + max_uplift as f64 * g_i / p as f64)) / (1.0 + k_da * (mwrec_kk * chunk_neutral_area).powf(q)) / max_slope.powf(q_);
|
||||||
|
|
||||||
// ∆p = ||chunk_i - rec_i,kk||
|
// ∆p = ||chunk_i - rec_i,kk||
|
||||||
// k = k_df * Δt / (Δp)^(q_)
|
// k = k_df * Δt / (Δp)^(q_)
|
||||||
@ -1084,7 +1065,7 @@ fn erode(
|
|||||||
let dxy = (uniform_idx_as_vec2(posi) - uniform_idx_as_vec2(posj)).map(|e| e as f64);
|
let dxy = (uniform_idx_as_vec2(posi) - uniform_idx_as_vec2(posj)).map(|e| e as f64);
|
||||||
let neighbor_distance = (neighbor_coef * dxy).magnitude();
|
let neighbor_distance = (neighbor_coef * dxy).magnitude();
|
||||||
|
|
||||||
let knew = (k * (1.0 + k_da * chunk_area_pow * (area_i * mwrec_kk as f64).powf(q)) / neighbor_distance.powf(q_)) as SimdType/*Compute*/;
|
let knew = (k * (1.0 + k_da * chunk_area_pow * (area_i * mwrec_kk).powf(q)) / neighbor_distance.powf(q_)) as SimdType/*Compute*/;
|
||||||
// let knew = (k * (1.0 + k_da * chunk_area_pow * (area_i * mwrec_i.extract(kk) as f64).powf(q)) / neighbor_distance.powf(q_)) as Compute;
|
// let knew = (k * (1.0 + k_da * chunk_area_pow * (area_i * mwrec_i.extract(kk) as f64).powf(q)) / neighbor_distance.powf(q_)) as Compute;
|
||||||
// let knew = 0.0;
|
// let knew = 0.0;
|
||||||
k_tot[kk] = knew;
|
k_tot[kk] = knew;
|
||||||
@ -1401,7 +1382,7 @@ fn erode(
|
|||||||
let sed = (h_t_i - old_b_i) as f64;
|
let sed = (h_t_i - old_b_i) as f64;
|
||||||
let n = n_f(posi);
|
let n = n_f(posi);
|
||||||
let g_i = if sed > sediment_thickness(n) {
|
let g_i = if sed > sediment_thickness(n) {
|
||||||
g_fs_mult_sed * g(posi) as Compute
|
(g_fs_mult_sed * g(posi)) as Compute
|
||||||
} else {
|
} else {
|
||||||
g(posi) as Compute
|
g(posi) as Compute
|
||||||
};
|
};
|
||||||
|
@ -411,7 +411,7 @@ impl WorldSim {
|
|||||||
// k_d_scale ≡ (K_d / K_d') = grid_scale^2 / (/*height_scale * */ time_scale)
|
// k_d_scale ≡ (K_d / K_d') = grid_scale^2 / (/*height_scale * */ time_scale)
|
||||||
let k_d_scale = |n: f32| grid_scale.powi(2) / (/*height_scale(n) * */time_scale(n));
|
let k_d_scale = |n: f32| grid_scale.powi(2) / (/*height_scale(n) * */time_scale(n));
|
||||||
// epsilon_0_scale ≡ (ε₀ / ε₀') = height_scale(n) / time_scale(n)
|
// epsilon_0_scale ≡ (ε₀ / ε₀') = height_scale(n) / time_scale(n)
|
||||||
let epsilon_0_scale = |n| (height_scale(n) / time_scale(n)) as f32;
|
let epsilon_0_scale = |n| (height_scale(n) / time_scale(n) as Alt) as f32;
|
||||||
|
|
||||||
// Approximate n for purposes of computation of parameters above over the whole grid (when
|
// Approximate n for purposes of computation of parameters above over the whole grid (when
|
||||||
// a chunk isn't available).
|
// a chunk isn't available).
|
||||||
|
Loading…
Reference in New Issue
Block a user