This document describes the sequencing process using the new Qt-based GUI tool. For an explanation of the manual way to do sequencing, consult intoduction and Sequencing HOWTO (both in German only). These documents also explain in more detail the background concepts and the hardware used. The updated sequencer offers several advantages compared to the old one:
The source code for the grabber can be found in ~terzic/code/grabber9. Generally, the higher the number at the end, the later (and better) the program.
Images and sequences are obtained through a digital camera connected to a Matrox Meteor framegrabber. There are three cameras and three PCs equipped with the framegrabbers, so three synchronised sequences can be recorded at the same time. The cameras are located in the steel cabinet in room 132.
Once the camera is connected to the computer, the sequencer can be started by clicking the 'grabber' icon. A simple dialog window will open, allowing you to change some of the parameters:
After clicking OK, the grab will start. Three progress windows will appear in turn, to show the progress of the memory allocation, sequence grabbing and image generation. At the moment, the process cannot be stopped once it's started, so doublecheck your parameters.
The program has to write alternately to two disks because a single disk cannot provide the sustained throughput required. After a while, the finished images will be on the two harddisks selected for storage (usually D and E).
If you click on the Advanced button on the main dialog window, the advanced dialog will pop up. Here you can change some less common options for the grab:
In addition to specifying the colour parameters manually, one can also generate them from the sequencer, by clicking the Calibrate button in the advanced dialog. The calibration consists of two steps.
First, a dialog will prompt you to cover the camera lens and take a completely black image. You can choose to skip this part (in which case a perfectly black image will be generated and used instead), or provide an image which was taken previously (or calculated from many black images, like explained in the Sequencing HOWTO).
Then, a dialog will prompt you to place something with a large white surface in front of the camera. Several white (not recycled) A3 papers are a good option. After clicking OK, the camera will take an image and show it in a scaled window. You can now graphically select a large rectangle of white colour. The program will then use the black image and the white rectangle to calculate the colour parameters itself.
At the moment, an MPEG file of default quality settings can be generated once the sequencing is over. It is done by running an NT version of Berkeley's mpeg_encode program, which was modified to accept PNGs as inputs as well. Its output is piped to the sequencer and dissected, in order to know how far it has progressed, for the progress bar to work. The progress bar is a bit jumpy because several lines seem to get bundled together on stdout (probably an issue of Unix/Windows CR/LF differences), but it works reliably.
Currently (and probably forever), movies can only be generated from the image files readable by Qt, so it should work for all the filetypes supported by the sequencer (the conversion utility for the mpeg encoder is also written using Qt).. The quality settings (speed, quality and scale) are settable through the GUI, and are based on Thomas Weiss' script, described in the mpeg-howto. Keep in mind that the quality setting is inverted in the GUI (10 means highest quality).
Since mpeg encoding can take ridiculous amounts of time, the GUI default is to only generate the parameter file for the encoder. The encoding process can then be done at any time, by simply running mpeg_encode mpegparams.txt from the directory containing the images and the mpegparams.txt file (default is d:\). Alternatively, you can choose to run the encoder directly from the sequencer, but be prepared to wait for a while, depending on the quality settings.
Currently, the export to PNG is very slow. This is partly due to the complexity of 32-bit PNG images, and partly due to the slowness of the Qt PNG export. Because of this, fully compressed JPEGs can be generated faster than uncompressed PNGs. As a result, it's recommended to use JPEGs for testing and prototypes, and PPMs/BMPs to check the quality of the images/colours. PNGs should be used only for final grabs, and armed with some patience. The PNG export becomes much quicker if no compression is used. If you use maximum compression on more than 100 frames, make sure you prepare a nice cup of coffee :)
The colour calibration algorithm gives worse results than using the default values provided by Thomas. This could be related to the light (more likely), or to the fact that I only use 1 black image instead of an average of 100 (less likely).
Since Qt doesn't support the TIFF format, no coloured TIFF export is available at this time.
MPEG scaling is supported, but only through a modified version of mpeg_encode, which explicitely uses binary mode for all pipes (Windows usually opens them as text). This mpeg_encode binary (and code) can be found under ~terzic/code/mpeg_encode/ and is installed in the bin subdirectory of the directory where the sequencer is installed.
Kasim Terzic, 27.10.2003