}}}
'''Quick Links'''
* [wiki:WKTRaster/PlanningAndFunding Planning & Funding]
* [wiki:WKTRaster/SpecificationWorking01 Beta 0.1.6 Working Specifications]
* [wiki:WKTRaster/SpecificationFinal01 Beta 0.1.6 Final Specifications]
* [wiki:WKTRaster/Documentation01 Beta 0.1.6 Documentation]
* [wiki:WKTRaster/FAQ FAQ]
* [wiki:WKTRaster/SpecificationWorking02 Beta 0.2.4 Working Specifications]
* [wiki:WKTRaster/SpecificationWorking03 Working Specifications for Future Versions]
{{{
#!html
}}}
'''What's new about WKT Raster?'''
''June 04, 2009'' '''- [http://www.gis4free.org/blog A prototype GDAL driver to WKT Raster implemented this summer]! '''[[BR]]Thanks to Mateuz Loskot, who proposed the Google Summer of Code project and Jorge Arevalo the student who was selected to implement it.
{{{
#!html
}}}
Welcome to the '''WKT Raster''' project home page!
'''PostGIS WKT Raster''' is an ongoing project aiming at developing '''raster support in PostGIS'''. It is a new project very different from the previous PGRaster project and also very different from [http://en.wikipedia.org/wiki/GeoRaster Oracle Spatial GeoRaster].
The goal of '''WKT Raster''' is to implement the RASTER type '''as much as possible like the GEOMETRY type''' is implemented in PostGIS and to offer '''a single set of overlay SQL functions''' (like ST_Intersects) operating '''seamlessly''' on vector and raster coverages.
== Development Info ==
* '''Planning -''' Beta 0.1.6 PostGIS WKT Raster should happen by september 2009. Look [wiki:WKTRaster/PlanningAndFunding at the planning page] for a detailed schedule and to know how to contribute.
* '''Specifications -''' To know more about or contribute your ideas about the design of WKT Raster consult [wiki:WKTRaster/SpecificationWorking01 the working specification page]. Accepted specifications are aggregates into the [wiki:WKTRaster/SpecificationFinal01 final specification page].
* '''Source Code -''' PostGIS WKT Raster source code is available from the OSGeo Subversion repository
{{{
svn checkout https://svn.osgeo.org/postgis/spike/wktraster wktraster
}}}
* '''!PowerPoint -''' Original Project Presentation - rationale, examples and preliminary specifications: [http://www.cef-cfr.ca/uploads/Membres/WKTRasterSpecifications1.0.ppt PPT], [http://www.cef-cfr.ca/uploads/Membres/WKTRasterSpecifications1.0.pdf PDF] (v1.0)
* '''More Info -''' For more details and examples of application:[[BR]][[BR]]
* Search for "WKT Raster" in the [http://postgis.refractions.net/pipermail/postgis-users/ PostGIS mailing list archive] or in [http://www.nabble.com/forum/Search.jtp?forum=1221&local=y&query=%22wkt+raster%22 Nabble]
* Write to [http://www.cef-cfr.ca/index.php?n=Membres.PierreRacine Pierre Racine]
* [http://trac.osgeo.org/gdal/wiki/SoCProjects WKT Raster driver] for [http://www.gdal.org/ GDAL] developed in frame of [http://socghop.appspot.com/ Google Summer of Code 2009] by [http://www.gis4free.org/blog/ Jorge Arevalo]
== Overview of Planned PostGIS WKT Raster Functionalities ==
'''WKT Raster...'''
'''...is as simple as PostGIS...'''
* one table = one raster coverage (like a vector coverage)
* one row = one tile or one raster object (like a vector coverage where one row = one geometry)
* only one new type: RASTER (like the PostGIS GEOMETRY type)
* each raster tile has a pixel size, a width and a height, a variable number of band, a pixel type per band and a nodata value per band. Everything essential to do base raster GIS operations.
'''...is an extension of PostGIS to be installed separately'''
* merge with PostGIS might occur in the future...
'''...has an import/export mechanism similar to shp2pgsql'''
* raster2pgsql and pgsql2raster utilities allowing import/export of a single raster or a batch of raster into a tiled coverage.
'''...allows easy conversion from/to geometry/raster...'''
* RT_AsPolygon(raster) -> geometry
* RT_AsRaster(geometry, pixelsize) -> raster
'''...implements base GIS raster operations available in most GIS...'''
* RT_Resample(raster, pixelsize, method) -> raster
* RT_Clip(raster|geometry,geometry) -> same type as first argument
* RT_Reclass(raster|geometry,string) -> same type as first argument
* RT_MapAlgebra(raster|geometry, raster), mathematical expression, "raster"|"geometry") -> raster/geometry
* etc...)
'''...introduces raster/geometry seamless geometry constructors...'''
* so you don't have to bother whether the layers are in raster or vector form when using analysis functions.
* RT_Intersection(raster|geometry, raster|geometry, "raster"|"geometry") -> raster/geometry
* RT_Union(raster|geometry, raster|geometry, "raster"|"geometry") -> raster/geometry
* RT_Accum(raster set|geometry set, "raster"|"geometry") -> raster/geometry
* RT_Transform(raster|geometry, SRID) -> same type as input
* etc...
'''...and seamless geometry operators...'''
* RT_Intersects(raster|geometry, raster|geometry) -> boolean
* RT_Contains(raster|geometry A, raster|geometry B) -> boolean
* etc...
'''...allows raster storage INSIDE the database (as WKB)...'''
* for efficient overlay analysis operations between vector and raster layers...
'''...or OUTSIDE the database (as JPEG or TIFF)...'''
* so desktop and web applications can quickly access and load raster tiles and nevertheless benefits from the powerful PostGIS GiST spatial index. Every WKT Raster SQL functions working with in-db raster tiles work seamlessly with out-db raster tiles.
'''...introduces the concept of raster objects...'''
* geographic features are stored as variable size raster tiles instead of polygons.
* allows vector to raster conversion without lost of information.
'''...is much more simple than PGRaster and Oracle !GeoRaster! WKT Raster supports...'''
* only one type (instead of two in Oracle Spatial: SDO_GEORASTER & SDO_RASTER). In WKT Raster there are no differences between rasters and tiles: a tile is a raster and a raster is a tile. i.e. one row = one tile = one raster; one table = one raster coverage.
* no metadata (like PostGIS)
* no masks (you can create a mask as a band)
* no multiple dimensions (only two: x, y). Not to be confused with bands; WKT Raster DO supports multiband raster...
* no pyramids (reduced resolution coverages can be stored as a separate layer)
== What do people think about WKT Raster? ==
[http://www.cleverelephant.ca/cv.html Paul Ramsey]:
''This proposal is better than any I have seen, addresses solving problems that if solved will provide actual new functionality and benefit to users, and clearly you've thought this through over some time''
[http://www.paragoncorporation.com/Team.aspx Regina Obe]:
''The functions WKT Raster proposes look pretty cool actually and my vision of the benefits of storing raster in the database are covered in it''