vgmrips / vgmtools

A collection of tools for the VGM file format
GNU General Public License v2.0
125 stars 18 forks source link

VGM Tools

by Valley Bell (@valleybell)

Tool List

dro2vgm - DRO to VGM Converter
imf2vgm - IMF to VGM Converter
opl_23 - OPL 2<->3 Converter
opt_oki - VGM OKIM6258 Optimizer
optdac - VGM DAC Optimizer
optvgm32 - VGM PWM Optimizer
optvgmrf - VGM RF-PCM Optimizer
raw2vgm - RAW to VGM Converter
vgm_cmp - VGM Compressor
vgm_cnt - VGM Command Counter
vgm_dbc - VGM Data Block Compressor
vgm_dso - VGM DAC Stream Optimizer
vgm_facc - Make VGM Frame Accurate
vgm_mono - VGM Mono
vgm_ndlz - VGM Undualizer
vgm_ptch - VGM Patcher
vgm_ren - VGM Renamer
vgm_smp1 - Remove 1 Sample Delays
vgm_sptd - VGM Splitter (Delay Edition)
vgm_spts - VGM Splitter (Sample Edition)
vgm_sro - VGM Sample-ROM Optimizer
vgm_stat - VGM Statistics
vgm_tag - VGM Tagger
vgm_tt - VGM Tag Transfer
vgm_trim - VGM Trimmer
vgm_vol - VGM Volume Detector
vgm2txt - VGM Text Writer
vgmlpfnd - VGM Loop Finder
vgmmerge - VGM Merger

DRO to VGM Converter (dro2vgm)

This tool converts DRO files (DOSBox RAW OPL) to VGM.

These DRO-versions are supported:

Version DosBox Release Date
0 0.61 4 Jul 2004
1 0.63 18 Nov 2004
2 0.73 14 Jul 2008

Note: The program may print a warning about incorrect delays. That's caused by old DRO-files (v0 and v1) because of the way DOSBox logs them. The program already HAS a detection to detect and fix some of these bugs, so most files should work.

IMF to VGM Converter (imf2vgm)

This tool converts IMF files (id Software Music Format) to VGM.

It supports IMF type-0 and type-1 files. The type is autodetected, but you can override the auto-detection with "-Type0" or "-Type1".

Note: The actual playback speed of IMF files depends on the game they are from. The files themselves contain no information about the actual playback speed.

Currently, the playback speed defaults to 700 Hz for files that use the .WLF extension and to 560 Hz for all others.

You can override the playback speed with the "-Hz" parameter.

The resulting VGMs can be forced to loop with the "-Loop" parameter.

OPL 2<->3 Converter (opl_23)

This handy tool allows you to convert between "single OPL2", "dual OPL2" and OPL3 VGMs. It can help you if you accidentally logged music with the wrong "oplmode" setting in DOSBox.

The tool can convert in 3 ways and performs additional actions, depending on the mode.

VGM OKIM6258 Optimizer (opt_oki)

This tool scans streamed OKIM6258 data (from VGM logs of X68000 games) and optimizes them into "play sample" commands for the VGM "DAC Stream" system.

As of June 2022, the tool is stable and easy to use. However the VGMs need to log the X68000 DMA commands. These commands are logged by XM6 VGM mod, 2021 release and MAME VGM mod 0.236 and later.

Note: The tool does a slightly fuzzy sample detection by default. (It ignores the last 4 bytes of each PCM sample.) The fuzzy comparision can be disabled using the -nofuzz parameter.

The tool will dump all PCM samples if you pass the -dump parameter.

VGM DAC Optimizer (optdac)

This tool cleans up YM2612 DAC writes.

I wrote this tool for optimizing logs of the MegaDrive version of "Worms".

The game uses a multi-channel DAC driver and constantly streams data to the YM2612's DAC channel. So when no sample is playing, it will constantly write the byte 0x80.

This tool detects when the same value is consecutively written 128 times or more to the DAC and removes all of them but the first one.

This allows optvgm to work better on VGM logs of this game.

This is a very special case though and using the tool on games that don't constantly write to the DAC might make the optvgm optimization worse. So please use with caution!

VGM PWM Optimizer (optvgm32)

NOTE: still in pre-alpha and not for public use

This tool is supposed to optimize the Sega 32X PWM data writes into data blocks.

I never got the actual detection of "repeating data" done, so right now it just turns everything into one large stream. (with synchronization commands every second)

VGM RF-PCM Optimizer (optvgmrf)

If you know optvgm, you know what optvgmrf does. (Internally it works completely different, but the result is the same.)

This tool optimized VGM files, that use PCM chips of the RF-family (RF5C68 and Sega MegaCD's RF5C164).

The file size of optimized files usually decreases to 5-10%.

The resulting output-file will be updated to vgm v1.60.

RAW to VGM Converter (raw2vgm)

This tool converts RAW files (Rdos Raw OPL Capture) to VGM.

The resulting VGMs can be forced to loop with the "-Loop" parameter. If the RAW file uses two OPL chips, the VGM will use two centered YM3812 chips.

VGM Compressor (vgm_cmp)

This tool can greatly reduce the size of a VGM by stripping unneccessary commands. Delays are also highly optimized.

The file size of compressed files usually decreases to 50-60% (Sega Master System with YM2413) or 15-40% (NeoGeo Pocket).

Usage: vgm_cmp [-justtmr] Input.vgm [Output.vgm]

If you insert the argument -justtmr, vgm_cmp will only strip commands that can't affect the playback in any way.

Notes:

VGM Command Counter (vgm_cnt)

This tool counts the commands/notes for each chip.

TODO: better description

VGM Data Block Compressor (vgm_dbc)

This tool optimizes VGM "Sample Database" blocks using lossless bit-packing, where possible.

TODO: better description

VGM DAC Stream Optimizer (vgm_dso)

This tool optimizes VGMs that use DAC Stream command 0x93 (Play From Offset) to use command 0x95 (Play Data Block)

TODO: better description

Make VGM Frame Accurate (vgm_facc)

This tool does exactly what is says - it rounds all delays to frames.

You can set the Frame Rate with VGMTool ("Playback rate").

All rates are accepted as long as a can be rounded to whole samples (44100 % Rate = 0).

WARNING: You should NOT use this tool unless you know EXACTLY what you are doing!

The only time you may want to use this tool is when:

Even then, make sure the left/right errors aren't too high, else you will introduce jitter.

After a conversion is finished, the rounding statistics are displayed. They show the maximum rounding errors (OldSample - RoundedSample) relative to the beginning of the frames.

Line 1: Left Error [always negative or 0]

Line 2: Right Error (all but 1st frame)

Line 3: Right Error (1st frame only)

The 3rd line is included, because initialisation can take many commands and takes more time than the rest of a song.

If the value of the first and/or the second line is quite high (e.g. >= 300 for 60 Hz) a frame accurate conversion is a bad idea.

Note: Even delays of 65535 samples are rounded. (e.g. to 65415 for 60 Hz)

VGM Mono (vgm_mono)

This tool makes VGMs mono, works with YM2610, YMF278B, YMW258/MultiPCM and X1-010.

TODO: better description

VGM Undualizer (vgm_ndlz)

This tool splits one VGM with "2x chip" into two VGMs with "1x chip" each.

TODO: better description

VGM Patcher (vgm_ptch)

general VGM patching utility, allows editing the VGM header (chip clocks/chip settings), checking/fixing VGMs and stripping chips/channels.

TODO: better description

VGM Renamer (vgm_ren)

This tool renames a VGM so that its file name follows the VGM's title tag.

When a playlist is given, track numbers are added and the playlist is rewritten with the new file names. The tool can also be used to easily renumber all files after changing the track order.

Remove 1 Sample Delays (vgm_smp1)

This tool helps to reduce the size of VGMs by removing delays of 1 sample length.

Example:

Delay 12 - Event A - Delay 1 - Event B - Delay 5

is rounded to:

Delay 12 - Event A - Event B - Delay 6

You may use this tool with:

You should NOT use this tool with:

Note: If you remove samples from VGMs compressed with vgm_cmp you should run vgm_cmp again. It may reduce the file size by some bytes.

VGM Splitter (Delay Edition, vgm_sptd)

This tool splits a vgm file into smaller pieces. This is useful if you record many songs to one file (e.g. in MAME or MESS).

It splits after a certain delay which you have to enter after the filename. It's given in samples, 1 second has 44100 samples in VGMs. (default is 32768)

The delay where a file is split is stripped, so you shouldn't have any silence at the beginning or end of the file.

Note: Sometimes it seems to produce some empty files if you use delay values >= 65536, but all others should be bug-free.

VGM Splitter (Sample Edition, vgm_spts)

This tool splits a vgm file into smaller pieces. This is useful if you record many songs to one file (e.g. in MAME or MESS).

The difference to the tool above is, that you have to enter the sample where you want to split the file. Entering 0 (simply pressing enter without typing has the same effect) closes the program.

The delay where a file is split is stripped, so you shouldn't have any silence at the beginning or end of the file.

Notes:

VGM Sample-ROM Optimizer (vgm_sro)

Like vgm_cmp, this tool can greatly reduce the size of a VGM. It strips unused data from Sample-ROMs.

The file size of optimized files usually decreases to 5-10%.

Before any data is stripped, vgm_sro will display all ROM Regions. So you can see what data is stripped.

The following chips are supported:

Notes:

VGM Statistics (vgm_stat)

This tool prints song length/loop length statistics for a folder or M3U playlist.

TODO: better description

VGM Tagger (vgm_tag)

This tool allows VGM tagging via commandline, HTML NCRs can be used in place of Unicode characters.

TODO: better description

VGM Tag Transfer (vgm_tt)

This tool transfers tags and/or file names of VGMs from one folder to the VGMs of another folder, based on song/loop length.

TODO: better description

VGM Trimmer (vgm_trim)

This is a simple vgm trimmer. It's recommended to use it if you have a completely clean loop (e.g. one found with the VGM Loop Finder).

You will be asked for a file name and three sample positions.

In order to make a safe but optimized trimming, the following commands are rewritten:

Commandline Usage: vgm_trim [-state] Input.vgm StartSmpl LoopSmpl EndSmpl [Output.vgm]

If you insert the argument -state then vgm_trim will put a save state of all used chips at the beginning of the VGM.

You can use this, if the instruments don't want to sound right even with silence at the beginning.

Notes:

VGM Volume Detector (vgm_vol)

This tool detects the peak volume of WAV files logged from VGMs.

TODO: better description

VGM Text Writer (vgm2txt)

This tool converts a VGM to a text file.

It's not as good as the vgm2txt of VGMTool (it doesn't print note names or frequencies), but supports VGM version 1.60 and almost all current chips.

Notes:

VGM Loop Finder (vgmlpfnd)

This tool can be a big help if you search for loop points.

It searches for blocks that match exactly, but have a different position in the file. Delays are ignored to make things possible.

After opening a file and entering a Step Size (higher values speed things up, lower ones are more accurate), and another 2 values there is a display like this:

     Source Block         Block Copy       Copy Information
Start   End Smpl    Start   End Smpl    Length  Cmds    Samples

It searches for matching blocks, so there's a "Source Block" and a "Block Copy". Each block has a start and end position (byte-values in hex) and also a sample start position. Copy Information shows the block length in bytes ("Length"), commands ("Cmds") and samples ("Samples").

If Source Block: End is greater than Block Copy: Start or at least equal, then congratulations - you have found the loop! However, don't forget to check the length of your loop or else you might cut the tune.

Then you can copy the sample values to a VGM Trimming tool of your choice - Source Block: Smpl as Loop Point and Block Copy: Smpl as End Point. (In this case vgm_trim should work well.)

Sometimes there are some letters shown before the Source Block: Smpl value:

While searching, you can press "Pause" to pause the search. (Press any other key to continue.) And you can press Ctrl + C to close the program. I'm sure you will WANT to do this if your file is big.

Successfully tested with:

There's absolute no way to use it with:

Some music engines that use the SN76496 or T6W28 seem to shuffle the order of commands sometimes. Music engines with dynamic channel allocation (like GEMS on MegaDrive) make it impossible to find loops.

Multi-chip-systems also may not work very well.

To speed the search and make it possible to find loops the following commands are ignored:

Notes:

VGM Merger (vgmmerge)

This small tool merges two (or more) vgms into one.

That's it. Really. You can use it e.g. to combine 2 mid2vgm files to get YM2413 + YM2612.

Usage: vgmmerge [-f:#] [-nodual] Input1.vgm Input2.vgm [Output.vgm]

Note: You can get quite many warnings if you merge multiple vgms with the same chips, but different chip attributes (e.g. clocks).

General Notes

IMPORTANT NOTE: Some parts of this file are outdated. Many of the VGM v1.61 features, as well as some newer tools aren't mentioned.