Some things may be incorrect, missing or broken. We are bit-by-bit filling in the gaps ahead of version 1.0.0.
Streamlined sample-based instrument platform
Floe lets you find, perform and transform sounds from sample libraries — from realistic instruments to synthesised tones. No-hassle, open-source and always free.
Floe is an engine, it requires sample libraries to play.
Alpha version of Floe’s GUI showing multiple libraries loaded.
Create expressive sounds
Floe loads libraries in the Floe format, and provides an intuitive interface for shaping, layering and performing the library’s sounds. It’s a powerful audio plugin for sound design, music production and live performance. It excels at enabling exploration between realistic multi-sampling and sample-based synthesis.
It’s based on an architecture of 3 sound layers that can be shaped and blended together, and additionally processed with a rack of built-in effects. It features comprehensive systems for discovering sounds and presets, and for creating your own sample libraries (programming required).
Widely compatible
It’s available as a plugin for your DAW (CLAP, VST3 and AU) on Windows and macOS. It’s free and open-source and always will be due to its GPL licence. There’s no lock-in, no sign-up, no nagging, just a focus on helping you make music.
Built on a solid foundation
Floe’s ancestor, Mirage, has been used by thousands of musicians and producers, professional and indie, in 13 products. Floe is the next step in the evolution of Mirage, with a focus on developing a hassle-free platform for new sample libraries.
Ongoing development
Floe is an ongoing project. We plan to expand its capabilities while always maintaining backwards compatibility. We’re always open to feedback and suggestions. By consolidating our efforts into improving this engine, we improve the capabilities of all its libraries.
Developed by the creator of FrozenPlain. FrozenPlain offer a range of sample libraries that will be updated to support the Floe format. We’re hoping to see other developers adopt the format too.
Floe’s mission
- Make sample libraries more expressive, playable and effective in music production.
- Lengthen the lifespan of sample libraries by providing a open-source platform for them with no lock-in.
- Prioritise helping people make meaningful music; not technical hassle, commercial pressure or unnecessary complexity.
About this website
This website contains everything you need to know about Floe. It’s presented in a book-like format, with chapters in the sidebar.
If you’re viewing this online, you might find the search feature useful: open it by clicking the magnifying glass icon at the top of the page. Additionally, there is a printer icon in the top right for either printing this book, or saving it to a PDF.
Requirements
Windows
On Windows, Floe is available in the CLAP and VST3 formats. We recommend using the CLAP version where possible. Requirements:
- Windows 10 or later
- 64-bit computer
- x86-64 processor with SSE2 support (almost all processors in a Windows PC since ~2006 have this)
- 64-bit CLAP or VST3 host
macOS
On macOS, Floe is available in the CLAP, VST3 and AU (v2) formats. We recommend using the CLAP version where possible. Requirements:
- macOS 11 (Big Sur) or later
- Apple Silicon or Intel (Floe is a universal binary)
- CLAP, AU (v2) or VST3 host
Plugin Hosts (DAWs)
Here are some examples of plugin hosts that can run Floe. There are many more than this.
- CLAP hosts on Windows & macOS: Reaper, Bitwig, FL Studio (2024 or newer) and Studio One Pro (v7 or newer).
- VST3 hosts on Windows & macOS: Cubase, Ableton Live, Reason, and more.
- AU hosts on macOS include: Logic Pro, GarageBand, and more.
Not supported
Just for clarity: there’s no Linux, no ‘standalone’ application and no AAX (Pro Tools) support. We hope to expand Floe’s compatibility in the future.
We are bit-by-bit filling in the gaps ahead of version 1.0.0.
Download & Install Floe
There’s two ways to install Floe: use the installer, or manually move files.
Either way, Floe is backwards-compatible. This means that you can replace an old version of Floe with a new version and everything will work.
Check the requirements before downloading. After installing Floe, you might want to install sample libraries or develop your own (programming required).
The latest released version of Floe is v0.0.2.
Installer
Floe Installer Windows: Download Floe-Installer-v0.0.2-Windows.zip (7 MB)
Floe Installer macOS: Download Floe-Installer-v0.0.2-macOS.zip (6 MB)
Download, unzip, and run the installer program. The installer will guide you through the installation process, including choosing the plugin formats you want to install.
Once the installation is complete you might need to restart your DAW in order for it to find the Floe plugins.
Manual Installation
Floe Manual Install Windows: Download Floe-Manual-Install-v0.0.2-Windows.zip (6 MB)
Floe Manual Install macOS: Download Floe-Manual-Install-v0.0.2-macOS.zip (6 MB)
Normally you’ll want to use the installer, but there could be some cases where you’d prefer to install Floe manually. To allow for this, we provide a zip file that contains Floe’s plugin files. Extract it and move the files to your plugin folders.
Windows:
- CLAP: Move
Floe.clap
intoC:\Program Files\Common Files\CLAP
- VST3: Move
Floe.vst3
intoC:\Program Files\Common Files\VST3
macOS:
- CLAP: Move
Floe.clap
into/Library/Audio/Plug-Ins/CLAP
- VST3: Move
Floe.vst3
into/Library/Audio/Plug-Ins/VST3
- AU: Move
Floe.component
into/Library/Audio/Plug-Ins/Components
Download links can also be found on the Github releases page.
Installing Libraries & Presets
Floe installs libraries and presets from ZIP files called Floe Packages.
Simply click the ‘Install package’ button in Floe’s settings panel and direct it to the package ZIP file. It will extract the libraries and presets into the correct folders. No need to restart Floe.
Here’s the full details
- Open Floe.
- Open the Settings panel using the gear icon at the top.
- Open the Packages tab.
- Click the ‘Install package’ button and direct it to the package ZIP file.
- Done. After installation, you may delete the ZIP file. No need to restart Floe.
Manually installing
Alternatively, you can manually install libraries and presets by extracting the ZIP file into the correct folders.
- Extract the package ZIP file (floe.zip).
- Open Floe.
- Open the Settings panel using the gear icon at the top.
- Open the Folders tab.
- Here you can control which folders Floe looks for libraries and presets in. Copy/move the contents of this package’s Libraries into one of Floe’s library folders, and the same for Presets into one Floe’s presets folder.
- Done. No need to restart Floe.
Uninstalling
Floe doesn’t yet have an uninstaller program. But you can manually uninstall it by deleting Floe’s files.
Delete libraries and presets
- Open Floe
- Click on the cog icon at the top.
- Open the ‘Folders’ tab.
- For each of the paths click the ‘open folder’ icon: . This will open the folder in your file manager.
- Delete all files in the folder.
Repeat this for each folder in Floe settings panel.
Delete settings and plugins
Settings are tiny files that store your preferences. Plugins files are normally ~15 MB in size.
Windows
- Settings:
C:\Users\Public\Floe\Settings
- CLAP:
C:\Program Files\Common Files\CLAP\Floe.clap
- VST3:
C:\Program Files\Common Files\VST3\Floe.vst3
macOS
- Settings:
/Users/Shared/Floe/Settings
- CLAP:
/Library/Audio/Plug-Ins/CLAP/Floe.clap
- VST3:
/Library/Audio/Plug-Ins/VST3/Floe.vst3
- AU:
/Library/Audio/Plug-Ins/Components/Floe.component
Mirage locations (legacy)
If you used to have Mirage installed then some additional files may be present.
Windows
- Settings:
C:/Users/<your-name>/AppData/Local/FrozenPlain/Mirage
- Settings:
C:/ProgramData/Mirage/Settings
macOS
- Settings:
/Users/your-name/Music/Audio Music Apps/Plug-In Settings/FrozenPlain
- Settings:
/Library/Application Support/FrozenPlain/Mirage/Settings
Previously known as Mirage
Floe is a continuation of FrozenPlain’s Mirage plugin (developed from 2018 to 2024). It adds new features and improvements but is similar in a lot of ways. Floe is backwards-compatible with Mirage libraries and presets. Mirage will no longer be developed.
Why the name change?
The project has taken a new direction and so we decided to give it a new name.
- Floe is free and open-source, whereas Mirage was closed-source.
- Floe is not directly tied to FrozenPlain. It’s a separate project that’s open to anyone - we want to encourage growth of Floe without being tied to a specific company.
- Mirage is already the name of a hardware sampler from the 80s - we want to avoid confusion.
Backwards-compatible with Mirage
Floe can load Mirage’s libraries, presets and settings file. If you have Mirage installed already, Floe will be able to find the same libraries and presets as Mirage.
You can leave Mirage installed if you want to keep using it: Floe will not interfere with Mirage’s installation.
Floe is a new plugin with a new name and new internals, targeting new plugin formats. Floe can’t replace Mirage automatically in your old, saved DAW projects.
Installation is different
Floe has a new, offline installer. Sample libraries are installed separately using Floe Packages.
Sample Libraries
View your installed libraries by clicking the info button on Floe’s main window.
Open format
Floe uses a custom sample library format which supports the following features:
- Velocity layers
- Round-robin
- Crossfade layers
- Loop points with crossfade
- Convolution reverb IRs
- Velocity layer feathering
- Trigger samples on note-off
It’s an open format consisting of a folder of audio files and a file in the Lua programming language called floe.lua
.
Access to the audio files gives you the freedom to use a library’s sounds in other software too.
Openness is a key goal of Floe sample libraries.
There’s no proprietary file formats. There’s just FLAC, WAV and Lua. By using widely-used file formats we ensure the longevity of libraries.
Floe’s sample library format is designed to be extended. We are planning to add new features to the format while always retaining backwards compatibility.
Where to get libraries
You can use libraries developed by others or you can develop your own. Developing your own libraries does require some basic programming knowledge.
Your library folders
Floe automatically scans for sample libraries in a set of folders. You can configure these folders in Floe’s settings panel, which is opened by clicking the cog icon at the top of Floe’s window. Subfolders are scanned too.
The default library folder cannot be removed, but you can add and remove any other folders you like.
Moving libraries (external drives, etc.)
You may rearrange your libraries in your folders as you see fit. Floe will automatically detect changes and apply them.
For example, you can move your existing libraries to another location (including an external drive):
- Open your library folder by clicking on the link button.
- Use your file manager of choice to copy-and-paste the library folders to your desired new location. Libraries are named something like this: ‘FrozenPlain - Slow’.
- Add this new location to Floe’s settings by clicking the ‘Add Folder’ button and selected the folder you pasted everything to. Remember, Floe scans the entire folder and its subfolders, you don’t need to add each library individually - add the parent folder instead.
Preset Folders
Floe automatically scans for presets in a set of folders - including subfolders. This works in the exact same way as your library folders.
Presets are tiny files and so there’s typically no need to move then to an external hard-drive.
Attribution
Sample library developers can license their libraries in various ways. Most developers use a license that allows you to use the sounds without having to credit them.
However, some sample libraries do require you to credit the creator when you use the sounds in your music. Typically, the requirement is that you include a bit of text along with your music in a reasonable place, such as the description box, album notes, or credits.
The most common licenses that require attribution are the Creative Commons licenses, such as the CC BY license. This license allows you to use the sounds for free, even in commercial projects, as long as you credit the creator.
Floe makes it easy to comply with these requirements. When you use a sound from a library that requires attribution, Floe will show a small icon in the top of the window. Clicking this will show you the exact text that you can copy and paste wherever you need to. Floe synchronises this list of attributions between all instances of Floe that are running, so you only need to do this once.
Example of the attribution GUI in Floe
Roadmap
Floe is an ongoing project that will have lots of backwards-compatible updates. We want to be able to release new features and improvements as soon as they’re ready.
We’re planning to release Floe v1.0 in Q1 2025. Here’s what we’re working on:
- Finish VST3 and AU support
- Complete the GUI for adding multiple libraries to a single instance
- Recreate the presets infrastructure and GUI
- Comprehensive testing of all plugin formats in all DAWs and operating systems
- Prepare a couple of Floe sample libraries ready for release
Later down the line, we’re planning to:
- Refresh the GUI: make it more consistent and performant, and refactor the code for easier expansion
- Overhaul the audio & MIDI processing engine for easier expansion, such as: MIDI MPE, MIDI2, polyphonic modulation, sample-accurate automation, MIDI learn.
- Add more features to the sample library format to allow for more complex instruments: legato, key-switches, drums, etc.
Even further down the line, we’re looking into:
- Allow for creating custom GUIs ‘views’ using the library Lua API
- Adding wavetable oscillators/granular synthesis as a option to layer with sampled instruments
- Adding a more comprehensive modulation system
Give us feedback on these using Github’s discussions section. FrozenPlain also have a Floe section on their forum.
Developing Libraries for Floe
This document explains the details of Floe’s sample library format and how to develop libraries for it. Developing libraries for Floe does require some basic programming knowledge.
Be sure to read the About Sample Libraries page first.
Why a new format?
No existing format met our requirements for Floe, which are:
- Libraries should be plain folders of audio files.
- Libraries should be portable across filesystems & operating systems.
- Libraries should be configured using a proper programming language to enable creating complex libraries in a maintainable way.
- The format should be extensible - allowing us to innovate in the field of sampling.
- The solution should easily integrate into Floe’s codebase.
Simple configuration
This format is designed for configuring audio files into playable instruments. It does not add any programming logic or custom GUIs. Floe has a ready-to-use GUI and lots of audio parameters.
The structure
Let’s look at the structure of a Floe sample library:
📂FrozenPlain - Slow/
├── 📄slow.floe.lua
├── 📄Licence.pdf
├── 📄About Slow.html
├── 📁Samples/
│ ├── 📄synth_sustain_c4.flac
│ └── 📄synth_sustain_d4.flac
└── 📁Images/
├── 📄background.png
└── 📄icon.png
There’s only one essential part of a Floe sample library: the floe.lua
file. This file can also end with .floe.lua
- for example, woodwind-textures.floe.lua
.
The rest of the structure are conventions that are recommended but not required:
- Licence: Sample libraries are recommended to have a file called Licence that describes the terms of use of the library. It can be any format.
- About: A file that describes the library. Any file format. Information about a library is useful for when someone might not have Floe’s GUI available. Use this document to explain what the library contains, website links and any other information that might be useful.
- Library folder name: The folder containing the
floe.lua
file should be named: “Developer - Library Name”. - Subfolders: Subfolders are up to the developer. We recommend ‘Samples’ for audio files and ‘Images’ for images. These can have any number of subfolders. Your
floe.lua
file can reference any file in these subfolders.
The floe.lua
file
The floe.lua
file is the most important part of a library. It’s a script that maps and configures the audio files into playable instruments, written in the Lua 5.4 programming language.
This file uses Floe’s Lua functions to create the library, create instruments, and add regions and impulse responses. It can reference any file in the library using relative paths.
Here’s an example of a floe.lua
file:
local library = floe.new_library({
name = "Iron Vibrations",
tagline = "Organic sounds from resonating metal objects",
library_url = "https://example.com/iron-vibrations",
description = "A collection of resonating metal objects sampled using a handheld stereo recorder.",
author = "Found-sound Labs",
author_url = "https://example.com",
minor_version = 1,
background_image_path = "Images/background.jpg",
icon_image_path = "Images/icon.png",
})
local instrument = floe.new_instrument(library, {
name = "Metal Fence Strike",
folders = "Fences/Steel",
description = "Tonal pluck metallic pluck made from striking a steel fence.",
tags = { "Pluck", "Metallic", "Organic" },
waveform_audio_path = "Samples/file1.flac",
})
floe.add_region(instrument, {
file = {
path = "Samples/One-shots/Resonating String.flac",
root_key = 60,
loop = { 24, 6600, 100, false },
},
trigger_criteria = {
trigger_event = "note-on",
key_range = { 60, 64 },
velocity_range = { 0, 100 },
round_robin_index = 0,
},
options = {
timbre_crossfade_region = { 0, 50 },
auto_map_key_range_group = "group1",
feather_overlapping_velocity_regions = false,
},
})
floe.set_attribution_requirement("Samples/bell.flac", {
title = "Bell Strike",
license_name = "CC-BY-4.0",
license_url = "https://creativecommons.org/licenses/by/4.0/",
attributed_to = "John Doe",
attribution_url = "https://example.com",
})
floe.add_ir(library, {
name = "Cathedral",
path = "irs/cathedral.flac",
tags = { "Cathedral", "Bright" },
})
return library
floe.new_library()
must be called and returned it at the end of the script. All other features are optional. When Floe runs your Lua file, it will show you any errors that occur along with a line number and a description.
How to get started
For now, we’ll assume that you have a folder of audio samples and know what notes they correspond to.
- Create a new folder in one of Floe’s sample library folders. We recommend naming it ‘Author Name - Library Name’.
- Create a file in that folder called
my-library.floe.lua
. - Create a subfolder called
Samples
and put your audio files in there. - Open the Lua file in your text editor. Sublime Text or Visual Studio Code are good choices.
- Use the
floe.new_library()
function to create your library, filling in all the fields marked[required]
in the Floe’s Lua reference. - Use
floe.new_instrument()
to create an instrument, and then add regions to it usingfloe.add_region()
. - At the end of the file, return the library object you just created.
- Floe automatically scans its library folders and will tell you if there’s any errors.
Creating high-quality samples
Levels
It’s important to ensure your audio samples have the the right levels. This makes browsing and switching samples in Floe a consistent, nice experience. Additionally, Floe offers the ability to layer sounds together; this process is more ergonomic when instruments have similar volume levels.
Signet can be a useful tool for changing the levels of your samples.
When changing the volume levels of a realistic multi-sampled instrument, you probably don’t want to normalise each sample individually because part of the character of the instrument is its volume variation. Instead, you should change the gain of the instrument as a whole. Signet has features for this. It also has features for proportionally moving levels towards a target level. This allows you to keep some of the character of an instrument while nudging it towards a more consistent level.
Here are some guidelines for levels:
- Each samples’s peak level should be less than -3 dB.
- RMS levels for an instrument as a whole should be around -18 dB. Play the instrument polyphonically and watch the RMS level. If the instrument is designed to be monophonic, then adjust for that.
- Impulse responses should have an RMS level of around -16 dB.
- The noise floor should be as low as possible: -60 dB is a good target. Use high-quality noise reduction tools to remove noise from your samples if you need to. Noise levels can quickly stack up with a multi-sampled instrument played polyphonically. Being too aggressive with algorithmic noise reduction can make your samples sound unnatural - so it’s a balance.
Sample rate, bit depth, and file format
Floe only supports FLAC and WAV files. We recommend using FLAC for your samples. It’s lossless and can reduce the file size by 50% to 70%. Floe loads FLAC files very quickly.
We find 44.1 kHz and 16-bit is often a perfectly reasonable choice. 48 kHz and 24-bit might also be appropriate in certain cases.
Volume envelopes of samples
Floe blurs the line between a sampler and a sample-based synthesizer. It has lots of parameters for manipulating the sound in real-time.
If your sample is a single continuous sound, then don’t include a fade-in or fade-out in the sample. Floe has a GUI for volume envelopes that offer more control: they can be adjusted to any value, automated by the DAW, and they are independent of the playback speed of the sample. If you have a sample that is stretched across a keyboard range, it will be sped-up or slowed-down in order to be the correct pitch. If there’s a volume fade then the speed of the fade will change depending on the pitch of the voice. This is not normally a desirable effect.
If your sound has important timbral variation over time, then don’t cut that away. Only if the sound is a constant tone should you remove the fade in/out.
Library Lua Scripts
This document describes the functions you can use in your sample library’s floe.lua
script to create and configure the library and its instruments.
Floe runs your script using Lua v5.4. You have access to some of Lua’s standard libraries: math
, string
, table
and utf8
. The other standard libraries are not available - including the require
function. This is to minimise security risks.
If there are any errors in your script, Floe will show them on the GUI along with a line number and a description of the problem.
Library Functions
Use these functions to create your sample library. Take note of the [required]
annotations - omitting these fields will cause an error.
floe.new_library
Creates a new library. It takes one parameter: a table of configuration. It returns a new library object. You should only create one library in your script. Return the library at the end of your script.
The library is the top-level object. It contains all the instruments, regions, and impulse responses.
local library = floe.new_library({
-- The name of the library. Keep it short and use tagline for more details.
-- [required]
name = "Iron Vibrations",
-- A few words to describe the library. [required]
tagline = "Organic sounds from resonating metal objects",
-- The URL for this Floe library.
-- [optional, default: no url]
library_url = "https://example.com/iron-vibrations",
-- A description of the library.
-- [optional, default: no description]
description = "A collection of resonating metal objects sampled using a handheld stereo recorder.",
-- Who created this library. Keep it short, use the description for more
-- details. [required]
author = "Found-sound Labs",
-- URL relating to the author or their work.
-- [optional, default: ]
author_url = "https://example.com",
-- The minor version of this library - backwards-compatible changes are
-- allowed on a library; this field represents that. Non-backwards-compatibile
-- changes are not allowed: you'd need to create a new library such as:
-- "Strings 2".
-- [optional, default: 1]
minor_version = 1,
-- Path relative to this script for the background image. It should be a jpg
-- or png.
-- [optional, default: ]
background_image_path = "Images/background.jpg",
-- Path relative to this script for the icon image. It should be a square jpg
-- or png.
-- [optional, default: ]
icon_image_path = "Images/icon.png",
})
floe.new_instrument
Creates a new instrument on the library. It takes 2 parameters: the library object and a table of configuration. It returns a new instrument object. You can call this function multiple times to create multiple instruments.
An instrument is like a musical instrument. It is a sound-producing entity that consists of one or more samples (samples are specified in regions). Each library can have multiple instruments.
local instrument = floe.new_instrument(library, {
-- The name of the instrument. Must be unique. [required]
name = "Metal Fence Strike",
-- Words separated by slashes used to hierarchically categorise the
-- instrument.
-- [optional, default: no folders]
folders = "Fences/Steel",
-- A description of the instrument.
-- [optional, default: no description]
description = "Tonal pluck metallic pluck made from striking a steel fence.",
-- An array of strings to denote properties of the instrument.
-- [optional, default: no tags]
tags = { "Pluck", "Metallic", "Organic" },
-- Path to an audio file relative to this script that should be used as the
-- waveform on Floe's GUI.
-- [optional, default: first region path]
waveform_audio_path = "Samples/file1.flac",
})
floe.add_region
Adds a region to an instrument. It takes 2 parameters: the instrument object and a table of configuration. Doesn’t return anything. You can call this function multiple times to create multiple regions.
A region is a part of an instrument. It defines an audio file and the conditions under which it will be played. For example, you might have a region that plays the audio file Piano_C3.flac
when the note C3 is played. Each instrument must have one or more regions.
floe.add_region(instrument, {
-- The file for this region. [required]
file = {
-- A path to an audio file, relative to this current lua file. [required]
path = "Samples/One-shots/Resonating String.flac",
-- The pitch of the audio file as a number from 0 to 127 (a MIDI note
-- number). On a range from 0 to 127. [required]
root_key = 60,
-- The region of the file that can be looped. It should be an array: 3
-- integers and 1 boolean: { start, end, crossfade, is_ping_pong boolean
-- }. Note that the end number is not inclusive. The start and end numbers
-- can be negative meaning they index the file from the end rather than
-- the start. For example, -1 == number_frames_in_file, -2 ==
-- (number_frames_in_file - 1), etc.
-- [optional, default: no loop]
loop = { 24, 6600, 100, false },
},
-- How this region should be triggered.
-- [optional, default: defaults]
trigger_criteria = {
-- What event triggers this region. Must be one of: "note-on" or
-- "note-off".
-- [optional, default: note-on]
trigger_event = "note-on",
-- The pitch range of the keyboard that this region is mapped to. These
-- should be MIDI note numbers, from 0 to 127. Note that the end number is
-- not inclusive.
-- [optional, default: { 60, 64 }]
key_range = { 60, 64 },
-- The velocity range of the keyboard that this region is mapped to. This
-- should be an array of 2 numbers ranging from 0 to 100. The first number
-- represents the start of the velocity range and the second number
-- represents 1-past the end of the range.
-- [optional, default: { 0, 100 }]
velocity_range = { 0, 100 },
-- Trigger this region only on this round-robin index. For example, if
-- this index is 0 and there are 2 other groups with round-robin indices
-- of 1 and 2, then this region will trigger on every third press of a key
-- only.
-- [optional, default: no round-robin]
round_robin_index = 0,
},
-- Additional options for this region.
-- [optional, default: defaults]
options = {
-- The start and end point, from 0 to 100, of the Timbre knob on Floe's
-- GUI that this region should be heard. You should overlay this range
-- with other timbre_crossfade_regions. Floe will create an even crossfade
-- of all overlapping sounds. Note that the end number is not inclusive.
-- [optional, default: no timbre-crossfade]
timbre_crossfade_region = { 0, 50 },
-- For every region that matches this group, automatically set the start
-- and end values for each region's key range based on its root key. Only
-- works if all region's velocity range are the same.
-- [optional, default: no auto-map]
auto_map_key_range_group = "group1",
-- If another region is triggered at the same time as this one and is
-- overlapping this, then both regions will play crossfaded together. This
-- smooths the transitions between velocity layers.
-- [optional, default: false]
feather_overlapping_velocity_regions = false,
},
})
floe.add_ir
Adds an reverb impulse response to the library. It takes 2 parameters: the library object and a table of configuration. Doesn’t return anything. You can call this function multiple times to create multiple impulse responses.
floe.add_ir(library, {
-- The name of the IR. Must be unique. [required]
name = "Cathedral",
-- File path to the impulse response file, relative to this script. [required]
path = "irs/cathedral.flac",
-- An array of strings to denote properties of the IR.
-- [optional, default: no tags]
tags = { "Cathedral", "Bright" },
})
floe.set_attribution_requirement
Sets the attribution information for a particular audio file or folder. It takes 2 parameters: a path to the file or folder whose license information you want to set, and a table of configuration. This is necessary if your library contains samples created by different people (licensed under CC BY, for example). If the path is a folder, the attribution requirement will be applied to all audio files in that folder and its subfolders.
floe.set_attribution_requirement("Samples/bell.flac", {
-- The title of the work. [required]
title = "Bell Strike",
-- Name of the license. [required]
license_name = "CC-BY-4.0",
-- URL to the license. [required]
license_url = "https://creativecommons.org/licenses/by/4.0/",
-- The name/identification of the persons or entities to attribute the work
-- to. [required]
attributed_to = "John Doe",
-- URL to the original work if possible.
-- [optional, default: ]
attribution_url = "https://example.com",
})
Support Function
Floe provides some additional functions to make developing libraries easier.
floe.extend_table
Extends a table with another table, including all sub-tables. It takes 2 parameters: the base table and the table to extend it with. The base table is not modified. The extension table is modified and returned. It has all the keys of the base table plus all the keys of the extended table. If a key exists in both tables, the value from the extension table is used.
Floe doesn’t have the concept of ‘groups’ like other formats like SFZ or Kontakt have. Instead, this function offers a way to apply a similar configuration to multiple regions. Alternatively, you can use functions and loops in Lua to add regions in a more dynamic way.
local group1 = {
trigger_criteria = {
trigger_event = "note-on",
velocity_range = { 0, 100 },
},
options = {
auto_map_key_range_group = "group1",
feather_overlapping_velocity_regions = false,
},
}
floe.add_region(instrument, floe.extend_table(group1, {
file = {
path = "One-shots/Resonating String 2.flac",
root_key = 65,
},
}))
floe.add_region(instrument, floe.extend_table(group1, {
file = {
path = "One-shots/Resonating String 3.flac",
root_key = 68,
},
}))
Develop Preset Packs
Developing preset packs is simply a matter of saving preset files into a folder and then packaging them into a Floe Package. Packages can can contain libraries and/or presets.
Package libraries & presets for distribution
The easiest and most reliable way to distribute your Floe sample libraries and presets is with Floe Packages.
Floe Packages are ZIP files that contain Floe sample libraries and/or presets. Packages are the files that users will download and use to install new libraries and presets into Floe.
Floe offers an easy-to-use GUI for installing these Packages. This installation process carefully considers the user’s existing libraries and presets, their versions, their installation preferences, even whether their installed libraries have been modified or not. The result is something that should ‘just work’ or at least provide clear instructions on what to do next.
As with Floe’s sample library format, openness is key. That’s why Floe Packages are just normal ZIP files with a specific structure. Anyone can create them and anyone can open them. Additionally, it gives the user the option to extract them manually rather than use Floe’s GUI if they wish.
Create Floe Packages using our command-line tool or any ZIP program.
Packager command-line tool
We recommend using our command-line tool to create Floe Packages. It ensures everything is set up correctly and adds a couple of nice-to-have features, particularly for users who want to install the package manually rather than with Floe’s GUI.
However, you can use any ZIP program to create Floe Packages. Just make sure they follow the structure described in the next section.
Download
Floe Packager Windows: Download Floe-Packager-v0.0.2-Windows.zip (1 MB)
Floe Packager macOS: Download Floe-Packager-v0.0.2-macOS.zip (1 MB)
Download the program, extract it, and run it from the command line.
Usage
Here’s the output of floe-packager --help
:
Takes libraries and presets and turns them into a Floe package file (floe.zip).
You can specify multiple libraries and preset-folders. Additionally:
- Validates any Lua files.
- Ensures libraries have a License file.
- Adds an 'About' document for each library.
- Adds a 'Installation' document for the package.
- Embeds a checksum file into the package for better change detection if the package
is installed manually.
Usage: floe-packager [ARGS]
Optional arguments:
--library-folders <path>... One or more library folders
--presets-folders <path>... One or more presets folders
--output-folder <path> Folder to write the created package to
--package-name <name> Package name - inferred from library name if not provided
Examples
These examples use bash syntax.
# Creates a Floe Package from the Slow library and the Slow Factory Presets.
# Slow and "Slow Factory Presets" are folders in the current directory.
./floe-packager --library-folders "Slow" \
--preset-folders "Slow Factory Presets" \
--output-folder .
# Creates a Floe Package containing multiple libraries and no presets
./floe-packager --library-folders "C:/Users/Sam/Floe-Dev/Strings" \
"C:/Users/Sam/Floe-Dev/Common-IRs" \
--output-folder "C:/Users/Sam/Floe-Dev/Releases" \
--package-name "FrozenPlain - Strings"
Packager structure
If you’re not using the packager tool, you need to know the structure of the Floe Package. It’s very simple.
Requirements of a floe package:
- The filename must end with
.floe.zip
- The ZIP must contain a folder called
Libraries
and/or a folder calledPresets
. If present, these folders must contain the libraries and presets respectively.
Be careful that your ZIP program is not adding an extra folder when you create the ZIP file. There should not be a top-level folder in the ZIP file, just the Libraries
and/or Presets
folders.
Example: single library & factory presets
📦FrozenPlain - Arctic Strings Package.floe.zip/
├── 📁Libraries
│ └── 📁Arctic Strings
│ ├── 📄arctic-strings.floe.lua
│ ├── 📁Samples
│ │ ├── 📄strings_c4.flac
│ │ └── 📄strings_d4.flac
│ └── 📁Images
│ ├── 📄background.png
│ └── 📄icon.png
└── 📁Presets
└── 📁Arctic Strings Factory
├── 📁Realistic
│ ├── 📄Octaved.floe-preset
│ └── 📄Soft.floe-preset
└── 📁Synthetic
├── 📄Bright.floe-preset
└── 📄Warm.floe-preset
Example: multiple libraries
📦Audioata - Synthwave Bundle Package.floe.zip/
├── 📁Libraries
│ ├── 📁Synthwave Bass
│ │ ├── 📄synthwave-bass.floe.lua
│ │ └── 📁Samples
│ │ ├── 📄bass_c1.flac
│ │ └── 📄bass_d1.flac
│ ├── 📁Synthwave Drums
│ │ ├── 📄synthwave-drums.floe.lua
│ │ └── 📁Samples
│ │ ├── 📄kick.flac
│ │ └── 📄snare.flac
│ └── 📁Synthwave Synths
│ ├── 📄synthwave-synths.floe.lua
│ └── 📁Samples/
│ ├── 📄synth_c4.flac
│ └── 📄synth_d4.flac
└── 📁Presets
└── 📁Synthwave Factory
├── 📄Clean Pad.floe-preset
├── 📄Dirty Lead.floe-preset
├── 📄Nebula Drone.floe-preset
├── 📄Punchy Kickdrum.floe-preset
├── 📄Backing FX.floe-preset
└── 📄Full Effect.floe-preset
Changelog
0.0.3
- Add support for packaging and installing MDATA libraries (Mirage)
- Add tooltips to the settings GUI
- Add new Info panel featuring info about installed libraries. ‘About’, ‘Metrics’ and ‘Licenses’ have been moved here too instead of being separate panels.
- Add new fields to the Lua API to support license info and attribution, such as CC BY
- Add attribution-required panel which appears when needed with generated copyable text for fulfilling attribution requirements. Synchronised between all instances of Floe. Makes complying with licenses like CC BY easy.
- Enable selecting multiple package to install at once
- Make notifications dismiss themselves after a few seconds
- Fixed externally deleted or moved-to-trash libraries not being removed from Floe
- Fixed not installing to the chosen location
0.0.2
- Fix Windows installer crash
- Don’t show a console window with the Windows installer
- Better logo for Windows installer
- Remove unnecessary ‘Floe Folders’ component from macOS installer
0.0.1
This is the first release of Floe. It’s ‘alpha quality’ at the moment - there will be bugs and there are a couple of missing features. This release is designed mostly to test our release process.
This release only contains the CLAP plugin. The VST3 and AU plugins will be released soon.
Mirage
Floe used to be called Mirage. Mirage contained many of the same features seen in Floe v0.0.1. But there are large structural changes, and some new features and improvements:
- Use multiple different libraries in the same instance.
- CLAP version added - VST3 and AU coming soon, VST2 support dropped.
- New installer: offline, no account/download-tickets needed. Libraries are installed separately.
- Ability for anyone to develop sample libraries using new Lua-based sample library format. The new format features a new system to tag instruments and libraries. Hot-reload library development: changes to a library are instantly applied to Floe.
- New comprehensive documentation.
- Floe now can have multiple library and preset folders. It will scan all of them for libraries and presets. This is a much more robust and flexible way to manage assets rather than trying to track individual files.
- New, robust infrastructure:
- Floe settings are saved in a more robust way avoiding issues with permissions/missing files.
- Improved default locations for saving libraries and presets to avoid permissions issues.
- New format for saving presets and DAW state - smaller and faster than before and allows for more expandability.
- New settings GUI.
- Floe packages: a robust way to install libraries and presets. Floe packages are zip files with a particular layout that contain libraries and presets. In the settings of Floe, you can install these packages. It handles all the details of installing/updating libraries and presets. It checks for existing installations and updates them if needed. It even checks if the files of any existing installation have been modified and will ask if you want to replace them. Everything just works as you’d expect.
Technical changes:
- Huge refactor of the codebase to be more maintainable and expandable. There’s still more to be done yet though.
- New build system using Zig; cross-compilation, dependency management, etc.
- Comprehensive CI/CD pipeline for testing and creating release builds.
- New ‘sample library server’, our system for providing libraries and audio files to Floe in a fast, async way.