{ "cells": [ { "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ "
\n", "\"FMP\"\n", "\"AudioLabs\"\n", "
" ] }, { "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ "
\n", "\"C0\"\n", "

FMP Notebooks
Python Notebooks for Fundamentals of Music Processing

\n", "\n", "
\n", "\n", "
\n", "\n", "

\n", "The FMP notebooks offer a collection of educational material closely following the textbook Fundamentals of Music Processing (FMP). This is the starting website, which is opened when calling https://www.audiolabs-erlangen.de/FMP. Besides giving an overview, this website provides information on the license and the main contributors. \n", "

" ] }, { "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ "
\n", "

Information on Current Status:

\n", "\n", "We work continuously on the FMP notebooks and provide updates on a regular basis (current version: 1.2.6). With the static HTML version of the FMP notebooks you can browse through the content right away. To run the Python code, please go to Get Started for instructions. For comments, please email me (Meinard Müller). I am grateful for feedback and suggestions.\n", "
\n", "
\n", "\n", "" ] }, { "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ "## About\n", "\n", "The FMP notebooks are a collection of educational material for teaching and learning Fundamentals of Music Processing (FMP) with a particular focus on the audio domain. Covering well-established topics in Music Information Retrieval (MIR) as motivating application scenarios, the FMP notebooks provide detailed textbook-like explanations of central techniques and algorithms in combination with Python code examples that illustrate how to implement the theory. All components including the introductions of MIR scenarios, illustrations, sound examples, technical concepts, mathematical details, and code examples are integrated into a consistent and comprehensive framework based on Jupyter notebooks. The FMP notebooks are suited for studying the theory and practice, for generating educational material for lectures, as well as for providing baseline implementations for many MIR tasks, thus addressing students, teachers, and researchers. \n", " \n", "\"CC\"\n", "\n", "The text and figures of these notebooks are licensed under a [Creative Commons\n", "Attribution-NonCommercial-ShareAlike 4.0 International License](https://creativecommons.org/licenses/by-nc-sa/4.0/) (see the file LICENSE). \n", "The Python package libfmp (i.e., the content of the directory libfmp) is licensed under the [MIT license](https://opensource.org/licenses/MIT) (see file libfmp_LICENSE) and is available at [GitHub](https://github.com/meinardmueller/libfmp). As for the audio material, the respective original licenses apply. This site contains material (text passages, figures) from the book Fundamentals of Music Processing. If you use code or material from this site, please give reference to this book (e.g. Figure 1.1 from [Müller, FMP, Springer 2021]). If you publish results obtained or using these Python notebooks, please consider the following references:\n", " \n", "
\n", "\"FMP_Cover\"\n", "
\n", "\n", " \n", "\n", "The FMP notebooks are maintained by Meinard Müller. For comments, please email meinard.mueller@audiolabs-erlangen.de. I am grateful for feedback and suggestions." ] }, { "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ "## Get Started\n", "\n", "If a static view of the FMP notebooks is enough for you, the exported HTML versions can be used right away without any installation. All material including the explanations, the figures, and the audio examples can be accessed by just following the **HTML links**. If you want to **execute** the Python code cells, you have to download the notebooks (along with the data), create an environment, and start a Jupyter server. You then need to follow the **IPYNB links** within the Jupyter session. The necessary steps are explained in detail in the [FMP notebook on how to get started](../B/B_GetStarted.html)." ] }, { "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ "## Overview\n", "\n", "The collection of FMP notebooks is organized along the eight chapters of the textbook [Müller, FMP, Springer 2015]. The following table gives an overview of these chapters and provides links. Furthermore, in [Part B](../B/B.html), we provide basic information on the Python programming language, introduce the Juypter framework, and provide various tools used throughout the FMP notebooks.\n", "\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", "\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", "\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", "\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", "\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", "\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", "\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", "\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", "\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", "\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", "\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", "\n", "\n", "\n", " \n", " \n", " \n", " \n", " \n", "\n", "\n", "
ChapterTitleNotions, Techniques & AlgorithmsHTMLIPYNB
BasicsGet started; Juypter framework; Anaconda; multimedia; Python programming; visualization; audio; Numba; annotations; libfmp; MIR resources[html][ipynb]
OverviewOverview of the notebooks (this notebook/website)[html][ipynb]
Music RepresentationsMusic notation; MIDI; audio signal; waveform; pitch; loudness; timbre[html][ipynb]
Fourier Analysis of SignalsDiscrete/analog signal; sinusoid; exponential; Fourier transform; Fourier representation; DFT; FFT; STFT[html][ipynb]
Music SynchronizationChroma feature; dynamic programming; dynamic time warping (DTW); alignment; user interface[html][ipynb]
Music Structure AnalysisSimilarity matrix; repetition; thumbnail; homogeneity; novelty; evaluation; precision; recall; F-measure; visualization; scape plot[html][ipynb]
Chord RecognitionHarmony; music theory; chords; scales; templates; hidden Markov model (HMM); evaluation[html][ipynb]
Tempo and Beat TrackingOnset; novelty; tempo; tempogram; beat; periodicity; Fourier analysis; autocorrelation[html][ipynb]
Content-Based Audio RetrievalIdentification; fingerprint; audio matching; version identification; cover song[html][ipynb]
Musically Informed Audio DecompositionHarmonic/percusive separation; signal reconstruction; instantaneous frequency; fundamental frequency (F0); trajectory; nonnegative matrix factorization (NMF)[html][ipynb]
\n", "\n", "" ] }, { "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ "## Acknowledgment\n", "\n", "

\n", "The notebooks are based on results, material, and insights that have been obtained in close collaboration with different people. I would like to express my gratitude to my former and current students, collaborators, and colleagues who have influenced and supported me in creating these notebooks. Also, various people have contributed to the code examples of the notebooks; credits are given in the notebooks' acknowledgement sections. Here, I will confine myself to only mentioning the names of the main contributors in alphabetical order: \n", " \n", "

\n", "

\n", "\n", "

\n", "Furthermore, some of the code examples have been inspired or are based on code provided by other code collections. In particular, I want to mention the following excellent sources:\n", "

\n", "\n", "\n", "\n", "" ] }, { "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ "\n", "\n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", " \n", "\n", "
\"C0\"\"C1\"\"C2\"\"C3\"\"C4\"\"C5\"\"C6\"\"C7\"\"C8\"
" ] } ], "metadata": { "kernelspec": { "display_name": "Python 3", "language": "python", "name": "python3" }, "language_info": { "codemirror_mode": { "name": "ipython", "version": 3 }, "file_extension": ".py", "mimetype": "text/x-python", "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", "version": "3.8.16" } }, "nbformat": 4, "nbformat_minor": 1 }