-
Notifications
You must be signed in to change notification settings - Fork 355
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Concept of dhewm3 running at 144Hz refresh #250
Comments
During testing I went through the whole base game and RoE expansion pack using i7-8700, GTX-1080 (drivers 431.60), 2560x1440 @144hz with default dhewm3 Ultra setting. I didn't use the in-game MSAA, instead used cheap nVidia FXAA, which looks OK in this old game and is almost resources free. GPU was resting the whole time at about 10%..30% load and I didn't encountered any engine crashes. Surprisingly there also weren't any slowdowns due to com_fixedTic "1", not even once. So at least on this CPU the high refresh seems to be viable. |
I suggest a little change in the grabber crosshair switching code for RoE. IMHO the crosshair rotation looks better unscaled in widescreen. I doubt it can be fixed to circle due to the dynamic rotation. The code is in d3xp\Player.cpp, idPlayer::DrawHUD function.
|
Nice, this works very well! I haven't tested it too much but it seems very solid. Ah, it's nice to have non-BFG edition at high refresh rates... |
Could anyone compile the 144hz fix for Linux? I'm using dhewm3 from the repositories. Right I have to play with com_fixedTic -1. |
Hey dezo2! I am not sure why this patch as not received as much attention as it should be! With the Librecoop coming along we are so close to having a better than BFG Edition type co-op experience for the first time ever. which raised the question, Any way to have this compatible librecoop on a client side level? If i used your base.dll It runs but everything is in fast forward. Any insight would be very welcomed! |
Hi dezo! Is there any chance of having this fantastic mod compatible with dhewm3 1.5.1? I've already played the game with it some years ago but wanted to give another go. |
Hi Alexi, |
seems to be working just fine with 1.5.1 |
Did a quick test with dezo2's build two replies before mine. Moving and jumping slows down when fps goes below 144Hz. No issues other than that. |
Hi dezo! Sorry to bother you again, but do you know if there is a similar 144Hz mod for Prey (2006) as well? |
I beat the base game on Nightmare. Not a single issue at 1920x1080. It was on my previous build with an i5-9600K @5.0GHz, GTX 1660 Super and 16GB DDR4 @3000MHZ. |
Has there been any progress made on this in the last 13 months? |
There's was (is?) a fork based on Stradex' branch from #297: https://github.com/simonedibilio/dhewm3 |
By the way, @dezo2, where is the source of the binaries you posted here? |
Sources of modified 1.5.2 are in the "neo.zip", two modified scripts that should go into the base folder are in "base.zip". I am not really a cpp/github guy, so I thought the changes I made are not up to standard here (it was just a test). I am sure there is a better way to do it instead of recompiling the whole thing with different values for USERCMD_HZ and USERCMD_MSEC in UsercmdGen.h and updating the two scripts. It will break compatibility with mods for sure. Anyway I marked every change with comment "// dezo2" to easy find them. Most of them are simple replaces of original hardcoded values. There was not much to do, the engine really had no problem with higher framerates, especially with todays CPUs with fast single core performance. I tested this last year with i5-13600 at 200 FPS no problem. Its just they decided at some point to screw it with hardcoded values, not sure why - maybe the weird physics. |
thank you! :) |
Hi! Do you know if there is something similar in the work for Prey (2006)? |
I don't think so, and as Prey's source code wasn't released it would be pretty hard to do. |
see dhewm#250 also requires modified scripts, but only two 1. doom_defs.script: #define GAME_FPS 60 => 144 #define GAME_FRAMETIME 0.016 => 0.007 2. weapon_chaingun.script: #define CHAINGUN_FIRE_SKIPFRAMES 7 => ( 7 * GAME_FPS / 60 )
I put your code changes into a git branch which is based on the latest dhewm3 code: Are there any known bugs with this code? |
I saw maybe 2 or 3 physics related glitches where imp couldn't jump out of his hole due to a moving part in the path. Other than that I was able to finish both the base game and RoE without anything game breaking. BUT the two adjusted script files from base.zip above are mandatory, otherwise the game will crash in Alpha Labs 3 (the crane section) and chaingun will fire too fast. |
Do you remember where those physics glitches happened? Why is With Stradex' approach there were reports about oxygen running out too slow (in the base game) or too fast (in d3xp), did you notice anything like that in your branch? (Stradex also modifies EDIT: Oh, and I understand correctly that all that was needed to fix that crane (I saw that mentioned in #297 as well) was to adjust |
IIRC the glitches were in map recycling1/2 somewhere (can't remember) and in RoE map erebus4 in the beginning where that new imp couldn't leap down from the ceiling. I could't figure out what to adjust in the physics code to make it work. Almost every high refresh monitor nowadays has variable refresh so the com_fixedTic can be ignored (left at default 0) as these monitors can handle anything in VRR range including the default 62.5 FPS hardcoded into the engine without any stutter/judder. It was an ancient fix to eliminate microstutter for fixed refresh rate monitors. It bypasses the ingame timer based FPS cap so it can be handled by VSync or external limiter instead. Because the engine uses integer value for frametime, ideal fixed refresh rates in Hz would be 50 (20ms), 100 (10ms), 125 (8ms), 200 (5ms) etc. Everything else causes microstutter as it is not aligned with integer frametimes. For example 60Hz does not match the default integer 16ms ingame constant because 1000/16=62.5 (not 60), so the game skips a frame every one second or so. That cvar removed those skips and made the game smoother but also caused slow downs when CPU/GPU is too slow to reach the target FPS. And obviously caused a bit of audio desync in cutscenes due to the wrong timing. For the oxygen tank I made fixes in the code - that was the first thing I noticed wrong with >60FPS. It is the "airTics" adjustment in Player.cpp source code. As for the scripts - yes, this was the fix for the crane and also the chaingun. Ideal approach would be to adjust it in the code somehow, so the users don't need to fiddle with it manually. It would be great to control all this with a simple cvar (for example "com_engineHz") and use that to overwrite the values when the engine reads and parses original scripts and also everywhere else in the code instead of the dreaded USERCMD_HZ constant. |
Thank you very much for the explanation! :)
Yeah, that's pretty much what Stradex' branch does - and it even patches the scripts to modify He also turned some times from integers into floats, so 8.333ms or whatever can be handled without losing too much precision. I haven't looked at that too closely yet, but it is potentially helpful. I hope that I can create something that works properly (and with all kinds of framerates) based on Stradex branch and your patch (but no promises yet, esp. the physics issues might end up as a dealbreaker that's too hard for me to fix, we'll see..) |
Oh, two more bugs that were reported with Stradex approach (from simonedibilio#2):
Does any of that sound familiar? |
Tried the mod switching multiple times now without problems. Can't trigger it. As for the second one I tried the 1st level in RoE and the grabber works normally right after I get it (after the cutscene). Also played trough the whole expansion at least once and this one I would remember. |
My branch based on Stradex' work and your fixes: #584 |
Another try, this time not using not that much of Stradex' work: #585 By the way, I think the mod switching issues are related to one mod using a different com_gameHz value than the other, so code like unsigned int now = SDL_GetTicks();
unsigned int tick = com_ticNumber * USERCMD_MSEC;
// now compare both values.. doesn't work that well, esp. if USERCMD_MSEC has been reduced in between and With your patches this isn't a problem because USERCMD_* was fixed to the same value for all mods. |
I made a custom win32 build for my testing purposes aimed to 144Hz displays, including RoE and dentonmod. After some testing I decided to share it here in case anyone of you guys wants to try it. It is by no means official proper engine fix, just an experiment if it can run smoothly at such
refresh. I also tried to fix some issues found on the way - see bellow. There can be more of them (mainly physics), but hopefully nothing game breaking.
dhewm3_144Hz.zip
To install this just copy the unzipped content over the stable 1.5.0 dhewm3 release, or merge the autoexec lines if you already use your own. Of course your display refresh has to be 144Hz before executing the game and in-game VSync must be active. The frame time for 144Hz is very close to 7ms, so that is the value I used in all binaries for the integer USERCMD_MSEC constant. With that and the com_fixedTic "1" plus VSync, the game speed looks alright. As for the CPU load, do NOT use r_finish "1" for input lag reduction, it tanks the CPU in some areas and may cause crashes in high refresh. Just leave it at "0", input lag will be lowered anyway with the shorter frame time.
Changes made in the binaries:
And this was adjusted in the scripts:
The text was updated successfully, but these errors were encountered: