You are here: Start » Function Reference » Computer Vision » Texture Analysis » LinearBinaryPattern

LinearBinaryPattern
Header: | FIL.h |
---|---|
Namespace: | fil |
Module: | FoundationBasic |
Creates histogram and map of Linear Binary Patterns (with radius 1 and size 8) of provided image.
Syntax
void fil::LinearBinaryPattern ( const fil::Image& inImage, ftl::Optional<const fil::Region&> inRoi, fil::LinearBinaryPatternType::Type inPatternType, fil::Histogram& outPatternHistogram, fil::Image& outTextureImage )
Parameters
Name | Type | Default | Description | |
---|---|---|---|---|
![]() |
inImage | const Image& | Mono-channel image. | |
![]() |
inRoi | Optional<const Region&> | NIL | Region of Interest. |
![]() |
inPatternType | LinearBinaryPatternType::Type | Type of LBP to produce. | |
![]() |
outPatternHistogram | Histogram& | Histogram of LBP codes found in inImage. | |
![]() |
outTextureImage | Image& | LBP map of input image. |
Requirements
For input inImage only pixel formats are supported: 1⨯uint8.
Read more about pixel formats in Image documentation.
Description
The LPB histogram (treated as a 256 dimensional feature vector) is a texture visual descriptor useful for texture classification.
It is obtained by calculating a pattern for each pixel, and then producing a histogram from all these numbers.
The pattern is a 8-bit array (coded in uint8) with results of comparisons of the center pixel value to all its neighbours.
Following types of LPB can be calculated:
- Plain
- RotationInvariant - all patterns (and thus histogram bins) that can be obtained by binary shifts from each other are merged into one
- Uniform - non-uniform patterns (these containing more than two 01 or 10 transitions - e.g. 00110010 has 4) are merged into one bin
- UniformRotationInvariant - apply both RotationInvariant and Uniform operations
More information can be found at https://en.wikipedia.org/wiki/Local_binary_patterns
Examples
![]() Source image with following ROIs defined: |
|
![]() LBP histograms calculated for top-left and top-right regions (different parts of fur) |
![]() LBP histograms calculated for top-left region and bottom region (nose) |
Errors
List of possible exceptions:
Error type | Description |
---|---|
DomainError | Not supported inImage pixel format in LinearBinaryPattern. Supported formats: 1xUInt8. |