Psychology/Neuroscience Experiments
in MATLAB Built on Psychtoolbox
MATLAB software built on Psychtoolbox for neuroscience/psychology experiments

Psychtoolbox is a popular MATLAB toolbox for neuroscience and psychology experiments. Building experiments in MATLAB with Psychtoolbox allows a degree of flexibility and precision that is essential in many research niches. However, it can be a technical and time consuming process. Redundancy is also a problem as reusing stimuli and functionality means refactored code across different experiments, or even reinventing it across labs.

PsychBench is software for MATLAB built on Psychtoolbox. It adds a layer to make building Psychtoolbox-based experiments faster, more accessible, and less repetitive. It aims to do this while retaining both the flexibility and precision of Psychtoolbox. You can choose between the visual method based in any spreadsheet app (Google Sheets allows dropdown menus and quick docs) or the coding method using a MATLAB script. An open-source library comes with a range of object types for stimuli and functionality. You can also add your own stimulus types to the library in MATLAB + Psychtoolbox code.

Download PsychBench beta (free)
for MATLAB with Psychtoolbox – Windows/macOS/Linux

This link downloads the MATLAB function pb_install.m. Run it from the MATLAB command line. You can type help pb_install for more information.

You'll also need...

Windows / macOS / Linux – 64-bit

MATLAB R2017b or later
(R2019a+ for visual method of making experiments, R2021a+ recommended)

PsychBench does not run in GNU Octave.

Psychtoolbox most recent version

Psychtoolbox requires GStreamer (free):
        Windows: GStreamer 64-bit MSVC runtime 1.22.5
        macOS (Intel and ARM): GStreamer runtime 1.22.5
        Linux: generally already installed

System requirement details >

Update history >

(Trouble updating?)

In earlier versions, bugs in Google's cloud API may preventing updating (newer versions use a different cloud service). If you get an error using pb_update, please update manually: delete the PsychBench folder, remove it and its subfolders from the MATLAB search path (MATLAB toolbar → Set Path), and reinstall with the most recent version using the download link above.

Experiments

Visual method

In the visual method we lay trials out in one or more tables in a spreadsheet. You can use any Excel-compatible spreadsheet app—Google Sheets is good since it gives you dropdown menus and quick docs. Rows are trial definitions. Columns are object properties. Values are MATLAB values or expressions. You only need to define each distinct trial once, and in any order. Then use a MATLAB expression to set a list of trial definitions to run through, including any repetition and ordering. Save or export to an Excel file. Then in MATLAB use the command loadExperiment to load it, and runExperiment to run.

For example, the two tables below would make an experiment that runs two repetitions of three distinct trials, all in random order. In each trial, a picture of an animal shows at trial start (the default) at a height of 8 degrees visual angle. The picture stops showing when the subject responds by any key press. Experiment results report picture file name and response latency for each trial. (See examples and demos for more realistic examples.)

Coding method

In the coding method the concepts are the same but we write a MATLAB script to build the experiment. This gives you all the flexibility of MATLAB, which may be needed for complex experiments. That said, it's not really code in the usual sense, more like a list of statements setting parameters. You can use for loops through conditions to automate defining trials. (Also note it's still possible to work semi-visually in the coding method using an optional tool sheet2vars.)

Here is the same experiment as above:

(Without PsychBench)

For comparison, here is some compact Psychtoolbox code that would run the same experiment, with the same timing precision and error handling. The difference with/without PsychBench is noticeable here but it balloons up for more realistic experiments.

Feature highlights

In the coding method make an experiment in a MATLAB script for full flexibility, optionally using spreadsheet tables to assist (tool sheet2vars). Or in the visual method you can make low to moderate complexity experiments in any spreadsheet app (Google Sheets allows dropdown menus and quick docs).
Organize experiments in terms of objects from a library of object types. Any object works anywhere in any experiment.
Set objects to start/end based on times or durations or on flexible cues like other objects, responses from subject, triggers, etc. Further timing is available through object types like sequence (e.g. for change blindness experiments).
Precise timing and time measurement, including time-buffering stimulus onsets/offsets, and synchronizing across modalities (visual, auditory, etc.). A technical summary of timing processes is here.
Properties all visual objects have allow setting position on screen, drift/movement, layering, rotation, flip, transparency, intensity, contrast, convolution, noise, gamma, custom shaders, additive blending, and more. More specific functionality is in each object type.
Default units of degrees visual angle for all values relating to distance on screen, including deg, deg/sec (e.g. speed), cycles/deg (e.g. spatial frequency), etc. Optionally use other units like px, cm, proportion of window size, etc.
Stereo display by most of the modes available in Psychtoolbox.
Record any visual stimulus to image file, series of image files, or movie file.
Sound playback and recording built on Psychtoolbox's PortAudio functions.
Tools and options for replication and randomization, including counterbalancing with respect to one or more variables independently or jointly.
Core response functionality including recording responses, times and latencies, translating response values, scoring, and more. More specific functionality is in each response handler object type (key press, text, mouse, button box, etc.).
Use system-independent key names.
Test any experiment by running it in auto response mode to simulate a subject run unattended.
Customizable experiment results output drawing from any object properties or custom information, saved in both .mat and .csv files.
Sync experiments with external devices like scanners within or across trials. Set timing relative to sync with zero drift.
Method of adjustment experiments where the subject can adjust object properties in real time. More specific functionality is in each adjuster object type (key press, mouse, etc.).
Staircase any property of any object using staircase objects (fixed step, QUEST, etc.).
Save and resume an experiment run to split it across multiple sessions.

Open-source object type library

PsychBench comes with a library of open-source (MATLAB + Psychtoolbox) object types.

We add new object types regularly. Please contact us with requests.

Visual

Auditory

Response handlers

Adjusters

Other

Custom code

If the library doesn't have the stimuli you need for an experiment, you can write your own code in MATLAB + Psychtoolbox. The approach is to write it as a new object type in your library—this allows you to use the code anywhere and have it work with all core functionality (timing, core visual options, staircasing, results output, etc.). You can make a quick type, or you can make a durable type with more flexibility and a fuller interface for other users. All the standard types that come with PsychBench are open source, so you can use them as examples and/or build off them.

Sharing object types

You can share an object type with other people just by zipping the type's folder and emailing it.

You can also contribute a type to the library that comes with PsychBench. If you would like to do this, please contact us. We would be happy to credit you. And thank-you!

Getting started / Making an experiment >

All documentation >

PsychBench has been supported by