SFF Life

How to undervolt your gpu

Published on:

Small form factor enthusiasts repeatedly stuff power hungry components into tighter spaces. Sometimes things get too hot, too loud, or too powerful. Or maybe a power supply is starting to fail, etc. Luckily, one can undervolt their most power hungry component, which is more likely than not the GPU, and can achieve power savings with temperature reduction all without sacrificing performance. And undervolting the GPU can be done quite quickly by any layperson.

Not to spoil anything but we’ll undervolt a GTX 1070 to within a GTX 1060’s TDP with no performance drops

Components we’ll be using:

  • 3dmark Timespy: Free GPU benchmark. To install, just make sure you click “Download Demo” in Steam. This benchmark will report a graphics score that we can use to detect performance regressions.
  • HWiNFO64: to measure our sensor readings (temperature, wattage, etc)
  • MSI Afterburner: to tweak the voltage / frequency curve of the gpu
  • Google sheets: A spreadsheet for tracking power usage, benchmarks, any modifications, etc
  • (optional): GPU-Z: we’ll only be using this tool, which provides a host of GPU information, for determining a GPU’s boost clock (but you can consult the manufacturer’s website too)
  • (optional): P4460 Kill a Watt electricity usage monitor: to measure output from the wall. This is the only thing that costs money on the list – you may be able to rent it from a local library or utility company. A wattmeter is not critical, but it’ll give us a sense of total component draw that the PSU has to supply. I bought one from my local hardware store.
P4460 Kill a Watt for monitoring electricity usage from the wall

P4460 Kill a Watt for monitoring electricity usage from the wall

Feel free to swap components out for alternatives, but I do want to stress the importance of benchmarks, as it’s desirable for any potential performance loss to become apparent when running benchmarks at each stage of the undervolt.

Attentive readers will note the absence of any stress tests (eg: Prime95 With AVX & Small FFTs + MSI Kombustor). It is my opinion that drawing obscene amounts of power to run these stress tests is just too unrealistic. Benchmarks should be stressful enough, else what are they benchmarking? I’ve used this method of undervolting for several months and have not experienced any crashes in game or other intensive workloads. But I understand the drive for those who want ultimate stability, so for that audience, I’d suggest after we work our way down the voltage ladder to start climbing up if stress tests fail.

Due note that it is easiest to perform undervolting with a PSU that is in good working condition with enough power to supply components at stock and then transfer to a smaller PSU if desired. This is also not a requirement, but saves troubleshooting time for those sticking 300w of components in with a 200w PSU.

🔗 Important HWiNFO sensors

I’ve highlighted all the sensors in HWiNFO that we’ll be using during our benchmarking

HWiNFO important sensors highlighted

HWiNFO important sensors highlighted

After a benchmark has concluded, we’ll record the two numbers in the max column and then click the highlighted reset button to have a clean slate for our next benchmark run.

The reason why we’re interested in max values instead of something like averages, is due to undervolting wanting to achieve values below a threshold. For instance, we want to achieve temperatures below thermal throttling and power usage below the budget for the GPU.

🔗 PSU and power draw example

Before we dive too deep into undervolting, let’s break down what it really means when we’re measuring the number of watts flowing through the wattmeter:

  • Kill A Watt shows 200 watts
  • The PSU (SSP-300-SUG) is 300W 80 Plus Gold certified
  • Since the PSU is gold certified, while between 20-100% load, it’s able to to convert 87%-90% of inbound power to the components with the rest dispersed as heat
  • Thus components are asking between 174-180 watts (else the PSU would be rated silver or platinum)
  • If the components are asking for max power (300 watts), the Kill A Watt should be reading 337-344 before shutdown

🔗 Initial Benchmarks and Measurements

First we’ll measure idle for completeness:

  • Close all programs including those in the background using any cpu cycles
  • Open HWiNFO
  • Wait for the system to settle down (ie, the wattmeter converges to a reading)
  • Record what’s being pulled from the wall, and max sensor info from HWiNFO.

Then benchmark the gpu with timespy. The score you are interested in is the graphics score. Use the process listed below

Timespy score we're interested in

Timespy score we’re interested in

  • Keep everything closed, except HWiNFO
  • Reset HWiNFO sensors
  • Run Timespy
  • Record score, max wattmeter reading, max watts / temp from the gpu
  • Repeat three times

Here’s an example of what I recorded for my initial measurements and how I interpreted them:

How I set up my spreadsheet for recording data

How I set up my spreadsheet for recording data

  • Average Timespy score: 5976
  • Max wattmeter reading: 241W
  • Max GPU watts: 159W
  • Max GPU temperature: 82c
  • Our GPU exceeds it’s TDP rating by 10W and total component draw is around 210-217W (241 * [.87, .9]).

🔗 GPU Undervolt

🔗 Determine Target Frequency

First, determine what target frequency you’d like your GPU to boost to, ideally a number between the GPU’s boost clock and max clock. The GPU’s boost clock will be listed in the manufacturer’s specification and also in GPU-Z. The GPU’s max clock is determined at runtime through GPU boost and will be reported as the “GPU Clock” in HWiNFO64 (make sure it’s running while the benchmark are in progress). Below are screenshots from HWiNFO64 and GPU-Z showing the differences between these two numbers.

GPU-Z depicting manufacturer's boost clock

GPU-Z depicting manufacturer’s boost clock

HWiNFO depicting GPU's max boost clock

HWiNFO depicting GPU’s max boost clock

So from those two screenshots, we can see

  • Boost clock: 1721mhz
  • Max clock: 1886mhz

GPU boost (different from boost clock) increases the GPU’s core clock while thermal and TDP headroom remain. This is somewhat counterproductive for us as any voltage increases to reach higher frequencies will cause an increase in power usage and blow our budget.

I chose my target frequency to be 1860mhz – 139mhz over boost and 26mhz under max, as during benchmarking the gpu clock was pinned at 1860mhz most the time (this is where HWiNFO average readings can come in handy!). The exact number doesn’t matter, as one can adjust their target frequency depending on their undervolting results. I change my target frequency later on. We’ll also choose our starting voltage to be 950mv, which is a pretty middling undervolt, and we’ll work our way down.

🔗 MSI Afterburner

The tool for undervolting! Powerful, but can be unintuitive at first.

Ctrl + F to bring up the voltage frequency curve. Find our target voltage of 950mv and take note of the frequency (1809mhz in the screenshot)

Default frequency curve

Default frequency curve

Our target frequency (1860mhz) is greater than 1809mhz by 51mhz, so we switch back to the starting window and increase the core clock by 51mhz.

Increase core clocks by 51MHz

Increase core clocks by 51MHz

This will shift the voltage frequency graph up by 51mhz ensuring a nice smooth ride up the voltage / frequency curve until we hit 1860mhz at 950mv. Then to guarantee we don’t exceed 950mv:

  • Select the point at 950mv
  • Hit “l” to lock the voltage
  • For all voltage points greater than 950mv, drag them to or below 1860mhz
  • Hit “✔” to apply
  • Afterburner will adjust the points to be the same frequency as our locked voltage
  • You may have to comb over the points to ensure that afterburner didn’t re-adjust any voltage points to be greater than 1860mhz. It happens. You can hit “Tab” or “Shift + Tab” to cycle through the voltages quickly after selecting a point, and “↓” to adjust frequency by 1MHz or “Ctrl + ↓” to adjust by 10MHz.
  • Hit “l” to unlock the voltage / frequency curve after confirming all voltages greater than 950mv are set to our target frequency. If one forgets this step, the GPU will be pinned to 950mv and unable to idle!
  • Hit “✔” to apply

End result should look like:

950mv undervolt with +51MHz

950mv undervolt with +51MHz

Since no voltage has a clock frequency greater than the frequency at 950mv, Afterburner will ensure that no voltage exceeding 950mv will be delivered to the GPU as there isn’t any frequency left to gain.

After our hard work, we’ll want to save this as a profile so that we can refer back to it after we inevitably undervolt too far. In addition, after determining what is the best undervolt, we’ll want to have that profile loaded on boot, so ensure the windows icon is selected.

Ensure the windows icon is selected to apply profile on boot

Ensure the windows icon is selected to apply profile on boot

🔗 Rinse and Repeat

Do the benchmark routine:

  • Clear / reset sensor data for max power usage and temperature
  • Start Timespy
  • Keep eyes glued on the kill a watt and record max draw
  • After Timespy completes record score, gpu max power usage, max temperature, and wall max wall draw.
  • Repeat 3 times

After three successful benchmarks:

  • Open Afterburner
  • Reset the voltage / frequency graph by hitting the “↺” icon
  • Decrement the target voltage by 25mv and keep the same target frequency
  • Calculate new core clock offset from new target voltage
  • Proceed to adjust all greater voltages to our frequency
  • Re-benchmark

If the undervolt is unstable then Timespy won’t finish and will display an error. That’s when you know you’ve undervolted too far and to dial it back one step. It is rare that undervolts would cause significant instability like blue screens, system freezes, or screen artifacts.

🔗 Results

Spreadsheet tracking the undervolt process

Spreadsheet tracking the undervolt process

  • Undervolted to 875mv at 1860mhz
  • 850mv was not stable
  • No affect on Timespy score (<1% difference)
  • GPU max wattage decreased from 159W to 124W (20-23% reduction)
  • GPU max temp decreased from 82 to 75 (9-10% reduction)
  • Attempting an undervolt of 875mv at 1886mhz (the original max clock) was not stable

These are good results that demonstrate that there is no performance loss from undervolting, yet one can mitigate heat and power usage.

🔗 One step further

I decided to double down on undervolting and see just how far we can take this. I repeated all the steps we’ve taken but with a target frequency set to the GPU’s boost clock (1721MHz). Fast forward an hour later and this is the resulting voltage / frequency curve I ended with.

Undervolted to 800mv at 172MHz

Undervolted to 800mv at 172MHz

And for completeness sake, here are all my results across all undervolts.

Final spreadsheet after additional undervolting

Final spreadsheet after additional undervolting

  • Undervolted to 800mv at 1721mhz
  • Slight decrease to Timespy score (6-7%)
  • GPU max wattage decreased from 159W to 105W (33% reduction)
  • GPU max temp decreased from 82 to 68 (15-17% reduction)

To me, the loss in performance in this chase to undervolt is greatly outweighed by the gain in efficiency.

🔗 Conclusion

As a comparison

  • A GTX 1060 6GB has a TDP of 120W
  • A GTX 1060 6GB has an average Timespy score of 4227
  • A GTX 1070 has an average Timespy score of 6082
  • With our Timespy score of 5948 at 124W, we have GTX 1070 performance at GTX 1060’s TDP
  • With our Timespy score of 5600 at 105W, we’re more energy efficient than a GTX 1060 yet still command a massive performance advantage

We’ve decreased power usage for the GPU considerably (54 watts!), lowered temperatures, and opted into additional undervolts for a near neglible performance loss.

Still not convinced? One thing that I’ve not mentioned is the noise reduction undervolting brings. Below is a graph from Afterburner that shows % fan speed during a timespy run to be between 50-60%.

Afterburner showing max fan usage between 50-60% after undervolt

Afterburner showing max fan usage between 50-60% after undervolt

I find this incredible. A single fan, ITX GPU at 100% load, below 70°C, under 60% fan max RPM. It’s a SFF miracle; a GPU that is small, powerful, and silent.

Undervolting, so underrated.


🔗 How to I know my GPU is respecting the undervolt?

  • Have your undervolt set in afterburner through the voltage / frequency editor. (We used 800mv in “One step further")
  • Ensure HWiNFO is open and reset
  • Run timespy or another intensive workload
  • Max GPU Core Voltage should not exceed our undervolt
HWiNFO showing our 800mv undervolt is respected

HWiNFO showing our 800mv undervolt is respected

🔗 How do I stress test the undervolt?

  • Do the most GPU intensive thing you regularly do
  • If that is not enough: download, install, and run MSI’s Kombustor for an hour

You’ve read this far or ctlr + f “stress” and can’t believe I’ve been so dismissive of stress tests. Not to go on a rant, but people put too much weight on stress tests, and some may find this guide woefully lacking if a stress test section is not included. Those same people will disagree amongst themselves about which stress tests should be ran, how they should be ran, and the durations of the tests. Anyone not following their formula is sacrificing stability. There is no perfect solution. You want to be comfortable with your computer, and that’s up to you to define.

So after a half of year of running the 800mv undervolt without crashes, I decided run Kombustor for a half day. No crashes. Sub 70°C. If Kombustor had crashed, it would not have worried me because (and as much as a weird flex as this is) I’m on this computer all day nearly every day and it’s rock solid for my workloads. If Kombustor crashing has you worried, no sweat – bump your undervolt up +25MHz until the stress test has ran long enough to satisfy you.

🔗 Discussion

This article has been discussed at the following external sites