Intro

One of the most problematic points when shooting spherical panoramas is the view straight down also called the nadir view. Either the tripod is visible or there may be alignment or color mismatches if shooting handheld.

Unfortunately neither the nadir nor the zenith (straight above) area can be edited directly in the equirectangular image since it is very distorted. For this task we need to extract a partial view - best in Rectilinear Projection.

Warning

Important! For all transformations that use non-overlapping images like assembling cube faces to an equirectangular image the 'Fast transform' option should be disabled. As a default 'Fast transform' is disabled for the Panorama Tools Plugins and for PTEditor. However, it is enabled by default for some of the GUIs (PTGui f.e.)

Fast Transform can cause the loss of some pixels in the corners of an rectilinear image which will be visible as small triangular black holes in the result image. More on 'Fast Transform' on Fulvio Senore's page.

PTGui 5 has a new internal stitcher which causes a similar effect even if Fast Transform is switched off. Don't use PTGui 5 internal stitcher to assemble cubefaces! Choose "Panotools Stitcher" (PTStitcher) instead.

Possibilities

There are basically three possibilities to extract partial rectilinear views:

PTEditor

PTEditor is a Java application provided with the standard Panorama Tools distribution. It should run on any OS where Java and the panotools runtime (the pano12 library) are installed. There is a nice tutorial on How to use PTEditor. This is the most convenient way to extract and insert any arbitrary rectilinear view. The disadvantage is that it doesn't save 16 bit images.

The plugins contain the Adjust filter, which is capable of extracting and inserting any view in almost any projection. Any data (pan/tilt angle, size of view etc.) has to be inserted manually. Yaw, roll and pitch value have to be calculated or estimated which makes the usage a bit inconvenient.

PanoCube Plus

PanoCube Plus can extract six cube faces (single, batch modes) for editing and then convert it directly into QTVR cubic movie(s). Both 8/16 bits per channel are supported - depending on the pano12 library used the cube faces are the same bit depth as the source images.

To activate "equirectangular to 6 cube faces" mode copy the file Script.txt to the folder where your source image is and set "1" as first character in this line using a text editor (notepad!):

1 # create tiles for editing ( 0 = NO, 1 = YES). Default NO.

in the file Script.txt and put it into pano's folder. Next drag and drop your single pano or folder with panos onto the program icon. The source file name and path should contain no spaces. The source image must be exactly in 2:1 format (f.e. 2000x1000 or 6000x3000 pixels). PanoCube calls PTStitcher 6 times and creates 6 files in the order front, right, back, left, top, bottom and replaces the last two characters of the name with 11, 22, 33, 44, 55, 66. All files ended with 55 are represent zenith view, ended with 66 - nadir view.

After editing drag again any one (not all!) tile or folder with tiles to get QTVR cubic movie(s). In batch mode important to have first six letters differ in filenames, otherwice PanoCube can skips "similar" files.

This technique is good if the final product is a QTVR movie. If you need an equirectangular for PTViewer you can of course drag the .mov file on panocube plus to get it converted, but image quality suffers because of intermediate JPEG compression and decompression and another interpolation step.

possibility to patch nadir in a relative early stage of editing thus leaving open any possibility of correcting over all colors etc.

preserving as much as possible of the original image data

To re-insert the patched cubeface into the original document implies that you have worked on a cube face with enough resolution, preferable the pixel width of the original pano divided by 3.

You can use the batch file or PTGui template mentioned above. You simply have to set output size equal to your original panorama size and create single image TIFFs as output. Any of those TIFF files can be added to the original panorama as a masked layer using the "Tiff to masked layers" action from http://www.erik-krause.de/ttt

GUI

All of the GUI front-ends should be capable of extracting an arbitrary rectilinear view from a spherical pano. Use the equirect image as input (don't forget to set the correct FoV) and specify a rectilinear image with 90� as output "panorama". Set all lens correction parameters to 0.0. Then change yaw and pitch of the input image until you get the desired view. Note that the values work the other way round than when inserting an image.

PTGui

PTGui offers an additional advantage: The panorama editor and numerical transform. To use it load your image as described above, open panorama editor and choose 'Numerical Transform' from the edit menu.

On the 'Panorama Settings' tab don't forget to uncheck 'Use fast transform' (for details see Warning at top of page).

To pan along the horizon f.e. in 20� steps insert 20 into the 'Yaw' field and press 'Apply' repeatedly until you get the desired view. Positive values pan right, negatives left.

Do the corresponding for 'Pitch' and 'Roll' if needed. This way you can extract any partial view. Once your are done create the "Panorama" (which is the desired partial view) using output format TIFF. Note down or save the exact values for Yaw, Roll and Pitch as shown on 'Image Parameters" tab page.

Now edit the partial view to your need. Then add it to the project with your original panorama and on 'Panorama settings' tab change to equirectangular and 360�x180�. Choose individual lens parameters for the new image on 'Lens settings' tab and set 'Rectilinear' and 90� on 'Image parameters' tab. The image should fit now perfectly in the original panorama.

In order to move the panorama back to it's original position go to panorama editor again and choose 'Numerical transform'. Now Enter the exact values for Yaw, Roll and Pitch you previously saved or noted down. The panorama should move back to it's original position now.

You can create either the complete panorama or the partial view only. Choose the size of the original panorama for output.