thresholdcv
Applies a threshold to each element of the given image, handle, resulting in a grayscale image, R, whose pixels represent the elements exceeding the threshold.
Syntax
[computedthreshold, R] = thresholdcv(handle, threshold, max, type)
Inputs
- handle
- Handle of an image.
- threshold
- Real vector of [width height] representing the dimensions of R.
- fx
- Threshold value.
- max
- Maximum value to use with type value of 8 or 16.
- type
- Threshold type. Valid values are:
- 0
- R(x,y) = max if handle(x,y) > threshold and 0 otherwise.
- 1
- R(x,y) = 0 if handle(x,y) > threshold and max otherwise.
- 2
- R(x,y) = threshold if handle(x,y) > threshold and handle(x,y) otherwise.
- 3
- R(x,y) = handle(x,y) if handle(x,y) > threshold and 0 otherwise.
- 4
- R(x,y) = 0 if handle(x,y) > threshold and handle(x,y) otherwise.
- 8
- Uses Otsu algorithm for optimal threshold.
- 16
- Uses Triangle algorithm for optimal threshold.
Outputs
- computedthreshold
- Computed threshold value.
- R
- Handle of the resized image.
Example
handle = imreadcv('bird4.jpg', 0);
[computedthreshold, mask] = thresholdcv(handle, 10, 255, 0);
data:image/s3,"s3://crabby-images/6e975/6e975c6725e94c17ec7e0212638ac3fa060be875" alt=""
Figure 1. Input image
data:image/s3,"s3://crabby-images/0114b/0114b146352412c2cd1561a7f0d96e2fb2d802c8" alt=""
Figure 2. Mask
src = imreadcv('thresholdcv_fig1.png');
figure(1);
imshowcv(src);
thresh = 0;
maxValue = 255;
[computedthreshold, mask] = thresholdcv(src, thresh, maxValue, 0); %Binary threshold
figure(2);
imshowcv(mask);
data:image/s3,"s3://crabby-images/54e47/54e4795bc0296c78aec8ed905f0a6c95f10150c4" alt=""
Figure 3. Input image
data:image/s3,"s3://crabby-images/68c8b/68c8b3a76616ecf2ef2203b49c6af69d742cdea5" alt=""
Figure 4. Mask
src = imreadcv('thresholdcv_fig1.png');
figure(1);
imshowcv(src);
thresh = 127;
maxValue = 255;
[computedthreshold, mask] = thresholdcv(src, thresh, maxValue, 0); %Binary threshold
figure(2);
imshowcv(mask);
data:image/s3,"s3://crabby-images/8163c/8163c27ccb2fa3997f908cbeb26db6d4a724e191" alt=""
Figure 5. Mask
src = imreadcv('thresholdcv_fig1.png');
figure(1);
imshowcv(src);
thresh = 127;
maxValue = 150;
[computedthreshold, mask] = thresholdcv(src, thresh, maxValue, 0); %Binary threshold
figure(2);
imshowcv(mask);
data:image/s3,"s3://crabby-images/966ea/966ea92593e1ae40fd8a13999da125056860df36" alt=""
Figure 6. Mask
src = imreadcv('thresholdcv_fig1.png');
figure(1);
imshowcv(src);
thresh = 0;
maxValue = 255;
[computedthreshold, mask] = thresholdcv(src, thresh, maxValue, 1); %Inverse binary threshold
figure(2);
imshowcv(mask);
data:image/s3,"s3://crabby-images/caeb0/caeb0e693c5be0f20185495afc594f5fc61dadab" alt=""
Figure 7. Mask
src = imreadcv('thresholdcv_fig1.png');
figure(1);
imshowcv(src);
thresh = 150;
maxValue = 255;
[computedthreshold, mask] = thresholdcv(src, thresh, maxValue, 2); %Inverse binary threshold
figure(2);
imshowcv(mask);
data:image/s3,"s3://crabby-images/2c681/2c681c67374e7b2268b3ead61d3beeeb363cb4b6" alt=""
Figure 8. Mask