As I blogged about back in February,
ENVI 5.1 introduced ENVITask as the new API for analytics. For the just
released ENVI 5.2 we have added a lot of new tasks and supporting
functionality. In the ENVI 5.1 release, we had 4 tasks, in ENVI 5.2 we now have
58:
IDL> nv = ENVI()
ENVI> PRINT, nv.TASK_NAMES
AutoChangeThresholdClassification BuildBandStack BuildRasterSeries
BuildTimeSeries ChangeThresholdClassification ClassificationAggregation ClassificationSmoothing
ClassificationToShapefile ColorSliceClassification DarkSubtractionCorrection
DimensionsResampleRaster EqualizationStretchRaster FXSegmentation
ForwardICATransform ForwardMNFTransform ForwardPCATransform
GaussianStretchRaster GramSchmidtPanSharpening ISODATAClassification
ImageBandDifference ImageIntersection ImageThresholdToROI
LinearPercentStretchRaster LinearRangeStretchRaster LogStretchRaster
MahalanobisDistanceClassification MappingResampleRaster
MaximumLikelihoodClassification MinimumDistanceClassification
NNDiffusePanSharpening OptimizedLinearStretchRaster PCPanSharpening
PercentThresholdClassification PixelScaleResampleRaster QUAC
QuerySpectralIndices ROIToClassification RPCOrthorectification
RXAnomalyDetection RadiometricCalibration RadiometricNormalization
RasterStatistics RasterViewshed RegridRaster RegridRasterSeriesByIndex
RegridRasterSeriesByIntersection RegridRasterSeriesByUnion ReprojectGLT
RootStretchRaster SpectralAngleMapperClassification SpectralIndex
SpectralIndices ThematicChange TrainingClassificationStatistics
VectorAttributeToROIs VectorRecordsToROI VegetationSuppression
VideoToRasterSeries
There isn't enough space to go into details about them all
here, but we have documentation with example code for each. Just look under
Programming > Routines > Data Processing in the ENVI help contents to
find them all (or here on the web). Or if you're feeling more adventurous you can just request a task using the
enviTask()
factory function and inspect the task object itself, since it provides a lot of
introspection and self-documentation.
We have added a couple of new properties to enviTaskParameter,
MIN and MAX. These are only applicable for numeric types, and provide for
bounded or unbounded range validation. These represent inclusive bounds, so if
MIN = 0 then VALUE ≥ 0. These are both optional properties on any
parameter, and can be specified independently if the range is unbounded.
Besides adding a lot of tasks to our catalog, a lot of work gone
into ensuring that each and every one of these enviTasks can be invoked on an
ENVI Services Engine server. These are published under a special ENVI service, so the URL to
find them will be http://<host>:<port>/ese/services/ENVI. We have expanded the datatypes supported by ESE to allow all 58 of the ENVITasks to be run. Look under Writing Tasks > Data Types > ENVI Data Types in the ESE help to learn how to specify these new types.
Another new feature is what we call the dynamic UI for ENVITasks. If you have an ENVITask object, you can pass it into an ENVIUI method
to build a dialog to set all the parameters. If you have some of the parameters
already set, those values will appear in the dialog. Here is a quick example
of how to do this:
IDL> e = ENVI()
ENVI> oTask = enviTask('NNDiffusePanSharpening')
ENVI> ret = e.UI.SelectTaskParameters(oTask)
The return value of the function is the name of the button
pressed by the user, either "OK" or "Cancel". Here is the
dialog that shows up for the NNDiffusePanSharpening task:

As you can see, different parameter types will use different
widgets to allow user input. Clicking on the input raster widgets will open up
the standard ENVI raster selection dialog, complete with spatial and spectral
subsetting options. The Pixel_Size_Ratio parameter is an integral type, so we
have the spinner box, and the two smoothness parameters are floating point so
they are specialized text entry widgets that only allow numbers to be typed
in. You'll also notice the Output_Raster parameter has been populated with a
filename, using the $TEMP environment variable for the path and the task name
as the filename. This can easily be changed by typing in a new filename, or
using the "..." button to use the file selection dialog to pick an
output location and name. The ? button at the bottom will bring up a help page describing each of the parameters in detail. The Preview button can be checked to run the task at the current viewport resolution and spatial extents, and will load the results into the view so you can verify if these are the parameter values you want. Once you hit OK, the task will be run on the full input data and saved to the files you specified.