Difference 3D (3D Analyst)

Summary

Eliminates portions of multipatch features in a target feature class that overlap with enclosed volumes of multipatch features in the subtraction feature class.

Illustration

Difference 3D

Usage

  • Closed multipatch geometry is required for this analysis. The Is Closed 3D tool can be used to determine if a multipatch feature class contains closed features, and the Enclose Multipatch tool can be used to eliminate gaps in multipatch features.

  • Input features that are fully enclosed by a subtract feature will be completely removed in the output

  • This tool's execution can be very time consuming, and care should be taken when selecting input datasets.

  • The output features will not have any of the attributes of the input features. If necessary, a spatial join to the source features or a relationship class to the optional output table can be constructed to map attributes from the input features to the output dataset.

Syntax

Difference3D(in_features_minuend, in_features_subtrahend, out_feature_class, {out_table})
ParameterExplanationData Type
in_features_minuend

The multipatch features that will have its features removed by the subtrahend features.

Feature Layer
in_features_subtrahend

The multipatch features that will be subtracted from the input.

Feature Layer
out_feature_class

The output multipatch feature class that will contain the resulting features.

Feature Class
out_table
(Optional)

An optional table that stores information about the relationship between the input features and the difference output. The following fields are present in this table:

  • Output_ID—The ID of the output feature.
  • Minuend_ID—The ID of the input feature.
  • Subtrahend—The ID of the subtract feature.
Table

Code sample

Difference3D example 1 (Python window)

The following sample demonstrates the use of this tool in the Python window.

arcpy.env.workspace = 'C:/data'
arcpy.Difference3D_3d('input_mp.shp', 'erase_mp.shp', 'difference_mp.shp')
Difference3D example 2 (stand-alone script)

The following sample demonstrates the use of this tool in a stand-alone Python script.

'''****************************************************************************
Name: Difference3D Example
Description: This script demonstrates how to create
             shadow volumes that fall along a specified surface using the
             Difference3D tool.
****************************************************************************'''
# Import system modules
import arcpy

# Set environment settings
arcpy.env.workspace = 'C:/data'

# Set Local Variables
inMP = 'buildings.shp'
eraseMP = 'bldg_extensions.shp'
outMP = arcpy.CreateUniqueName('bldgs_without_extensions.shp')

# Execute Difference3D
arcpy.Difference3D_3d(inMP, eraseMP, outMP)

Licensing information

  • Basic: Requires 3D Analyst
  • Standard: Requires 3D Analyst
  • Advanced: Requires 3D Analyst

Related topics