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/8a23e/8a23e55042a363ab71c5437919654a846d2e9bd3" alt=""
Figure 1. Input image
data:image/s3,"s3://crabby-images/da03b/da03bc4e4a895b101b4386ade50aca7ee01d956f" 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/32a41/32a4143a8688f33fcd07374a7d29b58267375e30" alt=""
Figure 3. Input image
data:image/s3,"s3://crabby-images/73d63/73d63bc6d3df7c02999aa47da82ddb522148c5db" 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/a80d2/a80d203630580267458b2834577600b8759c1b99" 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/52c67/52c6787d5ad917ce58f1be23b5e8af512ebfa024" 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/c23d9/c23d948a84cec0ba91f97fff2bbfcb67383ea7ac" 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/09464/09464c0c61332990a3c3afd7ca1e0f61c9e43773" alt=""
Figure 8. Mask