but he had pretty pictures!
|
|
Quote:
|
I found the problem last night and I no longer have this problem on my server. parse graphs for my server reflect what I have posted for live and eqmac...
|
So the options were completely rewrite the emu source or spend a night making changes locally? lol
|
Quote:
|
It was a rewrite of the following code that is found in
if(RuleB(Combat, UseIntervalAC)) damage = (max_dmg+eleBane); else damage = MakeRandomInt((min_dmg+eleBane),(max_dmg+eleBane)) ; and not a changing of settings. Yes cavedude I will share the code with you. I want to make a special case for raid mobs or if you want to do that after I show you the code thats fine. A column to npc_types called isRaid will need to be added to check and see if its a raid target because they operate differently as far as this goes than normal mobs. Edit: since you know all of the eqemu code better than me you might see a better way to check for raid target than what I suggested with a new column. I was thinking along the lines of the new isQuest column. |
Personally I'd just use the existing fields.. e.g. if you want them to hit harder give them higher combat stats :)
An easy way to do this is to create a separate table with all the NPC_ID's for 'raid mobs'. Then you can run a query with an = or join on the NPC_ID.. For example, Code:
update npc_types set npc_types.atk = 2 billion, npc_types.accuracy = 3 billion where npc_types.id = raidmobs.id I use something similar to balance non-boss mobs by their level. |
The hell with all this fancy mumbo-jumbo, I just let the raid mob beat the shit out of me for a few hours while I fine tune his stats :D
|
Code:
if(RuleB(Combat, UseIntervalAC)) { Edit: I commented out the current code in my attack.cpp starting at line 1870 and end at line 1874 then pasted the above at line 1875. |
And obviously this values I just made up with what I have seen from all of the parses I have done. They need to be fine tuned to really get it right. I stopped at dividing the mid by 5 at green con because I think that if you go any more you would defeat the purpose of AC. Right now though you dont get hit for continue top end without a ton of AC and if you have a ton AC you still get hit hard on occasion. The most testing I have done so far has been in CoM and EJ with a 50monk wearing gear only from kunark and classic. So far I am not getting completely owned like normal and I still have to stop and bw to keep fighting like it should be for dark blue and light blue mobs. If I use a fungi I have to do this less. Or just wait a bit for the regen to do it. Much like my experiences on live eqmac and p99.
|
For the raid check I was thinking of something along the lines of
if(RuleB(Combat, UseIntervalAC) && raid check) {..... copy paste the rest and then that could be adjusted to what you want raid mobs to reflect =) |
Assuming I am reading this right, this will get screwy when mobs have a relatively high min hit. For argument's sake consider a green mob, that hits for 50-100 damage
65% of the time it hits for 50 (unmitigated) 8 % of the time it hits for 25-50 (unmitigated) 8% of the time it hits for 20-40 (unmitigated) 8% of the time it hits for 16-33 (unmitigated) 8% of the time it hits for 14-28 (unmitigated) In all the latter cases, the max hit is at or below min hit. Once damage is calculated by this code it will go through the mitigation function. At which point damage will be set to min_hit (as it is lower than min_hit). So the final result will be a 97% chance for any green mob with comparably high min_hit a to hit for minimum. Feel free to correct me if I've missed something. |
I see what you're saying but at the same time I know of no mobs with a min hit of 50 that their max hit is only 100 or their min_hit multiplied by 2 to get the max_hit. Most of the time the max is x4 or more than what the min is. So if you had some custom mobs on your server that had only a dmg range of minx2 for max this could be a problem. But just looking through the npc_types, min_hit max_hit, nothing is set at a multiplier of x2 from min to max. Except like I said the level one mobs in the classic zones. In which case they aren't even what live is currently and need to be adjusted to reflect live.
Edit: Also these values are not set in stone. They can be adjusted to anything you want them to be. |
And yes you want green mobs hitting for minimum almost always except for raid mobs.
Unless you have gray con on your server then gray can be made the default and green can adjusted accordingly. |
The code below this.
Code:
//check if we're hitting above our max or below it. And actually this calculation can just be added into the end of the if statements in the switch case. |
Although it affects mobs with a lower ratio to a lesser degree, it's still a significant degree. It's also not part of your design and works against the concept of having brackets which you set. I only chose the green example because it had the most brackets. The figures look bad for other /con's as well.
At the 50% ratio: (over 4400 mobs) yellow mobs hit minimum 50% of the time. white mobs hit for minimum 70% of the time. At 40% ratio, these figures drop by a few % rather than a lot of %. I /coded over 4000 examples of mobs that have a 50% or higher ratio of mindmg to maxdmg, but edited them out on second thought ;) Over 14,000 mobs have 30% or higher ratios.. this is not an insignificant number. Don't let it stop you tinkering, but you might want to rethink the solution. |
But I believe that even if it reverts to a default of 50 unmitigated it will still be fine since by the time you run into a mob with a min or 50 your ac calculations will take over and it should still keep the same curve.
What do you think cavedude? Honestly so far I haven't had any problems but that doesn't mean there aren't any. |
You misunderstand me - it reverts to min_hit AFTER the mitigation from AC.
|
Yeah thats fine. If you go into SoF at lvl90 on live you dont get hit for 1 dmg you frequently get hit for their min if you have max aas and if you dont just straight up avoid or block their dmg. Again these values can be adjusted.
This switch case can be made into a function and then you could add more checks like if the mob has a ratio of .5 or more to follow a different case. |
Quote:
|
use this query to get the ratio's;
Code:
select id, name, maxdmg, mindmg, mindmg/maxdmg as ratio from npc_types where (mindmg/maxdmg) > 0.2 |
Quote:
Search for meleemitigation. IMO it's where you should be looking if you want to tweak mitigation code. Not to discourage you, but what you're doing at the moment is called a hack job :) |
If you remove my code and go with standard and you have a green mob that hits your for min and then you mitigated that down to below the min and then some other check say well its below min so just bring it back up doesnt that defeat the purpose of the ac check?
|
No, the way it works is that a mob hits for maxdmg, and then AC and other mitigation factors are pitted against attack to push damage down towards minimum. There are 20 different values that a mob can hit for on live, so the function looks at mindmg and maxdmg of a mob, works out the 18 values in between, and then the outcome of mitigation vs attack determines which of the 20 possible values is the final damage outcome.
|
FYI it appears that there are now at least 30 values on live.
|
Any word on a fix for this or if Cowboy's code is good enough?
|
I also have an issue that it seems npc's arent ever missing swings.
|
Quote:
|
This issue has been resolved on the Sleeper server - tests have shown AC to play a much larger role in overall combat damage.
http://epicemu.com/forum/ac-new-dama...ing-code-tests |
wtbmacestun = cowboy6534 ... just cant remember the pw to log into that account atm... anyway if anyone wants it I have the code we used on kegz server. I posted it in another thread but felt i would elaborate more in my own thread.
So basically when I started out on this little adventure to fix ac kegz didnt really have any interest until i found where in the code the actual problem was. The first implementation of it was what i posted here which did not work. The one that ended up working was kegz idea and it worked great. First what I found was that in this section of code no matter what happened before this section dmg was static to min and max. None of the previous code influence the dmg being done, or rather, mitigation wasnt being applied from a characters AC. Code:
if(RuleB(Combat, UseIntervalAC)) { If this never makes it in the main build it would have truly have been a waste for us to fix this. Seeing as he shut is server down and I am not in the position to run one myself atm. Although I am still constantly thinking about how to fix things on the server that isnt there any more.... As far as I know my monk weight fix still isnt implemented which is sad... Also all the hate that I received when I first brought this up made me not want to share with this community for a long time... But now that his project is gone and I have nothing to work towards again I thought I would share here. I have a few ideas on how to bring back the Iksar ac bonus that was removed from live a long time ago. Which can be made into a database option for servers that want it and servers that dont. The ac fix should not be made an option though. Its gone on long enough that AC has been broken. If you have any questions let me know. |
Quote:
Your post/code is very much appreciated. I have been feeling at lower levels game play was off. You have provided me with some ideas as to where to look and, potentially, tweak things. Thank you. I am not sure how to say this, but here goes. The fact you reconciled the treatment by a minority of individuals for your use of less than ideal word choices--yes, you could have been a bit more sensitive, shows emotional maturity. I suspect others, quite possibly the majority, such as myself visit as guests and have been lurking about for *many* years and appreciate your efforts. I try to learn from the behavior of others and when criticized, see it as an opportunity to learn from the experience. I, believe, you did just that. You did good. Best wishes :-D |
The exact line you want to look at in the attack.cpp is 1866. This is under the void npc::attack. The void mod::meleemitigation does nothing to actually mitigate dmg being done. If you want to test this out like we did. Change the min and max to static numbers for all mobs and youll see just that.
|
Thank you. I will.
|
I recently revised this code a bit if anyone is interested I thought i would share.
Code:
if(RuleB(Combat, UseIntervalAC)) { above the tank they would hit for max like normal keeping the dmg high and the encounters hard. But for none raid targets as long as they arent red it would allow ac to do what it needs to do to. What this does is take a % of your ac and reduces each hit by that percent. So if you have it set at 2 it would be dmg = max dmg - the persons ac who is being hit * 2/100 or for example dmg=20-100*2/100 dmg=20-200/100 dmg=20-2 dmg=18 |
Some interesting points on AC from a Sony dev in this post http://www.eqemulator.org/forums/sho...624#post229624
I realise it doesn't cover all of the different checks in combat, but I though it pertinent to this discussion. |
Yes, that is good information. Thank you.
|
All times are GMT -4. The time now is 07:33 AM. |
Powered by vBulletin®, Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.