Speakerbench Manual

Table of Contents

  1. Introduction
  2. The measurement procedure
  3. Collecting data into an object
  4. The fitting procedure
  5. The datasheet creator
  6. Sample data files
  7. Box Simulation
  8. External Resources
  9. About

Introduction

Speakerbench is a web-based application created by Jeff Candy and Claus Futtrup. It is made available to whoever might find it useful, including the loudspeaker Do-It-Yourself (DIY) community. It is a collection of several special-purpose modules aimed at low-frequency analysis and design of loudspeakers. The modules are

  1. Collect: merge three impedance measurements into a data container
  2. Fit: analyze data container to compute advanced model parameters
  3. Create: create a standard datasheet with advanced parameters
  4. Box: define a box and simulate the system response

A key feature of this set of tools is the ability to create and use an advanced transducer model that is more accurate than the traditional Thiele-Small model. Speakerbench doesn't do the actual measurement for you. You'll have to do that by yourself, so please have a careful look at the next section of this manual. The software is free to use, but not open source.

Key steps are marked in green. If you want a minimal description of what is going on, please refer to these boxes.

For videos, please see the Speakerbench YouTube channel [1].

This manual provides an overview to quickly get you going. For more detailed information, please see our Documentation pages.

The measurement procedure

Thiele-Small parameters are classically determined by adding mass to the moving part (cone) of the loudspeaker. Then, by comparing the weighted to the unweighted free-air impedance measurements, one can compute all model parameters. In the present case, to extract parameters for the new advanced model, the fitting procedure will require three impedance measurements:

  1. without added mass
  2. with an added mass, $m_1$
  3. with a larger added mass $m_2$ (roughly double $m_1$)

Ideally, $m_2$ will be in the same ballpark as the moving mass of the speaker you're measuring. Ballpark meaning it's not critical to be exact. The added-masses (in grams) will need to be entered into the data-collecting app. It is important to measure on a precision scale and specify the masses as accurately as possible.

These three impedance data files must be uploaded to the web app in ZMA file format, which lists 3 columns of data: frequency (column 1), impedance magnitude (column 2) and impedance phase (column 3). Acceptable ZMA files may contain header data (ignored) marked with an asterisk (*). Ideally the steady-state impedance measurements will be logarithmic, range from about 10 Hz to 20 kHz, and contain several hundred data points. However, linear frequency measurements with thousands of data points is also acceptable. Since the goal is to determine the advanced model parameters as accurately as possible, we recommend that $m_2$ consist of 4 masses and that $m_1$ consist of half these masses (with the other half removed from the cone). The four masses are placed in a cross-pattern (equally spaced) in a mechanically stable way near the voice coil and with a good physical connection to the voice coil. All 4 masses should be of approximately the same weight, yet for high precision they are individually marked and their weight measured individually before applied to the cone. This is illustrated in the image below.

Three drivers with and without added mass

Measure the impedance with all 4 mass-loads ($m_2$, left panel) and save this data to the first ZMA file. Now very gently remove the two diagonal masses, leaving the remaining masses balanced and rocking modes prevented during the measurement of the speaker. Remeasure the impedance with the remaining two masses ($m_1$, middle panel) and save this data to a second ZMA file. Now very gently remove the two masses leaving the bare cone (right panel). Measure the impedance of the unweighted cone and save this data to a third ZMA file.

We use Blu Tack for added-masses, with a non-magnetic metal nut or coin optionally embedded for increased density. Be aware that magnetic materials can interact with the magnet system giving spurious results!

As the masses are removed from the cone, please measure their weight again and ensure that you know how much mass you've removed from the cone. These masses should be the values you measured before. The reason we measure in reverse order, as described above, is because applying the masses to the speaker may stress the mechanical suspension parts, which alters the viscoelastic properties. It is easier to remove the masses without stressing the parts and potentially without the cone moving at all. This will ensure the highest possible precision in determining all parameters, including the viscoelastic $\beta$ value.

Measurement equipment, which supports saving impedance measurements in the ZMA file format (that we're aware of):

We recommend a stepped-sine signal measurement such that all frequency points are measured under steady-state conditions. It is our experience that a fast Chirp or Farina sweep will not result in acceptable precision. If your equipment only offers sweep options, we recommend a slow sweep to achieve reasonably high accuracy. Note: REW and DATS V3 both use a sweep.

Good luck.

Making a single data object

We provide a web app to collect the previous impedance measurements (and masses) into a single file. This single (JSON) object can be stored on your computer locally and later uploaded into the parameter fitting app. In principle this step is only a required step because we felt is was a practical way to store measurements, a practical way to feed the data to the fitter, and should anything strange occur, a practical way for you to share the data with us so we can potentially investigate.

The data collection app requires the following input:

  1. ZMA file containing impedance measurement of unweighted driver
  2. ZMA file containing impedance measurement of driver with added mass $m_1$
  3. ZMA file containing impedance measurement of driver with added mass $m_2$
  4. The value of $m_1$ in grams
  5. The value of $m_2$ in grams

This app also provides an optional comment field. We recommended that you type the driver name into this field. An optional field for specification of the input voltage is also available. Specifying the voltage is not a requirement either, but it's good practice to notice this because we know that the parameter values will depend on the input level. Remember to fill out these optional fields before you complete entering the five inputs.

The comment field is the first entry in the data object such that if you open up the file in a text editor, you can read your comment in plain text (at the top). This will help you identify the measurement. When measuring your driver, we recommend that you follow our measurement procedure.

For the three measurements in the ZMA files, all three measurements must contain the same data points (at the same measurement frequencies). It is not allowed to e.g. reduce the frequency range for some of the measurements.

The fitting procedure

This app uses the data stored in the previously generated JSON data container to generate a nonlinear fit to the advanced driver model. The free-air impedance in this model is given by

\begin{equation} Z = R_\mathrm{E} + s L_\mathrm{EB} + \left( \frac{1}{R_\mathrm{SS}} + \frac{1}{s L_\mathrm{E}} + \frac{1}{\sqrt{s} K_\mathrm{E}} \right)^{-1} \end{equation} \begin{equation} \hspace{1.5cm} + \frac{(B\ell)^2}{sM_\mathrm{MS} + R_0 + \displaystyle \frac{1}{s C_0 \left[ 1 + \beta\ln(1+\omega_0/s)\right]}} \; . \end{equation}

The equivalent electrical circuit for the driver in free air is

electrical circuit diagram

The parameter $\omega_0$ is set to $\omega_0 = 1.5 \cdot 2 \pi f_s$, where $f_s$ (the driver resonant frequency in Hz) will be determined by the fitting process. Some aspects of the dual-added-mass algorithm are described in our AES article, whereas other aspects are proprietary. The fit procedure is complicated, but provides a robust and accurate estimation of the model parameters. The advanced model utilizes what we consider to be the best analytic forms for both the electrical impedance (the Thorborg-Futtrup inductance model) and the mechanical impedance (the Knudsen-Jensen LOG model of viscoelasticity, with the added Retardation Spectra function as described by Agerkvist-Ritter). The fit parameters are suitable for high-accuracy loudspeaker box simulations (for designing loudspeaker systems). Please note that all information (including input variables and results) is stored in your browser and nothing is saved to the server (not even temporary data). At the end you should export the data and save the results to your local hard drive. If you don't and close the browser window, the data will be lost.

To compute the fit, simply upload the JSON container of the previous section into the app.

The fit analyzes your data and the fit result and provides you with a quality rating: Excellent, Good, Fair or Sorry.

We published an article in the "Loudspeaker Industry Sourcebook 2020" about Speakerbench, which explains some aspects of the fitting and how to analyze the results. Please see LIS 2020 pages 124-131 [2].

The datasheet creator

The Import tab ('page') in the Datasheet Creator application is a simple way to load one of a few predefined drivers into the creator. When working with your own measurements, please ignore this.

The datasheet creator takes input from the fitter. The purpose of the creator is to add information to your dataset such that it becomes enough information to constitute a complete datasheet for the driver (but without frequency response graphs or other pictures). This complete dataset may be filed on your computer locally and/or shared with others.

To be able to save the data, you must add the Brand and Model number

Input box for brand name

as well as the effective piston driver area (or diameter)

Input box for Sd and/or Dd

It is customary to add $X_{MAX}$, which is found available under the Simple tab, but it is not required by Speakerbench although some box simulation software might require this.

Once these additional parameters are added, the data object will be sufficient for box modeling. Beyond the necessary input data, you can provide additional information for the datasheet which may be useful in extreme environments; for example, air parameters (air temperature, barometric pressure, relative humidity) which are used for calculating $V_{AS}$.

Note: When you hover your mouse over a parameter, a tooltip appears and provides a brief explanation.

Sample data files

Here we offer a set of data, which you can use for testing the Speakerbench application, to see how it works, without having to measure your own data. We include data for all steps in the process. Just right-click on the links below and select "Save As" for downloading.

Object Link Needed by
Driver unweighted ZMA file Collect data (1)
Driver plus 8.017 grams ZMA file Collect data (1)
Driver plus 16.048 grams ZMA file Collect data (1)
Full 3-measurement dataset JSON file Calculate fit (2)
Fit parameters JSON file Datasheet creator (3)

Box Simulation

The point of measuring the driver and determining the parameters is to simulate (predict) the behavior in a box, before it is actually built. Although limited to closed and vented boxes (no passive radiators yet), the Speakerbench box model is relatively sophisticated.

To load parameters for a driver into the box simulator, you need to use the Datasheet Creator app. When the data visible in the Datasheet Creator generates a JSON output, the data is stored in your local browser memory and 'automagically' shows up in the box simulator.

Hereafter you set box parameters in the 'Settings' tab and simulate the system behavior.

Two enclosure models are supported by Speakerbench:

  1. classic
    • The classic series resistance-compliance model for the enclosure as described by Small, Benson and others. This model serves as a simple reference.
  2. Beranek
    • A 2-port model for the enclosure matrix as outlined by Beranek-Mellow that includes acoustic mass elements derived by solving the Helmholtz equation. Losses and volume expansion due to fill are included. The mass elements computed by this model depend on box geometry.

For bass reflex simulation, Speakerbench supports two port models

  1. classic
    • The classic series mass-resistance model for vent impedance as described by Small, Benson and others.
  2. T-line
    • An arbitrary-frequency transmission-line model that includes reflections and pipe resonance. The dissipation in the vent is chosen to match the classic theory at low frequency.

The Beranek-Mellow transmission matrix formulation is used to implement all enclosure and vent options. The calculated results are reliable only for the low-frequency range, below the first box resonance. At the bottom of the Settings tab, Speakerbench optionally supports the import of an impedance measurement as well as a frequency response measurement (can be gain adjusted). This is helpful after having built the speaker to compare measurements with the simulation.

The Speakerbench box model supports simulation of the step response, enabled by toggling Time domain in the Settings tab. This is more calculation intensive, so we recommend to leave it off until you wish to look at the Step tab. There are two plots, the time-pressure-response to an electrical step-input-signal on top, and below it the pole-zero plot. Since Speakerbench implements an advanced transducer model, with viscoelasticity and semi-inductance, the time domain response is calculated with a contour integration algorithm, as documented in our 2018 AES article.

Alignment Chart

The Speakerbench box simulator provides an Alignment Chart, which might be helpful in selecting a suitable box volume and port tuning for your driver. The chart plots $\alpha = V_{AS}/V_B$ on the x-axis and $h = f_P/f_S$ on the y-axis. Within this chart, Speakerbench shows a blue cross with your current choice as well as some dots that represents well known alignments (known from Thiele/Small theory). These are:

Tag Name Comments
B4Q - B4CA Butterworth Optimal $Q_T \approx 0.38 - 0.40$. Lossless $Q_T \approx 0.3827$. Where B4Q = QB3 (and SQB3) known from classic theory.
LR4Q - LR4CA Linkwitz-Riley Optimal $Q_T \approx 0.35 - 0.37$. Lossless $Q_T \approx 0.3536$.
IB4Q - IB4CA Inter-Order Butterworth Optimal $Q_T \approx 0.34 - 0.36$. Lossless $Q_T \approx 0.3398$. IB4Q is a special case of B4Q (= QB3).
BL4Q - BL4CA Bessel Optimal $Q_T \approx 0.31 - 0.33$. Lossless $Q_T \approx 0.3162$.
CD4Q - CD4CA Critically-Damped Optimal $Q_T \approx 0.25 - 0.27$. Lossless $Q_T = 0.25$.
B4-LR4 Transitional B4 and LR4 For $0.36 < Q_T < 0.39$, this is a transitional alignment between LR4 and B4
C4 - SC4 Chebychev and Sub-Chebyshev For $0.236 < Q_T < 1.416$. Below Butterworth $Q_T$ the Sub-Chebyshev without ripple is shown.
BB4 - SBB4 Boombox and Sub-Boombox For $0.20 < Q_T < 0.75$. Below Linkwitz-Riley $Q_T$ the Sub-Boombox without a peak is shown.
B2 Butterworth 2nd-order ($Q_{TC} = 1 / \sqrt{2} \,$) For driver $Q_T < 0.67$, this is a closed box alignment ($f_P = 0 \longleftrightarrow h = 0$)
BL2 Bessel 2nd-order ($Q_{TC} = 1 / \sqrt{3} \,$) For driver $Q_T < 0.55$, this is a closed box alignment ($f_P = 0 \longleftrightarrow h = 0$)

With your mouse/pointer you may click anywhere inside the chart. Speakerbench registers the pixel where you clicked and the associated $\alpha$ and $h$ values, and when you go back to the Settings tab and push the APPLY button, the box volume and port tuning is updated accordingly.

Note: For the discrete alignments, Speakerbench only shows the ones that are a reasonably good fit to the driver you have loaded. Unobtainable alignments are omitted. The assessment is made by evaluating how close the Quasi and the Compliance Alteration suggestions are to each other.

You can think of each discrete alignment as having potentially three algorithms, represented by an i, a CA, or a Q extension; for example, the 4th-order Butterworth could be represented by B4i, B4CA, and B4Q (historically B4Q is named QB3).

A bit complicated, maybe, but you will notice that if the two dots (CA and Q) associated with the same discrete target alignment are far apart, it is quite a 'stretch' to get something that meets the desired target alignment. On the other hand, if the CA and Q dots are close (for the same alignment), then your driver at hand is a good candidate for obtaining a frequency response close to this particular target alignment.

Note that the table indicates an 'optimal' driver $Q_T$ for obtaining the target response, but please note that the theory isn't an exact science, and in practice the real frequency response will deviate, as can be observed in the Speakerbench SPL tab.

For further information, please see our in-depth documentation about Alignments, and check out the article series about alignments [6], [7], [8], [9], [10], [11], [12], and [13]. P.S. The math in the articles published online is crippled. For better-looking math, please see the paper or PDF version of the magazines. With a subscription, they are available at KCK Media / Circuit Cellar.

[1] The Speakerbench YouTube channel.

[2] The Loudspeaker Industry Sourcebook (LIS) 2020 pages 124-131. The article is published in (browser friendly) HTML here: LIS 2020 Industry Feature article.

[3] We wrote a two-part article series in the AudioXpress magazine on how to analyze losses (Q-values) in the cabinet. The articles are published as open access and here you can read Part 1 and Part 2.

[4] The diyAudio forum thread about Speakerbench.

[5] The AV Nirvana forum thread about the dual added mass method and Speakerbench.

[6] AudioXpress January 2024 article about alignments and their history.

[7] Voice Coil Magazine May 2024 article about computation of classical alignments.

[8] Voice Coil Magazine June 2024 article about the LR4 (Linkwitz-Riley) alignment.

[9] Voice Coil Magazine July 2024 article about the IB4 (Inter-Order Butterworth) alignment.

[10] Voice Coil Magazine August 2024 article about the CD4 (Critically Damped) alignment.

[11] Voice Coil Magazine September 2024 article about Transitional alignments.

[12] Voice Coil Magazine October 2024 article about Compliance Alteration.

[13] Voice Coil Magazine January 2025 article about Quasi-Alignment Families. (Not available online)

About

Speakerbench Copyright © 2020-2025 by Jeff Candy and Claus Futtrup.

Disclaimer: No warranty on anything. This software is free but copyrighted. It is not public domain. All calculations are without any kind of warranty as well. No reliability can be guaranteed, at all.