Dear list,

I need your help with a more advanced wps python script with Geoscript. Thank 
you all in advance for your valuable time and comments.

I have successfully installed the 2.5.1 Geoserver with the geoscript and wps 
extensions and implemented some simple examples as the one described here:

http://suite.opengeo.org/opengeo-docs/processing/scripting/processcreate.html

I have also successfully implemented my own wps that combines gs:BarnesSurface 
and gs:Contour

For your help gs:Contour is defined here:

http://www.massapi.com/source/geoserver-2.1.1-src/geoserver-2.1.1/extension/wps/wps-core/src/main/java/org/geoserver/wps/gs/ContourProcess.java.html

As you can see it requires as input either levels that is type double[] either 
interval that is type Double  
The following code is working fine having "interval" in place of "levels" and 
"Double" instead of "ArrayList<Double>()" but I can't find how I should define 
levels1 in order to make it work with Double[].

I have made some efforts as the following code that is throwing an error
org.geotools.process.ProcessException: Could not convert -100 to target type [D

Do you have any ideas how to define levels1 in order to make it work?

Kind Regars,

Vassilis Dalakas

________________

from java.lang import String, Integer, Double
from geoscript.layer import Layer, Raster
from geoserver.wps import process
from geoscript.process import Process
from geoscript.geom import *
from org.geotools.data.simple import SimpleFeatureCollection
from org.geotools.geometry.jts import ReferencedEnvelope
from org.geotools.coverage.grid import GridCoverage2D
from java.util import ArrayList as ArrayList

barnes = Process.lookup('gs:BarnesSurface')
contour = Process.lookup('gs:Contour')

@process(
 title = 'Barnes and Contour',
 description = 'Uses Barnes Analysis to compute an interpolated surface over a 
set of irregular data points and computes contour lines at specified intervals 
or levels for the values in a raster.',
 inputs = {
   'data1': (SimpleFeatureCollection, 'Input features'),
   'valueAttr1': (String, 'Name of attribute containing the data value to be 
interpolated'),
   'scale1': (Double, 'Length scale for the interpolation, in units of the 
source data CRS'),
   'maxObservationDistance1': (Double, 'Maximum distance to an observation for 
it to support a grid cell, in units of the source CRS (default = 0, meaning all 
observations used)'),
   'pixelsPerCell1': (Integer, 'Resolution of the computed grid in pixels per 
grid cell (default = 1)'),
   'queryBuffer1': (Double, 'Distance to expand the query envelope by, in units 
of the source CRS (larger values provide a more stable surface)'),
   'outputBBOX1': (ReferencedEnvelope, 'Bounding box for output'),
   'outputWidth1': (Integer, 'Width of the output raster in pixels'),
   'outputHeight1': (Integer, 'Height of the output raster in pixels'),
   'levels1': (ArrayList<Double>(), 'Values of levels at which to generate 
contours')
 },
 outputs = {
   'result': (SimpleFeatureCollection, 'Contour line features. Contour level is 
in value attribute.')
 }
)

def run(data1, valueAttr1, scale1, maxObservationDistance1, pixelsPerCell1, 
queryBuffer1, outputBBOX1, outputWidth1, outputHeight1, levels1):
 barnesed = barnes.run(data=data1, valueAttr=valueAttr1, scale=scale1, 
maxObservationDistance=maxObservationDistance1, pixelsPerCell=pixelsPerCell1, 
queryBuffer=queryBuffer1, outputBBOX=outputBBOX1, outputWidth=outputWidth1, 
outputHeight=outputHeight1)['result']
 return contour.run(data=barnesed, levels=levels1)['result']
------------------------------------------------------------------------------
Open source business process management suite built on Java and Eclipse
Turn processes into business applications with Bonita BPM Community Edition
Quickly connect people, data, and systems into organized workflows
Winner of BOSSIE, CODIE, OW2 and Gartner awards
http://p.sf.net/sfu/Bonitasoft
_______________________________________________
Geoserver-users mailing list
Geoserver-users@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/geoserver-users

Reply via email to