Device independent file format
|Internet media type||
|Developed by||David R. Fuchs|
|Type of format||document|
The device independent file format (DVI) is the output file format of the TeX typesetting program, designed by David R. Fuchs and implemented by Donald E. Knuth in 1979. Unlike the TeX markup files used to generate them, DVI files are not intended to be human-readable; they consist of binary data describing the visual layout of a document in a manner not reliant on any specific image format, display hardware or printer. DVI files are typically used as input to a second program (called a DVI driver) which translates DVI files to graphical data. For example, most TeX software packages include a program for previewing DVI files on a user's computer display; this program is a driver. Drivers are also used to convert from DVI to popular page description languages (e.g. PostScript, PDF) and for printing.
DVI is not a document encryption format, and TeX markup may be at least partially reverse-engineered from DVI files, although this process is unlikely to produce high-level constructs identical to those present in the original markup, especially if the original markup used high-level TeX extensions (e.g. LaTeX).
DVI differs from PostScript and PDF in that it does not support any form of font embedding. (Both PostScript and PDF formats can either embed their fonts inside the documents, or reference external ones.) For a DVI file to be printed or even properly previewed, the fonts it references must be already installed. Also, unlike PostScript (but like PDF), DVI is not a full, Turing-complete programming language, though it does use a limited sort of machine language.
The DVI format was designed to be compact and easily machine-readable. Toward this end, a DVI file is a sequence of commands which form "a machine-like language", in Knuth's words. Each command begins with an eight-bit opcode, followed by zero or more bytes of parameters. For example, an opcode from the group 0x00 through 0x7F (decimal 127), set_char_i, typesets a single character and moves the implicit cursor right by that character's width. In contrast, opcode 0xF7 (decimal 247), pre (the preamble, which must be the first opcode in the DVI file), takes at least fourteen bytes of parameters, plus an optional comment of up to 255 bytes.
In a broader sense, a DVI file consists of a preamble, one or more pages, and a postamble. Six state variables are maintained as a tuple of signed, 32-bit integers: . h and v are the current horizontal and vertical offsets from the upper-left corner (increasing v moves down the page), w and x hold horizontal space values, y and z, vertical.
These variables can be pushed to or popped from the stack. In addition, the current font f is held as an integer value, but is not pushed and popped with the rest of the state variables when the opcodes
pop are encountered. Font spacing information is loaded from TFM files. The fonts themselves are not embedded in the DVI file, only referenced by an integer value defined in the relevant
fnt_defi op. (This is done exactly twice for each loaded font: once before it is referenced, and once in the postamble.) f contains an integer value of up to four bytes in length, though in practice, TeX only ever outputs font numbers in the range 0 through 255.
Similarly, the DVI format supports character codes up to four bytes in length, even though only the 0–255 range is commonly seen, as the TFM format is limited to that range. Character codes in DVI files refer to the character encoding of the current font rather than that of the system processing it. This means, for instance, that an EBCDIC-based system can process a DVI file that was generated by an ASCII-based system, so long as it has the same fonts installed.
DVI files are often converted into PDF, PostScript, or PCL format for reading and printing. They can be also viewed directly by using DVI viewers.
- DVI viewers: YAP (included in MiKTeX), xdvi, windvi, Evince, KDVI, Okular, dviout, dviwin, DView (included in BaKoMa TeX distribution), javaDVI, MDVI
- DVI to human-readable format: dvitype
- DVI-to-PDF converters: dvipdf, dvipdfm, dvipdfmx
- DVI-to-PS converters: dvips
- DVI-to-bitmap converters: dvipng (generates GIF or PNG), or use dvips and Ghostscript
- DVI-to-SVG converters: dvisvg, dvisvgm
dvipdf is a tool to translate DVI files (generated by TeX) to PDF files. Although it is still included in most LaTeX distributions, it is out-dated and users are advised to use instead the newer tool dvipdfm.
(PDF e-prints that cause fonts to render poorly on the screen, but fine in print, are often caused by not providing dvipdf with a good font mapping table such as the one bundled with dvipdfm.)
dvipdfm is a DVI to PDF translator, included in current LaTeX distributions such as teTeX. It produces PDF files of a quality superior to that of its now outdated predecessor dvipdf and also supports most of the newer special functions of the PDF format. It incorporates the *.eps graphics file format without problems. You can use it to convert
arquive.dvi with the command
dvipdfmx is an extended version of the dvipdfm DVI to PDF translator. The primary goal of the dvipdfmx project is to support multi-byte character encodings and CJK character sets for East Asian languages.
- Donald E. Knuth (December 1995). DVItype (WEB source code; extract full documentation using WEAVE). Version 3.6. Retrieved 2008-05-07.
- In 1986 Tomas Rokicki printed his first page with dvisw, an early DVI printer driver for the Amiga, on a QMS SmartWriter using AmigaTeX by Radical Eye Software. A link to a relic info about milestones of LaTeX history is available at this external site.
- Rokicki, Tomas (April 1988). "The Commodore Amiga: A Magic TeX Machine" (PDF). TUGboat 9 (1): 40–41. Retrieved 2010-11-19.
- The Dvipdfmx Project
- Fuchs, David (October 1982). "The format of TeX's DVI files" (PDF). TUGboat 3 (2): 13–19. Retrieved 2009-08-19.
- Description of the DVI file format ← broken link
- TeX DVI file Information utility
- MiKTeX TeX (includes YAP DVI viewer for Microsoft Windows platform)