Okay, so last post I was trying to understand the format of the Nikon Images. So they are standard TIFF format which contains some sort of header followed by locations to Image File Directories (IFD's) which each contain
tiff tags which point to the image information and the location of the image itself.
It turns out there are two important IDF entries that will point to information about the camera and information about the actual image. I will discuss the former.
Digital Cameras - The EXIF data
To reach the EXIF data, you need to the IFD entry with tag #
0x8769.
A simple hex dump and then search for the string "87 69" (fortunately) brings me right to the tag in question on the first try:
00000100 00 06 00 00 01 9c 87 69 00 04 00 00 00 01 00 00
00000110 01 e0 88 25 00 04 00 00 00 01 00 00 d4 d2 90 03
The tag is type 4 (int) and is actually a pointer to an EXIF IFD. From what I see, most digital cameras will have this so any routines grabbing this information will be useful. The EXIF IFD is yet another IFD and has its own set of tags which can be found
here.
With the large number of tags and data types, I have just created with the combination of associative arrays and dynamic objects a routine that creates an object with intuitive names for each variable. I will omit the details but if someone's interested just ask. I will post some source once I convert to python.
In the EXIF IFD, there is a pointer to yet another structure, called the MakerNote (tag # : 0x927C). Here is my MakerNote tag:
00000270 03 b0 92 7c 00 07 00 00 d0 de 00 00 03 f4 92 86
00000280 00 07 00 00 00 2c 00 00 03 b8 92 90 00 02 00 00
One thing you'll notice is it is a new type, type #7. This is actually a new type specified in the new Adobe TIFF 6.0 format. This format is undetermined. All it means is that you will need to refer to the maker of the file for more information on how to read this data. So, I just read it as an array of chars (1 byte) for now.
The Maker Note
So, the maker note is 0xd0de = 53470 bytes long and starts at 0x03f4. Let's find it. Here is the beginning:
000003f0 00 00 00 01 4e 69 6b 6f 6e 00 02 10 00 00 4d 4d
00000400 00 2a 00 00 00 08 00 36 00 01 00 07 00 00 00 04
00000410 30 32 31 30 00 02 00 03 00 00 00 02 00 00 03 20
00000420 00 04 00 02 00 00 00 08 00 00 02 96 00 05 00 02
...etc...
(you should be convinced that the bold letters do start at position 0x03f4)
The format is pretty simple. The first 5 characters spell out "Nikon" (0x4e, 0x69, 0x6b, 0x6f, 0x6e; refer to this
ASCII table to be sure I'm not lying to you) and are null terminated by "00". The next two bytes are the version (0x0210). Finally, the next two bytes refer the endianess of the MakerNote, because... It is another TIFF file!
From now on, we have entered a new
TIFF file within a file... Anyway, so okay, it's another TIFF file again in big endian and we see another magic value of "42" (0x002a). Finally, there's the offset, which is 8. Relative to the beginning of this file, that's just the next byte in the sequence.
The Linearization Curve
Okay, so let's skip all that. What I wanted to get to was the linearization curve.
There is one tag with the numbers 0x0096 and that is a pointer to the linearization table. I'll assume you've had enough with hex and I'll skip how to find it now. To figure out how to read it, there is a
good reference here which explains everything I have done here as well as how to read it. Again, I skip the details. Basically, you have to go to the right offset (see link I linked to and look for the lin table and do what it says for ver0 = 044 and ver1 = 0x20), read in some shorts (2 bytes), and then interpolate from 0 to 256 to 0 to 4096. The last step is not really necessary to see the curve.
Here is the curve:
|
Nikon D90 Linearization Curve linear plot |
|
Nikon D90 Linearization Curve log plot |
Where the second plot is a log-log plot.
From what I understand, a linearization curve is kind of like a
gamma correction, except it seems to follow a linear power law near the beginning (green) and a quadratic power law near the end (red). This is elucidated by the log-log plot. If your function obeyed one simple power law, then you should see points
aligned in one line with constant slope. Basically, under normal conditions, your eye is more sensitive to certain changes in intensity and less sensitive to other changes.
Next will be reading the image itself. It may take me a while because I'm busy with research and helping with people in my research team (wrote a
YUV 422 decoder for a camera, an interface from Yorick to a
spectrometer driver [I did not write driver in link, I used it to interface Yorick] to plot up some nice waterfall plots recently on top of trying to finish this PhD...)
Next on the agenda : Read these images, average them using the stacking technique in astrophotography, and then see what else can be done to improve the contrast on the nice features.
In the (far....) future: Get the USB SDR device to work in yorick and start plotting waterfall plots, then connect to a dish and start doing some radio astronomy....
Thanks for reading, if you have comments/suggestions let me know. I'm doing this all because it's fun and the only way to generate new ideas is to follow the footsteps of others and form your own point of view :-).