mirror of
https://gitlab.com/veloren/veloren.git
synced 2024-08-30 18:12:32 +00:00
Merge branch 'sharp/temperature_free_chaos' into 'master'
Chaos doesn't depend on temperature anymore. See merge request veloren/veloren!461
This commit is contained in:
commit
61546239a8
@ -25,7 +25,7 @@ pub fn structure_gen<'a>(
|
|||||||
let st_sample = &structure_samples[idx].as_ref()?;
|
let st_sample = &structure_samples[idx].as_ref()?;
|
||||||
|
|
||||||
// Assuming it's a tree... figure out when it SHOULDN'T spawn
|
// Assuming it's a tree... figure out when it SHOULDN'T spawn
|
||||||
if st_sample.tree_density < 0.5 + (st_seed as f32 / 1000.0).fract() * 0.2
|
if st_sample.tree_density < 0.5 + (st_seed as f32 / 1000.0).fract() * 0.5
|
||||||
|| st_sample.alt < st_sample.water_level
|
|| st_sample.alt < st_sample.water_level
|
||||||
|| st_sample.spawn_rate < 0.5
|
|| st_sample.spawn_rate < 0.5
|
||||||
{
|
{
|
||||||
|
@ -5,7 +5,9 @@ mod util;
|
|||||||
// Reexports
|
// Reexports
|
||||||
pub use self::location::Location;
|
pub use self::location::Location;
|
||||||
pub use self::settlement::Settlement;
|
pub use self::settlement::Settlement;
|
||||||
use self::util::{cdf_irwin_hall, uniform_idx_as_vec2, uniform_noise, InverseCdf};
|
use self::util::{
|
||||||
|
cdf_irwin_hall, uniform_idx_as_vec2, uniform_noise, vec2_as_uniform_idx, InverseCdf,
|
||||||
|
};
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
all::ForestKind,
|
all::ForestKind,
|
||||||
@ -143,11 +145,6 @@ impl WorldSim {
|
|||||||
)
|
)
|
||||||
});
|
});
|
||||||
|
|
||||||
// -1 to 1.
|
|
||||||
let temp_base = uniform_noise(|_, wposf| {
|
|
||||||
Some((gen_ctx.temp_nz.get((wposf.div(12000.0)).into_array()) as f32))
|
|
||||||
});
|
|
||||||
|
|
||||||
// chaos produces a value in [0.1, 1.24]. It is a meta-level factor intended to reflect how
|
// chaos produces a value in [0.1, 1.24]. It is a meta-level factor intended to reflect how
|
||||||
// "chaotic" the region is--how much weird stuff is going on on this terrain.
|
// "chaotic" the region is--how much weird stuff is going on on this terrain.
|
||||||
let chaos = uniform_noise(|posi, wposf| {
|
let chaos = uniform_noise(|posi, wposf| {
|
||||||
@ -180,20 +177,6 @@ impl WorldSim {
|
|||||||
// hill is 0 about 50% of the time).
|
// hill is 0 about 50% of the time).
|
||||||
// [0, 1] + 0.15 * [0, 1.6] = [0, 1.24]
|
// [0, 1] + 0.15 * [0, 1.6] = [0, 1.24]
|
||||||
.add(0.2 * hill)
|
.add(0.2 * hill)
|
||||||
// [0, 1.24] * [0.35, 1.0] = [0, 1.24].
|
|
||||||
// Sharply decreases (towards 0.35) when temperature is near desert_temp (from below),
|
|
||||||
// then saturates just before it actually becomes desert. Otherwise stays at 1.
|
|
||||||
// Note that this is not the *final* temperature, only the initial noise value for
|
|
||||||
// temperature.
|
|
||||||
.mul(
|
|
||||||
temp_base[posi]
|
|
||||||
.1
|
|
||||||
.sub(0.45)
|
|
||||||
.neg()
|
|
||||||
.mul(12.0)
|
|
||||||
.max(0.35)
|
|
||||||
.min(1.0),
|
|
||||||
)
|
|
||||||
// We can't have *no* chaos!
|
// We can't have *no* chaos!
|
||||||
.max(0.1),
|
.max(0.1),
|
||||||
)
|
)
|
||||||
@ -236,9 +219,36 @@ impl WorldSim {
|
|||||||
Some((alt_base[posi].1 + alt_main.mul(chaos[posi].1)).mul(map_edge_factor(posi)))
|
Some((alt_base[posi].1 + alt_main.mul(chaos[posi].1)).mul(map_edge_factor(posi)))
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Check whether any tiles around this tile are not water (since Lerp will ensure that they
|
||||||
|
// are included).
|
||||||
|
let pure_water = |posi| {
|
||||||
|
let pos = uniform_idx_as_vec2(posi);
|
||||||
|
for x in (pos.x - 1..=pos.x + 1) {
|
||||||
|
for y in (pos.y - 1..=pos.y + 1) {
|
||||||
|
if x >= 0 && y >= 0 && x < WORLD_SIZE.x as i32 && y < WORLD_SIZE.y as i32 {
|
||||||
|
let posi = vec2_as_uniform_idx(Vec2::new(x, y));
|
||||||
|
if alt[posi].1.mul(CONFIG.mountain_scale) > 0.0 {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
true
|
||||||
|
};
|
||||||
|
|
||||||
|
// -1 to 1.
|
||||||
|
let temp_base = uniform_noise(|posi, wposf| {
|
||||||
|
if pure_water(posi) {
|
||||||
|
None
|
||||||
|
} else {
|
||||||
|
Some((gen_ctx.temp_nz.get((wposf.div(12000.0)).into_array()) as f32))
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
// 0 to 1, hopefully.
|
// 0 to 1, hopefully.
|
||||||
let humid_base = uniform_noise(|posi, wposf| {
|
let humid_base = uniform_noise(|posi, wposf| {
|
||||||
if alt[posi].1 <= 5.0.div(CONFIG.mountain_scale) {
|
// Check whether any tiles around this tile are water.
|
||||||
|
if pure_water(posi) {
|
||||||
None
|
None
|
||||||
} else {
|
} else {
|
||||||
Some(
|
Some(
|
||||||
@ -398,7 +408,7 @@ impl WorldSim {
|
|||||||
.map2(WORLD_SIZE, |e, sz| e >= 0 && e < sz as i32)
|
.map2(WORLD_SIZE, |e, sz| e >= 0 && e < sz as i32)
|
||||||
.reduce_and()
|
.reduce_and()
|
||||||
{
|
{
|
||||||
Some(&self.chunks[chunk_pos.y as usize * WORLD_SIZE.x + chunk_pos.x as usize])
|
Some(&self.chunks[vec2_as_uniform_idx(chunk_pos)])
|
||||||
} else {
|
} else {
|
||||||
None
|
None
|
||||||
}
|
}
|
||||||
@ -409,7 +419,7 @@ impl WorldSim {
|
|||||||
.map2(WORLD_SIZE, |e, sz| e >= 0 && e < sz as i32)
|
.map2(WORLD_SIZE, |e, sz| e >= 0 && e < sz as i32)
|
||||||
.reduce_and()
|
.reduce_and()
|
||||||
{
|
{
|
||||||
Some(&mut self.chunks[chunk_pos.y as usize * WORLD_SIZE.x + chunk_pos.x as usize])
|
Some(&mut self.chunks[vec2_as_uniform_idx(chunk_pos)])
|
||||||
} else {
|
} else {
|
||||||
None
|
None
|
||||||
}
|
}
|
||||||
@ -573,9 +583,9 @@ impl SimChunk {
|
|||||||
// Weighted logit sum.
|
// Weighted logit sum.
|
||||||
logistic_cdf(logit(humidity) + 0.5 * logit(tree_density))
|
logistic_cdf(logit(humidity) + 0.5 * logit(tree_density))
|
||||||
}
|
}
|
||||||
// rescale to (-0.9, 0.9)
|
// rescale to (-0.95, 0.95)
|
||||||
.sub(0.5)
|
.sub(0.5)
|
||||||
.mul(0.9)
|
.mul(0.95)
|
||||||
.add(0.5)
|
.add(0.5)
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -96,7 +96,13 @@ pub type InverseCdf = Box<[(f32, f32)]>;
|
|||||||
/// Computes the position Vec2 of a SimChunk from an index, where the index was generated by
|
/// Computes the position Vec2 of a SimChunk from an index, where the index was generated by
|
||||||
/// uniform_noise.
|
/// uniform_noise.
|
||||||
pub fn uniform_idx_as_vec2(idx: usize) -> Vec2<i32> {
|
pub fn uniform_idx_as_vec2(idx: usize) -> Vec2<i32> {
|
||||||
Vec2::new((idx / WORLD_SIZE.x) as i32, (idx % WORLD_SIZE.x) as i32)
|
Vec2::new((idx % WORLD_SIZE.x) as i32, (idx / WORLD_SIZE.x) as i32)
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Computes the index of a Vec2 of a SimChunk from a position, where the index is generated by
|
||||||
|
/// uniform_noise. NOTE: Both components of idx should be in-bounds!
|
||||||
|
pub fn vec2_as_uniform_idx(idx: Vec2<i32>) -> usize {
|
||||||
|
(idx.y as usize * WORLD_SIZE.x + idx.x as usize) as usize
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Compute inverse cumulative distribution function for arbitrary function f, the hard way. We
|
/// Compute inverse cumulative distribution function for arbitrary function f, the hard way. We
|
||||||
|
Loading…
Reference in New Issue
Block a user