Name
tovid: Convert video to (S)VCD/DVD format
Description
tovid converts arbitrary video files into (S)VCD/DVD-compliant
MPEG format, suitable for burning to CD/DVD-R for playback on a
standalone DVD player.
Usage
tovid [OPTIONS] -in INFILE -out OUTPREFIX
Where INFILE is any multimedia video file, and OUTPREFIX is what
you want to call the output file, minus the file extension. OPTIONS
are additional customizations, described below.
By default, you will (hopefully) end up with an NTSC DVD-compliant
MPEG-2 video file; if you burn this file to a DVD-R, it should be
playable on most DVD players.
For example:
tovid -in foo.avi -out foo_encoded
-
Convert 'foo.avi' to NTSC DVD format, saving to 'foo_encoded.mpg'.
tovid -pal -vcd foo.avi -out foo_encoded
-
Convert 'foo.avi' to PAL VCD format, saving to 'foo_encoded.mpg'.
Basic options
- -v, -version
-
Print tovid version number only, then exit.
- -quiet
-
Reduce output to the console.
- -fake
-
Do not actually encode; only print the commands (mplayer, mpeg2enc etc.)
that would be executed. Useful in debugging; have tovid give you the
commands, and run them manually.
- -ffmpeg
-
Use ffmpeg for video encoding, instead of mplayer/mpeg2enc. Try this if
you have any problems with the default encoding method. Using this option,
encoding will be considerably faster. Works with -vcd, -svcd, and
-dvd.
Television standards
- -ntsc
-
NTSC format video (USA, Americas) (default)
- -ntscfilm
-
NTSC-film format video
- -pal
-
PAL format video (Europe and others)
Formats
Standard formats, should be playable in most DVD players:
- -dvd
-
(720x480 NTSC, 720x576 PAL) DVD-compatible output (default)
- -half-dvd
-
(352x480 NTSC, 352x576 PAL) Half-D1-compatible output
- -svcd
-
(480x480 NTSC, 480x576 PAL) Super VideoCD-compatible output
- -dvd-vcd
-
(352x240 NTSC, 352x288 PAL) VCD-on-DVD output
- -vcd
-
(352x240 NTSC, 352x288 PAL) VideoCD-compatible output
Non-standard formats, playable in some DVD players:
- -kvcd
-
(352x240 NTSC, 352x288 PAL) KVCD-enhanced long-playing video CD
- -kdvd
-
(720x480 NTSC, 720x576 PAL) KVCD-enhanced long-playing DVD
- -kvcdx3
-
(528x480 NTSC, 520x576 PAL) KVCDx3 specification
- -kvcdx3a
-
(544x480 NTSC, 544x576 PAL) KVCDx3a specification (slightly wider)
- -bdvd
-
(720x480 NTSC, 720x576 PAL) BVCD-enhanced long-playing DVD
See kvcd.net for details on the KVCD specification. Please
note that KVCD ("K Video Compression Dynamics") is the name of a compression
scheme that can be applied to any MPEG-1 or MPEG-2 video, and has little to
do with VCD ("Video Compact Disc"), which is the name of a standard video disc
format.
Advanced options
Aspect ratios
tovid automatically determines aspect ratio of the input video by playing it in
mplayer. If your video plays with correct aspect in mplayer, you should not
need to override the default tovid behavior.
If mplayer does not play your video with correct aspect, you may provide an
explicit aspect ratio in one of several ways:
- -full
-
Same as -aspect 4:3
- -wide
-
Same as -aspect 16:9
- -panavision
-
Same as -aspect 235:100
- -aspect WIDTH:HEIGHT
-
Custom aspect, where WIDTH and HEIGHT are integers.
NOTE: This is the INPUT aspect ratio. tovid chooses an optimal output aspect
ratio for the selected disc format (VCD, DVD, etc.) and does the appropriate
letterboxing or anamorphic scaling.
Video stream options
- -quality NUM (default 6)
-
Desired output quality, on a scale of 1 to 10, with 10 giving the best
quality at the expense of a larger output file. Default is 6. Output size
can vary by approximately a factor of 4 (that is, -quality 1 output
can be 1/4 the size of -quality 10 output). Your results may vary.
At present, this option affects both output bitrate and quantization (but
may, in the future, affect other quality/size-related attributes). Use
-vbitrate if you want to explicitly provide a maximum bitrate.
- -vbitrate NUM
-
Maximum bitrate to use for video (in kbits/sec). Must be within allowable
limits for the given format. Overrides default values. Ignored for VCD,
which must be constant bitrate.
- -interlaced
-
Do interlaced encoding of the input video. Use this option if your video is
interlaced, and you want to preserve as much picture quality as possible.
This option is ignored for VCD, which doesn't support it.
You can tell your source video is interlaced by playing it, and pausing
during a scene with horizontal motion; if you see a "comb" effect at the
edges of objects in the scene, you have interlaced video. Use this option
to encode it properly. If you would prefer to have output in progressive
format, use -progressive.
- -deinterlace | -progressive
-
Convert interlaced source video into progressive output video. Because
deinterlacing works by averaging fields together, some picture quality is
invariably lost. Uses an adaptive kernel deinterlacer (kerndeint), or,
if that's not available, the libavcodec deinterlacer (lavcdeint).
- -mkvsub LANG (EXPERIMENTAL)
-
Attempt to encode an integrated subtitle stream (such as may be found in
Matroska .mkv files) in the given language code (eng, jpn, etc.) May work
for other formats.
- -autosubs
-
Automatically include subtitle files with the same name as the input video.
- -subtitles FILE
-
Get subtitles from FILE and encode them into the video. WARNING: This
hard-codes the subtitles into the video, and you cannot turn them off while
viewing the video. By default, no subtitles are loaded. If your video is
already compliant with the chosen output format, it will be re-encoded to
include the subtitles.
- -type {live|animation|bw}
-
Optimize video encoding for different kinds of video. Use 'live' (default)
for live-action video, use 'animation' for cartoons or anime, and 'bw' for
black-and-white video. This option currently only has an effect with
KVCD/KSVCD output formats; other formats may support this in the future.
- -safe PERCENT
-
Fit the video within a safe area defined by PERCENT. For example,
-safe 90% will scale the video to 90% of the width/height of the output
resolution, and pad the edges with a black border. Use this if some of the
picture is cut off when played on your TV. The percent sign is optional.
- -filters {none,denoise,deblock,contrast,all} (default none)
-
Apply post-processing filters to enhance the video. If your input video is
very high quality, use 'none'. If your input video is grainy, use 'denoise';
if it looks washed out or faded, use 'contrast'. You can use multiple
filters separated by commas. To apply all filters, use 'all'.
- -fps RATIO
-
Force input video to be interpreted as RATIO frames per second. May be
necessary for some ASF, MOV, or other videos. RATIO should be an
integer ratio such as "24000:1001" (23.976fps), "30000:1001" (29.97fps), or
"25:1" (25fps). This option is temporary, and may disappear in future
releases. (Hint: To convert a decimal like 23.976 to an integer ratio, just
multiply by 1000, i.e. 23976:1000)
- -crop WIDTH:HEIGHT:X:Y
-
Crop a portion of the video WIDTH by HEIGHT in size, with the
top-left corner at X, Y.
Audio stream options
- -normalize [VOLUME]
-
If used without VOLUME argument, analyze the audio stream and then
normalize the volume of the audio.
This is useful if the audio is too quiet or too loud, or you want to
make volume consistent for a bunch of videos. Similar to running
normalize without any parameters. The default is -12dB average level
with 0dB gain.
If the optional VOLUME argument is supplied, ffmpeg will be used instead
to increase or decrease the volume. An argument of 256 is normal volume.
This option is useful for -slice, because there are sync issues if
audio and video are encoded separately after a seek.
- -amplitude NUM[dB]
-
In addition to analyzing and normalizing, apply the gain to the audio
such that the 'average' (RMS) sound level is NUM. Valid values
range 0.0 - 1.0, with 0.0 being silent and 1.0 being full scale. Use
NUMdB for a decibel gain below full scale (the default without
-amplitude is -12dB).
- -abitrate NUM
-
Encode audio at NUM kilobits per second. Reasonable values include
128, 224, and 384. The default is 224 kbits/sec, good enough for most
encodings. The value must be within the allowable range for the chosen disc
format; Ignored for VCD, which must be 224.
- -audiotrack NUM
-
Encode the given audio track, if the input video has multiple audio tracks.
NUM is 1 for the first track, 2 for the second, etc. You may
also provide a list of tracks, separated by spaces or commas, for example
-audiotrack 3,1,2. Use idvid on your source video to determine which
audio tracks it contains.
- -async NUM
-
Adjust audio synchronization by NUM seconds.
Other options
- -config FILE
-
Read configuration from FILE, containing 'tovid' alone on the first
line, and free-formatted (whitespace-separated) tovid command-line options
on remaining lines.
- -force
-
Force encoding of already-compliant video or audio streams.
- -overwrite
-
Overwrite any existing output files (with the same name as the given
-out option).
- -priority {low|medium|high}
-
Sets the main encoding process to the given priority. With high priority,
it may take other programs longer to load and respond. With lower priority,
other programs will be more responsive, but encoding may take 30-40%
longer. The default is high priority.
- -discsize NUM
-
When encoding, tovid automatically splits the output file into several
pieces if it exceeds the size of the target media. This option sets the
desired target DVD/CD-R size to NUM mebibytes (MiB, 2^20). By default,
splitting occurs at 700 for CD, 4300 for DVD. Use higher values at your
own risk. Use 650 or lower if you plan to burn to smaller-capacity CDs.
Doesn't work with the -ffmpeg option.
- -fit NUM
-
Fit the output file into NUM MiB. Rather than using default (or specified)
video bitrates, tovid will calculate the correct video bitrate that will
limit the final output size to NUM MiB. This is different than -discsize,
which cuts the final file into NUM MiB pieces. -fit makes sure that
the file never exceeds NUM MiB. This works with -ffmpeg, but not
with -vcd since VCDs have a standardized constant bitrate.
- -parallel
-
Perform ripping, encoding, and multiplexing processes in parallel using
named pipes. Maximizes CPU utilization and minimizes disk usage. Note that
this option simply does more tasks simultaneously, in order to make better
use of available CPU cycles; it's unrelated to multi-CPU processing (which
is done automatically anyway). Has no effect when -ffmpeg is used.
- -update SECS
-
Print status updates at intervals of SECS seconds. This affects how
regularly the progress-meter is updated. The default is once every five
seconds.
- -mplayeropts "OPTIONS"
-
Append OPTIONS to the mplayer command run during video encoding. Use
this if you want to add specific video filters (documented in the mplayer
manual page). Overriding some options will cause encoding to fail, so use
this with caution!
- -nofifo (EXPERIMENTAL)
-
Do not use a FIFO pipe for video encoding. If you are getting "Broken pipe"
errors with normal encoding, try this option. WARNING: This uses lots of
disk space (about 2 GB per minute of video).
- -keepfiles
-
Keep the intermediate files after encoding. Usually, this means the audio
and video streams are kept (eg the .ac3 and .m2v files for an NTSC DVD).
This doesn't work with -parallel because the intermediate files are named
pipes, and not real files.
- -slice START-END
-
Encode a segment from START to END (in seconds).
- -from-gui
-
Put tovid into a fully non-interactive state, suitable for calling from
a gui.
- -noask
-
Don't ask questions when choices need to be made. Assume reasonable
answers.
Configuration
Two configuration files are created the first time you run tovid. Edit them
to change tovid's directory use and default behavior.
Working and output directories are defined in ~/.tovid/preferences:
WORKING_DIR=/tmp
OUTPUT_DIR=/pub/video
If you would like to include certain command-line options all the time, edit
~/.tovid/tovid.config and add them.
See also
idvid(1), makedvd(1), makemenu(1), makeslides(1),
makevcd(1), makexml(1), postproc(1), tovid(1), todisc(1)
Contact
For further assistance, contact information, forum and IRC links,
please refer to the tovid homepage.