Loading...
Searching...
No Matches
Structured forests for fast edge detection
Introduction
In this tutorial you will learn how to use structured forests for the purpose of edge detection in an image.
Examples
data:image/s3,"s3://crabby-images/bad90/bad9009dc34db16d2a4e7280ef3440f3f2bbfa1a" alt=""
image
data:image/s3,"s3://crabby-images/ae1b1/ae1b183d16b9cc8b3945acd77780e84916eec33b" alt=""
image
data:image/s3,"s3://crabby-images/65965/65965b6e22feb4677d04c0b8fef80b4d67cdf830" alt=""
image
data:image/s3,"s3://crabby-images/a87b0/a87b0a82fd2e3d91bc93cf0f1aaff56603fac184" alt=""
image
data:image/s3,"s3://crabby-images/fc8e2/fc8e2c457671afb7e8e6f7cc461cd0ae7ef210fa" alt=""
image
data:image/s3,"s3://crabby-images/715d4/715d416112405182ada84610f64dc44abf932e52" alt=""
image
data:image/s3,"s3://crabby-images/ab377/ab377a17fc689b228c5c8a7755bc8d4b1b29094c" alt=""
image
data:image/s3,"s3://crabby-images/3a260/3a26031cea3550262bb32ec91a640e80c80cc86a" alt=""
image
data:image/s3,"s3://crabby-images/9bd69/9bd69aec80a9add2ad851f2fc8a5fba5421edff9" alt=""
image
data:image/s3,"s3://crabby-images/236b4/236b4f83c1ad0a49b7ff8a122a12a71817b53be1" alt=""
image
data:image/s3,"s3://crabby-images/becc3/becc397ff5398c6df584b4db4cfbf6fe69ac3f07" alt=""
image
data:image/s3,"s3://crabby-images/8f56a/8f56a43ab52c8076821b408e83eae35457ae3181" alt=""
image
- Note
- binarization techniques like Canny edge detector are applicable to edges produced by both algorithms (Sobel and StructuredEdgeDetection::detectEdges).
Source Code
CV_EXPORTS_W bool imwrite(const String &filename, InputArray img, const std::vector< int > ¶ms=std::vector< int >())
Saves an image to a specified file.
Definition: ximgproc.hpp:125
"black box" representation of the file storage associated with a file on disk.
Definition: core.hpp:106
Explanation
Load source color image
Convert source image to float [0;1] range
image.convertTo(image, DataType<float>::type, 1/255.0);void convertTo(OutputArray m, int rtype, double alpha=1, double beta=0) constConverts an array to another data type with optional scaling.Run main algorithm
Ptr<StructuredEdgeDetection> pDollar =createStructuredEdgeDetection(modelFilename);Mat edges;pDollar->detectEdges(image, edges);Show results
if ( outFilename.size() == 0 ){imshow("edges", edges);imshow("edges nms", edge_nms);waitKey(0);}elseimwrite(outFilename, 255*edges);
Literature
For more information, refer to the following papers : [Dollar2013] [Lim2013]