1
0
mirror of https://github.com/ComfyFactory/ComfyFactorio.git synced 2025-01-24 03:47:58 +02:00
ComfyFactorio/maps/pirates/balance.lua

641 lines
22 KiB
Lua
Raw Normal View History

-- This file is part of thesixthroc's Pirate Ship softmod, licensed under GPLv3 and stored at https://github.com/danielmartin0/ComfyFactorio-Pirates.
2021-10-13 09:21:53 +01:00
local Public = {}
local Math = require 'maps.pirates.math'
2022-05-29 12:43:31 +01:00
-- local Raffle = require 'maps.pirates.raffle'
2022-03-19 21:20:55 +00:00
-- local Memory = require 'maps.pirates.memory'
2021-10-13 09:21:53 +01:00
local Common = require 'maps.pirates.common'
2022-05-29 12:43:31 +01:00
-- local Utils = require 'maps.pirates.utils_local'
-- local _inspect = require 'utils.inspect'.inspect
2021-10-13 09:21:53 +01:00
2022-03-08 23:36:03 +00:00
-- this file is an API to all the balance tuning knobs
2022-06-02 22:08:55 +03:00
-- Kraken related parameters
Public.biter_swim_speed = 1
Public.kraken_biter_spawn_radius = 6 -- only used during non automatic forced spawning during kraken's "special ability"
Public.kraken_spit_targeting_player_chance = 0
2022-06-02 22:08:55 +03:00
Public.base_extra_character_speed = 1.44
2022-07-30 10:29:17 +01:00
Public.respawn_speed_boost = 1.85
2021-10-13 09:21:53 +01:00
-- maximum rate at which alert sound can be played when important buildings are damaged (like silo or cannons)
-- NOTE: frequency can sometimes be faster by 1 second than denoted, but accuracy doesn't really matter here
Public.alert_sound_max_frequency_in_seconds = 3
Public.cannon_extra_hp_for_upgrade = 1000
2022-06-03 14:15:42 +01:00
Public.cannon_starting_hp = 2000
Public.cannon_resistance_factor = 2
2021-10-13 09:21:53 +01:00
Public.technology_price_multiplier = 1
2022-06-02 22:08:55 +03:00
Public.rocket_launch_coin_reward = 5000
2022-06-03 20:55:57 +01:00
Public.base_caught_fish_amount = 3
Public.class_reward_tick_rate_in_seconds = 7
Public.poison_damage_multiplier = 1.85
Public.every_nth_tree_gives_coins = 6
Public.samurai_damage_taken_multiplier = 0.26
Public.samurai_damage_dealt_when_not_melee_multiplier = 0.75
2022-06-03 21:02:30 +01:00
Public.samurai_damage_dealt_with_melee = 25
2022-06-03 20:55:57 +01:00
Public.hatamoto_damage_taken_multiplier = 0.16
Public.hatamoto_damage_dealt_when_not_melee_multiplier = 0.75
2022-06-03 21:02:30 +01:00
Public.hatamoto_damage_dealt_with_melee = 45
2022-06-03 20:55:57 +01:00
Public.iron_leg_damage_taken_multiplier = 0.18
Public.iron_leg_iron_ore_required = 3000
Public.deckhand_extra_speed = 1.25
Public.deckhand_ore_grant_multiplier = 2
Public.deckhand_ore_scaling_enabled = true
Public.boatswain_extra_speed = 1.25
Public.boatswain_ore_grant_multiplier = 4
Public.boatswain_ore_scaling_enabled = true
Public.shoresman_extra_speed = 1.1
Public.shoresman_ore_grant_multiplier = 2
Public.shoresman_ore_scaling_enabled = true
Public.quartermaster_range = 19
Public.quartermaster_bonus_physical_damage = 1.3
2022-06-03 20:55:57 +01:00
Public.quartermaster_ore_scaling_enabled = false
Public.scout_extra_speed = 1.3
Public.scout_damage_taken_multiplier = 1.25
Public.scout_damage_dealt_multiplier = 0.6
Public.fisherman_reach_bonus = 10
Public.lumberjack_coins_from_tree = 12
2022-06-03 20:55:57 +01:00
Public.master_angler_reach_bonus = 16
Public.master_angler_fish_bonus = 2
Public.master_angler_coin_bonus = 20
2022-06-03 20:55:57 +01:00
Public.dredger_reach_bonus = 16
Public.dredger_fish_bonus = 2
2022-06-03 20:55:57 +01:00
Public.gourmet_ore_scaling_enabled = false
2022-07-31 10:23:59 +01:00
Public.chef_fish_received_for_biter_kill = 1
Public.chef_fish_received_for_worm_kill = 3
Public.rock_eater_damage_taken_multiplier = 0.8
Public.rock_eater_required_stone_furnace_to_heal_count = 1
Public.soldier_defender_summon_chance = 0.2
Public.veteran_destroyer_summon_chance = 0.2
Public.veteran_on_hit_slow_chance = 0.1
2022-06-03 20:55:57 +01:00
2021-10-13 09:21:53 +01:00
function Public.starting_boatEEIpower_production_MW()
-- return 3 * Math.sloped(Common.capacity_scale(), 1/2) / 2 --/2 as we have 2
return 3/2
end
function Public.starting_boatEEIelectric_buffer_size_MJ() --maybe needs to be at least the power_production
-- return 3 * Math.sloped(Common.capacity_scale(), 1/2) / 2 --/2 as we have 2
return 3/2
end
Public.EEI_stages = { --multipliers
2022-03-13 01:44:32 +00:00
1,2,4,7,11
2021-10-13 09:21:53 +01:00
}
function Public.scripted_biters_pollution_cost_multiplier()
2022-05-01 11:52:43 +01:00
2022-06-03 14:33:26 +01:00
return 1.45 / Math.sloped(Common.difficulty_scale(), 1/3) * (1 + 1.2 / ((1 + (Common.overworldx()/40))^(1.5+Common.difficulty_scale()))) -- the complicated factor just makes the early-game easier; in particular the first island, but on easier difficulties the next few islands as well
2021-10-13 09:21:53 +01:00
end
2021-10-14 10:23:34 +01:00
function Public.cost_to_leave_multiplier()
-- return Math.sloped(Common.difficulty_scale(), 7/10) --should scale with difficulty similar to, but slightly slower than, passive fuel depletion rate --Edit: not sure about this?
-- return Math.sloped(Common.difficulty_scale(), 9/10)
2022-03-14 12:44:30 +00:00
-- extra factor now that the cost scales with time:
return Math.sloped(Common.difficulty_scale(), 8/10)
2021-10-14 10:23:34 +01:00
end
2022-02-28 20:35:45 +00:00
function Public.crew_scale()
2022-03-04 17:57:58 +00:00
local ret = Common.activecrewcount()/10
if ret == 0 then ret = 1/10 end --if all players are afk
2022-05-09 00:36:48 +01:00
if ret > 2.1 then ret = 2.1 end --An upper cap on this is important, for two reasons:
-- large crews become disorganised
-- Higher values of this scale lower the amount of time you get on each island. But the amount of time certain island tasks take is fixed; e.g. the amount of ore is mostly invariant, and you need time to mine it.
2022-03-04 17:57:58 +00:00
return ret
2021-10-13 09:21:53 +01:00
end
function Public.silo_base_est_time()
2022-02-28 20:35:45 +00:00
local T = Public.expected_time_on_island() * Public.crew_scale()^(2/10) --to undo some of the time scaling
2021-10-13 09:21:53 +01:00
local est_secs
if T > 0 then
est_secs = T/6
else
est_secs = 60 * 6
end
if Common.overworldx() == 0 then est_secs = 60 * 2 end
return est_secs
end
function Public.time_quest_seconds()
2022-02-24 19:39:03 +00:00
return 2.8 * Public.silo_base_est_time()
2021-10-13 09:21:53 +01:00
end
function Public.silo_energy_needed_MJ()
local est_secs = Public.silo_base_est_time()
2021-10-31 20:34:18 +00:00
local est_base_power = 2*Public.starting_boatEEIpower_production_MW() * (1 + 0.05 * (Common.overworldx()/40)^(5/3))
2021-10-13 09:21:53 +01:00
2021-10-31 20:34:18 +00:00
return est_secs * est_base_power
-- return est_secs * est_base_power * Math.sloped(Common.difficulty_scale(), 1/3)
2021-10-13 09:21:53 +01:00
end
2022-02-24 19:39:03 +00:00
function Public.silo_count()
local E = Public.silo_energy_needed_MJ()
2022-05-29 16:27:04 +01:00
return Math.min(Math.ceil(E/(16.8 * 300)),6)
-- return Math.ceil(E/(16.8 * 300)) --no more than this many seconds to charge it. Players can in fact go even faster using beacons
2022-02-24 19:39:03 +00:00
end
2021-10-13 09:21:53 +01:00
2022-03-08 23:36:03 +00:00
function Public.game_slowness_scale()
-- return 1 / Public.crew_scale()^(55/100) / Math.sloped(Common.difficulty_scale(), 1/4) --changed crew_scale factor significantly to help smaller crews
return 1 / Public.crew_scale()^(50/100) / Math.sloped(Common.difficulty_scale(), 1/4) --changed crew_scale factor significantly to help smaller crews
2022-03-08 23:36:03 +00:00
end
2022-02-26 18:25:48 +00:00
function Public.max_time_on_island_formula() --always >0 --tuned
2021-10-13 09:21:53 +01:00
return 60 * (
2022-03-28 00:40:32 +01:00
-- (32 + 2.2 * (Common.overworldx()/40)^(1/3))
(33 + 0.2 * (Common.overworldx()/40)^(1/3)) --based on observing x=2000, lets try killing the extra time
2022-03-08 23:36:03 +00:00
) * Public.game_slowness_scale()
2021-10-13 09:21:53 +01:00
end
2022-07-31 10:23:59 +01:00
Public.rockets_needed_x = 40*20
2021-10-13 09:21:53 +01:00
function Public.max_time_on_island()
2022-05-07 21:41:45 +01:00
local x = Common.overworldx()
2022-07-31 10:23:59 +01:00
if x == 0 or (x >= Public.rockets_needed_x and x ~= 40*21) then
2022-03-08 23:36:03 +00:00
-- if Common.overworldx() == 0 or ((Common.overworldx()/40) > 20 and (Common.overworldx()/40) < 25) then
2021-10-13 09:21:53 +01:00
return -1
else
2022-05-07 21:41:45 +01:00
if x == 40 then
2022-05-23 02:01:01 +01:00
return 1.1 * Math.ceil(Public.max_time_on_island_formula()) --it's important for this island to be somewhat chill, so that it's not such a shock to go here from the first lobby chill island
2022-05-07 21:41:45 +01:00
else
return Math.ceil(Public.max_time_on_island_formula())
end
2021-10-13 09:21:53 +01:00
end
end
2022-03-07 12:57:07 +00:00
Public.expected_time_fraction = 3/5
2022-02-26 18:25:48 +00:00
function Public.expected_time_on_island() --always >0
2022-03-07 12:57:07 +00:00
return Public.expected_time_fraction * Public.max_time_on_island_formula()
2021-10-13 09:21:53 +01:00
end
2022-02-24 19:39:03 +00:00
function Public.fuel_depletion_rate_static()
if (not Common.overworldx()) then return 0 end
2022-02-26 18:25:48 +00:00
local T = Public.expected_time_on_island()
2022-02-24 19:39:03 +00:00
2022-02-28 16:36:46 +00:00
local rate
if Common.overworldx() > 0 then
2022-07-30 10:29:17 +01:00
rate = 570 * (0 + (Common.overworldx()/40)^(9/10)) * Public.crew_scale()^(1/8) * Math.sloped(Common.difficulty_scale(), 65/100) / T --most of the crewsize dependence is through T, i.e. the coal cost per island stays the same... but the extra player dependency accounts for the fact that even in compressed time, more players seem to get more resources per island
2022-02-28 16:36:46 +00:00
else
rate = 0
end
return -rate
2022-02-24 19:39:03 +00:00
end
function Public.fuel_depletion_rate_sailing()
if (not Common.overworldx()) then return 0 end
2022-07-30 10:29:17 +01:00
return - 7.75 * (1 + 0.135 * (Common.overworldx()/40)^(100/100)) * Math.sloped(Common.difficulty_scale(), 1/20) --shouldn't depend on difficulty much if at all, as available resources don't depend much on difficulty
2022-02-24 19:39:03 +00:00
end
2022-03-01 21:59:48 +00:00
function Public.silo_total_pollution()
return (
365 * (Common.difficulty_scale()^(1.2)) * Public.crew_scale()^(3/10) * (3.2 + 0.7 * (Common.overworldx()/40)^(1.6)) / Math.sloped(Common.difficulty_scale(), 1/5) --shape of the curve with x is tuned. Final factor of difficulty is to offset a change made to scripted_biters_pollution_cost_multiplier
2022-03-01 21:59:48 +00:00
)
end
2021-10-13 09:21:53 +01:00
function Public.boat_passive_pollution_per_minute(time)
local boost = 1
local T = Public.max_time_on_island_formula()
2022-03-08 23:36:03 +00:00
if (Common.overworldx()/40) > 25 then T = T * 0.9 end
2022-03-01 15:57:23 +00:00
if time then
if time >= 160/100 * T then
boost = 40
elseif time >= 130/100 * T then
boost = 30
elseif time >= 100/100 * T then --will still happen regularly, on islands without an auto-undock timer
2022-03-17 01:40:18 +00:00
boost = 20
elseif time >= 95/100 * T then
2022-03-05 19:56:41 +00:00
boost = 16
elseif time >= 90/100 * T then
boost = 12
2022-03-01 15:57:23 +00:00
elseif time >= 85/100 * T then
boost = 8
elseif time >= 80/100 * T then
2022-03-05 19:56:41 +00:00
boost = 5
2022-03-01 15:57:23 +00:00
elseif time >= 70/100 * T then
boost = 3
2022-03-05 19:56:41 +00:00
elseif time >= 60/100 * T then
2022-03-01 15:57:23 +00:00
boost = 2
2022-03-05 19:56:41 +00:00
elseif time >= 50/100 * T then
2022-03-05 23:42:47 +00:00
boost = 1.5
2022-03-01 15:57:23 +00:00
end
2021-10-13 09:21:53 +01:00
end
return boost * (
2.73 * (Common.difficulty_scale()^(1.1)) * (Common.overworldx()/40)^(1.8) * (Public.crew_scale())^(52/100)-- There is no _explicit_ T dependence, but it depends almost the same way on the crew_scale as T does.
) / Math.sloped(Common.difficulty_scale(), 1/5) --Final factor of difficulty is to offset a change made to scripted_biters_pollution_cost_multiplier
2021-10-13 09:21:53 +01:00
end
2022-03-17 01:40:18 +00:00
function Public.base_evolution_leagues(leagues)
2022-03-13 18:19:59 +00:00
local evo
2022-03-17 01:40:18 +00:00
local overworldx = leagues
2022-03-13 18:19:59 +00:00
2022-03-14 12:44:30 +00:00
if overworldx == 0 then
2022-03-13 18:19:59 +00:00
evo = 0
else
evo = (0.0201 * (overworldx/40)) * Math.sloped(Common.difficulty_scale(), 1/5)
2022-03-19 21:20:55 +00:00
2022-03-14 17:37:18 +00:00
if overworldx > 600 and overworldx < 1000 then
2022-03-14 12:44:30 +00:00
evo = evo + (0.0025 * (overworldx - 600)/40)
2022-05-23 02:01:01 +01:00
elseif overworldx >= 1000 then
2022-03-14 12:44:30 +00:00
evo = evo + 0.0025 * 10
2022-03-14 17:37:18 +00:00
end --extra slope from 600 to 1000 adds 2.5% evo
2022-03-13 01:44:32 +00:00
end
2022-03-13 18:19:59 +00:00
2021-10-13 09:21:53 +01:00
return evo
end
function Public.expected_time_evo()
2022-07-30 10:29:17 +01:00
return 0.125 --tuned
2021-10-13 09:21:53 +01:00
end
function Public.evolution_per_second()
local destination = Common.current_destination()
local T = Public.expected_time_on_island() --always greater than 0
local rate = Public.expected_time_evo() / T
if Common.overworldx() == 0 then rate = 0 end
-- scale by biter nests remaining:
if destination and destination.dynamic_data then
local initial_spawner_count = destination.dynamic_data.initial_spawner_count
if initial_spawner_count and initial_spawner_count > 0 then
local surface = game.surfaces[destination.surface_name]
if surface and surface.valid then
rate = rate * Common.spawner_count(surface) / destination.dynamic_data.initial_spawner_count
end
end
end
2022-03-04 18:24:04 +00:00
-- if _DEBUG then
-- local surface = game.surfaces[destination.surface_name]
-- game.print(Common.spawner_count(surface) .. ' ' .. destination.dynamic_data.initial_spawner_count)
-- end
2022-03-04 17:57:58 +00:00
2021-10-13 09:21:53 +01:00
return rate
end
2022-03-08 23:36:03 +00:00
function Public.evolution_per_nest_kill() --it's important to have evo go up with biter base kills, to provide resistance if you try to plow through all the bases
2021-10-13 09:21:53 +01:00
local destination = Common.current_destination()
if Common.overworldx() == 0 then return 0 end
if destination and destination.dynamic_data and destination.dynamic_data.timer and destination.dynamic_data.timer > 0 and destination.dynamic_data.initial_spawner_count and destination.dynamic_data.initial_spawner_count > 0 then
local initial_spawner_count = destination.dynamic_data.initial_spawner_count
local time = destination.dynamic_data.timer
2022-03-08 23:36:03 +00:00
-- local time_to_jump_to = Public.expected_time_on_island() * ((1/Public.expected_time_fraction)^(2/3))
local time_to_jump_to = Public.max_time_on_island_formula()
2022-03-07 12:57:07 +00:00
if time > time_to_jump_to then return 0
2021-10-13 09:21:53 +01:00
else
-- evo it 'would have' contributed:
2022-03-08 23:36:03 +00:00
return (1/initial_spawner_count) * Public.expected_time_evo() * (time_to_jump_to - time)/time_to_jump_to
2021-10-13 09:21:53 +01:00
end
else
return 0
end
-- return 0.003 * Common.difficulty_scale()
2021-10-13 09:21:53 +01:00
end
function Public.evolution_per_full_silo_charge()
2022-03-28 00:40:32 +01:00
--too low and you always charge immediately, too high and you always charge late
-- return 0.05
-- observed x=2000 run, changed this to:
2022-05-08 10:25:21 +01:00
-- return 0.05 + 0.03 * Common.overworldx()/1000
2022-05-07 21:41:45 +01:00
return 0.05 + 0.02 * Common.overworldx()/1000
2021-10-13 09:21:53 +01:00
end
-- function Public.bonus_damage_to_humans()
-- local ret = 0.025
-- local diff = Common.difficulty_scale()
-- if diff <= 0.7 then ret = 0 end
-- if diff >= 1.3 then ret = 0.050 end
-- return ret
-- end
2022-05-23 02:01:01 +01:00
function Public.biter_timeofday_bonus_damage(darkness) -- a surface having min_brightness of 0.2 will cap darkness at 0.8
return 0.1 * darkness
2021-10-13 09:21:53 +01:00
end
2022-03-19 21:20:55 +00:00
function Public.periodic_free_resources_per_x()
2022-02-25 00:01:28 +00:00
return {
}
2022-02-26 13:55:36 +00:00
-- return {
-- {name = 'iron-plate', count = Math.ceil(5 * (Common.overworldx()/40)^(2/3))},
-- {name = 'copper-plate', count = Math.ceil(1 * (Common.overworldx()/40)^(2/3))},
-- }
2021-10-13 09:21:53 +01:00
end
2022-03-19 21:20:55 +00:00
function Public.periodic_free_resources_per_destination_5_seconds()
2021-10-13 09:21:53 +01:00
return {
}
2022-02-25 00:01:28 +00:00
-- return {
-- {name = 'iron-ore', count = Math.ceil(7 * (Common.overworldx()/40)^(0.6))},
-- {name = 'copper-ore', count = Math.ceil(3 * (Common.overworldx()/40)^(0.6))},
-- }
2021-10-13 09:21:53 +01:00
end
function Public.class_resource_scale()
2022-03-05 19:56:41 +00:00
return 1 / (Public.crew_scale()^(2/5)) --already helped by longer timescales
2021-10-13 09:21:53 +01:00
end
function Public.biter_base_density_scale()
2022-03-04 17:57:58 +00:00
local p = Public.crew_scale()
if p >= 1 then
return p^(1/2)
2021-10-13 09:21:53 +01:00
else
2022-03-04 17:57:58 +00:00
return Math.max((p*10/6)^(1/2), 0.6)
2021-10-13 09:21:53 +01:00
end
end
2022-05-07 21:41:45 +01:00
function Public.rocket_launch_fuel_reward()
return Math.ceil(1250 * (1 + 0.13 * (Common.overworldx()/40)^(9/10)) * Math.sloped(Common.difficulty_scale(), 1/3))
-- return Math.ceil(1000 * (1 + 0.1 * (Common.overworldx()/40)^(8/10)) / Math.sloped(Common.difficulty_scale(), 1/4))
2021-10-13 09:21:53 +01:00
end
function Public.quest_reward_multiplier()
return (0.4 + 0.08 * (Common.overworldx()/40)^(8/10)) * Math.sloped(Common.difficulty_scale(), 1/3) * (Public.crew_scale())^(1/8)
2021-10-13 09:21:53 +01:00
end
function Public.island_richness_avg_multiplier()
2022-03-13 01:44:32 +00:00
local ret
2022-03-14 12:44:30 +00:00
-- local base = 0.7 + 0.1 * (Common.overworldx()/40)^(7/10) --tuned tbh
local base = 0.73 + 0.120 * (Common.overworldx()/40)^(65/100) --tuned tbh
2022-03-13 01:44:32 +00:00
2022-03-19 00:09:30 +00:00
ret = base * Math.sloped(Public.crew_scale(), 1/40) --we don't really have resources scaling by player count in this resource-constrained scenario, but we scale a little, to accommodate each player filling their inventory with useful tools. also, I would do higher than 1/40, but we go even slightly lower because we're applying this somewhat sooner than players actually get there.
2022-03-13 01:44:32 +00:00
return ret
end
2021-10-13 09:21:53 +01:00
function Public.resource_quest_multiplier()
2022-05-07 21:41:45 +01:00
return (1.0 + 0.075 * (Common.overworldx()/40)^(8/10)) * Math.sloped(Common.difficulty_scale(), 1/5) * (Public.crew_scale())^(1/10)
2021-10-13 09:21:53 +01:00
end
2022-07-30 10:29:17 +01:00
function Public.quest_market_entry_price_scale()
return 0.85 * (1 + 0.030 * (Common.overworldx()/40 - 1)) * ((1 + Public.crew_scale())^(1/3)) * Math.sloped(Common.difficulty_scale(), 1/2) --whilst the scenario philosophy says that resource scales tend to be independent of crew size, we account slightly for the fact that more players tend to handcraft more
end
2022-07-30 10:29:17 +01:00
function Public.quest_furnace_entry_price_scale()
return 0.85 * (1 + 0.010 * (Common.overworldx()/40 - 1)) * ((1 + Public.crew_scale())^(1/3)) * Math.sloped(Common.difficulty_scale(), 1/2) --slower increase with time, because this is more time-constrained than resource-constrained
end
2021-10-13 09:21:53 +01:00
2022-06-02 17:55:56 +01:00
function Public.apply_crew_buffs_per_league(force, leagues_travelled)
force.laboratory_productivity_bonus = force.laboratory_productivity_bonus + Math.max(0, 7/100 * leagues_travelled/40)
2021-10-13 09:21:53 +01:00
end
function Public.class_cost(at_dock)
if at_dock then
2022-06-02 12:47:59 +01:00
return 10000
else
return 6000
end
2022-03-04 17:57:58 +00:00
-- return Math.ceil(10000 / (Public.crew_scale()*10/4)^(1/6))
2021-10-13 09:21:53 +01:00
end
Public.quest_structures_first_appear_at = 40
2021-10-13 09:21:53 +01:00
2022-05-07 21:41:45 +01:00
Public.coin_sell_amount = 500
2022-03-11 16:46:02 +00:00
Public.starting_fuel = 4000
Public.silo_max_hp = 5000
Public.silo_resistance_factor = 7
2021-10-13 09:21:53 +01:00
function Public.pistol_damage_multiplier() return 2.25 end --2.0 slightly too low, 2.5 causes players to yell at each other for not using pistol
2021-10-13 09:21:53 +01:00
Public.kraken_static_evo = 0.35
2021-10-13 09:21:53 +01:00
function Public.kraken_evo_increase_per_shot()
2022-07-30 10:29:17 +01:00
-- return 1/100 * 0.08
return 0
end
function Public.kraken_evo_increase_per_second()
return 1/100 / 20
2021-10-13 09:21:53 +01:00
end
2022-03-17 01:40:18 +00:00
function Public.sandworm_evo_increase_per_spawn()
if _DEBUG then
return 1/100
else
2022-05-07 21:41:45 +01:00
return 1/100 * 1/7 * Math.sloped(Common.difficulty_scale(), 3/5)
2022-03-17 01:40:18 +00:00
end
end
function Public.kraken_kill_reward_items()
return {{name = 'coin', count = 800}, {name = 'utility-science-pack', count = 10}}
end
function Public.kraken_kill_reward_fuel()
return 150
2021-10-13 09:21:53 +01:00
end
function Public.kraken_health()
return Math.ceil(3500 * Math.max(1, 1 + 0.075 * (Common.overworldx()/40)^(13/10)) * (Public.crew_scale()^(4/8)) * Math.sloped(Common.difficulty_scale(), 3/4))
-- return Math.ceil(3500 * Math.max(1, 1 + 0.08 * ((Common.overworldx()/40)^(13/10)-6)) * (Public.crew_scale()^(5/8)) * Math.sloped(Common.difficulty_scale(), 3/4))
2021-10-13 09:21:53 +01:00
end
2022-03-01 15:57:23 +00:00
Public.kraken_regen_scale = 0.1 --starting off low
2022-02-26 23:33:19 +00:00
2022-03-19 21:20:55 +00:00
function Public.krakens_per_slot()
2021-10-13 09:21:53 +01:00
local rng = Math.random()
if rng < 0.03 then
return 2
elseif rng < 0.25 then
return 1
else
return 0
end
end
function Public.krakens_per_free_slot(overworldx)
local rng = Math.random()
2021-10-31 20:34:18 +00:00
local multiplier = 1
if overworldx and overworldx > 600 then
multiplier = 1 + (overworldx-600)/600
end
2022-03-08 23:36:03 +00:00
if rng < 0.0025 * multiplier then
return 3
elseif rng < 0.075 * multiplier then
return 1
2021-10-31 20:34:18 +00:00
elseif rng < 0.5 * multiplier then
2021-10-13 09:21:53 +01:00
return 1
else
return 0
end
end
function Public.main_shop_cost_multiplier()
return 1
end
function Public.barter_decay_parameter()
return 0.95
end
2022-03-04 18:09:28 +00:00
function Public.sandworm_speed()
return 6.4 * Math.sloped(Common.difficulty_scale(), 1/5)
2022-03-04 18:09:28 +00:00
end
2021-10-13 09:21:53 +01:00
-- function Public.island_otherresources_prospect_decay_parameter()
-- return 0.95
-- end
2022-03-08 23:36:03 +00:00
Public.research_buffs = { --currently disabled anyway
2021-10-13 09:21:53 +01:00
-- these already give .1 productivity so we're adding .1 to get to 20%
2022-07-30 10:29:17 +01:00
['mining-productivity-1'] = {['mining_drill_productivity_bonus'] = .1},
['mining-productivity-2'] = {['mining_drill_productivity_bonus'] = .1},
['mining-productivity-3'] = {['mining_drill_productivity_bonus'] = .1},
['mining-productivity-4'] = {['mining_drill_productivity_bonus'] = .1},
2022-03-01 21:59:48 +00:00
-- -- these already give .1 productivity so we're adding .1 to get to 20%
-- ['mining-productivity-1'] = {['mining-drill-productivity-bonus'] = .1, ['character-inventory-slots-bonus'] = 5},
-- ['mining-productivity-2'] = {['mining-drill-productivity-bonus'] = .1, ['character-inventory-slots-bonus'] = 5},
-- ['mining-productivity-3'] = {['mining-drill-productivity-bonus'] = .1, ['character-inventory-slots-bonus'] = 5},
-- ['mining-productivity-4'] = {['mining-drill-productivity-bonus'] = .1, ['character-inventory-slots-bonus'] = 5},
2021-10-13 09:21:53 +01:00
}
2022-03-08 23:36:03 +00:00
function Public.flamers_tech_multipliers()
2022-03-14 17:37:18 +00:00
return 0.8
2022-03-08 23:36:03 +00:00
end
2021-10-13 09:21:53 +01:00
2022-03-10 21:09:06 +00:00
function Public.flamers_base_nerf()
return -0.2
end
2021-10-13 09:21:53 +01:00
function Public.player_ammo_damage_modifiers() -- modifiers are fractional. bullet affects gun turrets, but flamethrower does not affect flamer turrets
local data = {
['artillery-shell'] = 0,
['biological'] = 0,
['bullet'] = 0.1,
['cannon-shell'] = 0,
['capsule'] = 0,
['electric'] = 0,
['flamethrower'] = 0, --these nerfs are elsewhere for finer control
2022-02-28 16:36:46 +00:00
['grenade'] = -0.05,
2021-10-13 09:21:53 +01:00
['landmine'] = 0,
['melee'] = 0, -- doesn't do anything apparently
['rocket'] = 0,
['shotgun-shell'] = 0
}
return data
end
function Public.player_turret_attack_modifiers()
local data = {
['gun-turret'] = 0,
['artillery-turret'] = 0,
['laser-turret'] = 0,
}
return data
end
function Public.player_gun_speed_modifiers()
local data = {
['artillery-shell'] = 0,
['biological'] = 0,
['bullet'] = 0,
['cannon-shell'] = 0,
['capsule'] = 0,
['electric'] = 0,
['flamethrower'] = 0, --these nerfs are elsewhere for finer control
['grenade'] = -0.25,
['landmine'] = 0,
2022-03-07 09:50:25 +00:00
['melee'] = 0, -- doesn't do anything apparently
2021-10-13 09:21:53 +01:00
['rocket'] = 0,
2022-03-08 23:36:03 +00:00
['shotgun-shell'] = 0
2021-10-13 09:21:53 +01:00
}
return data
end
2022-06-03 20:43:05 +01:00
Public.starting_items_player = {['pistol'] = 1, ['firearm-magazine'] = 20, ['raw-fish'] = 4, ['medium-electric-pole'] = 20, ['iron-plate'] = 50, ['copper-plate'] = 20, ['iron-gear-wheel'] = 6, ['copper-cable'] = 20, ['burner-inserter'] = 2, ['gun-turret'] = 1}
2021-10-13 09:21:53 +01:00
2022-06-03 20:43:05 +01:00
Public.starting_items_player_late = {['pistol'] = 1, ['firearm-magazine'] = 10, ['raw-fish'] = 4, ['small-electric-pole'] = 20, ['iron-plate'] = 50, ['copper-plate'] = 20, ['iron-gear-wheel'] = 6, ['copper-cable'] = 20, ['burner-inserter'] = 2, ['gun-turret'] = 1}
2021-10-13 09:21:53 +01:00
function Public.starting_items_crew_upstairs()
return {
{['steel-plate'] = 38},
{['stone-brick'] = 60},
{['grenade'] = 3},
{['shotgun'] = 2, ['shotgun-shell'] = 36},
2022-03-11 22:53:36 +00:00
-- {['raw-fish'] = 5},
2022-06-02 12:57:15 +01:00
{['coin'] = 1000},
2021-10-13 09:21:53 +01:00
}
end
function Public.starting_items_crew_downstairs()
return {
2022-03-01 21:59:48 +00:00
{['transport-belt'] = Math.random(600,650)},
2021-10-24 15:27:57 +01:00
{['underground-belt'] = 80},
2022-03-01 21:59:48 +00:00
{['splitter'] = Math.random(50,56)},
{['inserter'] = Math.random(120,140)},
{['storage-tank'] = 2},
2021-10-13 09:21:53 +01:00
{['medium-electric-pole'] = Math.random(15,21)},
2022-06-02 12:57:15 +01:00
{['coin'] = 1000},
2022-03-12 11:51:11 +00:00
{['solar-panel'] = 3},
2021-10-13 09:21:53 +01:00
}
end
function Public.pick_random_drilling_ore()
local number = Math.random(10)
if number <= 4 then -- 40%
return 'iron-ore'
elseif number <= 7 then -- 30%
return 'copper-ore'
elseif number <= 9 then -- 20%
return 'coal'
else -- 10%
return 'stone'
end
end
2021-10-13 09:21:53 +01:00
-- Current formula returns [50 - 200] + random(1, [10 - 40]) depending on completion progress
-- Formula is "a(100x)^(1/2) + random(1, 0.2a(100x)^(1/2))" where
-- x: progress in range [0-1] (when leagues are in 0-1000)
-- a: scaling
-- When the formula needs adjustments, I suggest changing scaling variable
function Public.pick_drilling_ore_amount()
local scaling = 20
local amount = scaling * Math.sqrt(100 * Common.game_completion_progress())
local extra_random_amount = Math.random(Math.ceil(0.2 * amount))
return amount + extra_random_amount
end
-- Current formula returns [15000 - 50000] + random(1, [3000 - 10000]) depending on completion progress
-- Formula is "a(1000000x)^(1/2) + random(1, 0.2a(1000000x)^(1/2))" where
-- x: progress in range [0-1] (when leagues are in 0-1000)
-- a: scaling
-- When the formula needs adjustments, I suggest changing scaling variable
-- Note: 3333 crude oil amount ~= 1% = 0.1/sec
function Public.pick_special_pumpjack_oil_amount()
local scaling = 50
local amount = scaling * Math.sqrt(1000000 * Common.game_completion_progress())
local extra_random_amount = Math.random(Math.ceil(0.2 * amount))
return amount + extra_random_amount
end
2021-10-13 09:21:53 +01:00
return Public