Skip to content
forked from ccrma/chunreal

ChucK in Unreal Engine, Updated to 5.5 with Harmonix Midi Stream support.

License

Notifications You must be signed in to change notification settings

Amir-BK/chunreal

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

2024-10-12.18-08-36.mp4

Support and Feedback (for this fork) https://discord.gg/EWFKWTz3

Status:

2024-10-04.11-40-28.mp4

ChucK Processors can now be applied as Source and Submix effect in preset chains.

2024-09-30.11-07-22.mp4

Real time parameter getters and setters within metasounds -

2024-10-05.18-36-52.mp4

Execute and Listen to Chuck events from BP or metasounds -

2024-10-07.11-08-14.mp4

Purpose of fork -

This fork encapsulates the chunreal repo as a plugin and makes some changes to the way the ChucK classes interact with Unreal.

The UChuckProcessor is a UObject that can be created as an asset in the editor where ChucK code can be input (with a work in progress syntax highlighter), this object has an audio object proxy and a registered meta sound data type and can be passed directly to the new Chuck Midi Renderer metasound node, the ChucK is compiled when the object proxy is created and thus should be able to play once assigned to the metasound node.

This repo is a work in progress and some aspects are still not working really well and might require redesign.

The end result should be reusable chuck assets that can be used inside metasounds with no BP setup and without needing to trigger compilation on the audio thread, making it simple to use ChucK components as instruments or effects in metasounds or in unDAW: https://github.com/Amir-BK/unDAW

New workflow!

I split the Chuck asset into two asset types, one is UChuckCode which represents a block of chuck code, either as a proxy to a file on disk (automatically created via the editor module) or just a text block, this asset can spawn a transient UChuckInstantiation object which is compiled upon its creation, the UChuckInstantiation actually owns the ChucK vm pointer and is used to render audio, there are BP methods that compile a UChuckCode to a UChuckInstantiation as well as a metasound node that does the same thing, thus allowing the user to create the chuck instance either fully inside metasounds or in BP/CPP, the chuck instance can then be manipulated via set/get parameter calls and will automatically recompile when the code in the UChuckCode object it was created from is updated.

As well as the metasound nodes a UChuckSynth component and ChuckSourceEffect and ChuckSubmixEffect classes are provided that can play chucks and manipulate them.

Automatic monitoring of chuck source files

The ChunrealEditor module monitors the working directory (inside the plugin folder) for .ck files and will automatically create chuck processor assets for these sources, changes to the source files are tracked and will trigger recompilation of chuck vms using these proxies, this is still a work in progress but there are many advantages to keeping the chucks as source files outside unreal, primarily being able to add them to source control and easily editing them from text editors outside unreal.

At the moment (a matter of days if not hours) it is the 'Chuck Project Editor' that monitors the directory rather than the module itself, the plan is not to have any dependencies on Editor Only functionality so that these chuck sources can also potentially be exposed and modified in packaged games at runtime.

This system also allows keeping the .ck files as source files outside unreal, for more easily working with revision control, right now the Chuck working directory is set to a directory inside the plugin folder, it can be changed in code, eventually I'll expose it in the project settings.

pseudo-includes and unreal discovery

As before ChucK 1.5.4 the only way to import files was using the machine.add command inside chuck I created a rudimentary framework to include chuck files and discover them in unreal, to make the chuck compiler ignore these directives they are marked in comments in the .ck file, as the plugin is still not updated to the new chuck version and as the new @import directive is not fully equivalent to the old machine.add for now these psuedo-includes are still used.

//UCHUCK(); -- Marks the chuck file for discovery in unreal
//UINSTRUMENT(); -- marks the file as an instrument, right now this doesn't make much of a difference but might help with categorization and search within unreal
//UINCLUDE("ABK-HmxMidi/HmxMidi.ck"); -- an example of an include directive that executes 'machine add' before the the main chuck file is executed.

Receiving harmonix midi streams in chuck instruments

The HmxMidi.ck is a simple chuck class that exposes three global int arrays and some methods for interactions with the harmonix midi stream similar to the standard MidiIn object, it needs to be included as a UINCLUDE in the chuck file, afterwards it can be used like this in order to trigger notes in the:

//UINCLUDE("ABK-HmxMidi/HmxMidi.ck");

global HmxMidiIn HarmonixMidi;
MidiMsg msg;

while( true )
{
    HarmonixMidi => now;

    while(HarmonixMidi.recv(msg))
    {
       if(HarmonixMidi.IsStdNoteOn(msg))
       {
        //NoteOn(msg.data2, msg.data3);
        //Do note on stuff 
       }
       else if(HarmonixMidi.IsStdNoteOff(msg))
        {
        //NoteOff(msg.data2);
        //Do note off stuff 
        }
    }

}

The polyphonic instrument framework uses Jack Atherton's TimbreLibrary classes as a framework and several of his instruments are included.

Chugins

Chugins should be added to the appropriate folder in the working directory, I included the compiled chugins for win64 but for other platforms they needed to be added, some of the instruments use GVerb so they might not work on Macos unless you add the mac chugins to the build.cs file for the chunreal module.

Manual creation (to be redesigned - Section oudated)

Instead of assigning the code via blueprints there's a new 'Chuck Processor' asset that can be created via the content browser - image

ChucK code can be added to this asset: image

Once this asset has been created and saved it can be used in a Metasound using the new Chuck Midi Renderer Node, despite its name this node doesn't have to be used with Midi, although at the moment it is not being assigned a ChucK global id and thus can only receive new params via midi, this will be fixed soon. image

2024-09-27.10-55-13.mp4

Currently the midi renderer is not polyphonic, working on that, the midi renderer node executes the 'noteEvent' and 'noteFreq' params on the chuck instance whenever it reads a note from the harmonix stream, you can see how to set up a simple instrument in the example midi renderer chuck processor provided in the project.

With these changes it is possible create re-usable chuck processor assets and use them in metasounds (as midi instruments or effects) without needing to interact with the metasound from blueprints.

All previously existing Chunreal nodes and methods still work.

The changes also make it possible to use Chunk instruments and effects easily with unDAW and the metasound builder system - check out the unDAW repo - https://github.com/Amir-BK/unDAW

2024-09-27.11-37-25.mp4

Loading samples and files from disk

The 'working directory' is currently set to "chunreal/WorkingDirectory" but when you try to load a sample with a relative unqualified path it will still search for it in the engine binary folder, you can make chucK look for samples in the working dir with the following syntax:

me.dir() + "kick_01.wav" => kick.read;

the working directory path can be changed in code, it is assigned to the ChucK when it is instantiated (so in the midi renderer node code), it can be exposed as a config variable and assigned per project, I'll eventually get to that, for now the WorkingDirectory inside the plugin seems usable.

Chunreal

ChucK - Strongly-timed Music Programming Language - in Unreal Engine 5

Chunreal is a plugin for Unreal Engine 5 that allows users to compile ChucK code at runtime. Multiple ChuckMain nodes can be chained in a MetaSound graph using stereo input & output to perform modular synthesis style digital signal processing.

Developed by Eito Murakami and Ge Wang with the help of Max Jardetzky at CCRMA | Stanford University.

Wiki Tutorial!

The Wiki page contains a step-by-step tutorial that demonstrates how to set up the Chunreal plugin in your Unreal Engine project.

https://github.com/ccrma/chunreal/wiki

Template Project

This repo contains all the content from the original Chunreal repository only encapsulated inside the plugin package, all the example content can be found inside the plugin's content folder, there's also a midi file to test the new node with.

Try Example Scenes!

Try opening the following example levels and playing in the editor viewport!

  • Chunreal_SetGlobals_ExampleLevel
  • Chunreal_ChainedDSP_ExampleLevel
  • Chunreal_1Source_ExampleLevel
  • Chunreal_ManySources_ExampleLevel
  • Chunreal_Physics_ExampleLevel
  • Chunreal_Mic_ExampleLevel
  • Chunreal_GlobalEvent_ExampleLevel
  • Chunreal_PitchChange_ExampleLevel

How To Use Chunreal

Setting Up ChuckMain Node

Chunreal_Simple_MetaSound asset contains an example of ChuckMain node implementation in a MetaSound source.

Input

  • Run Code: A trigger input for compiling ChucK code.
  • Code: A string input for ChucK code to be compiled.
  • ID: A string input for assigning a unique ID to a ChuckMain node. This is used to get and set global variables for a specific ChucK instance.
  • Audio Input Left: Audio input left channel. Can be accessed by adc.left inside a ChucK code.
  • Audio Input Right: Audio input right channel. Can be accessed by adc.right inside a ChucK code.
  • Volume Multiplier: A float input for applying a volume multiplier to both output channels.

Output

  • Audio Output Left: Audio output left channel. Can be accessed by dac.left inside a ChucK code.
  • Audio Output Right: Audio output right channel. Can be accessed by dac.right inside a ChucK code.
image

Set Parameters From A Blueprint Actor

Create a Blueprint actor, attach an audio component, and assign your MetaSound source that contains a ChuckMain node(s) as the sound parameter. Optionally, enable Allow Spatialization and apply Attenuation Settings. We prepared an example Binaural_SA sound attenuation asset.

Chunreal_Simple_BP asset provides a template.

image

A ChucK code can be written as a string and can be passed to the Audio Component that uses the MetaSound source as follows:

image

Alternatively, we prepared a ReadFile Blueprint function for loading a .ck file using an absolute path.

image

Getting & Setting ChucK Global Variables Using ID

A specific ChucK instance can be accessed using its assigned unique ID. Global event, int, float, and string variables can be accessed using the following Blueprint functions. To learn how to use each function, open each Blueprint Actor in ExampleBlueprints folder.

image

Connecting Multiple ChuckMain Nodes

Multiple ChuckMain nodes can be chained in a MetaSound source and can interact with other existing MetaSound nodes!

Chunreal_ChainedDSPExample_MetaSound and Chunreal_ChainedDSPExample_BP provide a template.

image

ChucK Community

Join us!! ChucK Community Discord | ChucK-users Mailing list

About

ChucK in Unreal Engine, Updated to 5.5 with Harmonix Midi Stream support.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C++ 73.8%
  • C 23.7%
  • ChucK 1.7%
  • Yacc 0.5%
  • Lex 0.2%
  • C# 0.1%