The RED R3D codec is high demanding in terms of resources, these are some recommendations.
- Set Performance->Pipe Units and Performance->IO Threads, to the numbers of cores of your system, with a maximum of 32 (higher values than 24 or so do will probably not improve speed significantly, and may increase latency and RAM usage).
Note: A value of 0 can also work well, as it means auto-configuration (which will use the above values).
- Check that Codecs->RED->GPU frames (parallel processing insiide the GPU) is set to the recommended value: 3 for NVidia Quadro boards. 2 for GeForce and everything else, except very old and small gpus which are better with 1.
- Set mConfig->Codecs->RED->ReduceFactor to a value that permits to work in realtime in your system. The default is 2 (1:2 factor) but depending on the codec variant and the system hardware you may need to set this value to 4 or even 8. This purpose of the reduce factor is to permit much faster speed by asking the codec to decode at smaller resolutions. Please note that the value that you set in here will be used by the R3DParams effect by default (while its parameter ReduceFactor = mConfig). But you can change it later as explained below.
The idea here is to use fast decoding for interactive speed and playbacks, and later set R3DParams->Reduce Factor to 1:1 for the final render or when you need top quality. Also please note that in many cases 1:2 can be enough even for the final render. For example if your master is HD , decoding at 8K 1:1 is usually a waste of resources.
In the Timeline, apply R3DParams effects to all your R3D clips. This effect controls the image extraction from the camera raw codec. When you need to go back and forth between high/low quality you can simply change the Reduce factor parameter in all the R3DParam effects in the timeline at the same time. You can do this with the VisualEditor->Propagate function (make the change in one R3DParams effect, select the reduce factor parameter, and press Propagate->All)
Full resolution proxies and multilayer groups.
For the R3D codec it does not make sense to pre-render low resolution proxies because you can always create them on the fly (by changing the reduce factor as explained above). But depending on your workflow it may be worth it to pre-render full resolution proxy versions. A full resolution render provides the full quality and also realtime performance. The only disadvantage is that you can not change the camera extraction settings on them (mainly the color science related settings of the raw codec, so try to get this right before the render). But Mistika multilayer groups provide a fast way to switch between the raw codec and the full resolution proxy, so ayou can always go back to the raw coded if needed. This workflow works as follows:
1 - Apply R3DParams to all your r3d clips, and let the reduce factor still at low quality for interactivity and realtime (1:2, 1:4, or 1:8 ). Try to do the most part of the conform at this stage to discard unused shots. This is to avoid rendering full resolution proxies for clips that are not really necessary, as those renders will be slow.
Also remember that you also have the Edit->Macros->LoadRawParams to load the camera settings that were decided on set. If you plan to use them execute this function before rendering the proxies.
2 - Set reduce factor to what you consider full quality for your project ( 1:1 or 1:2), and use VisualEditor->Propagate->All to switch all R3DParams to that setting. Then select all your clips, and render them in Split to segments mode (which permits to create one render per clip, You also have options to keep same names and timecodes as the originals).
For this render chose a codec that you can conformable playback in your systems. If your storage is fast enough then use Mistika .js codec. It is normally the fastest one and it is full quality uncompressed, also matching whatever master format (or reference monitor) you want, either YUV or RGB, 422 or 444, and 10 bit or HDR 16bit ), so once you have the clips in this format you will probably not need to use the raw R3D originals anymore.
But the Mistika .js format requires a fast storage, if the storage is not fast enough for Mistika .js then you can use Prores (it is realtime in almost any decent storage, although it compress images so you may need to switch back to r3d more often and also for the final render). Another good option is EXR DWA, which is quality lossless and very appropriated for collaborating with VFX applications, although it requires more CPU resources to work in realtime.
3- After the render you will find the proxy versions on top of the R3D clips. Now select all those clips in all tracks and create their groups them Edit->Macros->Group Segments. This function will create one group per segment, with both the R3D original and the proxy clip inside the group.
4- Each of these groups contains two independent layers ( as there is no effect connecting the rendered clip to the rest of the stack). In these cases, the group will only export the upper layer by default. But there is a handy tool to decide which layer you want use: When you want to switch between the raw version and the rendered proxy, select the affected groups and use Edit->Groups->UseLayer (options).
Please note that if for some reason you need to change the R3D params image extraction of any shot its rendered proxy will become obsolete, so you will want to render that proxy again. This workflow is mainly useful when this does not happen too often, which is the normal case.
Tips & Tricks
The interface also provides some tricks for additional interactivity in complex situations:
- Press shift while moving the monitor head will mute evaluation until shift key is released
- For permanent mute during long periods, press the V button (mute video).
- Set RecordMonitor->Menu.>Resolution to Dynamic mode, it will show full resolution on pause, but half resolution while doing playbacks. You will also find the same button in the VisualEditor
- The Edit->Setup->MuteMovingClips will mute the evaluation while dragging clips over the Timeline