From 962d5db3be62773db715b4a4705f5ba5ed6b67ff Mon Sep 17 00:00:00 2001 From: Andrew Tomaka Date: Mon, 8 Apr 2013 17:21:49 -0400 Subject: [PATCH] Update with new EHP formula: WIP --- libs/barbarian.php | 46 ++++++++++++++++++++++++++++++++++++++++++++ libs/diabloclass.php | 12 +----------- 2 files changed, 47 insertions(+), 11 deletions(-) diff --git a/libs/barbarian.php b/libs/barbarian.php index c146ff4..dc9fe54 100644 --- a/libs/barbarian.php +++ b/libs/barbarian.php @@ -5,4 +5,50 @@ class Barbarian extends DiabloClass { parent::__construct($stats); } + + function EHPScore() { + $ehp = $this->stats->getStat('EHP Unbuffed'); + + if($ehp < 1000000) { + return $ehp / 10000; + } elseif(1000000 <= $ehp && $ehp <= 2000000) { + return 100 + ($ehp - 1000000) / 20000; + } elseif(2000000 <= $ehp && $ehp <= 5000000) { + return 150 + ($ehp - 2000000) / 40000; + } elseif($ehp >= 5000000) { + return 225 + ($ehp - 5000000) / 100000; + } + } + + private + function calculateEHP() { + $incoming_attack = 100000; + $block_amount = 4206; + $ar_red = $this->getStat('Resistance') / + ($this->getStat('Resistance') + 315); + $armor_red = $this->getStat('Armor') / + ($this->getStat('Armor') + 3150); + $inherent_red = .3; + + $total_red = (1 - $ar_red) * (1 - $armor_red) * (1 - $inherent_red); + $raw_ehp = $this->getStat('Life') / $total_red; + + $net = $incoming_attack * $total_red; + + $after_block = $net * (1 - $this->getStat('Block')) + ($net - $block_amount) + * $this->getStat('Block'); + + $new_mit = $after_block / $incoming_attack; + + $raw_no_dodge = $this->getStat('Life') / $new_mit; + $net_no_dodge = $raw_no_dodge; + + $raw_ehp_dodge = $net_no_dodge / (1 - $this->getStat('Dodge Chance')); + $net_ehp_dodge = ($raw_ehp_dodge - $net_no_dodge) * .75 + $net_no_dodge; + + $final_ehp = $net_ehp_dodge * (1 + $this->getStat('Melee Damage Reduction') + + $this->getStat('Missile Damage Reduction') / 2); + + $this->stats->stats['EHP Unbuffed'] = $final_ehp; + } } \ No newline at end of file diff --git a/libs/diabloclass.php b/libs/diabloclass.php index c08b2ac..60ae1e7 100644 --- a/libs/diabloclass.php +++ b/libs/diabloclass.php @@ -39,17 +39,7 @@ class DiabloClass { } function EHPScore() { - $ehp = $this->stats->getStat('EHP Unbuffed'); - - if($ehp < 1000000) { - return $ehp / 10000; - } elseif(1000000 <= $ehp && $ehp <= 2000000) { - return 100 + ($ehp - 1000000) / 20000; - } elseif(2000000 <= $ehp && $ehp <= 5000000) { - return 150 + ($ehp - 2000000) / 40000; - } elseif($ehp >= 5000000) { - return 225 + ($ehp - 5000000) / 100000; - } + return 0; } function sustainScore() {