McAwesome-NoFrameSkip icon

NoFrameSkip

Makes late game lag more bearable (hopefully).

Last updated a month ago
Total downloads 4210
Total rating 2 
Categories Tweaks
Dependency string McAwesome-NoFrameSkip-1.0.1
Dependants 1 other package depends on this package

This mod requires the following mods to function

bbepis-BepInExPack-5.4.2117 icon
bbepis-BepInExPack

Unified BepInEx all-in-one modding pack - plugin framework, detour library

Preferred version: 5.4.2117

README

NoFrameSkip

Have you ever been annoyed at just how laggy the game gets whenever you hit anything 10+ loops into a run? Well, this mod... won't necessarily fix that, but should make the lag more bearable by reducing the max delta time in a frame.

Maximum delta time can be configured. Risk Of Options is supported.

Notes and warnings

This mod has not been tested in multiplayer and may result in weird behaviour.

If your GPU cannot run this game at 60 fps, this mod will result in the game running slower. If you're fine with this, you don't need to do anything. If you're not, try increasing the max delta time to be at least 1 / fps (e.g. 0.05 for 20 fps). However, if this results in significantly lower fps, you are likely CPU bottlenecked.

For both of the above, having Risk Of Options is recommended.

Explanation

Background

Risk of Rain 2, like many Unity games, have various calculations (mainly physics) run on a fixed tickrate. In ROR2, this is 60 tps (or once every 16.7 ms). This means that your survivor's movement, the Elder Lemurian fireball coming at you, or your ATG Missile going towards the Elder Lemurian have their calculations run 60 times every second.

The Cause

Well, to be more specific, it's 60 times every in-game second. You see, when you have several thousand projectiles, whether they're ATG Missiles, Molten Perforator fireballs, Ukulele chain lightnings, etc, those calculations can take quite a while.

The issue happens when they start to take longer than 16.7 ms to calculate. Let's say they take 20 ms to calculate in this hypothetical example.

T = 0s, the previous frame has been processed. We do the next one, starting with physics. They take 20 ms to calculate. T = 0.02s. It's been longer than 16.7 ms, so we need to calculate physics again. T = 0.04s. And again. T = 0.06s. And again...

You see the problem? The physics updates take longer than the tick interval, meaning that it'll just continue to calculate physics over and over and over and over. But not forever. Unity has a cap on how much time can pass in a single frame. By default (and in this game), the cap is 0.333 seconds of in-game time (maximum delta time).

As such, at T = 0.4s*, we break out of this loop and finally get to other calculations, including actually rendering the frame. Assuming all that happens instantly, this puts an effective cap on our framerate at 2.5 fps. Not very fluid.

* Math: 0.333 seconds of max delta time, multiplied by 0.02 seconds of physics calculation time, divided by 0.0167 seconds of fixed delta time.
(Note: The numbers shown here are rounded)

The Solution

Normally, this maximum delta time means that if your slow ass GPU can only render 1 frame every 50 ms, your CPU can calculate 3 physics ticks (3 * 16.7 ms = 50 ms) to compensate and so you get smoother gameplay. But when the bottleneck is the CPU, this simply results in a feedback loop until Unity decides that too much physics has happened and moves to render the frame anyway.

So the solution here is pretty simple: reduce the max delta time to be as low as possible (in this case, 0.0167 seconds).

Sources / Further Information

Unity Execution Order
Unity Time

Thumbnail source: Screenshot I took while using the mod on Debugging Plains (Original).