Request ideas about storing images in GVRS #12
Replies: 2 comments
-
With the Issue-10 release of GVRS, I have added some reserve elements to the file format that would support the addition of this feature without breaking compatibility. If I do add support for images to GVRS, it will not break backward compatibility with earlier versions of the software. |
Beta Was this translation helpful? Give feedback.
-
I just posted a new article describing some experiments I did using GVRS to store photographic image data. A lot of research will still be required before I incorporate image support into the GVRS API, but you may find the article interesting. Please see Using Gridfour for Image Processing, Storage, and Data Compression |
Beta Was this translation helpful? Give feedback.
-
I am posting this note to invite comments regarding the idea of integrating direct support for imagery (aerial photographs, conventional pictures, etc.) into the GVRS API and file format.
In the text below, I discuss some of my ideas, but I view them as a starting point. I welcome any comments from users who have other ideas… Particularly those that might save me from going down the wrong road.
Background
The GVRS file format and Java API is intended to simplify the processing of large raster data sets. One of the ideas behind GVRS is that an application can use it for high-speed processing of large data sets and then export the results to whatever data format is best suited for a user’s needs.
Currently, GVRS focuses on numerical information. Of course, there is another kind of raster information that a lot of people care about: images. I was wondering what everyone thought about implementing some sort of support for image formats in GVRS.
When I designed GVRS, I did not consider image data as being something for which GVRS could provide much “value added”. There are plenty of good graphics formats and supporting APIs out there already. Recently, however, I’ve been playing with some sample data that includes both aerial photographs and surface elevation samples. This effort involves working with two disjoint data products using separate APIs and two separate sets of data objects. It occurs to me that having limited built-in support for imagery might be a more convenient way to work. It might be an attractive feature for some users.
I spent a few evenings going through the PNG and TIFF format specifications, and have also taken a look at a less well-known format known as NITF. Image-processing is an important topic and these products all feature more complexity than might be obvious at first glance. For GVRS, I would deliberately focus on a narrow subset of these features. I list some basic features below. I will consider more advanced features such as CMYK and CIELAB color spaces, or ICC profiles. Doing so would depend on users identifying features that had the most utility and were of the highest priority. Image processing is a vast topic and it would be easy to spend a lot of time adding specialized features only to come up with a complex implementation that nobody wanted to use. I'd like to avoid that.
Beta Was this translation helpful? Give feedback.
All reactions