forked from mtcontrib/moretrees
fixup! Add date palm
Add an option to allow dates to grow unpollinated as well. Female palms will be pollinated randomly.
This commit is contained in:
parent
75e8027bf7
commit
9dd610e0e6
@ -22,6 +22,15 @@ local flowers_wither_ichance = 3
|
|||||||
|
|
||||||
-- implementation
|
-- implementation
|
||||||
|
|
||||||
|
local dates_regrow_prob
|
||||||
|
if moretrees.dates_regrow_unpollinated_percent <= 0 then
|
||||||
|
dates_regrow_prob = 0
|
||||||
|
elseif moretrees.dates_regrow_unpollinated_percent >= 100 then
|
||||||
|
dates_regrow_prob = 1
|
||||||
|
else
|
||||||
|
dates_regrow_prob = 1 - math.pow(moretrees.dates_regrow_unpollinated_percent/100, 1/flowers_wither_ichance)
|
||||||
|
end
|
||||||
|
|
||||||
-- Make the date palm fruit trunk a real trunk (it is generated as a fruit)
|
-- Make the date palm fruit trunk a real trunk (it is generated as a fruit)
|
||||||
local trunk = minetest.registered_nodes["moretrees:date_palm_trunk"]
|
local trunk = minetest.registered_nodes["moretrees:date_palm_trunk"]
|
||||||
local ftrunk = {}
|
local ftrunk = {}
|
||||||
@ -91,7 +100,7 @@ local date_regrow_abm_spec = {
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
}
|
}
|
||||||
if moretrees.dates_regrow then
|
if moretrees.dates_regrow_pollinated or moretrees.dates_regrow_unpollinated_percent > 0 then
|
||||||
minetest.register_abm(date_regrow_abm_spec)
|
minetest.register_abm(date_regrow_abm_spec)
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -517,7 +526,8 @@ local dates_growfn = function(pos, elapsed)
|
|||||||
local action
|
local action
|
||||||
if not node then
|
if not node then
|
||||||
return
|
return
|
||||||
elseif not moretrees.dates_regrow then
|
elseif not moretrees.dates_regrow_pollinated and dates_regrow_prob == 0 then
|
||||||
|
-- Regrowing of dates is disabled.
|
||||||
if string.find(node.name, "moretrees:dates_f") then
|
if string.find(node.name, "moretrees:dates_f") then
|
||||||
minetest.swap_node(pos, {name="moretrees:dates_f4"})
|
minetest.swap_node(pos, {name="moretrees:dates_f4"})
|
||||||
elseif string.find(node.name, "moretrees:dates_m") then
|
elseif string.find(node.name, "moretrees:dates_m") then
|
||||||
@ -526,7 +536,11 @@ local dates_growfn = function(pos, elapsed)
|
|||||||
minetest.remove_node(pos)
|
minetest.remove_node(pos)
|
||||||
end
|
end
|
||||||
return
|
return
|
||||||
elseif node.name == "moretrees:dates_f0" and find_male_blossom(pos) then
|
elseif node.name == "moretrees:dates_f0" and math.random(100) <= 100 * dates_regrow_prob then
|
||||||
|
-- Dates grow unpollinated
|
||||||
|
minetest.swap_node(pos, {name="moretrees:dates_f1"})
|
||||||
|
action = "nopollinate"
|
||||||
|
elseif node.name == "moretrees:dates_f0" and moretrees.dates_regrow_pollinated and find_male_blossom(pos) then
|
||||||
-- Pollinate flowers
|
-- Pollinate flowers
|
||||||
minetest.swap_node(pos, {name="moretrees:dates_f1"})
|
minetest.swap_node(pos, {name="moretrees:dates_f1"})
|
||||||
action = "pollinate"
|
action = "pollinate"
|
||||||
@ -614,13 +628,13 @@ local dates_growfn_profiling = function(pos, elapsed)
|
|||||||
local sum = 0
|
local sum = 0
|
||||||
local count = 0
|
local count = 0
|
||||||
if sect_search_stats.count > 0 and stat.pollinate and stat.pollinate.count > 0 then
|
if sect_search_stats.count > 0 and stat.pollinate and stat.pollinate.count > 0 then
|
||||||
print(string.format("\t%-10s: %6d (%4.1f%%): %6dus (%d..%d)",
|
print(string.format("\t%-12s: %6d (%4.1f%%): %6dus (%d..%d)",
|
||||||
"search", sect_search_stats.count,
|
"search", sect_search_stats.count,
|
||||||
100*sect_search_stats.count/stat.pollinate.count,
|
100*sect_search_stats.count/stat.pollinate.count,
|
||||||
sect_search_stats.sum/sect_search_stats.count,
|
sect_search_stats.sum/sect_search_stats.count,
|
||||||
sect_search_stats.min, sect_search_stats.max))
|
sect_search_stats.min, sect_search_stats.max))
|
||||||
else
|
else
|
||||||
print(string.format("\t%-10s: %6d (%4.1f%%): %6dus (%d..%d)",
|
print(string.format("\t%-12s: %6d (%4.1f%%): %6dus (%d..%d)",
|
||||||
"search", sect_search_stats.count,
|
"search", sect_search_stats.count,
|
||||||
0, 0, 0, 0))
|
0, 0, 0, 0))
|
||||||
end
|
end
|
||||||
@ -628,13 +642,13 @@ local dates_growfn_profiling = function(pos, elapsed)
|
|||||||
if action ~= "count" then
|
if action ~= "count" then
|
||||||
count = count + data.count
|
count = count + data.count
|
||||||
sum = sum + data.sum
|
sum = sum + data.sum
|
||||||
print(string.format("\t%-10s: %6d (%4.1f%%): %6dus (%d..%d)",
|
print(string.format("\t%-12s: %6d (%4.1f%%): %6dus (%d..%d)",
|
||||||
action, data.count,
|
action, data.count,
|
||||||
100*data.count/stat.count, data.sum/data.count,
|
100*data.count/stat.count, data.sum/data.count,
|
||||||
data.min, data.max))
|
data.min, data.max))
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
print(string.format("\t%-10s: %6d ( 100%%): %6dus",
|
print(string.format("\t%-12s: %6d ( 100%%): %6dus",
|
||||||
"TOTAL", count, sum/count))
|
"TOTAL", count, sum/count))
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -696,14 +710,15 @@ for _,suffix in ipairs({"f0", "f1", "f2", "f3", "f4", "m0", "fn", "n"}) do
|
|||||||
fixed = {-0.3, -0.3, -0.3, 0.3, 3.5, 0.3}
|
fixed = {-0.3, -0.3, -0.3, 0.3, 3.5, 0.3}
|
||||||
},
|
},
|
||||||
on_timer = dates_growfn,
|
on_timer = dates_growfn,
|
||||||
on_construct = moretrees.dates_regrow and dates_starttimer,
|
on_construct = (moretrees.dates_regrow_pollinated or moretrees.dates_regrow_unpollinated_percent > 0)
|
||||||
|
and dates_starttimer,
|
||||||
|
|
||||||
}
|
}
|
||||||
minetest.register_node("moretrees:dates_"..suffix, datedef)
|
minetest.register_node("moretrees:dates_"..suffix, datedef)
|
||||||
end
|
end
|
||||||
|
|
||||||
-- If regrowing was previously disabled, but is enabled now, make sure timers are started for existing dates
|
-- If regrowing was previously disabled, but is enabled now, make sure timers are started for existing dates
|
||||||
if moretrees.dates_regrow then
|
if moretrees.dates_regrow_pollinated or moretrees.dates_regrow_unpollinated_percent > 0 then
|
||||||
local spec = {
|
local spec = {
|
||||||
name = "moretrees:restart_dates_regrow_timer",
|
name = "moretrees:restart_dates_regrow_timer",
|
||||||
nodenames = "group:moretrees_dates",
|
nodenames = "group:moretrees_dates",
|
||||||
|
@ -75,7 +75,22 @@ moretrees.coconut_item_drop_ichance = 10 -- inverse probability of ripe coconu
|
|||||||
|
|
||||||
-- Date palm settings
|
-- Date palm settings
|
||||||
|
|
||||||
moretrees.dates_regrow = true
|
-- Suggested configuration alternatives:
|
||||||
|
-- - Dates grow only when pollinated:
|
||||||
|
-- - Set dates_regrow_pollinated to true
|
||||||
|
-- - Set dates_regrow_unpollinated_percent to 0
|
||||||
|
-- - Disable pollination:
|
||||||
|
-- - Set dates_regrow_pollinated to false
|
||||||
|
-- - Set dates_regrow_unpollinated_percent to some larger positive value, e.g. 95
|
||||||
|
-- - Dates grow, but more and faster if male flowers are nearby
|
||||||
|
-- - Set dates_regrow_pollinated to true
|
||||||
|
-- - Set dates_regrow_unpollinated_percent to some small positive value, e.g. 33
|
||||||
|
-- - Optional but recommended: Reduce the pollination distance, e.g. to 30
|
||||||
|
|
||||||
|
moretrees.dates_regrow_pollinated = true -- Enable pollination. If enabled, male trees are required for dates to grow.
|
||||||
|
-- If disabled, dates_regrow_unpollinated_percent must be non-zero for dates to regrow.
|
||||||
|
moretrees.dates_regrow_unpollinated_percent = 0 -- Percentage of female dates becoming dates without being pollinated.
|
||||||
|
-- If 0, dates_regrow_pollinated must be enabled for dates to grow.
|
||||||
moretrees.dates_female_percent = 57 -- Ratio of female to male trees - tune this to improve # of generated trees that actually bear fruit
|
moretrees.dates_female_percent = 57 -- Ratio of female to male trees - tune this to improve # of generated trees that actually bear fruit
|
||||||
-- ~57% gives near optimal results for groups of 3 random trees, while it is only slightly suboptimal
|
-- ~57% gives near optimal results for groups of 3 random trees, while it is only slightly suboptimal
|
||||||
-- for groups of 2 and 4 random trees (~2% less fruit than optimal).
|
-- for groups of 2 and 4 random trees (~2% less fruit than optimal).
|
||||||
|
Loading…
Reference in New Issue
Block a user