Skip to content

WaveBeans/wavebeans

Repository files navigation

WaveBeans

Build And Test Maven Central

A set of tools to process audio signals using Kotlin/Java/Scala/etc. You can either use it via command line or develop your own program which can be run as a part of you application:

  • generate signals and new instruments;
  • change existing signals, wave-files or audio streams;
  • mix different audio stream together;
  • research and explore audio signals;
  • make preparation for machine learning algorithms;
  • and many more.

Everything using one tool in single- or multi-threaded environment, or even distributing computation across multiple nodes.

Quick links

Getting started

It's important to understand how you're about to use the WaveBeans, however if you're new to the tool the easiest way would be to use command line tool which provides comprehensive interface to the functionality and allows start working as soon as possible without deep dive.

Prerequisites

Overall all you need is to have JRE/JDK 8+ installed and configured properly, so JAVA_HOME variable points to correct Java home folder.

Developing an audio application

WaveBeans is written on Kotlin, but might be compatible with all other JVM languages -- Java, Scala, etc (not tested at the moment).

If you want to use WaveBeans in your application just add it as a maven dependency. Here is what you would need to add into your build.gradle.kts file (the example uses Kotlin DSL for gradle with Kotlin):

  • (optionally) The artifacts are published to Maven Central, usually it is available by default, but if it's not for some reason you may add it manually:
repositories {
    mavenCentral()
}
  • Add main API artifact to the dependencies:
dependencies {
    implementation("io.wavebeans:lib:$wavebeans_version")
}
  • (optionally) You may need to add dependency onexe project if you are going to use extended execution capabilities:
dependencies {
    implementation("io.wavebeans:exe:$wavebeans_version")
}
  • Make sure the JVM target version is 1.8:
import org.jetbrains.kotlin.gradle.tasks.KotlinCompile

tasks.withType<KotlinCompile>().all {
    kotlinOptions.jvmTarget = "1.8"
}

And start using it. Just create kotlin-file like this:

import io.wavebeans.execution.*
import io.wavebeans.lib.io.*
import io.wavebeans.lib.stream.*
import java.io.File

fun main() {
    // describe what you want compute
    val out = 440.sine()
            .trim(1000)
            .toMono16bitWav("file://" + File("sine440.wav").absoluteFile)

    // this code launches it in single threaded mode,
    // follow execution documentation for details
    SingleThreadedOverseer(listOf(out)).use { overseer ->
        if (!overseer.eval(44100.0f).all { it.get().finished }) {
            println("Execution failed. Check logs")
        }
    }
}

For more follow usage documentation and project documentation.

Logging

WaveBeans uses slf4j for logging, but it doesn't provide the default logging engine when it is being used inside application. You would need to configure it properly on your own.

WaveBeans Cli

WaveBeans provides a command line interface to work with audio files. Basically it allows you to run the program written on Kotlin script. Along with it, it provides some smoother API to wrap the code, but that's all the difference comparing to using it inside your application. You can even use Kotlin SDK classes and methods as usual.

For example, let's generate 1 second of 440Hz sinusoid and store it as wav-file in current directory (this is a bash script):

export FILE="$(pwd)/sine440.wav"
./wavebeans --execute "440.sine().trim(1000).toMono16bitWav(\"file://$FILE\").out()"

For more information usage documentation and follow projects documentation.

Installing Cli

You need to have JRE 8 installed and configured. Also familiarity with Kotlin really helps.

In order to start using WaveBeans via command line you just need to download the binaries.

Building from source

Project uses gradle as a build system. And also, please make sure you installed JDK 8 and Git before doing that. Then follow the steps:

  1. Clone the repository:

    via https

    git clone https://github.com/WaveBeans/wavebeans.git

    or via ssh

    git clone git@github.com:WaveBeans/wavebeans.git
  2. Build and run tests using gradle wrapper:

    cd wavebeans/
    ./gradlew build test

Among everything else, you can find artifact of Cli tool under cli/build/distributions/.

Using IDE for development

Follow this instructions.

Contribution

Any feedback, bug reports, and pull requests are welcome!

For pull requests, please stick to the following guidelines:

  • Add tests for any new features and bug fixes. Ideally, each PR should increase the test coverage.
  • Put a reasonable amount of comments into the code.
  • Separate unrelated changes into multiple pull requests.

Please note that by contributing any code or documentation to this repository (by raising pull requests, or otherwise) you explicitly agree to the Contributor License Agreement.

Questions?

If there are any other questions, concerns or suggestions please feel free to use following communication channels: