Improve Route 3 strategies, add Earthquake strategy to Machokes fight, support safe strategy on Giovanni's gym fight, improve first-turn Sky Attack survival against Blue

This commit is contained in:
Kyle Coburn 2015-03-30 15:20:13 -07:00
parent 539357a9d6
commit b08d7cef82
2 changed files with 153 additions and 44 deletions

View File

@ -1147,7 +1147,7 @@ strategyFunctions = {
shopPewterMart = function()
return shop.transaction{
buy = {{name="potion", index=1, amount=8}}
buy = {{name="potion", index=1, amount=9}}
}
end,
@ -1197,8 +1197,46 @@ strategyFunctions = {
return buffTo("leer", defLimit)
end,
bugCatcher = function()
if (battle.isActive()) then
canProgress = true
local isWeedle = pokemon.isOpponent("weedle")
if (isWeedle and not tempDir) then
tempDir = true
end
secondCaterpie = tempDir
if (not isWeedle and secondCaterpie) then
if (level4Nidoran and nidoSpeed >= 14 and pokemon.index(0, "attack") >= 19) then
-- print("IA "..pokemon.index(0, "attack"))
battle.automate()
return
end
end
strategyFunctions.leer({{"caterpie",8}, {"weedle",7}})
elseif (canProgress) then
return true
else
battle.automate()
end
end,
shortsKid = function()
local fightingEkans = pokemon.isOpponent("ekans")
if (fightingEkans) then
local wrapping = memory.value("battle", "turns") > 0
if (wrapping) then
local curr_hp = memory.double("battle", "our_hp")
if (not tempDir) then
tempDir = curr_hp
end
if (tempDir - curr_hp < 4 and curr_hp < 14 and not opponentDamaged()) then
inventory.use("potion", nil, true)
return false
end
elseif (tempDir) then
tempDir = nil
end
end
control.battlePotion(fightingEkans or damaged(2))
return strategyFunctions.leer({{"rattata",9}, {"ekans",10}})
end,
@ -2411,41 +2449,71 @@ strategyFunctions = {
return useItem({item="elixer", poke="nidoking", chain=data.chain, close=data.close})
end,
fightGiovanniMachoke = function()
if (initialize()) then
if (nidoAttack >= 55) then
local eqRequired = nidoSpecial >= 47 and 7 or 8
if (battle.pp("earthquake") >= eqRequired) then
bridge.chat("Using Earthquake strats on the Machokes")
return true
end
end
end
return prepare("x_special")
end,
checkGiovanni = function()
local ryhornDamage = math.floor(combat.healthFor("GiovanniRhyhorn") * 0.9)
if (initialize()) then
local earthquakePP = battle.pp("earthquake")
if (earthquakePP > 1) then
if (riskGiovanni and earthquakePP > 2 and battle.pp("horn_drill") > 4 and (yolo or pokemon.info("nidoking", "hp") > combat.healthFor("GiovanniRhyhorn") * 0.925)) then -- RISK
if (earthquakePP >= 2) then
if (riskGiovanni) then
if (earthquakePP >= 5) then
bridge.chat("Saved enough Earthquake PP for safe strats on Giovanni!")
elseif (earthquakePP >= 3 and battle.pp("horn_drill") >= 5 and (yolo or pokemon.info("nidoking", "hp") >= ryhornDamage)) then -- RISK
bridge.chat("Using risky strats on Giovanni to skip the extra Max Ether...")
else
riskGiovanni = false
end
end
return true
end
local message = "Ran out of Earthquake PP :( "
if (not yolo) then
message = message.." Time for safe strats."
if (yolo) then
message = message.."Risking on Giovanni."
else
message = message.."Time for standard strats."
end
bridge.chat(message)
riskGiovanni = false
end
return strategyFunctions.potion({hp=50, yolo=10})
end,
fightGiovanniMachoke = function(data)
return prepare("x_special")
return strategyFunctions.potion({hp=50, yolo=ryhornDamage})
end,
fightGiovanni = function()
if (battle.isActive()) then
if (initialize()) then
tempDir = battle.pp("earthquake")
canProgress = true
if (riskGiovanni and not prepare("x_special")) then
return false
end
local forced
local forced, needsXSpecial
local startEqPP = tempDir
if (riskGiovanni) then
if (startEqPP < 5) then
needsXSpecial = true
end
if (needsXSpecial or battle.pp("earthquake") < 4) then
forced = "ice_beam"
end
else
needsXSpecial = startEqPP < 2
if (pokemon.isOpponent("rhydon")) then
forced = "ice_beam"
end
end
if (needsXSpecial and not prepare("x_special")) then
return false
end
battle.automate(forced)
elseif (canProgress) then
return true
@ -2732,25 +2800,65 @@ strategyFunctions = {
blue = function()
if (battle.isActive()) then
if (not canProgress) then
canProgress = true
if (memory.value("battle", "turns") > 0 and not isPrepared("x_accuracy", "x_speed")) then
local toPotion = inventory.contains("full_restore", "super_potion")
if (battle.potionsForHit(toPotion)) then
inventory.use(toPotion, nil, true)
return false
end
end
if (not tempDir) then
if (nidoSpecial > 45 and pokemon.index(0, "speed") > 52 and inventory.contains("x_special")) then
if (nidoSpecial >= 45 and pokemon.index(0, "speed") >= 52 and inventory.contains("x_special")) then
tempDir = "x_special"
else
tempDir = "x_speed"
end
print(tempDir.." strats")
tempDir = "x_speed" -- TODO find min stats, remove override
if (not STREAMING_MODE) then
tempDir = "x_speed"
end
end
local boostFirst = pokemon.index(0, "hp") < 55
local firstItem, secondItem
if (boostFirst) then
firstItem = tempDir
secondItem = "x_accuracy"
else
firstItem = "x_accuracy"
secondItem = tempDir
end
local forced = "horn_drill"
if (memory.value("battle", "turns") > 0) then
local skyDamage = combat.healthFor("BlueSky")
local healCutoff = skyDamage * 0.825
if (initialize()) then
if (not isPrepared("x_accuracy", tempDir)) then
local msg = "Uh oh... First-turn Sky Attack could end the run here, "
if (pokemon.index(0, "hp") > skyDamage) then
msg = msg.."no criticals pls D:"
elseif (canHealFor(healCutoff)) then
msg = msg.."attempting to heal for it"
if (not canHealFor(skyDamage)) then
msg = msg.." (damage range)"
end
msg = msg.."."
else
msg = msg.."and nothing left to heal with BibleThump"
end
bridge.chat(msg)
end
end
if (prepare(firstItem)) then
if (not isPrepared(secondItem)) then
local toPotion = canHealFor(healCutoff)
if (toPotion) then
inventory.use(toPotion, nil, true)
return false
end
end
if (prepare("x_accuracy", tempDir)) then
local forced = "horn_drill"
battle.automate(forced)
end
end
else
if (prepare(firstItem, secondItem)) then
if (pokemon.isOpponent("alakazam")) then
if (tempDir == "x_speed") then
forced = "earthquake"
@ -2762,6 +2870,7 @@ strategyFunctions = {
end
battle.automate(forced)
end
end
elseif (canProgress) then
return true
else

View File

@ -67,7 +67,7 @@ local paths = {
-- Leaving Pewter City
{2, {23,18}, {40,18}},
-- Route 3
{14, {0,10}, {s="a",a="Route 3"}, {c="catchFlier"}, {c="pp",on=true}, {s="battleModeSet"}, {8,10}, {8,8}, {11,8}, {11,6}, {s="leer",{"caterpie",8},{"weedle",7}}, {11,4}, {12,4}, {s="potion",hp=19}, {13,4}, {s="interact",dir="Right"}, {s="shortsKid"}, {13,5}, {s="potionBeforeCocoons"}, {18,5}, {s="interact",dir="Right"}, {s="swapHornAttack"}, {18,6}, {22,6}, {22,5}, {s="potion",hp=4}, {24,5}, {s="interact",dir="Down"}, {s="fightMetapod"}, {27,5}, {27,9}, {s="catchFlierBackup"}, {37,8}, {37,5}, {49,5}, {49,10}, {57,10}, {57,8}, {59,8}, {59,-1}},
{14, {0,10}, {s="a",a="Route 3"}, {c="catchFlier"}, {c="pp",on=true}, {s="battleModeSet"}, {8,10}, {8,8}, {11,8}, {11,6}, {s="bugCatcher"}, {11,4}, {12,4}, {s="potion",hp=19}, {13,4}, {s="interact",dir="Right"}, {s="shortsKid"}, {13,5}, {s="potionBeforeCocoons"}, {18,5}, {s="interact",dir="Right"}, {s="swapHornAttack"}, {18,6}, {22,6}, {22,5}, {s="potion",hp=4}, {24,5}, {s="interact",dir="Down"}, {s="fightMetapod"}, {27,5}, {27,9}, {s="catchFlierBackup"}, {37,8}, {37,5}, {49,5}, {49,10}, {57,10}, {57,8}, {59,8}, {59,-1}},
-- To the Center
{15, {9,16}, {c="pp",on=false}, {12,16}, {12,6}, {11,6}, {11,5}},
-- PP up
@ -135,7 +135,7 @@ local paths = {
-- Underground exit
{74, {4,4}, {3,8}},
-- Oddish
{17, {17,14}, {s="a",a="Vermilion City"}, {c="catchOddish"}, {17,15}, {s="potion",hp=9,yolo=5}, {17,19}, {s="catchOddish"}, {11,29}, {s="potion",hp=9,yolo=5}, {11,29}, {s="waitToFight",dir="Down"}, {10,29}, {10,30}, {s="potion",hp=9,yolo=5}, {10,31}, {9,31}, {9,32}, {s="potion",hp=20,yolo=18}, {9,36}},
{17, {17,14}, {s="a",a="Vermilion City"}, {c="catchOddish"}, {17,15}, {s="potion",hp=10,yolo=7}, {17,19}, {s="catchOddish"}, {11,29}, {s="potion",hp=10,yolo=7}, {11,29}, {s="waitToFight",dir="Down"}, {10,29}, {10,30}, {s="potion",hp=10,yolo=7}, {10,31}, {9,31}, {9,32}, {s="potion",hp=20,yolo=18}, {9,36}},
-- Enter Vermilion
{5, {19,0}, {c="disableCatch"}, {19,6}, {21,6}, {21,14}, {23,14}, {23,13}},
-- Vermilion mart