Monday, January 27. 2014Writing PostGIS raster Map Algebra Callback Functions in PLV8Printer FriendlyRecommended Books: PostGIS Cookbook PostgreSQL: Up and Running PostGIS in Action (2nd edition)
Trackbacks
Trackback specific URI for this entry
No Trackbacks
Comments
Display comments as
(Linear | Threaded)
Good to know. I wonder if PL/Pythonu will match Javascript's performance?
I was thinking about that myself but haven't had a chance to test PL/Python in that regard. My gut feeling says it will be slower just because I think the V8 engine is less of a load than the Python environment.
Besides PL/V8 you can create window functions which you can't in PL/Python :)
One thought I have had is to rewrite the provided callback functions in C. Having said that, it's awesome that the are easy performance improvements... 52 to 18 seconds just by using a different PL language.
I was going to investigate the ST_Range4MA function. I had started creating a simplified since I didn't need the userargs piece. While that was not quite as fast as the SQL one. It was within 1-2 second. So I'm thinking we maybe don't want to do that user args check in each loop maybe check if it needs to be done and take a simpler route if no userargs is passed in.
So a lot of the gain was my simplication. I suspect copying the array in the beginning adds a lot of overhead.
Just tried creating a quick map algebra call back function in plpython3 in PostgreSQL 9.3. Unfortunately it seems like a no go.
When it comes in even if the body of the function does nothing, it tries to cast the multi-dimensional to a list which fails. Returning with error: ERROR: cannot convert multidimensional array to Python list DETAIL: PL/Python only supports one-dimensional arrays. |
Entry's LinksQuicksearchCalendar
Categories
ArchivesBlog Administration |