forked from JzHuai0108/ImageSegmentor
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMMOFUNC.h
82 lines (75 loc) · 5.01 KB
/
MMOFUNC.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
/***************************************************************/
/* */
/* Mathematical Morphological Operations */
/*refer to IMPLEMENTATION OF MATHEMATICAL MORPHOLOGICAL OPERATIONS FOR spatial data by dong pinliang */
/***************************************************************/
/* The following is a list of functions in the C programming */
/* language for (1) maximum/minimum calculation, (2) binary or */
/* gray scale image dilation, (3) binary or gray scale image */
/* erosion, (4) binary image hit/miss transform, (5) binary */
/* image thinning, and (6) trimming of thinned image. */
/*-------------------------------------------------------------*/
/* Description of arguments in the functions: */
/* arry - pointer to a one-dimensional array; */
/* num - size of the one-dimensional array; */
/* img - input image (defined as pointer to pointer); */
/* xsize - size of input image in X; */
/* ysize - size of input image in Y; */
/* st - pointer to a structuring element defined as */
/* a 1-D array; */
/* wdsz - size of the structuring element defined as an */
/* n by n window where n is an odd. For thinning and */
/* trimming, wdsz=n=3; For other operations, wdsz can */
/* be 3, 5, 7, etc. The structuring element may have */
/* different shapes such as box, plus and cross. For */
/* gray scale image operations, box shape is used in */
/* relevant functions for simplicity. */
/* nitr - number of iterations for a specific operation; */
/* opt - option for gray scale or binary operations; opt=1 */
/* for gray scale, opt=0 for binary, and opt=-1 for */
/* erosion in thinning. */
/* th - threshold for gray scale dilation and erosion */
/* operations. th=0 can be used to dilate/erode all */
/* the image pixels without setting non-zero pixel to */
/* zero. */
/* */
/* Note: functions are indicated if they are called by others. */
/* */
/* Written by: */
/* */
/* Pinliang Dong */
/* Department of Geology */
/* University of New Brunswick */
/* Fredericton, N.B. */
/* Canada E3B 5A3 */
/* */
/* October 1995. */
/*-------------------------------------------------------------*/
/*-------------------------------------------------------------*/
/* (1) Calculate maximum and minimum values. */
/* Called by dilation () and erosion (). */
/*-------------------------------------------------------------*/
#include<malloc.h>
void max_min(int *arry, int num); /* data array, and size of array */
/*-------------------------------------------------------------*/
/* (2) Dilation of image (binary or gray scale) */
/*-------------------------------------------------------------*/
int **dilation (int **img, int xsize, int ysize,int *st,int nitr,int wdsz,int opt,int th);
/*-------------------------------------------------------------*/
/* (3) Erosion of image (binary or gray scale). */
/* Called by hitmiss (). */
/*-------------------------------------------------------------*/
int **erosion(int **img,int xsize,int ysize,int *st,int nitr,int wdsz,int opt,int th);
/*-------------------------------------------------------------*/
/* (4) Hit/miss transformation of image. */
/* Called by thinning (). */
/*-------------------------------------------------------------*/
int **hitmiss(int **img, int xsize, int ysize, int *st, int wdsz);
/*-------------------------------------------------------------*/
/* (5) Thinning of image. */
/*-------------------------------------------------------------*/
int **thinning(int **img,int xsize,int ysize,int nitr,int wdsz);
/*-------------------------------------------------------------*/
/* (6) Trimming of 1-pixel thick skeleton legs & short lines. */
/*-------------------------------------------------------------*/
int **trimming(int **img, int xsize, int ysize, int nitr);