neural-amp-modeler

Neural network emulator for guitar amplifiers
Log | Files | Refs | README | LICENSE

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 +-----------------+-----------------+