This task classifies a raster using a trained TensorFlow mask-based model. The result is a classification image. An optional output is a class activation raster whose pixel values represent the probability (0 to 1) of matching the feature of interest. If necessary, this task will convert a raster into an ENVIDeepLearningRaster for classification. To avoid having to convert the same input raster again, use the BuildDeepLearningRaster task once to convert it to an ENVIDeepLearningRaster.
This task is part of ENVI Deep Learning, which requires a separate license and installation.
Example
Sample data files are available on our ENVI Tutorials web page. Click the "Deep Learning" link in the ENVI Tutorial Data section to download a .zip file containing the data. Extract the contents to a local directory. Files are located in the tornado directory.
This example classifies an orthophoto of a seaport using a model that was previously trained to find shipping containers. It displays the resulting class activation raster over the input orthophoto. Toggle the class activation raster on and off in the Layer Manager to view the underlying orthophoto.
e = ENVI()
File = 'C:\MyTutorialFiles\ImageToClassify.dat'
Raster = enviDeepLearningRaster(File)
ModelFile = 'C:\MyTutorialFiles\TrainedModel.h5'
Model = ENVITensorFlowModel(ModelFile)
Task = ENVITask('TensorFlowPixelClassification')
Task.INPUT_RASTER = Raster
Task.INPUT_MODEL = Model
Task.OUTPUT_CLASSIFICATION_RASTER_URI = e.GetTemporaryFilename()
Task.OUTPUT_CLASS_ACTIVATION_RASTER_URI = e.GetTemporaryFilename()
Task.Execute
e.Data.Add, Task.OUTPUT_CLASSIFICATION_RASTER
View = e.GetView()
Layer = View.CreateLayer(Raster)
Layer2 = View.CreateLayer(Task.OUTPUT_CLASSIFICATION_RASTER)
View.Zoom, /FULL_EXTENT
Syntax
Result = ENVITask('TensorFlowPixelClassification')
Input properties (Set, Get): INPUT_MODEL, INPUT_RASTER, OUTPUT_CLASSIFICATION_RASTER_URI, OUTPUT_CLASS_ACTIVATION_RASTER_URI
Output properties (Get only): OUTPUT_CLASSIFICATION_RASTER, OUTPUT_CLASS_ACTIVATION_RASTER
Properties marked as "Set" are those that you can set to specific values. You can also retrieve their current values any time. Properties marked as "Get" are those whose values you can retrieve but not set.
Methods
This task inherits the following methods from ENVITask. See the ENVITask topic in ENVI Help.
- AddParameter
- Execute
- Parameter
- ParameterNames
- RemoveParameters
Properties
This task inherits the following properties from ENVITask:
COMMUTE_ON_DOWNSAMPLE
COMMUTE_ON_SUBSET
DESCRIPTION
DISPLAY_NAME
NAME
REVISION
See the ENVITask topic in ENVI Help for details.
This task also contains the following properties:
INPUT_MODEL (required)
Specify the mask-based TensorFlowModel to use for classifying INPUT_RASTER.
INPUT_RASTER (required)
Specify the raster to classify.
OUTPUT_CLASSIFICATION_RASTER
This is a reference to the output classification raster of filetype ENVI. It is a single-band raster whose values range from 0 to the number of classes.
OUTPUT_CLASSIFICATION_RASTER_URI (optional)
Specify a string with the fully qualified filename and path of the associated OUTPUT_CLASSIFICATION_RASTER. If you do not set this property, the classification raster will not be created. You must set this property or the OUTPUT_CLASS_ACTIVATION_RASTER_URI property. You can also set both.
OUTPUT_CLASS_ACTIVATION_RASTER
This is a reference to the output class activation raster of filetype ENVI. It is a float raster with one band for each class, including the background class, whose values range from 0 to 1.
OUTPUT_CLASS_ACTIVATION_RASTER_URI (optional)
Specify a string with the fully qualified filename and path of the associated OUTPUT_CLASS_ACTIVATION_RASTER. If you do not set this property, the class activation raster will not be created. You must set this property or the OUTPUT_CLASSIFICATION_RASTER_URI property. You can also set both.
Version History
See Also
BuildLabelRasterFromROI Task, BuildLabelRasterFromClassification Task, TrainTensorFlowPixelModel Task