Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/atilimcetin/guided-filter
Fast and complete guided filter implementation for OpenCV
https://github.com/atilimcetin/guided-filter
Last synced: 4 months ago
JSON representation
Fast and complete guided filter implementation for OpenCV
- Host: GitHub
- URL: https://github.com/atilimcetin/guided-filter
- Owner: atilimcetin
- License: mit
- Created: 2014-12-19T18:35:46.000Z (about 10 years ago)
- Default Branch: master
- Last Pushed: 2020-06-01T17:00:16.000Z (over 4 years ago)
- Last Synced: 2024-07-21T08:32:45.216Z (7 months ago)
- Language: C++
- Size: 10.7 KB
- Stars: 349
- Watchers: 9
- Forks: 114
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-lists - Guided Filter
README
# Guided filter for OpenCV
Guided filter is an edge-preserving smoothing filter like the bilateral filter. It is straightforward to implement and has linear complexity independent of the kernel size. For more details about this filter see [[Kaiming10]](http://research.microsoft.com/en-us/um/people/kahe/eccv10/).
## Usage
The interface consists of one simple function `guidedFilter` and a class `GuidedFilter`. If you have multiple images to filter with the same guidance image then use `GuidedFilter` class to avoid extra computations on initialization stage. The code supports single-channel and 3-channel (color) guidance images and `CV_8U`, `CV_8S`, `CV_16U`, `CV_16S`, `CV_32S`, `CV_32F` and `CV_64F` data types.
## Examples
These examples are adapted from the [original MATLAB implementation](http://research.microsoft.com/en-us/um/people/kahe/eccv10/guided-filter-code-v1.rar).
### Smoothing
```c++
cv::Mat I = cv::imread("./img_smoothing/cat.bmp", CV_LOAD_IMAGE_GRAYSCALE);
cv::Mat p = I;int r = 4; // try r=2, 4, or 8
double eps = 0.2 * 0.2; // try eps=0.1^2, 0.2^2, 0.4^2eps *= 255 * 255; // Because the intensity range of our images is [0, 255]
cv::Mat q = guidedFilter(I, p, r, eps);
```[data:image/s3,"s3://crabby-images/cd06f/cd06fabe5e6e619eee4f3775fc17e29fe9cf47e6" alt="Cat"](http://atilimcetin.com/guided-filter/img_smoothing/cat.png)
[data:image/s3,"s3://crabby-images/f08f9/f08f9f4cff22d371c5bd3baaaca4893310140da7" alt="r=2, eps=0.1^2"](http://atilimcetin.com/guided-filter/img_smoothing/cat-2-0.1.png)
[data:image/s3,"s3://crabby-images/f46bb/f46bbea410199f7e317b52a675f405940613d810" alt="r=2, eps=0.2^2"](http://atilimcetin.com/guided-filter/img_smoothing/cat-2-0.2.png)
[data:image/s3,"s3://crabby-images/8ab74/8ab74c3ac3fa1554abc6cb16f388a0f2efca750b" alt="r=2, eps=0.4^2"](http://atilimcetin.com/guided-filter/img_smoothing/cat-2-0.4.png)[data:image/s3,"s3://crabby-images/676df/676df8c5d0af6a1d62d528cad87fa8dadb978f45" alt="r=4, eps=0.1^2"](http://atilimcetin.com/guided-filter/img_smoothing/cat-4-0.1.png)
[data:image/s3,"s3://crabby-images/1d13f/1d13fb235c759355273847574a18b491ce314562" alt="r=4, eps=0.2^2"](http://atilimcetin.com/guided-filter/img_smoothing/cat-4-0.2.png)
[data:image/s3,"s3://crabby-images/f6270/f62703c68af3e6df486f3b480719b324aad070af" alt="r=4, eps=0.4^2"](http://atilimcetin.com/guided-filter/img_smoothing/cat-4-0.4.png)[data:image/s3,"s3://crabby-images/f5091/f50910dbe3b29d282680d80ebe04352b25179fa9" alt="r=8, eps=0.1^2"](http://atilimcetin.com/guided-filter/img_smoothing/cat-8-0.1.png)
[data:image/s3,"s3://crabby-images/4d9c9/4d9c978b05515bdd7f3fefe9191bf7c0b70655a6" alt="r=8, eps=0.2^2"](http://atilimcetin.com/guided-filter/img_smoothing/cat-8-0.2.png)
[data:image/s3,"s3://crabby-images/ceb67/ceb673adafe339df163a0230daaee43388a782d7" alt="r=8, eps=0.4^2"](http://atilimcetin.com/guided-filter/img_smoothing/cat-8-0.4.png)### Flash/no-flash denoising
```c++
cv::Mat I = cv::imread("./img_flash/cave-flash.bmp", CV_LOAD_IMAGE_COLOR);
cv::Mat p = cv::imread("./img_flash/cave-noflash.bmp", CV_LOAD_IMAGE_COLOR);int r = 8;
double eps = 0.02 * 0.02;eps *= 255 * 255; // Because the intensity range of our images is [0, 255]
cv::Mat q = guidedFilter(I, p, r, eps);
```[data:image/s3,"s3://crabby-images/54971/54971a4ef9571c66115108fa2a6bf23c9d463bc6" alt="Cave Flash"](http://atilimcetin.com/guided-filter/img_flash/cave-flash.png)
[data:image/s3,"s3://crabby-images/c55eb/c55ebad58a3bc7e75603d14e195d8d49aa2135ad" alt="Cave No Flash"](http://atilimcetin.com/guided-filter/img_flash/cave-noflash.png)
[data:image/s3,"s3://crabby-images/260ff/260ffd1109538c4b1a4768283e65dcd2f4600971" alt="Cave Denoised"](http://atilimcetin.com/guided-filter/img_flash/cave-denoised.png)### Feathering
```c++
cv::Mat I = cv::imread("./img_feathering/toy.bmp", CV_LOAD_IMAGE_COLOR);
cv::Mat p = cv::imread("./img_feathering/toy-mask.bmp", CV_LOAD_IMAGE_GRAYSCALE);int r = 60;
double eps = 1e-6;eps *= 255 * 255; // Because the intensity range of our images is [0, 255]
cv::Mat q = guidedFilter(I, p, r, eps);
```[data:image/s3,"s3://crabby-images/20b24/20b246e4de52bb59c45bb935bd76f9a7adb8270e" alt="Mask"](http://atilimcetin.com/guided-filter/img_feathering/toy-mask.png)
[data:image/s3,"s3://crabby-images/6401f/6401f8a9dca8d0c4926daa96196fde782f62cfb1" alt="Guidance"](http://atilimcetin.com/guided-filter/img_feathering/toy.png)
[data:image/s3,"s3://crabby-images/81982/819826d74a0c0a73b4cb2b63937b7520ed164d82" alt="Feathering"](http://atilimcetin.com/guided-filter/img_feathering/toy-feather.png)### Enhancement
```c++
cv::Mat I = cv::imread("./img_enhancement/tulips.bmp", CV_LOAD_IMAGE_COLOR);
I.convertTo(I, CV_32F, 1.0 / 255.0);cv::Mat p = I;
int r = 16;
double eps = 0.1 * 0.1;cv::Mat q = guidedFilter(I, p, r, eps);
cv::Mat I_enhanced = (I - q) * 5 + q;
```[data:image/s3,"s3://crabby-images/95cf5/95cf58757247511acfa28f7f21dc0226581bc71c" alt="Tulip"](http://atilimcetin.com/guided-filter/img_enhancement/tulips.png)
[data:image/s3,"s3://crabby-images/2e8aa/2e8aaefb83522f774f97c2a263d9a79ffe4e5d77" alt="Smoothed"](http://atilimcetin.com/guided-filter/img_enhancement/tulips-smoothed.png)
[data:image/s3,"s3://crabby-images/0a736/0a736c1d06af57195121f9fcdb0ac253316f6957" alt="Enhanced"](http://atilimcetin.com/guided-filter/img_enhancement/tulips-enhanced.png)## License
MIT license.