calibration.rst (12422B)
1 How to determine the calibration levels of your recording setup 2 =============================================================== 3 4 Background 5 ---------- 6 7 With the arrival of highly-accurate modeling technologies like NAM, there's been 8 an interest in ensuring that the gain staging of the signal entering and leaving 9 models is accurate *in the digital realm* to what one would experience when 10 plugging into the source analog gear. 11 12 As of version 0.10.0, :ref:`the NAM file spec<nam-file-spec>` defines a pair of 13 metadata fields, ``"input_level_dbu"`` and ``"output_level_dbu"``, that document 14 the relationship between the *digital* and *analog* signal strengths. 15 Specifically, these fields record the *analog* signal strength (in dBu) that 16 corresponds to the loudest signal that can be represented *digitally*. With 17 these two values recorded, one can calibrate the gain staging of the digital 18 models to accurately reflect the behavior of the source in its native analog 19 realm. 20 21 This tutorial explains how to take the measurements to fill in these metadata. 22 23 Notes 24 ----- 25 26 A few things before we begin: 27 28 * **As with all metadata, providing calibration levels is optional.** If you 29 don't want to do this, you can leave them blank. The models will still work in 30 any plug-in that supports playing NAMs, but the gain-staging may not be 31 accurate to the source gear. 32 * **Pay attention to what's in front of your model.** If you are using a model 33 with a calibrated input level, that level will *only* be correct if either (A) 34 there are no effects in front of it, or (B) any preceding effects' *input and 35 output* calibration levels are known and accounted for. This is possible to do 36 automatically within a single plug-in, but if there is *another* plug-in in 37 front of your NAM whose calibration is not known, then all bets are off! 38 * **You can still use your ears!** Before getting too deep into this, remember 39 that we're trying to make music. Don't let the "correct" answer get in the way 40 of making the music you *want* to make! 41 42 Tools needed 43 ------------ 44 45 In addition to your reamping gear (interface, reamp box, DI box, load 46 box/microphone, cables), you're going to need to know how loud things are. In 47 the *digital* realm, the meters in your DAW tell you what you need to know; for 48 the *analog* electrical signal, you will need a 49 `multimeter <https://en.wikipedia.org/wiki/Multimeter>`_. 50 51 Procedure 52 --------- 53 54 First, set up your gear as you would normally for reamping: 55 56 * Mute the inputs to your interface in your DAW. 57 * Connect the output of your interface to the input of your gear via the reamp 58 box. 59 * Connect the output from your gear (or load box, or microphone) to the input of 60 your interface. 61 * Turn the output from your interface to its maximum value. 62 * Begin reamping and set the gain on the return input to your interface so that 63 no clipping occurs. 64 65 .. image:: media/calibration/reamp-setup.jpg 66 :scale: 15 % 67 :align: center 68 69 *Figure: Example reamping setup. The output from the Focusrite Solo passes 70 through the reamp box into the input of the amp. The (effects loop!) send from 71 the amp is returned to the recording input of the interface.* 72 73 .. note:: My advice is to **set the reamping send level as high as your gear 74 will allow.** If it's too low, then the model won't see any examples of the 75 gear distorting under a very hot signal and may not predict it accurately. You 76 don't need to worry if it's exactly accurate to how loud a guitar is--that's 77 the purpose of calibration--what's important is that the model has trained on 78 examples that are at least as loud as (preferably even louder than!) how the 79 model will be used in practice. 80 81 Go ahead and reamp your gear to get the data for your model. **So long as you're 82 happy with your send level and the return doesn't clip, you're good.** 83 84 From this point onwards, **do not change any hardware gain levels**. You already 85 recorded your data; if you make any changes, your calibration measurements won't 86 correspond to your data. 87 88 Next, measure the send level. To do this, play a sine wave with 1kHz frequency 89 and 0dBFS peak amplitude. Some plug-ins can do tone generation, or else you can 90 just loop this 1-second file: 91 `sine 1k.wav <https://drive.google.com/file/d/18y53y4yi_QEUundLlBZsjdY_OeytC6y1/view?usp=drive_link>`_. 92 Unplug your cable from the gear you are reamping and measure the RMS voltage 93 across its tip and sleeve. 94 95 .. image:: media/calibration/voltage.jpg 96 :scale: 15 % 97 :align: center 98 99 *Figure: Measuring the level of the jack that was plugged into the input of the 100 amp. I measure 6.40 Volts RMS.* 101 102 Convert the RMS voltage to dBu using the formula: 103 104 .. math:: 105 106 \text{dBu} = 20 \times \log_{10}\left(\frac{V_{\text{RMS}}}{0.7746}\right) 107 108 Alternatively, the bottom of this page has a table of pre-computed values you 109 can reference. 110 111 *Example: In the picture above, I measured 6.40 V. This corresponds to 18.3 dBu.* 112 113 Next, measure the return level. To do this, start by connecting the send from 114 your interface directly to the return you used for recording. Remember, **do not 115 change any hardware gain levels** or else you're going to have a different 116 calibration from how you recorded your data! 117 118 .. image:: media/calibration/reamp-setup-no-amp.jpg 119 :scale: 15 % 120 :align: center 121 122 *Figure: My reamping setup, with the send plugged directly back into the 123 return.* 124 125 Play the sine tone, and note the return level (in dBFS) in your DAW: 126 127 .. image:: media/calibration/sine-tone.png 128 :scale: 30 % 129 :align: center 130 131 *Figure: Monitoring the return level. The "send" track is outputting a 1 kHz 132 sine tone at 0 dBFS. The return track is clipping.* 133 134 You may find that your send signal is so loud that it clips the return, like 135 above. *This is not a problem.* If this happens, reduce the level of the sine 136 tone in the DAW until the return doesn't clip *(You should do not change the 137 ``input.wav`` file as well. In fact, hopefully you already reamped so that 138 you're not tempted!)* 139 140 .. image:: media/calibration/sine-tone-level-reduced.png 141 :scale: 30 % 142 :align: center 143 144 *Figure: Monitoring the return level. The "send" track is outputting a 1 kHz 145 sine tone at -6.50 dBFS. The return track is measuring -0.5 dBFS.* 146 147 Note the return level (-0.5 dBFS above) and the amount by which you changed the 148 sine tone's level (-6.50 dB). 149 150 To compute the return level, remember: what we are trying to do is figure out 151 how loud an analog signal is (in dBu) that barely clips the return on our 152 interface (i.e. achieves 0 dBFS). We know the analog level of the sine tone (at 153 full volume, i.e. 0 dBFS) from above, so the formula to compute your return 154 level calibration, in dBu, is: 155 156 .. math:: 157 158 \text{dBu}_{return} = \text{dBu}_{send} + \Delta - L, 159 160 where Δ is the amount by which you changed the sine tone's level, and *L* is 161 the observed return level in the DAW (in dBFS peak). 162 163 For example, using the numbers above, I get 164 *18.3 + (-6.50) - (-0.5) = 12.3 dBu*. 165 166 Careful: The return level calibration may not be what you think it is 167 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 168 169 As of this writing (October 2024), some users are likely familiar with a 170 manufacturer-provided calibration level for their interface's inputs. For 171 example, the maximum input level for the instrument inputs on the 4th-generation 172 Focusrite Scarlett 18i20 is listed in its manual as 12 dBu: 173 174 .. image:: media/calibration/scarlett-instrument-input-doc.png 175 :align: center 176 :scale: 50 % 177 178 *Figure: Instrument input specifications, from the manual for the* 179 `Focusrite Scarlett 18i20 4th Generation <https://downloads.focusrite.com/focusrite/scarlett-4th-gen/scarlett-18i20-4th-gen>`_ 180 *.* 181 182 This is specifically for when the interface is set to **minimum gain**; if you 183 adjust (increase) the gain when recording to get a bigger waveform when 184 recording, then this will *reduce* the dBu at which clipping happens. **If you 185 record with your gain all the way down**, then you can use the manufacturer's 186 specification; but if not, then you should calculate it as above. (You may also 187 find that if you compute measure it yourself, the calibration for your own 188 interface's inputs may be slightly different from the manufacturer's spec.) 189 190 Providing the calibration in the metadata 191 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 192 193 Once you've figure out the calibration levels for your recording, you can 194 provide them as metadata when making your model. Using the numbers from above, I 195 would write this: 196 197 .. image:: media/calibration/metadata-gui.png 198 :align: center 199 :scale: 50 % 200 201 *Figure: Metadata for the local GUI-based trainer.* 202 203 A note on updating old model files 204 ---------------------------------- 205 206 If you know the levels from a model that you made previously, you can update 207 old files to include this metadata. ``.nam`` files conform to the JSON file 208 format and can be edited as plain text. If you want to do this, you can make a 209 new model and use it as a reference for how to add the new metadata fields to 210 your old files. Look for the fields ``"input_level_dbu"`` and 211 ``"output_level_dbu"`` in the new file and copy them to your old file in the 212 corresponding location, changing the numbers as necessary. (If you only know 213 one, then you can leave the other as `null`.) As always, it's recommended to 214 save a backup of your file before you being editing it in case you make a 215 mistake. 216 217 Appendix: Conversion table between RMS voltage and dBu 218 ------------------------------------------------------ 219 220 +-----------------+-----------------+ 221 | RMS Voltage (V) | dBu | 222 +=================+=================+ 223 | 0.8 | 0.0 | 224 +-----------------+-----------------+ 225 | 0.9 | 1.0 | 226 +-----------------+-----------------+ 227 | 1.0 | 2.0 | 228 +-----------------+-----------------+ 229 | 1.1 | 3.0 | 230 +-----------------+-----------------+ 231 | 1.2 | 4.0 | 232 +-----------------+-----------------+ 233 | 1.3 | 4.5 | 234 +-----------------+-----------------+ 235 | 1.4 | 5.0 | 236 +-----------------+-----------------+ 237 | 1.5 | 6.0 | 238 +-----------------+-----------------+ 239 | 1.6 | 6.5 | 240 +-----------------+-----------------+ 241 | 1.7 | 7.0 | 242 +-----------------+-----------------+ 243 | 1.8 | 7.5 | 244 +-----------------+-----------------+ 245 | 1.9 | 8.0 | 246 +-----------------+-----------------+ 247 | 2.1 | 8.5 | 248 +-----------------+-----------------+ 249 | 2.2 | 9.0 | 250 +-----------------+-----------------+ 251 | 2.3 | 9.5 | 252 +-----------------+-----------------+ 253 | 2.4 | 10.0 | 254 +-----------------+-----------------+ 255 | 2.6 | 10.5 | 256 +-----------------+-----------------+ 257 | 2.7 | 11.0 | 258 +-----------------+-----------------+ 259 | 2.9 | 11.5 | 260 +-----------------+-----------------+ 261 | 3.1 | 12.0 | 262 +-----------------+-----------------+ 263 | 3.3 | 12.5 | 264 +-----------------+-----------------+ 265 | 3.5 | 13.0 | 266 +-----------------+-----------------+ 267 | 3.7 | 13.5 | 268 +-----------------+-----------------+ 269 | 3.9 | 14.0 | 270 +-----------------+-----------------+ 271 | 4.1 | 14.5 | 272 +-----------------+-----------------+ 273 | 4.4 | 15.0 | 274 +-----------------+-----------------+ 275 | 4.6 | 15.5 | 276 +-----------------+-----------------+ 277 | 4.9 | 16.0 | 278 +-----------------+-----------------+ 279 | 5.2 | 16.5 | 280 +-----------------+-----------------+ 281 | 5.5 | 17.0 | 282 +-----------------+-----------------+ 283 | 5.8 | 17.5 | 284 +-----------------+-----------------+ 285 | 6.2 | 18.0 | 286 +-----------------+-----------------+ 287 | 6.5 | 18.5 | 288 +-----------------+-----------------+ 289 | 6.9 | 19.0 | 290 +-----------------+-----------------+ 291 | 7.3 | 19.5 | 292 +-----------------+-----------------+ 293 | 7.7 | 20.0 | 294 +-----------------+-----------------+