# Distribution Coercion Transform pixel values so their distribution matches a target shape (uniform, Gaussian, or discrete levels) using rank-based reassignment. Equivalent to Gwyddion's coerce.c module. ## Inputs | Name | Type | Required | Description | |------|------|----------|-------------| | field | DATA_FIELD | Yes | Input field whose value distribution will be transformed | ## Outputs | Name | Type | Description | |------|------|-------------| | result | DATA_FIELD | Field with pixel values reassigned to match the target distribution | ## Controls | Name | Type | Default | Description | |------|------|---------|-------------| | distribution | dropdown | uniform | Target distribution shape: uniform, gaussian, or levels | | n_levels | INT | 4 | Number of discrete output levels (2-1000); visible only for levels mode | | processing | dropdown | field | Processing scope: field (entire array at once) or rows (line-by-line) | ## Notes - The transformation is rank-based: pixels are sorted, then reassigned values drawn from the target distribution in sorted order. This preserves the relative ordering of all pixel values. - Uniform mode spreads values evenly between the original minimum and maximum. - Gaussian mode maps ranks to the inverse normal CDF, scaled to match the original mean and standard deviation. - Levels mode quantizes the data into a fixed number of evenly spaced discrete values, useful for terrace-like visualization or discrete height analysis. - Row mode applies the transformation independently to each scan line, which can correct line-to-line distribution variations in SPM data.