digital-image-processing-cpp
digital-image-processing-cpp copied to clipboard
cpp implementation for algorithms in the book "digital image processing and computer vision"("数字图像处理与机器视觉-Visual C++与Matlab实现")
digital-image-processing-cpp
cpp implementation for algorithms in the book "数字图像处理与机器视觉-Visual C++与Matlab实现"
To compile CH3_pixel_operation.cpp
:
./compile.sh -DCH3 CH3_pixel_operation.cpp utility.cpp
In which -DCH3
activates the main
function in the source file, otherwise main
function is ignored. And this source file includes utility.h
, so we need to compile CH3_pixel_operation.cpp
with utility.h
's implementation, which is utility.cpp
.
Similar method for CH 4,5,6,7,8 to compile.
To compile CH9_image_segmentation.cpp
:
./compile.sh -DCH9 CH9_image_segmentation.cpp CH3_pixel_operation.cpp CH5_spatial_domain_image_enhancement.cpp CH8_morphology_image_processing.cpp utility.cpp
Because it includes the corresponding headers.
CH3 pixel operation
Threshold
Set threshold as 100:
data:image/s3,"s3://crabby-images/d8b54/d8b54f43e0dea8d4693aa8d802639b22ef27cce4" alt="drawing"
Linear Transform
Set dFa
as 2.0
, set dFb
as -55
:
data:image/s3,"s3://crabby-images/114f7/114f7e5ff7c39299ccdd573bbb109fb04998b860" alt="drawing"
Gamma Transform
Set gamma
as 1.8
, set comp
as 0
:
data:image/s3,"s3://crabby-images/2cd90/2cd902b4bfdafc64bae35fabd3893216c56c10f6" alt="drawing"
Log Transform
Set dC
as 10:
data:image/s3,"s3://crabby-images/4605c/4605c23dd76a43eff3d548345d97ac7955cdc4ee" alt="drawing"
Partial Linear Transform
Set x1
, x2
, y1
, y2
as 20
, 50
, 100
, 200
:
data:image/s3,"s3://crabby-images/42672/42672eee79037a1cc5998aab904982a901938d58" alt="drawing"
Histogram equalization
data:image/s3,"s3://crabby-images/99645/99645f7db5d239fc11dc12dbd848e4c9ec51c95a" alt="drawing"
Histogram matching to dark
data:image/s3,"s3://crabby-images/a2fe3/a2fe307fecc9226cd1e5770096940f62e163bb59" alt="drawing"
Histogram matching to light
data:image/s3,"s3://crabby-images/dd6d3/dd6d31ed8ff5dcf622b2d1924d565d11e0b4a9db" alt="drawing"
CH4 geometric transformation
Move
Move 20
right and 50
down:
data:image/s3,"s3://crabby-images/95509/9550906f6363011194dc4f555e407e61d5866314" alt="drawing"
Horizontal mirror
data:image/s3,"s3://crabby-images/d137c/d137c449698128c00fb574942bbe4ee141aabe00" alt="drawing"
Vertical mirror
data:image/s3,"s3://crabby-images/f9ff6/f9ff6e4761ffacb25b8553c696c0c02e493e5622" alt="drawing"
Scale
data:image/s3,"s3://crabby-images/0516b/0516bfd9d0fced92e44b145120756929339edbbd" alt="drawing"
Rotate
Rotate 30 degrees counterclockwise:
data:image/s3,"s3://crabby-images/ac94d/ac94d6303daf8324d906032c57d2433d97823822" alt="drawing"
Image projection restore
data:image/s3,"s3://crabby-images/3af1c/3af1cb1a340e973cb4dd2f89ace92ccdf5708aa2" alt="drawing"
data:image/s3,"s3://crabby-images/9364b/9364b5c3f93fad5db5c85701339e61a0b10835b7" alt="drawing"
CH5 spatial domain image enhancement
Smooth average
Kernel size 3:
data:image/s3,"s3://crabby-images/16d17/16d1754d55b3c68084cbe41e6f2441b70caa2401" alt="drawing"
Kernel size 5:
data:image/s3,"s3://crabby-images/951dc/951dcc4f06fb803a851e9a0dacfc502b10a73d01" alt="drawing"
Kernel size 7:
data:image/s3,"s3://crabby-images/9a914/9a91403f7a18fd5d3a4735854f0bf5c76b8b6433" alt="drawing"
Smooth gaussian
data:image/s3,"s3://crabby-images/2aa22/2aa220d58fdc7797da2660e4ad742912c3f8eca3" alt="drawing"
Log edge detection
data:image/s3,"s3://crabby-images/d4870/d48703ead60707a481a7422ce8b7bd561c73c5f8" alt="drawing"
Average vs Gaussian vs Median filter
data:image/s3,"s3://crabby-images/e6625/e662507012c8eb55677ad5ea3ea45a6ee16d777b" alt="drawing"
Roberts cross gradient operator
Positive 45 degrees v.s. Negative 45 degrees v.s. Positive+Negative 45 degrees:
data:image/s3,"s3://crabby-images/9789f/9789fa6bbca4509c4da473e05be83e35859b25e5" alt="drawing"
Sobel gradient operator
Vertical v.s. Horizontal v.s. Vertical+Horizontal:
data:image/s3,"s3://crabby-images/1abd2/1abd249a3917aa15455e0ccb6ea8646404609f8c" alt="drawing"
Laplacian operator
90 degrees rotation isotropy v.s. 45 degrees rotation isotropy v.s. Weighted
data:image/s3,"s3://crabby-images/e28d4/e28d45c724a5785ed2e0877af1f323c99c5cd56f" alt="drawing"
Enhancement
Roberts positive 45 degrees:
data:image/s3,"s3://crabby-images/9b98f/9b98fdfa45ccdfd59b315d2292d71e42f714c04c" alt="drawing"
Sobel vertical:
data:image/s3,"s3://crabby-images/57639/5763959e7a42e3af11af1660a0d6286b6d103623" alt="drawing"
Laplacian weighted:
data:image/s3,"s3://crabby-images/85b7d/85b7d6200bfc60b66e08931611dc8b3386ea7f31" alt="drawing"
CH6 frequency domain image enhancement
Ideal low pass filter
data:image/s3,"s3://crabby-images/cf307/cf307c59b701ec4e5857e15d00247a2ee9fb77c9" alt="drawing"
Gauss low pass filter
data:image/s3,"s3://crabby-images/cf307/cf307c59b701ec4e5857e15d00247a2ee9fb77c9" alt="drawing"
Gauss high pass filter
data:image/s3,"s3://crabby-images/1f36b/1f36bcec24c5af9844d4d01ceecda09d5ce01cc7" alt="drawing"
Laplace filter
data:image/s3,"s3://crabby-images/81347/81347462f935e8e9babbb27e2cdab91288381826" alt="drawing"
Gauss band rejection filter
Image and noised image in frequency domain:
Filter and filterd image in frequency domain:
Before and after applying Gauss band rejection filter:
CH7 color image processing
CMY
data:image/s3,"s3://crabby-images/dd5a0/dd5a0c0a39682e38278dc7786cad478864024281" alt="drawing"
HSI
data:image/s3,"s3://crabby-images/95c67/95c67af2a55cbd0e5d3be8e098c56cdf0b61b479" alt="drawing"
HSV
data:image/s3,"s3://crabby-images/0e700/0e7004d0281557b58b70405c5929a6ddcbf2db90" alt="drawing"
YUV
data:image/s3,"s3://crabby-images/746c4/746c48fbb239a377a461f67e223c79072038d894" alt="drawing"
YIQ
data:image/s3,"s3://crabby-images/dc9f1/dc9f16808bb1c1f826e0788d180dcdedab535558" alt="drawing"
Color compensating
data:image/s3,"s3://crabby-images/25d64/25d64d6b4713ac9c15a80f4a87cbb64a5a1feef8" alt="drawing"
data:image/s3,"s3://crabby-images/d06dc/d06dc4d30efba2c51f42092222d896139d9eedd3" alt="drawing"
Color balancing
data:image/s3,"s3://crabby-images/78b03/78b0314306d4924ca52fb80ccc3154d9ea456bcc" alt="drawing"
CH8 morphology image processing
Erode using 3 x 3 square kernel and using cross kernel
data:image/s3,"s3://crabby-images/97d9d/97d9da7d2ae6e04ee6ae19a5c775032864dfc42a" alt="drawing"
Dilate using 3 x 3 square kernel and using cross kernel
data:image/s3,"s3://crabby-images/193d1/193d1a8065ea33c2c4e8dfb5e7e36a0d17df4ed1" alt="drawing"
Erode operation and open operation
data:image/s3,"s3://crabby-images/72c74/72c74cfe24e149138838ad130aa70439fd666ff5" alt="drawing"
Dilate operation and close operation
data:image/s3,"s3://crabby-images/0f43d/0f43dee31a29887cb779abd1fdb07a37b8dcf70a" alt="drawing"
Hit-or-miss transform with 50 x 50 square kernel
data:image/s3,"s3://crabby-images/b54df/b54df9077e50dfd519f48ee6da4199c66b5ff038" alt="drawing"
Extract boundary
data:image/s3,"s3://crabby-images/c6ef9/c6ef9741f03747ff225f89d6229622ed428bc3ce" alt="drawing"
Trace boundary
data:image/s3,"s3://crabby-images/079d6/079d6b51042e3c63cabd02e095146f2dfd1f5850" alt="drawing"
Fill region
data:image/s3,"s3://crabby-images/5843b/5843b231a59d43bc271ffb22a71fa3b54f6223b8" alt="drawing"
Label connected component
data:image/s3,"s3://crabby-images/b8c2c/b8c2cab37557f72cee2d81e29a419ba3c43eade0" alt="drawing"
Thining
data:image/s3,"s3://crabby-images/6dec1/6dec165417501058e246585b7fb3e534d06394bc" alt="drawing"
Pixelate
data:image/s3,"s3://crabby-images/7cf66/7cf66f8488e2d088ee8c7d72918a2dd3cb544521" alt="drawing"
Convex hull unconstrained and constrained(using bounding rectangle)
data:image/s3,"s3://crabby-images/a2c58/a2c5800f8b0973f8a6d62777b0e6f583cbfe6656" alt="drawing"
Gray dilate
data:image/s3,"s3://crabby-images/d623b/d623b159c876a4bc47e6eb65f7f633953d3ce393" alt="drawing"
Gray erode
data:image/s3,"s3://crabby-images/3e1be/3e1bec56d7d72599269322a0075fc7deaa58e700" alt="drawing"
Gray open
data:image/s3,"s3://crabby-images/11d19/11d196d74666f691a032b5512cad26edad3bc6d3" alt="drawing"
Gray close
data:image/s3,"s3://crabby-images/1217d/1217d714630984d55cc3cfe0354d19c3fc614b7b" alt="drawing"
Top-hat transform
data:image/s3,"s3://crabby-images/850b8/850b8fb7546835a10c46c259f6c89c0855e83f64" alt="drawing"
CH9 image segmentation
Edge detection using Prewitt operator
data:image/s3,"s3://crabby-images/91335/91335128c45fa28e9477b7aef6e085b79726bff3" alt="drawing"
Edge detection using Sobel operator
data:image/s3,"s3://crabby-images/9bda3/9bda39df57df859a407d6109f99cc06fcc37a12a" alt="drawing"
Edge detection using LoG operator
data:image/s3,"s3://crabby-images/f2f03/f2f03103b6624515a456dbdc524791e87a22d7e1" alt="drawing"
Canny edge detector
data:image/s3,"s3://crabby-images/ff435/ff435560da32874c5f9a80ee90cd708ba42d14c3" alt="drawing"
Hough transformation for line detection
data:image/s3,"s3://crabby-images/eb024/eb0245ae96401bf290101d77ff1bee9f08e5196d" alt="drawing"
Automatically choose threshold for binarization
data:image/s3,"s3://crabby-images/298fd/298fd15a86ff48598286e090a3d38e7a428bb747" alt="drawing"
Region growing for image segmentation
data:image/s3,"s3://crabby-images/d337c/d337c6568e581c315e3cee49babd0194b254fb2d" alt="drawing"
Region splitting(decomposing) for image segmentation
data:image/s3,"s3://crabby-images/ed5e6/ed5e6ecef509a2c0172cccbd1297037a98600c6b" alt="drawing"