annotate docs/SMC15/smc2015template.tex @ 656:0a401224660b

Added dev-main branch warning at top of files
author Nicholas Jillings <n.g.r.jillings@se14.qmul.ac.uk>
date Fri, 10 Apr 2015 10:25:52 +0100
parents
children e0abe55f5514
rev   line source
n@656 1 % -----------------------------------------------
n@656 2 % Template for SMC 2012
n@656 3 % adapted from the template for SMC 2011, which was adapted from that of SMC 2010
n@656 4 % -----------------------------------------------
n@656 5
n@656 6 \documentclass{article}
n@656 7 \usepackage{smc2015}
n@656 8 \usepackage{times}
n@656 9 \usepackage{ifpdf}
n@656 10 \usepackage[english]{babel}
n@656 11 \usepackage{cite}
n@656 12
n@656 13 %%%%%%%%%%%%%%%%%%%%%%%% Some useful packages %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
n@656 14 %%%%%%%%%%%%%%%%%%%%%%%% See related documentation %%%%%%%%%%%%%%%%%%%%%%%%%%
n@656 15 %\usepackage{amsmath} % popular packages from Am. Math. Soc. Please use the
n@656 16 %\usepackage{amssymb} % related math environments (split, subequation, cases,
n@656 17 %\usepackage{amsfonts}% multline, etc.)
n@656 18 %\usepackage{bm} % Bold Math package, defines the command \bf{}
n@656 19 %\usepackage{paralist}% extended list environments
n@656 20 %%subfig.sty is the modern replacement for subfigure.sty. However, subfig.sty
n@656 21 %%requires and automatically loads caption.sty which overrides class handling
n@656 22 %%of captions. To prevent this problem, preload caption.sty with caption=false
n@656 23 %\usepackage[caption=false]{caption}
n@656 24 %\usepackage[font=footnotesize]{subfig}
n@656 25
n@656 26
n@656 27 %user defined variables
n@656 28 \def\papertitle{APE FOR WEB: A BROWSER-BASED EVALUATION TOOL FOR AUDIO} %?
n@656 29 \def\firstauthor{Nicholas Jillings}
n@656 30 \def\secondauthor{Brecht De Man}
n@656 31 \def\thirdauthor{David Moffat}
n@656 32 \def\fourthauthor{Joshua D. Reiss}
n@656 33
n@656 34 % adds the automatic
n@656 35 % Saves a lot of ouptut space in PDF... after conversion with the distiller
n@656 36 % Delete if you cannot get PS fonts working on your system.
n@656 37
n@656 38 % pdf-tex settings: detect automatically if run by latex or pdflatex
n@656 39 \newif\ifpdf
n@656 40 \ifx\pdfoutput\relax
n@656 41 \else
n@656 42 \ifcase\pdfoutput
n@656 43 \pdffalse
n@656 44 \else
n@656 45 \pdftrue
n@656 46 \fi
n@656 47
n@656 48 \ifpdf % compiling with pdflatex
n@656 49 \usepackage[pdftex,
n@656 50 pdftitle={\papertitle},
n@656 51 pdfauthor={\firstauthor, \secondauthor, \thirdauthor},
n@656 52 bookmarksnumbered, % use section numbers with bookmarks
n@656 53 pdfstartview=XYZ % start with zoom=100% instead of full screen;
n@656 54 % especially useful if working with a big screen :-)
n@656 55 ]{hyperref}
n@656 56 %\pdfcompresslevel=9
n@656 57
n@656 58 \usepackage[pdftex]{graphicx}
n@656 59 % declare the path(s) where your graphic files are and their extensions so
n@656 60 %you won't have to specify these with every instance of \includegraphics
n@656 61 \graphicspath{{./figures/}}
n@656 62 \DeclareGraphicsExtensions{.pdf,.jpeg,.png}
n@656 63
n@656 64 \usepackage[figure,table]{hypcap}
n@656 65
n@656 66 \else % compiling with latex
n@656 67 \usepackage[dvips,
n@656 68 bookmarksnumbered, % use section numbers with bookmarks
n@656 69 pdfstartview=XYZ % start with zoom=100% instead of full screen
n@656 70 ]{hyperref} % hyperrefs are active in the pdf file after conversion
n@656 71
n@656 72 \usepackage[dvips]{epsfig,graphicx}
n@656 73 % declare the path(s) where your graphic files are and their extensions so
n@656 74 %you won't have to specify these with every instance of \includegraphics
n@656 75 \graphicspath{{./figures/}}
n@656 76 \DeclareGraphicsExtensions{.eps}
n@656 77
n@656 78 \usepackage[figure,table]{hypcap}
n@656 79 \fi
n@656 80
n@656 81 %setup the hyperref package - make the links black without a surrounding frame
n@656 82 \hypersetup{
n@656 83 colorlinks,%
n@656 84 citecolor=black,%
n@656 85 filecolor=black,%
n@656 86 linkcolor=black,%
n@656 87 urlcolor=black
n@656 88 }
n@656 89
n@656 90
n@656 91 % Title.
n@656 92 % ------
n@656 93 \title{\papertitle}
n@656 94
n@656 95 % Authors
n@656 96 % Please note that submissions are NOT anonymous, therefore
n@656 97 % authors' names have to be VISIBLE in your manuscript.
n@656 98 %
n@656 99 % Single address
n@656 100 % To use with only one author or several with the same address
n@656 101 % ---------------
n@656 102 %\oneauthor
n@656 103 % {\firstauthor} {Affiliation1 \\ %
n@656 104 % {\tt \href{mailto:author1@smcnetwork.org}{author1@smcnetwork.org}}}
n@656 105
n@656 106 %Two addresses
n@656 107 %--------------
n@656 108 % \twoauthors
n@656 109 % {\firstauthor} {Affiliation1 \\ %
n@656 110 % {\tt \href{mailto:author1@smcnetwork.org}{author1@smcnetwork.org}}}
n@656 111 % {\secondauthor} {Affiliation2 \\ %
n@656 112 % {\tt \href{mailto:author2@smcnetwork.org}{author2@smcnetwork.org}}}
n@656 113
n@656 114
n@656 115
n@656 116 % FIX!!!
n@656 117 \fourauthors
n@656 118 {\firstauthor} {%Affiliation1 \\
n@656 119 {\tt \href{mailto:b.deman@qmul.ac.uk}{n.g.r.jillings@se14.qmul.ac.uk, }}}
n@656 120 {\secondauthor} {%Affiliation2\\ %
n@656 121 {\tt \href{mailto:n.g.r.jillings@se14.qmul.ac.uk}{\{b.deman,}}}
n@656 122 {\thirdauthor} {%Affiliation3\\ %
n@656 123 {\tt \href{mailto:d.j.moffat@qmul.ac.uk}{d.j.moffat, }}}
n@656 124 {\fourthauthor} {%Affiliation4\\ %
n@656 125 {\tt \href{mailto:joshua.reiss@qmul.ac.uk}{joshua.reiss\}@qmul.ac.uk}}}
n@656 126
n@656 127 % ***************************************** the document starts here ***************
n@656 128 \begin{document}
n@656 129 %
n@656 130 \capstartfalse
n@656 131 \maketitle
n@656 132 \capstarttrue
n@656 133 %
n@656 134 \begin{abstract}
n@656 135 Place your abstract at the top left column on the first page.
n@656 136 Please write about 150-200 words that specifically highlight the purpose of your work,
n@656 137 its context, and provide a brief synopsis of your results.
n@656 138 Avoid equations in this part.\\
n@656 139 TOTAL PAPER: Minimum 4 pages, 6 preferred, max. 8 (6 for demos/posters)\\
n@656 140 \end{abstract}
n@656 141 %
n@656 142
n@656 143 \section{Introduction}\label{sec:introduction}
n@656 144
n@656 145 background (types of research where this type of perceptual evaluation of audio is relevant)\\
n@656 146
n@656 147 multiple stimulus perceptual evaluation (reference to Bech etc.)\\
n@656 148
n@656 149 prior work: \cite{deman2014b} in MATLAB, much less easy to deploy, and often stops working due to version updates \\
n@656 150
n@656 151 goal, what are we trying to do? \\
n@656 152
n@656 153 [Previously, due to limited functionality of HTML, ..., it was not possible to design this type of interfaces with such high quality audio... ]
n@656 154
n@656 155
n@656 156 \section{Design considerations}\label{sec:designconsiderations}
n@656 157
n@656 158 We present a browser-based perceptual evaluation tool for audio that ... \\
n@656 159
n@656 160 see \cite{deman2014b}: requirements informed by research on music production (see my work and that of others' in the group), such as randomisation, playback of high quality audio, some degree of flexibility in terms of configuration, ... \\
n@656 161
n@656 162
n@656 163 \section{Implementation}\label{sec:implementation}
n@656 164 %[Nick???]
n@656 165
n@656 166 %section on overall architecture\\
n@656 167
n@656 168 %section with overview of the structure of the input and output files, perhaps with graph or table
n@656 169
n@656 170 The tool runs entirely inside the browser through the new HTML5 Web Audio API. The API is supported by most major web browsers (except Internet Explorer) and allows for constructing a chain of audio processing elements to produce a high quality, real time signal process to manipulate audio streams. The API supports multi-channel processing and has an accurate playback timer for precise scheduled playback control. The web audio API is controlled through the browser JavaScript and is therefore highly controllable. The Web Audio API processing is all controlled in a separate thread to the main JavaScript thread, meaning there is no blocking due to real time processing.
n@656 171
n@656 172 \subsection{Architecture}\label{sec:architecture}
n@656 173
n@656 174 The web tool itself is split into several files to operate:
n@656 175 \begin{itemize}
n@656 176 \item apeTool.html: The main index file to load the scripts, this is the file the browser must request to load
n@656 177 \item core.js: Contains functions and objects to manage the audio control, audio objects for testing and loading of files
n@656 178 \item ape.js: Parses setup files to create the interface as instructed, following the same style chain as the MATLAB APE Tool.
n@656 179 \end{itemize}
n@656 180
n@656 181 The HTML file loads the core.js file with it along with a few other ancillary files (such as the jQuery javascript extensions), the browser JavaScript begins to execute the on page instructions, which gives the URL of the test setup XML document (outlined in the next section). The core.js parses this document and executes the function in ape.js to build the web page with the given audio files. The reason for separating these two files is to allow for further interface designs (such as Mushra or A-B tests) to be used, which would still require the same underlying core functions outlined in core.js
n@656 182
n@656 183 The ape.js file has only two main functions: loadInterface(xmlDoc) and interfaceXMLSave(). The first function is called to build the interface once the setup document has been loaded. This includes creating the slider interface to rate the tracks and creating the comment boxes bellow. The bars in the slider ranking at the top of the page are randomly spaced. It also instructs the audio engine in the core.js to create the audio objects. The audio objects are custom built audio nodes built on the web audio API. They consist of a bufferSourceNode (a node which holds a buffer of audio samples for playback) and a gainNode. These are then connected to the audioEngine (itself a custom web audio node) containing a gainNode (where the various audio Objects connect to) for summation before passing the output to the destination Node, a fixed node created where the browser then passes the audio information to the system sound device.
n@656 184
n@656 185 When an audioObject is created, the URL of the audio sample to load is given to it. This is downloaded into the browser asynchronously using the XMLHttpRequest object. This allows for downloading of any file into the JavaScript environment for further processing. It is particularly useful for the web audio API because it supports downloading of files in their binary form, allowing a perfect copy. Once the asynchronous download is complete, the file is then decoded using the web audio API offline decoder. This uses the browser available decoding schemes to decode the audio files into raw float32 arrays, which are in-turn passed to the relevant audioObject bufferSourceNode for playback.
n@656 186
n@656 187 Browsers support various audio file formats and are not consistent in any format. One sure format that all browsers support is the WAV format. Although not a compact, web friendly format, most transport systems are of a high enough bandwidth this should not be a problem. However one problem is that of sample rate. On loading, the browser uses the sample rate assigned by the system sound device. The browser does not have the ability to request a different sound rate. Therefore the default operation when an audio file is loaded with a different sample rate to that of the system is to convert the sample rate. To provide a check for this, the desired sample rate can be supplied with the setup XML and checked against. If the sample rates do not match, a browser alert window is shown asking for the sample rate to be correctly adjusted. This happens before any loading or decoding of audio files. Only once the sample rates match will the system actually fetch any files, keeping down requests for the larger files until they are actually needed.
n@656 188
n@656 189 During playback, the playback nodes loop indefinitely until playback is stopped. The gain nodes in the audioObjects enable dynamic muting of nodes. When a bar in the sliding ranking is clicked, the audio engine mutes all audioObjects and un-mutes the clicked one. Therefore, if the audio samples are perfectly aligned up and of the same sample length, they will remain perfectly aligned with each other.
n@656 190
n@656 191 \subsection{Setup and Results Formats}\label{sec:setupresultsformats}
n@656 192
n@656 193 Setup and the results both use the common XML document format to outline the various parameters. The setup file contains all the information needed to initialise a test session. Several Nodes can be defined to outline the audio samples to use, questions to be asked and any pre- or post-test questions or instructions. Having one document to modify allows for quick manipulation in a 'human readable' form to create new tests, or adjust current ones, without needing to edit which web files.
n@656 194
n@656 195 The results file is dynamically generated by the interface upon clicking the submit button. There will be checks, depending on the setup file, to ensure that all tracks have been evaluated and their positions in the slider moved. The XML returned contains a node per audioObject and contains its rating in the slider and any comments written in its associated comment box. The rating returned is normalised to be within a integer range of 0 to 100. This normalises the pixel representation of different browser windows. If a window for instance is only 1280 wide, reporting its pixel position is not representative to a display with a width of 1920.
n@656 196
n@656 197 The pre- and post-test options allow for comments or questions to be presented before or after the test. These are automatically generated based upon the given setup XML and allow nearly any form of question and comment to be included in a window on its own. Questions are stored and presented in the response section labelled 'pretest' and 'posttest' along with the question ID and its response. Questions can be made optionally mandatory. Example questions may involve entering mixing experience or listening environment.
n@656 198
n@656 199 The results will also contain information collected by any defined pre/post questions. These are referenced against the setup XML by using the same ID as well as printing in the same question, so readable responses can be obtained. Future development will also evolve to include any session data, such as the browser the tool was used in, how long the test took and any other metrics. Currently the results files are downloaded on the user side of the browser as a .xml file to be manually returned. However the end goal is to allow the XML files to be submitted over the web to a receiving server to store them, allowing for automated collection.
n@656 200
n@656 201 Here is an example of the setup XML and the results XML:
n@656 202 % Should we include an Example of the input and output XML structure??
n@656 203
n@656 204 \section{Applications}\label{sec:applications} %?
n@656 205 discussion of use of this toolbox (possibly based on a quick mock test using my research data, to be repeated with a large number of participants and more data later)\\
n@656 206
n@656 207 \subsection{Listening Environment Standardisation}
n@656 208
n@656 209 In order to reduce the impact of having a non-standardised listening environment and unobservable participants, a series of pre-test standard questions have been put together to ask every participant. The first part of this is that every participant is asked to carry out the test, wherever possible, with a pair of quality headphones.
n@656 210
n@656 211 \begin{itemize}
n@656 212 \item Name (text box)
n@656 213 \item I am happy for name to be used in an academic publication (check box)
n@656 214 \item First Language (text box)
n@656 215 \item Location eg. country, city (text box)
n@656 216 \item Playback System (ratio box (Headphones or Speaker))
n@656 217 \item Make and Model of Playback System (text box)
n@656 218 \item Please assess how good you believe your hearing to be, where 1 is deaf, 10 is professional critical listener (Dropdown box 1-10)
n@656 219 \end{itemize}
n@656 220
n@656 221
n@656 222 There are also a series of considerations that have been made towards ensuring there is a standardised listening environment, so it is possible to
n@656 223 \begin{itemize}
n@656 224 \item Begin with standardised listening test - to confirm listening experience
n@656 225 \item Perform loudness equalisation on all tracks
n@656 226 \\** OR THIS SHOULD BE DONE BEFORE THE EXPERIMENT
n@656 227 \item Randomise order of tests
n@656 228 \item Randomise order of tracks in each test
n@656 229 \item Repeat each experiment a number of times
n@656 230 \\** TO REMOVE THE FAMILIARISATION WITH EXPERIMENT VARIABLE
n@656 231 \\** TO ENSURE CONSISTENCY OF USER
n@656 232 \item Track all user interactions with system
n@656 233 \end{itemize}
n@656 234
n@656 235
n@656 236
n@656 237
n@656 238
n@656 239 \section{Conclusions and future work}\label{sec:conclusions}
n@656 240
n@656 241 In this paper we have presented an approach to creating a browser-based listening test environment that can be used for a variety of types of perceptual evaluation of audio.
n@656 242 Specifically, we discussed the use of the toolbox in the context of assessment of preference for different production practices, with identical source material.
n@656 243 The purpose of this paper is to outline the design of this tool, to describe our implementation using basic HTML5 functionality, and to discuss design challenges and limitations of our approach. % or something
n@656 244
n@656 245 % future work
n@656 246 Further work may include the development of other common test designs, such as [...], and [...]. In addition, [...].
n@656 247
n@656 248 \begin{itemize}
n@656 249 \item Options for MUSHRA style experiment with vertical slide per track, APE style experiment where all tracks are on a single horizontal axis, or AB test
n@656 250 \end{itemize}
n@656 251
n@656 252
n@656 253 ...
n@656 254
n@656 255 The source code of this tool can be found on \url{code.soundsoftware.ac.uk/projects/browserevaluationtool}.
n@656 256
n@656 257
n@656 258 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
n@656 259 %bibliography here
n@656 260 \bibliography{smc2015template}
n@656 261
n@656 262
n@656 263
n@656 264 \end{document}
n@656 265
n@656 266
n@656 267
n@656 268 % RUBBISH
n@656 269
n@656 270 %\subsection{Equations}
n@656 271 %Equations of importance,
n@656 272 %or to which you refer later,
n@656 273 %should be placed on separated lines and numbered.
n@656 274 %The number should be on the right side, in parentheses.
n@656 275 %\begin{equation}
n@656 276 %E=mc^{2+\delta}.
n@656 277 %\label{eq:Emc2}
n@656 278 %\end{equation}
n@656 279 %Refer to equations like so:
n@656 280 %As (\ref{eq:Emc2}) shows,
n@656 281 %I do not completely trust Special Relativity.
n@656 282 %
n@656 283 %\subsection{Figures, Tables and Captions}
n@656 284 %\begin{table}[t]
n@656 285 % \begin{center}
n@656 286 % \begin{tabular}{|l|l|}
n@656 287 % \hline
n@656 288 % String value & Numeric value \\
n@656 289 % \hline
n@656 290 % Hej SMC & 2015 \\
n@656 291 % \hline
n@656 292 % \end{tabular}
n@656 293 %\end{center}
n@656 294 % \caption{Table captions should be placed below the table, exactly like this,
n@656 295 % but using words different from these.}
n@656 296 % \label{tab:example}
n@656 297 %\end{table}
n@656 298
n@656 299 %\begin{figure}[t]
n@656 300 %\figbox{
n@656 301 %\subfloat[][]{\includegraphics[width=60mm]{figure}\label{fig:subfigex_a}}\\
n@656 302 %\subfloat[][]{\includegraphics[width=80mm]{figure}\label{fig:subfigex_b}}
n@656 303 %}
n@656 304 %\caption{Here's an example using the subfig package.\label{fig:subfigex} }
n@656 305 %\end{figure}
n@656 306
n@656 307
n@656 308
n@656 309
n@656 310
n@656 311 %\begin{acknowledgments}
n@656 312 %You may acknowledge people, projects,
n@656 313 %funding agencies, etc.
n@656 314 %which can be included after the second-level heading
n@656 315 %``Acknowledgments'' (with no numbering).
n@656 316 %\end{acknowledgments}
n@656 317