Menu
News
All News
Dungeons & Dragons
Level Up: Advanced 5th Edition
Pathfinder
Starfinder
Warhammer
2d20 System
Year Zero Engine
Industry News
Reviews
Dragon Reflections
White Dwarf Reflections
Columns
Weekly Digests
Weekly News Digest
Freebies, Sales & Bundles
RPG Print News
RPG Crowdfunding News
Game Content
ENterplanetary DimENsions
Mythological Figures
Opinion
Worlds of Design
Peregrine's Nest
RPG Evolution
Other Columns
From the Freelancing Frontline
Monster ENcyclopedia
WotC/TSR Alumni Look Back
4 Hours w/RSD (Ryan Dancey)
The Road to 3E (Jonathan Tweet)
Greenwood's Realms (Ed Greenwood)
Drawmij's TSR (Jim Ward)
Community
Forums & Topics
Forum List
Latest Posts
Forum list
*Dungeons & Dragons
Level Up: Advanced 5th Edition
D&D Older Editions, OSR, & D&D Variants
*TTRPGs General
*Pathfinder & Starfinder
EN Publishing
*Geek Talk & Media
Search forums
Chat/Discord
Resources
Wiki
Pages
Latest activity
Media
New media
New comments
Search media
Downloads
Latest reviews
Search resources
EN Publishing
Store
EN5ider
Adventures in ZEITGEIST
Awfully Cheerful Engine
What's OLD is NEW
Judge Dredd & The Worlds Of 2000AD
War of the Burning Sky
Level Up: Advanced 5E
Events & Releases
Upcoming Events
Private Events
Featured Events
Socials!
EN Publishing
Twitter
BlueSky
Facebook
Instagram
EN World
BlueSky
YouTube
Facebook
Twitter
Twitch
Podcast
Features
Top 5 RPGs Compiled Charts 2004-Present
Adventure Game Industry Market Research Summary (RPGs) V1.0
Ryan Dancey: Acquiring TSR
Q&A With Gary Gygax
D&D Rules FAQs
TSR, WotC, & Paizo: A Comparative History
D&D Pronunciation Guide
Million Dollar TTRPG Kickstarters
Tabletop RPG Podcast Hall of Fame
Eric Noah's Unofficial D&D 3rd Edition News
D&D in the Mainstream
D&D & RPG History
About Morrus
Log in
Register
What's new
Search
Search
Search titles only
By:
Forums & Topics
Forum List
Latest Posts
Forum list
*Dungeons & Dragons
Level Up: Advanced 5th Edition
D&D Older Editions, OSR, & D&D Variants
*TTRPGs General
*Pathfinder & Starfinder
EN Publishing
*Geek Talk & Media
Search forums
Chat/Discord
Menu
Log in
Register
Install the app
Install
Upgrade your account to a Community Supporter account and remove most of the site ads.
Community
General Tabletop Discussion
*Dungeons & Dragons
Calculating Overkill Damage
JavaScript is disabled. For a better experience, please enable JavaScript in your browser before proceeding.
You are using an out of date browser. It may not display this or other websites correctly.
You should upgrade or use an
alternative browser
.
Reply to thread
Message
<blockquote data-quote="m00" data-source="post: 7236059" data-attributes="member: 6905775"><p>Count me in the group that thinks this is a useful white-room exercise.</p><p></p><p>Here is how I think about this problem: There is a combatant fighting an infinite supply of identical enemies, each with <em>H</em> hit points. The probability that the combatant hits an enemy with an attack is <em>p</em>; when the combatant hits, they cause <em>XdN + b</em> damage. We're not interested in how long the combatant will last before going down, so the enemies do not fight back. As soon as the combatant kills an enemy, their next attack can effectively be targeted at the next enemy (i.e., no wasted attacks).</p><p></p><p>Imagine the "state" of the system is the amount of damage on the current enemy (from 0 to <em>H</em>). Each attack moves the "state" up according to the combatant's probability of hitting and how much damage they cause. We can make a table where the rows correspond to the current state of the system, and the columns correspond to the next state of the system; the ith row and jth column is the probability that the system goes from state i to state j during the current attack. The probabilities of going between states can be encoded to include things like critical hits, whether the attacker chooses to use GWF, etc. As soon as the state reaches <em>H</em>, it starts over again from state 0 (no damage). In this context, "overkill damage" just means that the system can never move beyond state <em>H</em>, even if the damage we've caused indicated we should have (i.e., even we did enough damage to go from 5 to 10, but <em>H</em> = 8, then our new state only goes to 8, so we incurred 2 overkill damage).</p><p></p><p>The advantage of this setup is that we've actually defined a <a href="https://en.wikipedia.org/wiki/Markov_chain#Finite_state_space" target="_blank">finite state-space Markov chain</a>, which lets us exploit a lot of powerful math. For example, we can compute the expected amount of time that the system takes to go from state <em>H</em> (the enemy just died) back to state <em>H</em> (the next enemy died), which is the inverse of the rate at which the combatant kills enemies*: if we are considering two combatants with different weapons/fighting styles, we may compare the ratio of their expected amounts of damage (against an enemy with infinite HP) to the ratio of their "kill rate", to get a sense of how much damage is being wasted/how efficiently they are killing enemies.</p><p></p><p>So, here's how this plays out with some real numbers. Here's our enemy: a 10 HP sack-of-HP that the combatant hits 60% of the time (<em>H</em> = 10, <em>p</em> = 0.6). Our combatant (attacker 1) hits for 1d8 damage (expected damage 4.5). Here's what our damage table looks like (I've included critical hits, and rounded for clarity):</p><p></p><p>[TABLE="class: grid, width: 500"]</p><p>[TR]</p><p>[TD][/TD]</p><p>[TD]<strong>0</strong>[/TD]</p><p>[TD]<strong>1</strong>[/TD]</p><p>[TD]<strong>2</strong>[/TD]</p><p>[TD]<strong>3</strong>[/TD]</p><p>[TD]<strong>4</strong>[/TD]</p><p>[TD]<strong>5</strong>[/TD]</p><p>[TD]<strong>6</strong>[/TD]</p><p>[TD]<strong>7</strong>[/TD]</p><p>[TD]<strong>8</strong>[/TD]</p><p>[TD]<strong>9</strong>[/TD]</p><p>[TD]<strong>10</strong>[/TD]</p><p>[/TR]</p><p>[TR]</p><p>[TD]<strong>0</strong>[/TD]</p><p>[TD]0.400[/TD]</p><p>[TD]0.069[/TD]</p><p>[TD]0.070[/TD]</p><p>[TD]0.070[/TD]</p><p>[TD]0.071[/TD]</p><p>[TD]0.072[/TD]</p><p>[TD]0.073[/TD]</p><p>[TD]0.073[/TD]</p><p>[TD]0.074[/TD]</p><p>[TD]0.006[/TD]</p><p>[TD]0.022[/TD]</p><p>[/TR]</p><p>[TR]</p><p>[TD]<strong>1</strong>[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.400[/TD]</p><p>[TD]0.069[/TD]</p><p>[TD]0.070[/TD]</p><p>[TD]0.070[/TD]</p><p>[TD]0.071[/TD]</p><p>[TD]0.072[/TD]</p><p>[TD]0.073[/TD]</p><p>[TD]0.073[/TD]</p><p>[TD]0.074[/TD]</p><p>[TD]0.028[/TD]</p><p>[/TR]</p><p>[TR]</p><p>[TD]<strong>2</strong>[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.400[/TD]</p><p>[TD]0.069[/TD]</p><p>[TD]0.070[/TD]</p><p>[TD]0.070[/TD]</p><p>[TD]0.071[/TD]</p><p>[TD]0.072[/TD]</p><p>[TD]0.073[/TD]</p><p>[TD]0.073[/TD]</p><p>[TD]0.102[/TD]</p><p>[/TR]</p><p>[TR]</p><p>[TD]<strong>3</strong>[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.400[/TD]</p><p>[TD]0.069[/TD]</p><p>[TD]0.070[/TD]</p><p>[TD]0.070[/TD]</p><p>[TD]0.071[/TD]</p><p>[TD]0.072[/TD]</p><p>[TD]0.073[/TD]</p><p>[TD]0.176[/TD]</p><p>[/TR]</p><p>[TR]</p><p>[TD]<strong>4</strong>[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.400[/TD]</p><p>[TD]0.069[/TD]</p><p>[TD]0.070[/TD]</p><p>[TD]0.070[/TD]</p><p>[TD]0.071[/TD]</p><p>[TD]0.072[/TD]</p><p>[TD]0.248[/TD]</p><p>[/TR]</p><p>[TR]</p><p>[TD]<strong>5</strong>[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.400[/TD]</p><p>[TD]0.069[/TD]</p><p>[TD]0.070[/TD]</p><p>[TD]0.070[/TD]</p><p>[TD]0.071[/TD]</p><p>[TD]0.320[/TD]</p><p>[/TR]</p><p>[TR]</p><p>[TD]<strong>6</strong>[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.400[/TD]</p><p>[TD]0.069[/TD]</p><p>[TD]0.070[/TD]</p><p>[TD]0.070[/TD]</p><p>[TD]0.391[/TD]</p><p>[/TR]</p><p>[TR]</p><p>[TD]<strong>7</strong>[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.400[/TD]</p><p>[TD]0.069[/TD]</p><p>[TD]0.070[/TD]</p><p>[TD]0.462[/TD]</p><p>[/TR]</p><p>[TR]</p><p>[TD]<strong>8</strong>[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.400[/TD]</p><p>[TD]0.069[/TD]</p><p>[TD]0.531[/TD]</p><p>[/TR]</p><p>[TR]</p><p>[TD]<strong>9</strong>[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.000[/TD]</p><p>[TD]0.400[/TD]</p><p>[TD]0.600[/TD]</p><p>[/TR]</p><p>[TR]</p><p>[TD]<strong>10</strong>[/TD]</p><p>[TD]0.400[/TD]</p><p>[TD]0.069[/TD]</p><p>[TD]0.070[/TD]</p><p>[TD]0.070[/TD]</p><p>[TD]0.071[/TD]</p><p>[TD]0.072[/TD]</p><p>[TD]0.073[/TD]</p><p>[TD]0.073[/TD]</p><p>[TD]0.074[/TD]</p><p>[TD]0.006[/TD]</p><p>[TD]0.022[/TD]</p><p>[/TR]</p><p>[/TABLE]</p><p></p><p>So, for example, attacker 1 misses 40% of the time, and causes 1 damage 6.9% of the time (including critical hits). Attacker 1 kills their current enemy in one attack 2.2% of the time!</p><p></p><p>The "kill rate" for this matrix is 0.229 enemies per round (remember the expected time per kill is the inverse of this rate). If we consider a new attacker (attacker 2) that causes 2d6 damage, the kill rate becomes 0.323 enemies per round. The ratio of kill rates is 0.708 (attacker one kills opponents 71% times as fast as attacker two). However, the ratio of their expected amounts of damage is 0.643 (4.5 / 7), which is obviously less than 0.708; attacker 2 is less efficient than attacker 1! The difference of these ratios is a measure of efficiency.</p><p></p><p>There are some obvious special cases. For example, when <em>H</em> = 1, every attack that hits kills an enemy, so both attacker 1 and 2 have identical kill rates (attacker 2 is wasting a lot of damage!). As <em>H</em> goes to infinity, the amount of damage attacker 2 wastes decreases, so the ratio of kill rates converges to the ratio of the expected damage.</p><p></p><p>There are obviously other ways to approach this problem, but I think this one could be useful!</p><p></p><p>* these quantities can be computed by solving for the "stationary distribution" of the rate matrix</p></blockquote><p></p>
[QUOTE="m00, post: 7236059, member: 6905775"] Count me in the group that thinks this is a useful white-room exercise. Here is how I think about this problem: There is a combatant fighting an infinite supply of identical enemies, each with [I]H[/I] hit points. The probability that the combatant hits an enemy with an attack is [I]p[/I]; when the combatant hits, they cause [I]XdN + b[/I] damage. We're not interested in how long the combatant will last before going down, so the enemies do not fight back. As soon as the combatant kills an enemy, their next attack can effectively be targeted at the next enemy (i.e., no wasted attacks). Imagine the "state" of the system is the amount of damage on the current enemy (from 0 to [I]H[/I]). Each attack moves the "state" up according to the combatant's probability of hitting and how much damage they cause. We can make a table where the rows correspond to the current state of the system, and the columns correspond to the next state of the system; the ith row and jth column is the probability that the system goes from state i to state j during the current attack. The probabilities of going between states can be encoded to include things like critical hits, whether the attacker chooses to use GWF, etc. As soon as the state reaches [I]H[/I], it starts over again from state 0 (no damage). In this context, "overkill damage" just means that the system can never move beyond state [I]H[/I], even if the damage we've caused indicated we should have (i.e., even we did enough damage to go from 5 to 10, but [I]H[/I] = 8, then our new state only goes to 8, so we incurred 2 overkill damage). The advantage of this setup is that we've actually defined a [URL="https://en.wikipedia.org/wiki/Markov_chain#Finite_state_space"]finite state-space Markov chain[/URL], which lets us exploit a lot of powerful math. For example, we can compute the expected amount of time that the system takes to go from state [I]H[/I] (the enemy just died) back to state [I]H[/I] (the next enemy died), which is the inverse of the rate at which the combatant kills enemies*: if we are considering two combatants with different weapons/fighting styles, we may compare the ratio of their expected amounts of damage (against an enemy with infinite HP) to the ratio of their "kill rate", to get a sense of how much damage is being wasted/how efficiently they are killing enemies. So, here's how this plays out with some real numbers. Here's our enemy: a 10 HP sack-of-HP that the combatant hits 60% of the time ([I]H[/I] = 10, [I]p[/I] = 0.6). Our combatant (attacker 1) hits for 1d8 damage (expected damage 4.5). Here's what our damage table looks like (I've included critical hits, and rounded for clarity): [TABLE="class: grid, width: 500"] [TR] [TD][/TD] [TD][B]0[/B][/TD] [TD][B]1[/B][/TD] [TD][B]2[/B][/TD] [TD][B]3[/B][/TD] [TD][B]4[/B][/TD] [TD][B]5[/B][/TD] [TD][B]6[/B][/TD] [TD][B]7[/B][/TD] [TD][B]8[/B][/TD] [TD][B]9[/B][/TD] [TD][B]10[/B][/TD] [/TR] [TR] [TD][B]0[/B][/TD] [TD]0.400[/TD] [TD]0.069[/TD] [TD]0.070[/TD] [TD]0.070[/TD] [TD]0.071[/TD] [TD]0.072[/TD] [TD]0.073[/TD] [TD]0.073[/TD] [TD]0.074[/TD] [TD]0.006[/TD] [TD]0.022[/TD] [/TR] [TR] [TD][B]1[/B][/TD] [TD]0.000[/TD] [TD]0.400[/TD] [TD]0.069[/TD] [TD]0.070[/TD] [TD]0.070[/TD] [TD]0.071[/TD] [TD]0.072[/TD] [TD]0.073[/TD] [TD]0.073[/TD] [TD]0.074[/TD] [TD]0.028[/TD] [/TR] [TR] [TD][B]2[/B][/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.400[/TD] [TD]0.069[/TD] [TD]0.070[/TD] [TD]0.070[/TD] [TD]0.071[/TD] [TD]0.072[/TD] [TD]0.073[/TD] [TD]0.073[/TD] [TD]0.102[/TD] [/TR] [TR] [TD][B]3[/B][/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.400[/TD] [TD]0.069[/TD] [TD]0.070[/TD] [TD]0.070[/TD] [TD]0.071[/TD] [TD]0.072[/TD] [TD]0.073[/TD] [TD]0.176[/TD] [/TR] [TR] [TD][B]4[/B][/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.400[/TD] [TD]0.069[/TD] [TD]0.070[/TD] [TD]0.070[/TD] [TD]0.071[/TD] [TD]0.072[/TD] [TD]0.248[/TD] [/TR] [TR] [TD][B]5[/B][/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.400[/TD] [TD]0.069[/TD] [TD]0.070[/TD] [TD]0.070[/TD] [TD]0.071[/TD] [TD]0.320[/TD] [/TR] [TR] [TD][B]6[/B][/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.400[/TD] [TD]0.069[/TD] [TD]0.070[/TD] [TD]0.070[/TD] [TD]0.391[/TD] [/TR] [TR] [TD][B]7[/B][/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.400[/TD] [TD]0.069[/TD] [TD]0.070[/TD] [TD]0.462[/TD] [/TR] [TR] [TD][B]8[/B][/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.400[/TD] [TD]0.069[/TD] [TD]0.531[/TD] [/TR] [TR] [TD][B]9[/B][/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.000[/TD] [TD]0.400[/TD] [TD]0.600[/TD] [/TR] [TR] [TD][B]10[/B][/TD] [TD]0.400[/TD] [TD]0.069[/TD] [TD]0.070[/TD] [TD]0.070[/TD] [TD]0.071[/TD] [TD]0.072[/TD] [TD]0.073[/TD] [TD]0.073[/TD] [TD]0.074[/TD] [TD]0.006[/TD] [TD]0.022[/TD] [/TR] [/TABLE] So, for example, attacker 1 misses 40% of the time, and causes 1 damage 6.9% of the time (including critical hits). Attacker 1 kills their current enemy in one attack 2.2% of the time! The "kill rate" for this matrix is 0.229 enemies per round (remember the expected time per kill is the inverse of this rate). If we consider a new attacker (attacker 2) that causes 2d6 damage, the kill rate becomes 0.323 enemies per round. The ratio of kill rates is 0.708 (attacker one kills opponents 71% times as fast as attacker two). However, the ratio of their expected amounts of damage is 0.643 (4.5 / 7), which is obviously less than 0.708; attacker 2 is less efficient than attacker 1! The difference of these ratios is a measure of efficiency. There are some obvious special cases. For example, when [I]H[/I] = 1, every attack that hits kills an enemy, so both attacker 1 and 2 have identical kill rates (attacker 2 is wasting a lot of damage!). As [I]H[/I] goes to infinity, the amount of damage attacker 2 wastes decreases, so the ratio of kill rates converges to the ratio of the expected damage. There are obviously other ways to approach this problem, but I think this one could be useful! * these quantities can be computed by solving for the "stationary distribution" of the rate matrix [/QUOTE]
Insert quotes…
Verification
Post reply
Community
General Tabletop Discussion
*Dungeons & Dragons
Calculating Overkill Damage
Top