GRIM SYNC - Advanced REAPER to Wwise Bridge System

게임 오디오

This article was originally published on lkctools.com.

Introduction

This is a short overview of the features of Grim Sync, the latest system to connect REAPER and Wwise. It allows you to define file names, containers, Events, and even object properties. It is possible to import sounds, voices, and music with Grim Sync. The focus is on allowing you to create complex structures directly in REAPER and to iterate quickly. If you are interested in the idea behind the tool and the motivation for creating it, you can read more about it here.

Screen Shot 2023-03-09 at 15.03.53

Basic principle

Grim Sync is based on a custom REAPER workflow called Render Blocks. Those are groups of items, visually and functionally packed into blocks, which allow you to have rendering flexibility, better project organization, automatic naming, and various metatags that affect render settings. Using blocks saves time and speeds up the export process.

img2

Example of packed and named Render Blocks

Tracks & regions as containers

One of the features of Render Blocks is to use the hierarchy of tracks, regions, and metatags to define file names. This way you can create a structure inside an rpp project, and then use it to name the files. If there is more than one file with the same name, they will be indexed. 

Track Hierarchy:
        Dragon
        Fire
                Burst
                Sizzle

Resulting file names:
        Dragon_Fire_Burst.wav
        Dragon_Fire_Sizzle_01.wav
       
Dragon_Fire_Sizzle_02.wav
       
Dragon_Fire_Sizzle_03.wav

img3

Example of Render Blocks named using track + region nesting

You can also choose the order in which you want the file name to be created using different formulas.

img4

Various AutoNaming formulas

With Grim Sync, the idea is to use the same structure to create Wwise containers.

Example:
        [a]Dragon
                [r]Fire
                        [b]Burst
                        [sq]Sizzle

Results:

  • FILE: Dragon_Fire_Burst.wav
  • PATH: \<Actor-Mixer>Dragon\<Random Container>Fire\<Blend Container>Burst\<Sound SFX> Dragon_Fire_Burst
  • FILE: Dragon_Fire_Sizzle.wav
  • PATH: \<Actor-Mixer>Dragon\<Random Container>Fire\<Sequence Container>Sizzle\<Sound SFX> Dragon_Fire_Sizzle

There are different prefixes that represent various Wwise objects, including music containers.

  • [wu] - Work Unit
  • [f] - Virtual Folder
  • [a] - Actor-Mixer
  • [r] - Random Container
  • [sq] - Sequence Container
  • [sw] - Switch Container
  • [b] - Blend Container
  • [msw] - Music Switch Container
  • [mpl] - Music Playlist Container
  • [msg] - Music Segment

You can add these prefixes to track/region names manually, but there are also toolbar and shortcut actions that you can use to speed up the process.

img5

Custom Grim Sync actions toolbar in REAPER

Special red actions allow you to ignore specific tracks/regions so their names are not included in the resulting file name or hierarchy.

Once you are done with naming, you can run Grim Manager.

Using Grim Manager 

The manager is there for a number of reasons: to see the list of audio files to be rendered; to preview the designed Wwise hierarchy; to create Play and Stop Events from specific containers/sounds, and to validate existing links to the Wwise objects.

img6

Grim Manager showing structure and audio files

Invalid Structures

If you try to create a hierarchy that is not possible inside Wwise, for instance, an Actor-Mixer inside an Interactive Music Hierarchy, you will get an error and syncing will not be allowed until you fix the problem.

img7

Actor-Mixer is not allowed within the Interactive Music Hierarchy

Creating Events

Events can be created automatically from all objects except Work Units, Virtual Folders, and Actor-Mixers. You can simply check the box next to the container and you will see the resulting Event name inside the Event List section. Additionally, you can define which Events will have a corresponding Stop Event, which is helpful for loops. Event prefixes and suffixes can be defined within project settings.

img8

Three Events will be created from two containers and one sound

img9

Two Stop Events will be created for respective Play Events

Running GRIM SYNC action

Once we are satisfied with our sound design and structure design, we can click the GRIM SYNC button. This will render all files, import them to Wwise, and create containers and Events.

img10

Resulting hierarchy in Wwise

Iterating with ReaOpen

When you decide that some sounds in Wwise need to be reworked, you can simply right-click them and call ReaOpen. It is a separate and free tool that works by finding the original sound inside REAPER. 

img11

ReaOpen context menu

The cool thing is that, even if REAPER isn’t open, the tool will run the program, open the corresponding rpp project, and find the original sound. You can then edit the sound and run the GRIM SYNC action again, and the sound will be updated inside Wwise.

Customizing Import Locations

By default, all sounds will use Actor-Mixer Hierarchy\Default Work Unit as a root import location. However, you can use link regions, or link tracks to specify the custom location where you would like to create the structure. They can be defined for Event root location as well.

img12

Wwise Link Region

img13

Wwise Link Track

Linking sounds to Wwise objects

This feature allows users to permanently link blocks to Sound SFX objects within Wwise. This accomplishes two things. First, it allows ReaOpen to find original blocks even if you changed their location inside the timeline of a REAPER project. Secondly, it allows for changing the structure in Wwise. You can move sounds to different places, create parent containers, and even rename Sound SFX objects without losing the connection to the original REAPER sound.

img14

Exported and linked blocks

Validation Process

This process is what allows linked sounds to be so flexible. Validation runs through track/region links and also through linked blocks and then checks in Wwise if these links are still valid. Since links are based on GUID (a unique id dedicated to each Wwise object), the validation process will report errors only when objects have been deleted from Wwise.

img15

Block after failed validation process

img16

Details of the validation report

Wwise Metatags

Metatags are a Render Blocks feature that allows you to specify certain render settings per block. For example, you can render mono, stereo, and surround audio files at the same time. You can specify desired loudness, or how long the tail should be.

img17

Render Blocks with multiple metatags defined

Wwise Metatags are the same, but they affect Wwise Sound object properties like Volume, Pitch, Lowpass, Highpass, InitialDelay, etc. They are defined with a hashtag (#) prefix.

img18

Naming editor specifying Wwise Metatags

img19

Resulting changes in the Wwise Sound SFX object

Defining Metatags is possible per Render Block and all properties listed in the Wwise documentation should be available (except for read-only values).

Creating Timeline Group

Using Wwise Metatags and a special REAPER action called Add timeline delay metatags to selected blocks, you can keep a relative temporal relationship between a group of sounds in REAPER.

img20

Timeline group created by using a custom script

After importing to Wwise, you can use them within a Blend Container to get the same resulting sound without baking silence into your assets.

img21

Sounds will retain their relative temporal relationship

Smart Subpaths

There are two types of Smart Subpaths, one for the Originals, and one for Events. The idea behind both of these is to define a set of container types that will be taken into account when choosing where in the Originals folder to import sounds, or where in the Events hierarchy to create Events. The goal is to partially or fully mirror the container hierarchy within the Originals/Events hierarchy.

img22

Track hierarchy in REAPER with predefined container types

img23

Smart Originals Subpath settings

img24

Resulting hierarchy in Wwise

img25

Smart Originals Subpath affecting audio file locations

img26

Smart Events Subpath affecting Event locations

In short, the Smart Subpaths feature allows you to predefine the level of depth that you want to keep for Originals/Events, and once you decide that, your job is done; everything will be done automatically. However, caution is advised when changing structure in Wwise post-import because that will also affect how Smart Subpaths work, so be careful.

Single Items & NVK Folder items

Although Grim Sync is based on Render Blocks, there is also support for single items and NVK Folder items. The prerequisite for those to be detected by Grim Manager is to name them with @ prefix. The idea behind this is to allow people who are not used to the Render Blocks workflow to still benefit from Grim Sync.

img27

Single items named with @ prefix

img28

NVK Folder items named with @ prefix

Conclusion

Since games are becoming more complicated and larger every year, there is an overwhelming need for optimizing all production workflows, including audio. Game audio still suffers from the legacy of tools that were originally created for music production and post-production of linear media. Grim Sync is an attempt to evolve the communication between DAWs and middleware by introducing features that allow flexibility and automation. Hopefully, it will help sound designers focus more on creating awesome sounds and spend less time on manual tasks like naming, dragging, clicking, and scrolling. Grim Sync has a free version, so if you are interested in trying it for yourself, you are more than welcome to do so.

Nikola Lukić

Technical Sound Designer and Creator

LKC Tools

Nikola Lukić

Technical Sound Designer and Creator

LKC Tools

Nikola Lukić is a technical sound designer and a creator of LKC Tools. In his free time, he is developing various tools, tips, and tutorials for sound design, game audio, and music production. It is a passion project and Grim Sync is the latest result of that passion.

lkctools.com/

 @lkctools

댓글

Andres Alvarez

March 09, 2023 at 08:52 pm

I am a heavy user of Grim Sync and i can recommend it to every Reaper user to improve the workflow!

댓글 달기

이메일 주소는 공개되지 않습니다.

다른 글

머더러스 퍼수츠(Murderous Pursuits)의 대사와 대화 설계 - 제 1부

안녕하세요 여러분. 저는 Blazing Griffin(블레이징 그리핀)의 게임 팀의 오디오 디자이너인 제이미 크로스(Jaime Cross)입니다. 저희는 몇 달 전에 머더러스...

5.5.2020 - 작성자: 제이미 크로스(JAIME CROSS)

Mastering Suite(마스터링 스위트)의 비하인드 스토리: 게임 내 오디오 마스터링

Mastering Suite 는 게임 산업의 크리에이티브와 엔지니어들이 일련의 협력을 통해 얻은 결과입니다. 수년간 PlayStation은 게임 오디오 개발자 커뮤니티와 협력하여...

23.7.2020 - 작성자: 단젤리 솀브리 (DANJELI SCHEMBRI )

Wwise 미디 기본 지식: 뉴 슈퍼 럭키스 테일(New Super Lucky Tale)의 폭스베리 타이머 음악적 미디 마법!

안녕하세요 멋진 Wwise 사용자분들 :) 게임 오디오 업계에서 살아남기 위한 필수적인 스킬은 바로 문제를 해결하는 능력입니다. 사용하는 도구의 크고 작은 모든 면을 아는 것은...

8.2.2021 - 작성자: 애론 브라운(AARON BROWN)

새로운 Impacter 플러그인 알아보기

개요 Impacter(임팩터)는 기존의 SoundSeed Impact 플러그인을 영감으로 하는 새로운 음원 플러그인입니다. 이 플러그인은 '타격음' 사운드 파일을 저작 도구로...

20.5.2021 - 작성자: 라이언 돈 (RYAN DONE)

텔 미 와이(Tell Me Why) | 오디오 다이어리 제 2부: 음악

Tell Me Why의 음악은 본질적으로 캐릭터의 서사와 감정을 뒷받침하도록 설계되었습니다. 게임의 이야기는 두 주인공에게 아주 자세하게 집중되어 있으며 생각에 잠기기 쉬운 느린...

23.6.2022 - 작성자: 루이 마르탱 (Louis Martin)

Wwise를 사용한 반복 재생 기반 자동차 엔진음 디자인 | 제 1부

이 시리즈에서는 Wwise Authoring과 오디오 및 자동차 전문 지식을 알맞게 사용해서 간단한 반복 재생 기반 자동차 엔진 사운드를 디자인하는 방법을 살펴보려고 합니다! ...

18.4.2023 - 작성자: 아르토 코이비스토 (Arto Koivisto)

다른 글

머더러스 퍼수츠(Murderous Pursuits)의 대사와 대화 설계 - 제 1부

안녕하세요 여러분. 저는 Blazing Griffin(블레이징 그리핀)의 게임 팀의 오디오 디자이너인 제이미 크로스(Jaime Cross)입니다. 저희는 몇 달 전에 머더러스...

Mastering Suite(마스터링 스위트)의 비하인드 스토리: 게임 내 오디오 마스터링

Mastering Suite 는 게임 산업의 크리에이티브와 엔지니어들이 일련의 협력을 통해 얻은 결과입니다. 수년간 PlayStation은 게임 오디오 개발자 커뮤니티와 협력하여...

Wwise 미디 기본 지식: 뉴 슈퍼 럭키스 테일(New Super Lucky Tale)의 폭스베리 타이머 음악적 미디 마법!

안녕하세요 멋진 Wwise 사용자분들 :) 게임 오디오 업계에서 살아남기 위한 필수적인 스킬은 바로 문제를 해결하는 능력입니다. 사용하는 도구의 크고 작은 모든 면을 아는 것은...