imclearborder
영상 테두리에 연결된 밝은 구조체 표시 안 함
설명
예제
연결성이 테두리 지우기에 미치는 영향
단순한 이진 영상을 만듭니다.
BW = [0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 1 1 1 0 0 0 0 1 0 1 1 1 0 0 0 0 0 0 1 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0];
4-연결성을 사용하여 영상 테두리의 픽셀을 지웁니다. imclearborder
는 (5,2)의 픽셀을 지우지 않습니다. 4-연결성에서는 (4,1)의 테두리 픽셀에 연결된 것으로 간주되지 않기 때문입니다.
BWc1 = imclearborder(BW,4)
BWc1 = 9×9
0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0
0 0 0 1 1 1 0 0 0
0 1 0 1 1 1 0 0 0
0 0 0 1 1 1 0 0 0
0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0
이제 8-연결성을 사용하여 영상 테두리의 픽셀을 지웁니다. imclearborder
는 (5,2)의 픽셀을 지웁니다. 8-연결성에서는 테두리 픽셀 (4,1)에 연결된 것으로 간주되기 때문입니다.
BWc2 = imclearborder(BW,8)
BWc2 = 9×9
0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0
0 0 0 1 1 1 0 0 0
0 0 0 1 1 1 0 0 0
0 0 0 1 1 1 0 0 0
0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0
입력 인수
I
— 회색조 또는 이진 영상
숫자형 배열 | 논리형 배열
회색조 또는 이진 영상으로, 숫자형 배열 또는 논리형 배열로 지정됩니다.
예: I = imread('pout.tif');
데이터형: single
| double
| int8
| int16
| int32
| uint8
| uint16
| uint32
| logical
conn
— 픽셀 연결성
4
| 8
| 6
| 18
| 26
| 0
과 1
로 구성된 3×3×...×3 행렬
픽셀 연결성으로, 다음 표에 있는 값 중 하나로 지정됩니다. 디폴트 연결성은 2차원 영상의 경우 8
, 3차원 영상의 경우 26
입니다.
값 | 의미 | |
---|---|---|
2차원 연결성 | ||
| 경계가 서로 닿으면 픽셀이 연결됩니다. 픽셀의 이웃은 가로 또는 세로 방향으로 인접한 픽셀입니다. |
현재 픽셀은 회색으로 표시됩니다. |
| 경계 또는 코너가 서로 닿으면 픽셀이 연결됩니다. 픽셀의 이웃은 가로, 세로 또는 대각선 방향으로 인접한 픽셀입니다. |
현재 픽셀은 회색으로 표시됩니다. |
3차원 연결성 | ||
| 면이 서로 닿으면 픽셀이 연결됩니다. 픽셀의 이웃은 다음 방향으로 인접한 픽셀입니다.
|
현재 픽셀은 회색으로 표시됩니다. |
| 면 또는 경계가 서로 닿으면 픽셀이 연결됩니다. 픽셀의 이웃은 다음 방향으로 인접한 픽셀입니다.
|
현재 픽셀은 큐브의 중앙입니다. |
| 면, 경계 또는 코너가 서로 닿으면 픽셀이 연결됩니다. 픽셀의 이웃은 다음 방향으로 인접한 픽셀입니다.
|
현재 픽셀은 큐브의 중앙입니다. |
더 높은 차원의 경우, imclearborder
는 디폴트 값
을 사용합니다.conndef
(ndims(I),'maximal')
0
과 1
로 구성된 3×3×...×3 행렬을 지정하여 모든 차원에 대해 더 일반적인 방식으로 연결성을 정의할 수도 있습니다. 값이 1
인 요소는 conn
의 중앙 요소를 기준으로 하여 이웃 픽셀의 위치를 정의합니다. conn
은 그 중앙 요소를 기준으로 대칭이어야 합니다. 자세한 내용은 Specifying Custom Connectivities 항목을 참조하십시오.
참고
디폴트가 아닌 연결성을 지정할 경우 입력 영상의 경계에 있는 픽셀이 테두리 픽셀로 간주되지 않을 수 있습니다. 예를 들어, conn = [0 0 0; 1 1 1; 0 0 0]
이면 이 연결성 정의에 따라 첫 번째 행과 마지막 행의 요소들은 영상 범위를 벗어난 영역과 연결되지 않기 때문에 테두리 픽셀로 간주되지 않습니다.
데이터형: double
| logical
출력 인수
J
— 처리된 영상
숫자형 배열 | 논리형 배열
처리된 회색조 또는 이진 영상으로, 지정한 입력 영상에 따라 숫자형 배열 또는 논리형 배열로 반환됩니다.
알고리즘
imclearborder
는 다음과 같은 경우 모폴로지 재구성을 사용합니다.
마스크 영상이 입력 영상인 경우.
마스크 영상과 동일한 테두리 부분을 제외한 모든 곳에서 마커 영상이 0인 경우.
참고 문헌
[1] Soille, P., Morphological Image Analysis: Principles and Applications, Springer, 1999, pp. 164-165.
확장 기능
C/C++ 코드 생성
MATLAB® Coder™를 사용하여 C 코드나 C++ 코드를 생성할 수 있습니다.
사용법 관련 참고 및 제한 사항:
imclearborder
함수는 C 코드 생성을 지원합니다(MATLAB® Coder™가 필요함). 일반적인MATLAB Host Computer
대상 플랫폼을 선택할 경우imclearborder
함수는 미리 컴파일된 플랫폼별 공유 라이브러리를 사용하는 코드를 생성합니다. 공유 라이브러리를 사용하면 성능 최적화가 유지되지만 코드를 생성할 수 있는 대상 플랫폼이 제한됩니다. 자세한 내용은 Types of Code Generation Support in Image Processing Toolbox 항목을 참조하십시오.최대 3차원 입력값만 지원합니다.
선택 사항인 두 번째 입력 인수
conn
은 컴파일타임 상수여야 합니다.
버전 내역
R2006a 이전에 개발됨
참고 항목
MATLAB 명령
다음 MATLAB 명령에 해당하는 링크를 클릭했습니다.
명령을 실행하려면 MATLAB 명령 창에 입력하십시오. 웹 브라우저는 MATLAB 명령을 지원하지 않습니다.
Select a Web Site
Choose a web site to get translated content where available and see local events and offers. Based on your location, we recommend that you select: .
You can also select a web site from the following list:
How to Get Best Site Performance
Select the China site (in Chinese or English) for best site performance. Other MathWorks country sites are not optimized for visits from your location.
Americas
- América Latina (Español)
- Canada (English)
- United States (English)
Europe
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)