Giter Site home page Giter Site logo

wave's Introduction

Wave

This package can view metadata from a wave file. It also reads the data chunks and seperates it into multiple channels. Each channel has its own amplitude values. This is useful if you want to render a waveform for instance.

How to install

You can install with composer. Use a composer.json file with the following lines:

"minimum-stability": "dev",
"require": {
    "boyhagemann/wave": "dev-master"
}

How to use

First, let's make a wave object based on a wave file:

<?php

use BoyHagemann\Wave\Wave;

$wave = new Wave();
$wave->setFilename('path/to/your/file.wav');

After that, if the file turns out to be a valid wave file, you can get several metadata from it.

How a wave is made

A wave file is made out of chunks; packages of data. Each chunk has its own name, size and unique data. We are actually only interested in 2 types of chunk: the Fmt and the Data chunk.

Metadata (fmt chunk)

For instance, the "Fmt" chunk contains a description of the wave file contents. To get this metadata, you can enter these lines:

$metadata = $wave->analyze()->getMetadata();
$metadata->getName();
$metadata->getSize();
$metadata->getFormat();
$metadata->getChannels();
$metadata->getSampleRate();
$metadata->getBytesPerSecond();
$metadata->getBlockSize();
$metadata->getBitsPerSample();
$metadata->getExtensionSize();
$metadata->getExtensionData();

Data chunk

This chunk contains all the actual wave data. It is build up in packages of several bytes, depending on the number of channels the wave has. All analyzed data is stored in seperate channels, depending on the number of channels of the file. To get the raw amplitudes of a file, do the following:

// Assuming we already analyzed the wave...
$data = $wave->getWaveformData();

// Get the amplitude values for each channel
foreach($data->getChannels() as $channel) {
    $amplitudes[] = $channel->getValues();
}

Analyzing

The analyzing process can be a hefty one. Normally, you scan every package in the data chunk. It can use all your php processing power and can quickly result in a maximum execution time error. To prevent this, you can set the level of detail for analysing the data. You can set the number of steps between the packages that are to be analyzed. The greater the steps, the faster the script will run. The smaller the steps, the more accurate the waveform will be. By default, the steps are set to 100, but you can alter this easily:

$wave->setSteps(10000);

wave's People

Contributors

webble avatar boyhagemann avatar

Watchers

James Cloos avatar Leandro Reis avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.