Created
January 12, 2019 02:29
-
-
Save symisc/aeefb109a67f8e35bcdb2433bf5b941b to your computer and use it in GitHub Desktop.
This program extracts ridges and bifurcations from a fingerprint image.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/* | |
* Programming introduction with the SOD Embedded Image Processing API. | |
* Copyright (C) PixLab | Symisc Systems, https://sod.pixlab.io | |
*/ | |
/* | |
* Compile this file together with the SOD embedded source code to generate | |
* the executable. For example: | |
* | |
* gcc sod.c minutiae.c -lm -Ofast -march=native -Wall -std=c99 -o sod_img_proc | |
* | |
* Under Microsoft Visual Studio (>= 2015), just drop `sod.c` and its accompanying | |
* header files on your source tree and you're done. If you have any trouble | |
* integrating SOD in your project, please submit a support request at: | |
* https://sod.pixlab.io/support.html | |
*/ | |
/* | |
* This simple program is a quick introduction on how to embed and start | |
* experimenting with SOD without having to do a lot of tedious | |
* reading and configuration. | |
* | |
* Make sure you have the latest release of SOD from: | |
* https://pixlab.io/downloads | |
* The SOD Embedded C/C++ documentation is available at: | |
* https://sod.pixlab.io/api.html | |
*/ | |
#include <stdio.h> | |
#include "sod.h" | |
/* | |
* This program extracts ridges and bifurcations from a fingerprint image. | |
* | |
* Minutiae extraction is applied to skeletonized fingerprint image | |
* | |
* The target image must be binary (i.e. images whose pixels have only two possible intensity | |
* value mostly black or white). You can obtain a binary image via sod_canny_edge_image(), | |
* sod_otsu_binarize_image(), sod_binarize_image() or sod_threshold_image(). | |
* | |
* More information about this process can be found at https://sod.pixlab.io/c_api/sod_minutiae.html | |
*/ | |
int main(int argc, char *argv[]) | |
{ | |
/* Input image (pass a path or use the test image shipped with the samples ZIP archive) | |
* | |
* Minutiae extraction is applied to skeletonized fingerprint image. | |
*/ | |
const char *zInput = argc > 1 ? argv[1] : "./fingerprint/fp_whole.pgm"; | |
/* Processed output image path */ | |
const char *zOut = argc > 2 ? argv[2] : "./out_fp.png"; | |
/* Load the input image in the grayscale colorspace */ | |
sod_img imgIn = sod_img_load_from_file(zInput, SOD_IMG_GRAYSCALE/* single channel colorspace (gray)*/); | |
if (imgIn.data == 0) { | |
/* Invalid path, unsupported format, memory failure, etc. */ | |
puts("Cannot load input image..exiting"); | |
return 0; | |
} | |
/* Binarize the input image before the thinning process */ | |
sod_img binImg = sod_threshold_image(imgIn, 0.5); | |
/* Perform Hilditch thinning on this binary image. */ | |
sod_img hildImg = sod_hilditch_thin_image(binImg); | |
/* Perform extraction of minutiae candidates in fingerprint image */ | |
int total, np1, np2; | |
sod_img imgOut = sod_minutiae(hildImg, &total, &np1, &np2); | |
printf("total number of BLACK points = %d\n", total); | |
printf("number of ending points = %d\n", np1); | |
printf("number of bifurcations = %d\n\n", np2); | |
/* Finally save our processed image to the specified path */ | |
sod_img_save_as_png(imgOut, zOut); | |
/* Cleanup */ | |
sod_free_image(imgIn); | |
sod_free_image(binImg); | |
sod_free_image(hildImg); | |
sod_free_image(imgOut); | |
return 0; | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
This program extracts ridges and bifurcations from a fingerprint image.
Minutiae extraction is applied to skeletonized fingerprint image
The target image must be binary (i.e. images whose pixels have only two possible intensity
value mostly black or white). You can obtain a binary image via sod_canny_edge_image(),
sod_otsu_binarize_image(), sod_binarize_image() or sod_threshold_image().
More information about this process can be found at https://sod.pixlab.io/c_api/sod_minutiae.html