beets/docs/plugins/echonest.rst
2013-10-27 11:08:42 +01:00

82 lines
2.6 KiB
ReStructuredText

Echonest Plugin
===============
The ``echonest`` plugin will automatically fetch and store the following audio
descriptors from the `EchoNest API`_. All except for ``tempo`` will be stored in
flexattrs and *not* in the audio file itself. ``tempo`` will be stored in
``bpm``:
- danceability
- energy
- liveness
- loudness
- speechiness
- tempo
See `Acoustic Attributes`_ for a detailed description.
.. _EchoNest API: http://developer.echonest.com/
.. _Acoustic Attributes: http://developer.echonest.com/acoustic-attributes.html
Installing Dependencies
-----------------------
This plugin requires the pyechonest library in order to talk to the EchoNest
API. At least version 8.0.1 is required.
There are packages for most major linux distributions, you can download the
library from the Echo Nest, or you can install the library from `pip`_,
like so::
$ pip install pyechonest
To transcode music, this plugin requires the `ffmpeg`_ command-line tool.
To get fingerprinting working, you'll need to install the `ENMFP`_ codegen
command-line tool. The ``ENMFP`` codegen binary distribution has executables
for all major OSs and architectures. Please note that fingerprinting is not
required if ``upload`` and ``convert`` is enabled, which is the default.
.. _pip: http://pip.openplans.org/
.. _FFmpeg: http://ffmpeg.org
.. _ENMFP: http://static.echonest.com/ENMFP_codegen.zip
Configuring
-----------
Beets includes its own Echo Nest API key, but you can `apply for your own`_ for
free from the Echo Nest. To specify your own API key, add the key to your
:doc:`configuration file </reference/config>` as the value for ``apikey`` under
the key ``echonest_tempo`` like so::
echonest:
apikey: YOUR_API_KEY
In addition, the ``auto`` config option lets you disable automatic metadata
fetching during import. To do so, add this to your ``config.yaml``::
echonest:
auto: no
The ``echonest`` plugin tries to upload files to the Echo Nest server if it
can not be identified by other means. If you don't want that, disable the
``upload`` config option like so::
echonest:
upload: no
The Echo Nest server only supports a limited range of file formats. The
``plugin`` automatically converts unsupported files to ``ogg``. If you don't
want that, disable the ``convert`` config option like so::
echonest:
convert: no
If the ``ENMFP`` binary is not in your path, you'll need to add a key called
``codegen`` under the ``echonest`` section like so::
echonest:
codegen: PATH/TO/YOUR/CODEGEN/BINARY
.. _apply for your own: http://developer.echonest.com/account/register