Difference between revisions of "MIR workshop 2008"

From CCRMA Wiki
Jump to: navigation, search
(References for additional info)
(logistics)
 
(134 intermediate revisions by 5 users not shown)
Line 1: Line 1:
= CCRMA Workshop: Music Information Retrieval =
+
= Intelligent Audio Systems: Foundations and Applications of Music Information Retrieval =
 
+
This is Jay and Ge's brainstorming page for this summer's MIR workshop.
+
  
 
== logistics ==
 
== logistics ==
* Summer 2008
+
Workshop Title: '''"Intelligent Audio Systems: Foundations and Applications of Music Information Retrieval"
* Instructors: [http://www.imagine-research.com/ Jay LeBoeuf] and [http://ccrma.stanford.edu/~ge/ Ge Wang]
+
'''
 +
* 9-5 PM.  July 21 through August 1 2008
 +
* Instructors: [http://www.imagine-research.com/ Jay LeBoeuf]
  
 +
== Abstract ==
  
== workshop title ==
+
This workshop will teach the underlying ideas, approaches, technologies, and practical design of intelligent audio systems using Music Information Retrieval (MIR) algorithms.
* "Intelligent Audio Systems: Foundations and Applications of Music Information Retrieval"
+
  
== workshop outline == Introduction to Capabilities of MIR
+
MIR is a highly-interdisciplinary field bridging the domains of digital audio signal processing, pattern recognition, software system design, and machine learning.  Simply put, MIR algorithms allow a computer to “listen” and “understand or make sense of” audio data, such as MP3s in a personal music collection, live streaming audio, or gigabytes of sound effects, in an effort to reduce the semantic gap between high-level musical information and low-level audio data.  In the same way that listeners can recognize the characteristics of sound and music – tempo, key, chord progressions, genre, or song structure – MIR algorithms are capable of recognizing and extracting this information, enabling systems to perform extensive sorting, searching, music recommendation, metadata generation, transcription, and even aiding/generating real-time performance.
  
Survey of the field, real-world applications, MIR research, and challenges
+
This workshop will target students, researchers, and industry audio engineers who are unfamiliar with the field of Music Information Retrieval (MIR).  We will demonstrate the myriad of exciting technologies enabled by the fusion of basic signal processing techniques with machine learning and pattern recognition.  Lectures will cover topics such as low-level feature extraction, generation of higher-level features such as onset timings and chord estimations, audio similarity clustering, search, and retrieval techniques, and design and evaluation of machine classification systems.  The presentations will be applied, multimedia-rich, overview of the building blocks of modern MIR systems.  Our goal is to make the understanding and application of highly-interdisciplinary technologies and complex algorithms approachable.     
* Current commercial applications
+
** Music Recommender Systems
+
** Playlisting systems
+
** DJ systems
+
** Music Transcription
+
** DAW technologies
+
** Band in a box
+
* Academic MIR research projects
+
** MARSYAS
+
** CLAM
+
** IMIRSEL
+
** Ongoing work and projects at McGill / UCSD / Columbia / Princeton / Stanford / UK / beyond
+
  
 +
The workshop will consist of half-day lectures, half-day supervised lab sessions, classroom exercises, demonstrations, and discussions.
  
Signal Processing Basics (if necessary)
+
Labs will allow students to design basic ground-up "intelligent audio systems", leveraging existing MIR toolboxes, programming environments, and applications.  Labs will include creation and evaluation of basic instrument recognition, transcription, and real-time audio analysis systems. 
 +
 
 +
Knowledge of basic digital audio principles and familiarity with basic programming (Matlab, C/C++, and/or ChucK) will be useful.
 +
Students are highly encouraged to bring their own audio source material for course labs and demonstrations.
 +
 
 +
== Workshop syllabus ==
 +
 
 +
* Administration
 +
** Introductions
 +
** CCRMA Overview
 +
** Final Projects
 +
* Introduction to Capabilities and Applications of MIR
 +
** Why MIR?
 +
** Overview of potential research and commercial applications
 +
** Basic System Overview and Architecture
 +
* Survey of the field, real-world applications, MIR research, and challenges
 +
** Current commercial applications
 +
** Searching, Similarity, and Seed Query Systems
 +
** Recommendation and Playlisting systems
 +
** How stuff works: Select Commercial MIR projects
 +
** Academic MIR research projects
 +
** Music Transcription
 +
** Real-time machine listening and audio analysis 
 +
 
 +
=== Timing and Segmentation ===
 +
* Frames and Windows
 +
* Onset Detection
 +
* Beat & Tempo Extraction
  
 
=== Feature Extraction ===
 
=== Feature Extraction ===
 
* Low Level Features
 
* Low Level Features
** "Classic" Spectral features (Centroid, Flux, RMS, Rolloff, Flatness, Kurtosis)
 
 
** Zero Crossing
 
** Zero Crossing
** Beat Histogram (?)
+
** Temporal centroid, Log Attack time, Attack slope)
** Spectral Bands / Filters
+
** Spectral features (Centroid, Flux, RMS, Rolloff, Flatness, Kurtosis, Brightness)
** MFCC, LPC, (source-filter modeling)
+
** Spectral bands
 +
** Log spectrogram
 +
** Chroma bins
 +
** MFCC
 
** MPEG-7
 
** MPEG-7
  
 
* Higher-level features
 
* Higher-level features
** Chroma features
 
 
** Key Estimation
 
** Key Estimation
 
** Chord Estimation
 
** Chord Estimation
** Pitch Estimation
 
 
** Genre (genre, artist ID, similarity)
 
** Genre (genre, artist ID, similarity)
 
** "Fingerprints"
 
** "Fingerprints"
  
=== Rhythm Analysis ===
+
=== Analysis / Decision Making ===
* Onset Detection
+
* Classification
* Beat Detection
+
** Heuristic Analysis
* Meter detection
+
** Distance measures (Euclidean, Manhattan, etc.)
 
+
** k-NN
=== Data Reduction Techniques ===
+
** SVM / One-class SVM
* Linear regression
+
* Clustering and probability density models
* Threshold, Adaptive Threshold
+
** Density distance measures (centroid distance, EMD, KL-divergence, etc)
* Peak Picking
+
** k-Means
* PCA / LDA
+
** Clustering
* Feature Selection
+
** GMM
 
+
** HMM
=== Structure and Segmentation ===
+
* Nested classifier / Anchor-space / template-based systems
* CASA 101
+
* Structural Analysis and Segmentation
+
 
+
=== Classification Algorithms ===
+
* k-NN
+
* SVM
+
* HMM
+
* Neural Nets
+
  
=== Classification ===
+
=== Model / Data Preparation Techniques ===
* concept and design
+
* Data Preparation
* genre-classification
+
** PCA / LDA
* similarity retrieval
+
** Scaling data
* instrument/speaker/source identification
+
* Model organization
 +
** concept and design
 +
** Data set construction and organization
 +
** Walk through example: audio similarity retrieval
 +
** Walk through example: instrument/speaker/source identification
  
 
=== Evaluation Methodology ===
 
=== Evaluation Methodology ===
* Data set construction
 
 
* Feature selection
 
* Feature selection
 
* Cross Validation
 
* Cross Validation
 
* Information Retrieval metrics (precision, recall, F-Measure)  
 
* Information Retrieval metrics (precision, recall, F-Measure)  
  
=== Lab Exercises ===
+
Plus guest lectures/visits from academic experts and real-world folks.
* Feature extraction from audio
+
* Classification tasks
+
* Segmentation : Onset Detector, Pitch Change, Frame Size, etc.
+
* Feature Extract 1 audio example: Sort & Play slices via feature values.  Add cowbell on just a certain beat, note, or word.  Do a simple transcription (via thresholds) of a loop. 
+
* Load a folder of Sample-A examples, then Sample-B examples.  Feature extract each and build a classifier.  Then, load a "test example" and compare it against the A and B via classifier.  Look at classification and distance from examples as probability. 
+
* Building an Instrument Identifier Tool using source audio material
+
* Organization of data sets and Evaluating system accuracy
+
* Speaker change detection
+
* Clustering Techniques Demo: Song Segmentation, Drum Transcription
+
* Dan Ellis' Practicals?
+
* Investigate the classifier accuracy as the number of Gaussian mixture components and/or the number of feature dimensions is varied. You can even vary the amount of training data used by subselecting rows in ftrs and labs. Can you make a plot of accuracy versus system complexity? How about versus training time?
+
* Prototyping real-time MIR algorithms and systems with ChucK/UAna
+
* Case study: Which of these can you automatically classify:
+
http://en.wikipedia.org/wiki/List_of_Music_Genome_Project_attributes
+
http://en.wikipedia.org/wiki/List_of_Music_Genome_Project_attributes_by_type
+
A given song is represented by a vector containing approximately 150 genes. Each gene corresponds to a characteristic of the music, for example, gender of lead vocalist, level of distortion on the electric guitar, type of background vocals, etc. Rock and pop songs have 150 genes, rap songs have 350, and jazz songs have approximately 400. Other genres of music, such as world and classical, have 300-500 genes. The system depends on a sufficient number of genes to render useful results. Each gene is assigned a number between 1 and 5, and fractional values are allowed but are limited to half integers.(US Patent Number 7003515)
+
  
Guest lecturer from a local music information retrieval startup?
+
== software, libraries, examples ==
Audible Magic, Gracenote, Midomi
+
Applications & Environments
Dr. Jon Shlens - PCA
+
* [http://www.mathworks.com/products/matlab/ MATLAB]
 
+
== potential software, libraries, examples ==
+
* MATLAB
+
 
* [http://chuck.cs.princeton.edu/ ChucK] / [http://chuck.cs.princeton.edu/uana/ UAna]
 
* [http://chuck.cs.princeton.edu/ ChucK] / [http://chuck.cs.princeton.edu/uana/ UAna]
* Sonic Visualizer [http://www.sonicvisualiser.org/]
+
* [http://www.cs.waikato.ac.nz/ml/weka/ Weka Machine Learning and Data Mining Toolbox (Standalone app / Java)]
* Marsyas
+
* [http://www.sonicvisualiser.org/ Sonic Visualizer]
* CLAM
+
 
* Machine Learning Libraries
+
Machine Learning Libraries & Toolboxes
* Weka Machine Learning and Data Mining Toolbox (Standalone app / Java)  
+
* [http://www.ncrg.aston.ac.uk/netlab/ Netlab Pattern Recognition and Clustering Toolbox (Matlab)]
* Netlab Pattern Recognition and Clustering Toolbox (Matlab)
+
* [http://www.csie.ntu.edu.tw/~cjlin/libsvm/#matlab libsvm SVM toolbox (Matlab)]
* libsvm SVM toolbox (Matlab)
+
* [http://www.jyu.fi/hum/laitokset/musiikki/en/research/coe/materials/mirtoolbox/Download/fg_base_view MIR Toolboxes (Matlab)]
* MA, MIDI, and MIR Toolboxes (Matlab)
+
Optional Toolboxes
 +
* [http://www.ofai.at/~elias.pampalk/ma/ MA Toolbox]
 +
* [http://www.jyu.fi/hum/laitokset/musiikki/en/research/coe/materials/miditoolbox MIDI Toolbox]
 
* [see also below references]
 
* [see also below references]
 +
* [http://marsyas.sness.net/ Marsyas]
 +
* [http://cosmal.ucsd.edu/cal/projects/CATbox/catbox.htm UCSD CatBox]
 +
* CLAM
 +
* Genetic Algorithm: http://www.ise.ncsu.edu/mirage/GAToolBox/gaot/
 +
* Spider http://www.kyb.tuebingen.mpg.de/bs/people/spider/
 +
* HTK http://htk.eng.cam.ac.uk/
  
== Abstract ==  
+
== Lectures ==  
 +
[http://cm-wiki.stanford.edu/wiki/MIR_workshop_2008_notes CCRMA MIR 2008 Workshop Wiki - complementary study notes for these lectures.]
  
This workshop will teach the underlying ideas, approaches, technologies, and practical design of intelligent audio systems using Music Information Retrieval (MIR) algorithms.  
+
[http://ccrma.stanford.edu/workshops/mir2008/Day1_CCRMA_MIR_workshop_2008.pdf Lecture 1 - Introduction and motivations for MIR.  Onset detection, zero crossing rate, and heuristic classification.]
  
MIR is a highly-interdisciplinary field bridging the domains of digital audio signal processing, pattern recognition, software system design, and machine learning. Simply put, MIR algorithms allow a computer to “listen” and “understand or make sense of” audio data, such as MP3s in a personal music collection, live streaming audio, or gigabytes of sound effects, in an effort to reduce the semantic gap between high-level musical information and low-level audio data.  In the same way that listeners can recognize the characteristics of sound and music – tempo, key, chord progressions, genre, or song structure – MIR algorithms are capable of recognizing and extracting this information, enabling systems to perform extensive sorting, searching, music recommendation, metadata generation, transcription, and even aiding/generating real-time performance.
+
[http://ccrma.stanford.edu/workshops/mir2008/Day2_CCRMA_MIR_workshop_2008.pdf Lecture 2 - k-NN, spectral moments, spectral features, octave bands, profiles, and scaling.]
  
This workshop will target students, researchers, and industry audio engineers who are unfamiliar with the field of Music Information Retrieval (MIR). We will demonstrate the myriad of exciting technologies enabled by the fusion of basic signal processing techniques with machine learning and pattern recognition. Lectures will cover topics such as low-level feature extraction, generation of higher-level features such as onset timings and chord estimations, audio similarity clustering, search, and retrieval techniques, and design and evaluation of machine classification systems.  The presentations will be applied, multimedia-rich, overview of the building blocks of modern MIR systems.  Our goal is to make the understanding and application of highly-interdisciplinary technologies and complex algorithms approachable.    
+
[http://ccrma.stanford.edu/workshops/mir2008/Day3_CCRMA_MIR_workshop_2008.pdf Lecture 3 - Log spectrogram, chromagrams, key and chord estimation, discuss final projects.]
  
The workshop will consist of half-day lectures, half-day supervised lab sessions, classroom exercises, demonstrations, and discussions.
+
[http://ccrma.stanford.edu/workshops/mir2008/Day4_CCRMA_MIR_workshop_2008.pdf Lecture 4 - Sonifying feature data, temporal feature extractors, MFCCs, unsupervised classification, k-means clustering.]
  
Labs will allow students to design basic ground-up "intelligent audio systems", leveraging existing MIR toolboxes, programming environments, and applications.  Labs will include creation and evaluation of basic instrument recognition, transcription, and real-time audio analysis systems.
+
[http://ccrma.stanford.edu/workshops/mir2008/Day5_CCRMA_MIR_workshop_2008.pdf Lecture 5 - Support Vector Machines: Binary, RBF parameters, grid search, practical information for designing SVM classifiers.]
  
Knowledge of basic digital audio principles and familiarity with basic programming (Matlab, C/C++, and/or ChucK) will be useful.  
+
[http://ccrma.stanford.edu/workshops/mir2008/Day6_CCRMA_MIR_workshop_2008.pdf Lecture 6 - One-class SVM, nu parameter, accuracy, cross-validation, evaluation metrics, assembling training and testing data, probabilistic clustering with GMMs, GMM parameters, distance measures between PDFs, Expectation-Maximization, Artist and Genre classification.]
Students are highly encouraged to bring their own audio source material for course labs and demonstrations.
+
 
 +
[http://ccrma.stanford.edu/workshops/mir2008/Day8_CCRMA_MIR_workshop_2008.pdf Lecture 8 - Practical considerations for building classifiers, Hidden Markov Models.]
 +
 
 +
[http://ccrma.stanford.edu/workshops/mir2008/Day9_CCRMA_MIR_workshop_2008.pdf Lecture 9 - Code sharing resources, MPEG-7 feature extractors.]
 +
 
 +
[http://ccrma.stanford.edu/workshops/mir2008/Day10_CCRMA_MIR_workshop_2008.pdf Lecture 10 - Course summary, acknowledgments, resources for research.]
 +
 
 +
== Labs ==
 +
[http://ccrma.stanford.edu/workshops/mir2008/Lab%201%20-%20Playing%20with%20audio%20slices.pdf Lab 1 - Playing with audio slices]
 +
 
 +
Abstract: This lab will introduce you to the practice of analyzing, segmenting, feature extracting, and applying basic classifications to audio files. Our future labs will build upon this essential work -but will use more sophisticated training sets, features, and classifiers.
 +
 
 +
[http://ccrma.stanford.edu/workshops/mir2008/Lab%202%20-%20My%20first%20audio%20classifier.pdf Lab 2 - My first audio classifier]
 +
 
 +
Abstract: My first audio classifier: introducing K-NN!  We can now appreciate why we need additional intelligence in our systems - heuristics can't very far in the world of complex audio signals.  We'll be using Netlab's implementation of the k-NN for our work here.  It proves be a straight-forward and easy to use implementation.  The steps and skills of working with one classifier will scale nicely to working with other, more complex classifiers.  We're also going to be using the new features in our arsenal: cherishing those "spectral moments" (centroid, bandwidth, skewness, kurtosis) and also examining other spectral statistics. 
 +
 
 +
[http://ccrma.stanford.edu/workshops/mir2008/Lab%203%20-%20Experimenting,%20Tonality,%20and%20Tempo.pdf Lab 3 - Experimenting, Tonality, and Tempo]
 +
 
 +
Abstract: As we anecdotally observed in yesterday's lab, several parameters can affect the quality of our classifications.
 +
# Audio files used in the training data sets.
 +
# Features used in training / testing.
 +
# Use of scaling for features.
 +
# The size of the frames extracted from the audio. 
 +
 +
We'll gain an intuitive feel for each of the effect of each of these parameters  by trying some simple experiments. 
 +
Afterwards, we'll dive into a lab on extracting tonal information from you audio streams
 +
 
 +
[http://ccrma.stanford.edu/workshops/mir2008/Lab%204%20-%20Cluster%20Lab.pdf Lab 4 - Cluster Lab]
 +
 
 +
Abstract: Sometimes, an unsupervised learning technique is preferred. Perhaps you do not have access to adequate training data, the classifications for the training data's labels events are not completely clear, or you just want to quickly sort real-world, unseen, data into groups based on it's feature similarity. Regardless of your situation, clustering is a great option!  Lab also introduces MFCCs as a main measure of timbral similarity. 
 +
 
 +
[http://ccrma.stanford.edu/workshops/mir2008/Lab%205%20-%20SVMs.pdf Lab 5 SVMs]
 +
 
 +
Abstract: In this lab, you'll learn how to scale, format data, and find the optimum parameters for binary classification Support Vector Machines.  We'll train/build models and test them on real-world data. 
 +
 
 +
[http://ccrma.stanford.edu/workshops/mir2008/Lab%206%20-%20Gaussian%20Mixture%20Models.pdf Lab 6 - Gaussian Mixture Models]
 +
 
 +
Abstract: By the end of this lab, you will understand the how to use GMM models - a probabilistic clustering and "soft classification" technique.
 +
 
 +
[http://ccrma.stanford.edu/workshops/mir2008/Lab%207%20-%20HMM%20%20Cross%20validation%20-%20Final%20Projects.pdf Lab 7 - Cross Validation, HMMs, Final Projects]
 +
 
 +
Abstract: By the end of this lab, you should have a skeletal outline of where your project is going to go, what data you will use, what features, classifiers / techniques you will use, and what your metric of success / goal is.  Additionally, the lab includes a walk through of cross-validation techniques for measuring your accuracy and a list of helpful HMM functions. 
 +
 
 +
[http://ccrma.stanford.edu/workshops/mir2008/audio.zip Audio source material]
 +
 
 +
[http://ccrma.stanford.edu/~mw/ Some helpful matlab scripts and utilities (Courtesy of the MIR Workshop 2008 summer students)]
 +
 
 +
== Final Projects from MIR 2008 Workshop ==
 +
* Beat and segment detection comparisons using Harmonic Change Detection Function, MFCC, key strength, spectrum, and novelty. [http://ccrma.stanford.edu/~cmaxwell/mir2008-project.pdf Cynthia slides] 
 +
* Vocal onset detection, segmentation, analysis, and classification.  (Chuck Cooper)
 +
* Using audio similarity metrics to remix songs from similar sounding audio snippets.  (Mike Williams) Mike to post his temporal centroid code. 
 +
* Measuring audio similarity between recordings of Beethoven and Haydn quartets, using shifted chromagram and delta chromagram similarity matrices.  (Jason Sundram)
 +
* Real-time decomposition and reassembly of audio via similarity features and k-nearest neighbor.  (Joseph Rosenzweig)
 +
* Classification of orchestral instrument classes using timbral features and an array of SVMs. (Alberto Pinto)
 +
* Resynthesis of electronic music using sound effects and real-world sound snippets.  {Cobi van Tonder)
  
 
== References for additional info ==  
 
== References for additional info ==  
Tools:  
+
Recommended books:
 +
* Data Mining: Practical Machine Learning Tools and Techniques, Second Edition by Ian H. Witten , Eibe Frank (includes software)
 +
* Netlab by Ian T. Nabney  (includes software)
 +
* Signal Processing Methods for Music Transcription, Klapuri, A. and Davy, M. (Editors)
 +
* Computational Auditory Scene Analysis: Principles, Algorithms, and Applications, DeLiang Wang (Editor), Guy J. Brown (Editor)
 +
* Speech and Audio Signal Processing:Processing and perception of speech and music Ben Gold & Nelson Morgan, Wiley 2000
 +
 
 +
Prerequisite / background material:
 +
* http://140.114.76.148/jang/books/audioSignalProcessing/
 +
* [http://ccrma.stanford.edu/workshops/mir2008/learnmatlab_sp3.pdf The Mathworks' Matlab Tutorial]
 +
* [http://ismir2007.ismir.net/proceedings/ISMIR2007_tutorial_Lartillot.pdf ISMIR2007 MIR Toolbox Tutorial]
 +
 
 +
Papers:
 +
* Check out the references listed at the end of the Klapuri & Davy book
 +
* Check out Papers listed on Pg 136-7 of  MIR Toolbox: http://www.jyu.fi/hum/laitokset/musiikki/en/research/coe/materials/mirtoolbox/userguide1.1
 +
 
 +
Other books (not necessary reviewed by the instructors yet):
 +
* Pattern Recognition and Machine Learning (Information Science and Statistics) by Christopher M. Bishop
 +
* Neural Networks for Pattern Recognition, Christopher M. Bishop, Oxford University Press, 1995.
 +
* Pattern Classification, 2nd edition, R Duda, P Hart and D Stork, Wiley Interscience, 2001.
 +
* "Artificial Intelligence: A Modern Approach" Second Edition, Russell R & Norvig P, Prentice Hall, 2003.
 +
* Machine Learning, Tom Mitchell, McGraw Hill, 1997.
 +
 
 +
Interesting Links:  
 
* http://www.ifs.tuwien.ac.at/mir/howtos.html
 
* http://www.ifs.tuwien.ac.at/mir/howtos.html
 
* http://www.jyu.fi/hum/laitokset/musiikki/en/research/coe/materials
 
* http://www.jyu.fi/hum/laitokset/musiikki/en/research/coe/materials
 
* http://www.music-ir.org/evaluation/tools.html
 
* http://www.music-ir.org/evaluation/tools.html
 
Toolboxes to explore:
 
 
* http://140.114.76.148/jang/matlab/toolbox/
 
* http://140.114.76.148/jang/matlab/toolbox/
* http://www.jyu.fi/hum/laitokset/musiikki/en/research/coe/materials/miditoolbox/
 
* http://users.jyu.fi/~lartillo/mirtoolbox/
 
 
* http://htk.eng.cam.ac.uk/
 
* http://htk.eng.cam.ac.uk/
* Genetic Algorithm: http://www.ise.ncsu.edu/mirage/GAToolBox/gaot/
 
* Will not use: Spider http://www.kyb.tuebingen.mpg.de/bs/people/spider/
 
Online Tutorials / Course materials:
 
* http://140.114.76.148/jang/books/audioSignalProcessing/
 
  
Papers:
+
== Audio Source Material ==
* http://www.csie.ntu.edu.tw/~cjlin/papers/guide/guide.pdf
+
OLPC Sound Sample Archive (8.5 GB) [http://wiki.laptop.org/go/Sound_samples]
* http://www.kyb.tuebingen.mpg.de/bs/people/weston/svmpractical/
+
* http://www.inf.ed.ac.uk/teaching/courses/inf2b/learnnotes/inf2b-learn14-notes.pdf
+
* [http://www.inf.ed.ac.uk/teaching/courses/inf2b/learnnotes/inf2b-learn02-notes.pdf Simple review of probability with introduction of Bayes Rules ]  
+
  
Evaluation
+
RWC Music Database (n DVDs) [available in Stanford Music library]
* http://ismir2007.ismir.net/proceedings/ISMIR2007_p323_ehmann.pdf
+
  
Books - NOT YET REVIEWED
+
[http://staff.aist.go.jp/m.goto/RWC-MDB/rwc-mdb-i.html RWC - Sound Instruments Table of Contents]
    * Neural Networks for Pattern Recognition, Christopher M. Bishop, Oxford University Press, 1995.
+
    * Pattern Classification, 2nd edition, R Duda, P Hart and D Stork, Wiley Interscience, 2001.
+
    * "Artificial Intelligence: A Modern Approach" Second Edition, Russell R & Norvig P, Prentice Hall, 2003.
+
    * Machine Learning, Tom Mitchell, McGraw Hill, 1997.
+
  
 +
http://staff.aist.go.jp/m.goto/RWC-MDB/rwc-mdb-i.html
  
Student Projects
+
Ideas:
* http://ccrma.stanford.edu/~steinunn/220c/
+
* [http://www.ee.columbia.edu/~dpwe/e6820/projects.html Potential Ideas from Dan Ellis' Course]
 +
* [http://en.wikipedia.org/wiki/List_of_Music_Genome_Project_attributes_by_type List of Music Genomes]
  
== Audio Source Material ==
+
== THE WIKI VALUE-ADD - Supplemental information for the lectures...==
OLPC Sound Sample Archive (8.5 GB) [http://wiki.laptop.org/go/Sound_samples]
+
[http://cm-wiki.stanford.edu/wiki/MIR_workshop_2008_notes Explanations, tutorials, code demos, recommended papers here - for each topic....]
  
RWC Music Database (n DVDs) [available in Stanford Music library]
+
[http://cm-wiki.stanford.edu/wiki/MIRToolbox_wishes MIRToolbox comments, wishes, wants]
  
 +
== MATLAB Utility Scripts ==
 +
* [http://ccrma.stanford.edu/~mw/ Mike's scripts]
 +
 +
* [[Reading MP3 Files]]
 +
* [[Low-Pass Filter]]
  
 
[[Category: Workshops]]
 
[[Category: Workshops]]
 +
 +
== ChucK ==
 +
 +
ChucK is a strongly-timed audio programming language that we will be using for real-time audio analysis.
 +
 +
* [http://ccrma.stanford.edu/workshops/mir2008/chuck%20examples%20from%20Perry.zip Perry Cook's demonstrations from his guest lecture]
 +
* [http://chuck.stanford.edu/ Chuck @ Stanford]
 +
* [http://electro-music.com/forum/forum-140.html the electro-music.com ChucK forum]
 +
* [http://www.youtube.com/watch?v=2rpk461T6l4 Ge presents ChucK to the Stanford HCI seminar]
 +
* [http://slork.stanford.edu/ Slork, the Stanford Laptop Orchestra]
 +
* [http://wiki.cs.princeton.edu/index.php/ChucK/Programs some example code]
 +
* [http://soundlab.cs.princeton.edu/publications/uana_icmc2007.pdf UAna paper]
 +
* [http://audicle.cs.princeton.edu/mini/mac/doc/maui_api.html MAUI--Mac only]
 +
* [http://ccrma.stanford.edu/~warren/MIRchuck.zip ChucK examples]
 +
* [http://smelt.cs.princeton.edu/ S.M.E.L.T.]
 +
 +
[[MIR_workshop_2009]]

Latest revision as of 11:02, 28 June 2014

Intelligent Audio Systems: Foundations and Applications of Music Information Retrieval

logistics

Workshop Title: "Intelligent Audio Systems: Foundations and Applications of Music Information Retrieval"

  • 9-5 PM. July 21 through August 1 2008
  • Instructors: Jay LeBoeuf

Abstract

This workshop will teach the underlying ideas, approaches, technologies, and practical design of intelligent audio systems using Music Information Retrieval (MIR) algorithms.

MIR is a highly-interdisciplinary field bridging the domains of digital audio signal processing, pattern recognition, software system design, and machine learning. Simply put, MIR algorithms allow a computer to “listen” and “understand or make sense of” audio data, such as MP3s in a personal music collection, live streaming audio, or gigabytes of sound effects, in an effort to reduce the semantic gap between high-level musical information and low-level audio data. In the same way that listeners can recognize the characteristics of sound and music – tempo, key, chord progressions, genre, or song structure – MIR algorithms are capable of recognizing and extracting this information, enabling systems to perform extensive sorting, searching, music recommendation, metadata generation, transcription, and even aiding/generating real-time performance.

This workshop will target students, researchers, and industry audio engineers who are unfamiliar with the field of Music Information Retrieval (MIR). We will demonstrate the myriad of exciting technologies enabled by the fusion of basic signal processing techniques with machine learning and pattern recognition. Lectures will cover topics such as low-level feature extraction, generation of higher-level features such as onset timings and chord estimations, audio similarity clustering, search, and retrieval techniques, and design and evaluation of machine classification systems. The presentations will be applied, multimedia-rich, overview of the building blocks of modern MIR systems. Our goal is to make the understanding and application of highly-interdisciplinary technologies and complex algorithms approachable.

The workshop will consist of half-day lectures, half-day supervised lab sessions, classroom exercises, demonstrations, and discussions.

Labs will allow students to design basic ground-up "intelligent audio systems", leveraging existing MIR toolboxes, programming environments, and applications. Labs will include creation and evaluation of basic instrument recognition, transcription, and real-time audio analysis systems.

Knowledge of basic digital audio principles and familiarity with basic programming (Matlab, C/C++, and/or ChucK) will be useful. Students are highly encouraged to bring their own audio source material for course labs and demonstrations.

Workshop syllabus

  • Administration
    • Introductions
    • CCRMA Overview
    • Final Projects
  • Introduction to Capabilities and Applications of MIR
    • Why MIR?
    • Overview of potential research and commercial applications
    • Basic System Overview and Architecture
  • Survey of the field, real-world applications, MIR research, and challenges
    • Current commercial applications
    • Searching, Similarity, and Seed Query Systems
    • Recommendation and Playlisting systems
    • How stuff works: Select Commercial MIR projects
    • Academic MIR research projects
    • Music Transcription
    • Real-time machine listening and audio analysis

Timing and Segmentation

  • Frames and Windows
  • Onset Detection
  • Beat & Tempo Extraction

Feature Extraction

  • Low Level Features
    • Zero Crossing
    • Temporal centroid, Log Attack time, Attack slope)
    • Spectral features (Centroid, Flux, RMS, Rolloff, Flatness, Kurtosis, Brightness)
    • Spectral bands
    • Log spectrogram
    • Chroma bins
    • MFCC
    • MPEG-7
  • Higher-level features
    • Key Estimation
    • Chord Estimation
    • Genre (genre, artist ID, similarity)
    • "Fingerprints"

Analysis / Decision Making

  • Classification
    • Heuristic Analysis
    • Distance measures (Euclidean, Manhattan, etc.)
    • k-NN
    • SVM / One-class SVM
  • Clustering and probability density models
    • Density distance measures (centroid distance, EMD, KL-divergence, etc)
    • k-Means
    • Clustering
    • GMM
    • HMM
  • Nested classifier / Anchor-space / template-based systems

Model / Data Preparation Techniques

  • Data Preparation
    • PCA / LDA
    • Scaling data
  • Model organization
    • concept and design
    • Data set construction and organization
    • Walk through example: audio similarity retrieval
    • Walk through example: instrument/speaker/source identification

Evaluation Methodology

  • Feature selection
  • Cross Validation
  • Information Retrieval metrics (precision, recall, F-Measure)

Plus guest lectures/visits from academic experts and real-world folks.

software, libraries, examples

Applications & Environments

Machine Learning Libraries & Toolboxes

Optional Toolboxes

Lectures

CCRMA MIR 2008 Workshop Wiki - complementary study notes for these lectures.

Lecture 1 - Introduction and motivations for MIR. Onset detection, zero crossing rate, and heuristic classification.

Lecture 2 - k-NN, spectral moments, spectral features, octave bands, profiles, and scaling.

Lecture 3 - Log spectrogram, chromagrams, key and chord estimation, discuss final projects.

Lecture 4 - Sonifying feature data, temporal feature extractors, MFCCs, unsupervised classification, k-means clustering.

Lecture 5 - Support Vector Machines: Binary, RBF parameters, grid search, practical information for designing SVM classifiers.

Lecture 6 - One-class SVM, nu parameter, accuracy, cross-validation, evaluation metrics, assembling training and testing data, probabilistic clustering with GMMs, GMM parameters, distance measures between PDFs, Expectation-Maximization, Artist and Genre classification.

Lecture 8 - Practical considerations for building classifiers, Hidden Markov Models.

Lecture 9 - Code sharing resources, MPEG-7 feature extractors.

Lecture 10 - Course summary, acknowledgments, resources for research.

Labs

Lab 1 - Playing with audio slices

Abstract: This lab will introduce you to the practice of analyzing, segmenting, feature extracting, and applying basic classifications to audio files. Our future labs will build upon this essential work -but will use more sophisticated training sets, features, and classifiers.

Lab 2 - My first audio classifier

Abstract: My first audio classifier: introducing K-NN! We can now appreciate why we need additional intelligence in our systems - heuristics can't very far in the world of complex audio signals. We'll be using Netlab's implementation of the k-NN for our work here. It proves be a straight-forward and easy to use implementation. The steps and skills of working with one classifier will scale nicely to working with other, more complex classifiers. We're also going to be using the new features in our arsenal: cherishing those "spectral moments" (centroid, bandwidth, skewness, kurtosis) and also examining other spectral statistics.

Lab 3 - Experimenting, Tonality, and Tempo

Abstract: As we anecdotally observed in yesterday's lab, several parameters can affect the quality of our classifications.

  1. Audio files used in the training data sets.
  2. Features used in training / testing.
  3. Use of scaling for features.
  4. The size of the frames extracted from the audio.

We'll gain an intuitive feel for each of the effect of each of these parameters by trying some simple experiments. Afterwards, we'll dive into a lab on extracting tonal information from you audio streams

Lab 4 - Cluster Lab

Abstract: Sometimes, an unsupervised learning technique is preferred. Perhaps you do not have access to adequate training data, the classifications for the training data's labels events are not completely clear, or you just want to quickly sort real-world, unseen, data into groups based on it's feature similarity. Regardless of your situation, clustering is a great option! Lab also introduces MFCCs as a main measure of timbral similarity.

Lab 5 SVMs

Abstract: In this lab, you'll learn how to scale, format data, and find the optimum parameters for binary classification Support Vector Machines. We'll train/build models and test them on real-world data.

Lab 6 - Gaussian Mixture Models

Abstract: By the end of this lab, you will understand the how to use GMM models - a probabilistic clustering and "soft classification" technique.

Lab 7 - Cross Validation, HMMs, Final Projects

Abstract: By the end of this lab, you should have a skeletal outline of where your project is going to go, what data you will use, what features, classifiers / techniques you will use, and what your metric of success / goal is. Additionally, the lab includes a walk through of cross-validation techniques for measuring your accuracy and a list of helpful HMM functions.

Audio source material

Some helpful matlab scripts and utilities (Courtesy of the MIR Workshop 2008 summer students)

Final Projects from MIR 2008 Workshop

  • Beat and segment detection comparisons using Harmonic Change Detection Function, MFCC, key strength, spectrum, and novelty. Cynthia slides
  • Vocal onset detection, segmentation, analysis, and classification. (Chuck Cooper)
  • Using audio similarity metrics to remix songs from similar sounding audio snippets. (Mike Williams) Mike to post his temporal centroid code.
  • Measuring audio similarity between recordings of Beethoven and Haydn quartets, using shifted chromagram and delta chromagram similarity matrices. (Jason Sundram)
  • Real-time decomposition and reassembly of audio via similarity features and k-nearest neighbor. (Joseph Rosenzweig)
  • Classification of orchestral instrument classes using timbral features and an array of SVMs. (Alberto Pinto)
  • Resynthesis of electronic music using sound effects and real-world sound snippets. {Cobi van Tonder)

References for additional info

Recommended books:

  • Data Mining: Practical Machine Learning Tools and Techniques, Second Edition by Ian H. Witten , Eibe Frank (includes software)
  • Netlab by Ian T. Nabney (includes software)
  • Signal Processing Methods for Music Transcription, Klapuri, A. and Davy, M. (Editors)
  • Computational Auditory Scene Analysis: Principles, Algorithms, and Applications, DeLiang Wang (Editor), Guy J. Brown (Editor)
  • Speech and Audio Signal Processing:Processing and perception of speech and music Ben Gold & Nelson Morgan, Wiley 2000

Prerequisite / background material:

Papers:

Other books (not necessary reviewed by the instructors yet):

  • Pattern Recognition and Machine Learning (Information Science and Statistics) by Christopher M. Bishop
  • Neural Networks for Pattern Recognition, Christopher M. Bishop, Oxford University Press, 1995.
  • Pattern Classification, 2nd edition, R Duda, P Hart and D Stork, Wiley Interscience, 2001.
  • "Artificial Intelligence: A Modern Approach" Second Edition, Russell R & Norvig P, Prentice Hall, 2003.
  • Machine Learning, Tom Mitchell, McGraw Hill, 1997.

Interesting Links:

Audio Source Material

OLPC Sound Sample Archive (8.5 GB) [1]

RWC Music Database (n DVDs) [available in Stanford Music library]

RWC - Sound Instruments Table of Contents

http://staff.aist.go.jp/m.goto/RWC-MDB/rwc-mdb-i.html

Ideas:

THE WIKI VALUE-ADD - Supplemental information for the lectures...

Explanations, tutorials, code demos, recommended papers here - for each topic....

MIRToolbox comments, wishes, wants

MATLAB Utility Scripts

ChucK

ChucK is a strongly-timed audio programming language that we will be using for real-time audio analysis.

MIR_workshop_2009