doc finalization: sample

This commit is contained in:
tildearrow 2023-09-09 23:52:30 -05:00
parent 087f6214fd
commit 45e7b4ac0b

View file

@ -1,8 +1,8 @@
# samples # samples
In the context of Furnace, a sound sample (usually just referred to as a sample) is a string of numbers that represent sampled PCM audio. in the context of Furnace, a sound sample (usually just referred to as a sample) stores a sound.
In Furnace, these samples can be generated by importing a .wav (think of it as an higher quality MP3) file. in Furnace, these samples can be generated by importing a .wav file.
## supported chips ## supported chips
@ -10,28 +10,34 @@ the following sound chips have sample support:
- NES/Ricoh 2A03 (with DPCM support and only on channel 5) - NES/Ricoh 2A03 (with DPCM support and only on channel 5)
- Sega Genesis/YM2612 (channel 6 only) - Sega Genesis/YM2612 (channel 6 only)
- PC Engine/TurboGrafx-16/HuC6280 - PC Engine/TurboGrafx-16
- Amiga/Paula - Amiga
- SegaPCM - SegaPCM
- NEC PC-9801/YM2608 (ADPCM channel only) - YM2608 (ADPCM channel only)
- Neo Geo/Neo Geo CD/YM2610 (ADPCM channels only) - YM2610(B) (ADPCM channels only)
- Seta/Allumer X1-010 - Seta/Allumer X1-010
- Atari Lynx - Atari Lynx
- MSM6258 and MSM6295 - MSM6258
- YMU759/MA-2 (last channel only) - MSM6295
- QSound - QSound
- ZX Spectrum 48k (1-bit) - ZX Spectrum 48K (1-bit overlay)
- RF5C68 - RF5C68
- SNES/S-DSP - SNES
- WonderSwan (second channel only) - WonderSwan (channel 2 only)
- tildearrow Sound Unit - Sound Unit
- VERA (last channel only) - VERA (last channel only)
- Y8950 (last channel only) - Y8950 (last channel only)
- Konami K007232 - Konami K007232
- Konami K053260
- Irem GA20 - Irem GA20
- Ensoniq OTTO/ES5506 - Ensoniq OTTO/ES5506
- Yamaha PCMD8/YMZ280B - Yamaha PCMD8/YMZ280B
- MMC5 (last channel only) - MMC5 (last channel only)
- VRC6 (software!)
- AY-3-8910 (software!)
- AY8930 (software!)
- Namco C140
- Namco C219
## compatible sample mode (LEGACY) ## compatible sample mode (LEGACY)
@ -50,18 +56,18 @@ due to limitations in some of those sound chips, some restrictions exist:
- NES: if on DPCM mode, only a limited selection of frequencies is available, and loop position isn't supported (only entire sample). - NES: if on DPCM mode, only a limited selection of frequencies is available, and loop position isn't supported (only entire sample).
- SegaPCM: your sample can't be longer than 65535, and the maximum frequency is 31.25KHz. - SegaPCM: your sample can't be longer than 65535, and the maximum frequency is 31.25KHz.
- QSound: your sample can't be longer than 65535, and the loop length shall not be greater than 32767. - QSound: your sample can't be longer than 65535, and the loop length shall not be greater than 32767.
- Neo Geo (ADPCM-A): no looping supported. your samples will play at 18.518KHz. - ADPCM-A: no looping supported. your samples will play at around 18.518KHz.
- Neo Geo (ADPCM-B): no loop position supported (only entire sample), and the maximum frequency is 55.555KHz. - ADPCM-B/YM2608: no loop position supported (only entire sample), and the maximum frequency is 55.555KHz.
- YM2608: the maximum frequency is 55.555KHz.
- MSM6258/MSM6295: no arbitrary frequency. - MSM6258/MSM6295: no arbitrary frequency.
- ZX Spectrum Beeper: your sample can't be longer than 2048, and it always plays at ~55KHz. - ZX Spectrum Beeper: your sample can't be longer than 2048, and it always plays at ~55KHz.
- Seta/Allumer X1-010: frequency resolution is terrible in the lower end. your sample can't be longer than 131072. - Seta/Allumer X1-010: frequency resolution is terrible in the lower end. your sample can't be longer than 131072.
- C219: sample lengths and loop will be set to an even number, and your sample can't be longer than 131070.
furthermore, many of these chips have a limited amount of sample memory. check memory usage in window > statistics. furthermore, many of these chips have a limited amount of sample memory. check memory usage in window > statistics.
# the sample editor # the sample editor
you can actually tweak your samples in Furnace's sample editor, which can be accessed by clicking on `window` (at the top of the screen) then clicking on `sample editor`. you can edit your samples in Furnace's sample editor, which can be accessed by clicking on `window` (at the top of the screen) then clicking on `sample editor`, or by double-clicking a sample in the sample list.
the changes you make will be applied as soon as you've committed them to your sample, but they can be undone and redone, just like text. the changes you make will be applied as soon as you've committed them to your sample, but they can be undone and redone, just like text.
@ -81,19 +87,25 @@ in there, you can modify certain data pertaining to your sample, such as the:
- Right-clicking brings up a menu: - Right-clicking brings up a menu:
- **save raw...**: brings up a file selector, then saves the sample as raw data. - **save raw...**: brings up a file selector, then saves the sample as raw data.
- **Name**: name in sample list. - **Name**: name in sample list.
- button to left of **Info**: collapses and expands the info bar. - button to left of **Info**: collapses and expands the info section.
- **Type**: sample format. only 8-bit and 16-bit PCM samples are editable. selecting a format converts the sample data. - **Type**: sample format.
- **BRR emphasis**: boosts higher frequencies to compensate for the SNES low-pass filter. should not be enabled for BRR-type samples. only appears when applicable. - only 8-bit and 16-bit PCM samples are editable.
- **8-bit dither**: applies dithering to samples meant to play back at 8-bit resolution. only appears when applicable. - selecting a format converts the sample data.
- **BRR emphasis**: boosts higher frequencies to compensate for the SNES low-pass filter.
- should not be enabled for BRR-type samples.
- only appears when applicable.
- **8-bit dither**: applies dithering to samples meant to play back at 8-bit resolution.
- only appears when applicable.
- **Rate**: switches to normal rate values. - **Rate**: switches to normal rate values.
- **Compat Rate**: switches to DefleMask-compatible rate values for sample mapping. - **Compat Rate**: switches to DefleMask-compatible rate values for sample mapping.
- **use of this is discouraged!**
- **Hz**: base frequency of sample played at `C-4`. - **Hz**: base frequency of sample played at `C-4`.
- **Note**: note corresponding to Hz. - **Note**: note corresponding to Hz.
- **Fine**: fine tuning. ranges from -64 to 63, which maps to -1 to almost +1 semitone. - **Fine**: fine tuning. ranges from -64 to 63, which maps to -1 to almost +1 semitone.
- **Loop**: enable or disable sample loop. only on supported chips. - **Loop**: enable or disable sample loop. only on supported chips.
- **Mode**: direction of loop. backward and ping pong loops are only natively available on some chips; on others, loop will be automatically unrolled as needed. - **Mode**: direction of loop. backward and ping pong loops are only natively available on some chips.
- **Start**: start of loop. - **Start**: start of loop.
- **End**: end of loop. - **End**: end of loop.
@ -126,7 +138,8 @@ in there, you can modify certain data pertaining to your sample, such as the:
- **Trim**: removes all but selection. - **Trim**: removes all but selection.
- **Reverse**: reverses direction of selection. - **Reverse**: reverses direction of selection.
- **Invert**: flips selection "vertically". - **Invert**: flips selection "vertically".
- **Signed/unsigned exchange**: reinterprets selection data as being of the opposite sign. if a sample sounds fine elsewhere but is distorted on import, it may have been interpreted as signed when it should be unsigned, or vice versa; this will correct that. - **Signed/unsigned exchange**: reinterprets selection data as being of the opposite sign.
- if a sample sounds fine elsewhere but is distorted on import, it may have been interpreted as signed when it should be unsigned, or vice versa; this will correct that.
- **Apply filter**: filters the selection. pops up a dialog box: - **Apply filter**: filters the selection. pops up a dialog box:
- **From**: filter cutoff frequency at start of selection. - **From**: filter cutoff frequency at start of selection.
- **To**: filter cutoff frequency at end of selection. - **To**: filter cutoff frequency at end of selection.
@ -137,6 +150,6 @@ in there, you can modify certain data pertaining to your sample, such as the:
- **High-pass**: amount to attenuate everything below cutoff. - **High-pass**: amount to attenuate everything below cutoff.
- **Preview sample**: plays sample at base frequency. - **Preview sample**: plays sample at base frequency.
- **Stop sample preview**: stops preview. - **Stop sample preview**: stops preview.
- **Create instrument from sample**: creates a new instrument with its initial sample set to the current sample. - **Create instrument from sample**: creates a new instrument with its sample set to the current sample.
- **Zoom**: shows and sets sample view zoom level. - **Zoom**: shows and sets sample view zoom level.
- **Zoom mode**: switches between "Auto" (entire sample fits in window) and "100%" (each horizontal pixel represents one sample point). - **Zoom mode**: switches between "Auto" (entire sample fits in window) and "100%" (each horizontal pixel represents one sample point).