Instrument Banks

Pre-designed instrument patches are immediately available in banks. These in turn are contained within a bank root. These bank roots are themselves contained in a root path. The entire structure bearing a direct relationship to MIDI Program Change, Bank LSB and Bank MSB controllers respectively. For normal work that gives up to 128 Instruments in 128 banks in 128 Roots - potentially over 2 million! Yoshimi actually has an extra 32 Instruments in each bank which are only accessible to MIDI using a custom extended program change control.

Note that Yoshimi uses the standard MIDI numbers, starting from 1 for program (instrument) changes, and 0 for banks and roots.

As well as instrument files themselves, a bank will have a hidden ID file .bankdir. This serves two purposes. It speeds up bank searches. If this is present there is no need to positively identify at least one instrument. It also contains the version number from the last time it was updated.

We advise against making any changes to the bank structure through any external means (such as a desktop filer) as it is possible to invalidate Yoshimi's records and cause it to perform a complete bank reset. This in turn could change all the MIDI numbers, breaking any previous projects.

An instrument bank

This first image is of a typical instrument bank, and the first item at the top is a menu of alternative banks. Following this is a button that opens the instrument Search window for loading an instrument by its type classification from any bank at all. Next is a button that takes you to the Root paths window, and finally there is one for the Bank roots window.

The menu is quick to use when changing banks, but doesn't give you the flexibility of using the buttons for bank roots and root paths. In particular, a right hand mouse click on these buttons will close this window while opening the wanted one, and a right-click on the Close button (bottom right) will return you to where you came from.

Below this is a table of all the instruments in the current bank, with coloured backgrounds indicating what engine types are being used. In order, these are AddSynth, SubSynth, PadSynth (a reminder is shown at the bottom of the window).

Clicking on one of these will load the instrument into the currently selected part, and highlight it in the bank, so you can easily see where it came from. If selected with a right-click it will also close the window. If the virtual keyboard is visible, then it will be given keyboard focus so you can use it to quickly try out different sounds.

The buttons on the bottom row determine what action is to be performed when clicking on an instrument. The coloured underscore shows which is the currently active one, and by default it will be Select.

With these buttons, you set the operation you want to perform before clicking on an entry, and regardless of whether the action is successful or not, it will always return to 'Select' Also, the next four buttons will only work where you have filesystem write permission, as they all make actual file changes.

Rename When chosen, clicking on an instrument entry a small editable window will be opened with the existing name. Changing this will change the name here and the actual filename. It will not change the name of the current part.

Save Clicking on a table slot will save the currently selected part to that location. If there is already an entry there, you will be asked if you want to overwrite it. It will not save the default 'Simple Sound'. There would be no point, as that can easily be recovered by clearing the instrument.

Delete This asks for confirmation before permanently removing the selected Instrument.

Swap This is a two stage operation. You select one instrument (which will then be highlighted) followed by either a second instrument to actually swap with, or an empty slot to just move it to a new location. Additionally, after making your first selection you can change bank, or even bank root before making the second selection, so you can move and swap right across the entire bank structure.

divider

A bank root

A bank root

There are just two buttons on the top row of this window. One taking you to the Root paths and the other to the currently selected Instruments bank. These buttons behave in the same way as before, with a right-click closing this window as it opens the next.

The table of banks also behaves in a similar way to the Instruments one.

The first four buttons on the bottom row also operate in the same way. However, when deleting you will be warned that you will also be completely removing the instrument files, and exactly how many there are.

We suggest you avoid Bank 0, as this is the one that many sequencers automatically send from time to time. Yoshimi reports attempts to access non-existent banks, but otherwise does nothing.

Import If you want to add a bank obtained from elsewhere (via the Internet for example) this provides a safe managed way of doing so without disturbing the rest of your bank setup. After setting this option click on an empty bank slot and you will be given a filer window to identify the bank you wish to import. Use the normal controls to find it, then instead of using the navigation controls click on the filer's Import button. This will only install actual instrument files, any others or subdirectories will be ignored. Once installed, you can rename it if you wish.

Export This also operates in a managed way. It will not allow you to overwrite existing directories, not even bank ones. On selecting a bank for export you will again get a filer window for deciding where you want it to go, but the Name field will also be active so you can change it to something else. This will copy out the entire contents of the bank - it doesn't expect to find anything other than instruments and the bank ID.

divider

A root path

Root paths

As you can see, the behaviour of this window is quite different to the others. First there is a list of the known bank root paths, preceded by their MIDI numbers. The one with a following '*' is the one currently in use.

Add root directory Clicking on this will open a filer window so that you can choose a directory. Note this is a directory containing banks, not a bank itself. When you've reached the required one, clicking on the From button will add it to the list and make it the current one. If there were no banks in that directory the filer will offer to make one, and place an instrument in it. To do this it has to use part 1, so overwrites anything that may be there.

Remove root dir You first need to click on the path you want to remove before this operation becomes active. This doesn't actually delete the directory or its contents, but simply removes it from the path list.

Make current Makes a chosen root path the current one, but doesn't open it.

Open Current Provides a convenient way to open a bank root. As usual, a right-click will close this one at the same time.

Finally there is a spin box enabling you to change the MIDI number of the selected one. This can be any number between 0 and 127. It is only a number change. No files are moved. When changing this, a button will appear marked 'Pending'. The change is only made and the list position moved once this is clicked. If you set it to the number of an existing one the two will swap places. It also makes this the current root path.

We suggest you avoid Root 0, as this is the one that many sequencers automatically send from time to time. Yoshimi reports attempts to access non-existent roots, but otherwise does nothing.

Note
.local/share/yoshimi/found/yoshimi/banks is a root path automatically created on first time startup, and is a copy of the installed default one. It is provided so that you have the contents in a form that you can add to, move around and edit. You can't do this with the default ones.

divider Back to top

Back to Bank Root Next (Parts and Channels)