You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

492 lines
15 KiB

# About this Project
This application has been developed as a part of bachelor's thesis at Brno University of Technology - Faculty of Information Technology (BUT FIT).
The topic of this thesis was **Generating a 3D Fingerprint Model** from input fingerprint image.
This application consists of two main parts. The first part of the application uses custom filter library to apply image filters to enhance fingerprint images.
This library consists of several filters imported from image processing modules.
The second part uses the processed image to make a 3D model of the fingerprint.
The model can then be used to print an accurate representation of human fingerprint using a 3D printer.
This model can either be planar, curved or mapped to a finger model.
# Prerequisites
For now this has only been tested on Ubuntu gnu/linux machines.
It should however be possible to run it in on most distributions, WSL and virtual machines of most linux distributions.
This guide is for Ubuntu machines only.
Before cloning repository, you need these to succesfully use the application.
* **python** version 3.10 is a requirement might work on earlier python 3 versions
```sh
2 years ago
sudo apt install python3.10
```
* **virtualenv** package for virtual enviroment creation, other packages are installed automatically later
```sh
2 years ago
pip install virtualenv
```
# Installation
This will install the application and its components into the Documents directory.
It will also install several required python packages, including **venv**, which is used to create a virtual enviroment. Just paste and these commands into the command line.
1. Go to a suitable installation folder, for example **Documents**:
```sh
2 years ago
cd /home/username/Documents
```
2. Clone the repository to this directory:
```sh
git clone https://strade.fit.vutbr.cz/git/xlanro00/BP_DP-xlanro00.git
```
3. Go inside the newly created directory:
```sh
2 years ago
cd BP_DP-xlanro00
```
2 years ago
4. Create and activate the virtual enviroment:
```sh
2 years ago
virtualenv .venv && source .venv/bin/activate
```
5. Automatically install required python modules from **requirements.txt**:
```sh
2 years ago
pip install -r requirements.txt
```
Now, you are all set to run the application.
Examples of how to do this are shown in the section bellow.
# Filtering images
Once all the requirements are installed, the application is ready to use.
Fingerprint sample is located in res/examples, its name is Palec_P4.tif.
* You will need to enter the virtual enviroment every time you want to use the application.
2 years ago
```sh
source .venv/bin/activate
```
* The application requires **input** and **output filenames** including path from the root project directory, **dpi** and **filter list** as shown bellow.
```sh
python3 src/main.py input_file output_file dpi filters
```
There are two ways to enter the filters:
1. manually list all filter names and their parameters on the **command line**:
```sh
python3 src/main.py res/examples/Palec_P4.tif res/examples/Palec_P4_from_cline.png 600 total_variation weight=0.15 median ksize=5
```
2. load them from preset in a JSON **configuration file**, that can be used to tune and modify existing presets, or create new ones:
```sh
python3 src/main.py res/examples/Palec_P4.tif res/examples/Palec_P4_from_preset.png 600 --config conf/conf.json new_ridge
```
# Configuration and presets
There is an option to input the filter series as a preset from JSON configuration file.
Here the presets are stored and are ready to be used whenever needed. You can usehow many filters you need as long as you like the output.
It is therefore highly recommended to check the output after every preset change.
Filter used in the example above is listed bellow, along with the general form of configuration file.
<style>
table {
border-collapse: collapse;
width: 100%;
}
th, td {
padding: 8px;
text-align: left;
border-bottom: 1px solid #ddd;
}
th {
background-color: #f2f2f2;
}
.code {
font-family: 'Courier New', monospace;
background-color: #f5f5f5;
padding: 8px;
}
.language-json {
color: #333;
}
</style>
<table>
<thead>
<tr>
<th>General format</th>
<th>Woking example</th>
</tr>
</thead>
<tbody>
<tr>
<td>
<pre><code class="language-json">
{
"preset": [
{
"name": "filter_name",
"parameter": value,
"parameter": value
},
{
"name": "filter_name",
"parameter": value
}
],
"preset": [
...
]
...
}
</code></pre>
</td>
<td>
<pre><code class="language-json">
{
"git_example": [
2 years ago
{
2 years ago
"name": "denoise_tv_chambolle",
"weight": 0.01,
"iterations": 1
2 years ago
},
{
2 years ago
"name": "median",
"ksize": 3
}
]
}
</code></pre>
</td>
</tr>
</tbody>
</table>
To avoid accidental loss of information caused by modifying presets that have been used to generate stl files,
these presets are stored inside a JSON file db.json.
This file serves as a simple database for storing presets, stored presets are modified by adding generated hash of all the filters in that preset.
There is also an option to save current command line setting as a preset using -d switch and it's new name:
## Available filters with parameters
Overview of all implemented filters and their parameters with descriptions is listed below.
2 years ago
- median blur
- ksize (int) - Kernel size, determines how large of an area the filter processes.
2 years ago
- gaussian blur
- sigma (int) - Gaussian kernel standart deviation, determines the weight of further pixels on the currently processed pixel.
2 years ago
- bilateral blur
- diameter (int) - Diameter of pixel neighborhood used for filtering.
- sigmaColor (int) - Determines the weight of pixels of different color.
- sigmaSpace (int) - Determines the weight of further pixels.
2 years ago
- bilateral_scikit
- sigmaColor (float) - Determines the weight of pixels of different color.
- sigmaSpace (float) - Determines the weight of further pixels.
2 years ago
- nlmeans (non-local means)
- patch_size (int) - Size of patches used for denoising.
- patch_distance (int) - Distance in pixels where to search for patches.
- h (float) - Cut-off distance, higher means more smoothed image.
2 years ago
- total_variation
- weight (float) - Denoising weight, determines how much the image will be denoised.
2 years ago
- block_match
2 years ago
- sigma (float)- Standart deviation
2 years ago
- unsharp mask scikit
- radius (int) - Radius of the gaussian filter.
- amount (float) - Strength of the unsharp mask, determines how much of the mask will be used for filtering.
- unsharp mask pil
- radius (int) - Radius of the gaussian filter.
- amount (float) - Strength of the unsharp mask, determines how much of the mask will be used for filtering.
- threshold (int) -
2 years ago
- farid
- meijering
- sato
- hessian
- sigmas (float) - Standart deviations
2 years ago
- invert
2 years ago
- scale_values
2 years ago
- binarize
- threshold (int) - Value to cut differentiate pixels.
2 years ago
- binarize_otsu
2 years ago
- add_margin
- margin (int) - Number of pixels to add to the sides of the image.
- color (int) - Color value of newly added pixels.
2 years ago
- erode
- kernel (numpy matrix) - Shape of the kernel used to erode image.
2 years ago
- dilate
- kernel (numpy matrix)- Shape of the kernel used to dilate image.
2 years ago
# Comparison
Image before processing the fingerprint and after applying a presets.
Before | After
:--------------------------------------------:|:--------------------------------------------------:
![](res/examples/example_git/Palec_P4.png) | ![](res/examples/example_git/Palec_P4_mod.png)
# Generating curved finger model
It is possible to generate stl model using the `--stl` switch. This requires more parameters, first of which is the type of generated fingerprint.
If the mode is set to `c`, the output model will be a curved finger model, with optional parameters following the filename controlling its shape.
First optional parameter is papilar line height `height_line`, second is thickness of the model `height_base`,
third the rate of curvature along x axis `curv_rate_x` and the third is the rate of curvature along y axis `curv_rate_y`.
2 years ago
* General form for curved stl generation:
```
python3 src/main.py input_file output_file dpi --config config_file preset --stl c height_line height_base curvature_x curvature_y
2 years ago
```
* Working example curved stl generation:
2 years ago
```
python3 src/main.py res/examples/Palec_P4.tif res/examples/Palec_P4_from_preset.png 600 --config conf/conf.json new_ridge --stl c 2 10 2 2
```
2 years ago
# Generating planar finger model
2 years ago
Using `p` mode makes the generated fingerprint model flat.
Optional parameters are height of the papilar lines and base thickness.
2 years ago
* General command form for planar stl generation:
```
python3 src/main.py input_file output_file dpi --config config_file preset --stl p height_line height_base
2 years ago
```
* Working example of planar stl generation:
```
python3 src/main.py res/examples/Palec_P4.tif res/examples/Palec_P4_from_preset.png 600 --config conf/conf.json new_ridge --stl p 2 10
2 years ago
```
2 years ago
2 years ago
# Mapping to existing finger model
2 years ago
Using `m` mode modifies the preexisting finger model to contain fingerprint.
First optional parameter is papilar line height `height_line`, second is the number of iterations `iter` to make the finger mesh denser. Higher number of itertions results in denser finger mesh and better result.
The next three parameters are axis offsets for the finger, `finger_x`, `finger_y`, `finger_z`.
These control the location of the finger. They need to be set only if the user wants to move core of the print closer to the center of the finger model.
The last parameter `finger_model` allows the user to choose custom finger model.
* General command form for mapped stl generation
```
python3 src/main.py input_file output_file dpi --config config_file preset --stl m height_line iter finger_x finger_y finger_z finger_model
```
* Working example of finger mapping
```
python3 src/main.py res/examples/Palec_P4.tif res/examples/Palec_P4.png 600 --config conf/conf.json new_ridge --stl m 0.2 2 0 0 0 res/finger_backup/finger.stl
```
# Usage
When in doubt, you can always check the help with:
python3 src/main.py --help
Which will print out the following message.
```
usage: main.py [-h] [-m | --mirror | --no-mirror] input_file output_file dpi ([-c | --config config_file preset] | [filters ...]) [-s | --stl p height_line height_base | --stl c height_line height_base curv_rate_x curv_rate_y | --stl m height_line iter finger_x finger_y finger_z finger_model] [-d | --database database_filename]
Program for processing a 2D image into 3D fingerprint.
positional arguments:
input_file input file path
output_file output file path
dpi dpi of used scanner
filters list of filter names and their parameters in form [filter_name1 param1=value
param2=value filter_name2 param1=value...]
options:
-h, --help show this help message and exit
-m, --mirror, --no-mirror
switch to mirror input image
-s [STL ...], --stl [STL ...]
create stl model from processed image
-c CONFIG CONFIG, --config CONFIG CONFIG
pair: name of the config file with presets, name of the preset
-d DATABASE, --database DATABASE
switch to store presets in config database
```
# Troubleshooting
<table>
<thead>
<tr>
<th>Error message</th>
<th>Solution</th>
</tr>
</thead>
<tbody>
<tr>
<td>
main.py: error: the following arguments are required: input_file, output_file, dpi, filters
</td>
<td>
You probably forgot to include some of the required arguments.
</td>
</tr>
<tr>
<td>
ERROR: Input file res/Palec_P14.tif does not exist
</td>
<td>
The file you want to process does not exist, check the filename again.
</td>
</tr>
<tr>
<td>
ERROR: Config file not found
</td>
<td>
The config file you want to load config from does not exist, check the filename again.
</td>
</tr>
<tr>
<td>
ERROR: Preset not found in config file
</td>
<td>
The preset is not present in selected config file, check the file again or select the correct config file.
</td>
</tr>
<tr>
<td>
ERROR: Filter undefined_filter not found
</td>
<td>
One of the filters from command line is not defined in the library, check its name.
</td>
</tr>
<tr>
<td>
ERROR: Unrecognized generation mode
</td>
<td>
The first parameter of stl generation should be p, c or m, check it again.
</td>
</tr>
<tr>
<td>
ERROR: Line depth must be less than plate thickness
</td>
<td>
When generating a cast, the depth must be less than the base plate thckness, otherwise it would have holes on the other side.
</td>
</tr>
<tr>
<td>
ERROR: Depth of plate height must be positive
</td>
<td>
Cannot generate negative base plate thickness, check order of arguments.
</td>
</tr>
<tr>
<td>
ERROR: Base and line height must both be positive
</td>
<td>
In curved generation any negative argument is an error, casts are only for planar mode.
</td>
</tr>
<tr>
<td>
ERROR: Fingerprint image is outside of the finger model
</td>
<td>
Outside of range of the finger, fingerprint cannot be mapped to nothing. Try to change finger_x, finger_y and finger_z parameters.
</td>
</tr>
</tbody>
</table>
# Roadmap
- [x] Load and store image
- [x] Apply basic image processing filters
2 years ago
- [X] Scale the image using given dpi
- [X] Create filter library with more filters
2 years ago
- [X] Add more suitable filters to the library
- [x] Use presets from config files
- [X] Add the option to save current filter preset to config file
2 years ago
- [X] Add the option to modify filter parameters
- [X] Convert the processed image to flat stl lithophane
- [X] Add the option to curve the lithophane into the shape of a finger
- [X] Export final model ready for 3D print
- [X] Add the option to map the fingerprint onto a given finger model
- [X] Finalize, document everything
#
### Author
Rostislav Lán - xlanro00@stud.fit.vutbr.cz
### Supervisor
Ing. Petr Malaník
### Links
Project Link: [https://strade.fit.vutbr.cz/git/xlanro00/BP_DP-xlanro00](https://strade.fit.vutbr.cz/git/xlanro00/BP_DP-xlanro00)