This code implements the pipeline described in the IEEE TVCG 2018 paper "Pigmento: Pigment-Based Image Analysis and Editing" Jianchao Tan, Stephen DiVerdi, Jingwan Lu and Yotam Gingold.
- The input image should be a good size, like 600*600. If it is large image, it will be slow for weights map extraction or layer map extraction.
- The flower image is from Nel Jansen.
- Python 3.9
- Numpy
- Scipy
- Pillow
- numba
- matplotlib
- autograd
- scikit-image
- scikit-learn
- cvxopt (with 'glpk' solver option)
- opencv3 (brew install opencv3)
- step1_ANLS_with_autograd.py
- Solve_KM_mixing_model_fixed_KS_with_autograd.py
- Solve_KM_layer_model_fixed_KS_with_autograd.py
- fast_energy_RGB_lap_adjusted_weights.py
- Editing_GUI.py
User can give number of pigments, for example, "6" in the command line below.
$ cd new_pipeline_executable
$ python step1_ANLS_with_autograd.py wheatfield-crop-steve.png Existing_KS_parameter_KS.txt 2 None wheatfield-crop-steve-sampled_pixels-400 0 6 10.0 0.0 0.0 0.001 0.001 1e-6 /wheatfield-crop None 0 1 1000 400 1 0
You can use default parameter values in command line directly, only need change example name.
$ cd new_pipeline_executable/wheatfield-crop
$ python ../Solve_KM_mixing_model_fixed_KS_with_autograd.py wheatfield-crop-steve.png primary_pigments_KS-6.txt None wheatfield-crop-steve-primary_pigments_color_vertex-6-KM_weights-W_w_10.0-W_sparse_0.1-W_spatial_1.0-choice_0-blf-W_neighbors_0.0-Recursive_Yes 10.0 0.1 0 1.0 0.0 blf Yes
You need create a layer order file manually: "order1.txt" and put it in /wheatfield-crop folder, since we are using 6 pigments, so "order1.txt" content can be like: 0 1 2 3 4 5 or their permutations.Then you can run below command.
$ cd new_pipeline_executable/wheatfield-crop
$ python ../Solve_KM_layer_model_fixed_KS_with_autograd.py wheatfield-crop-steve.png primary_pigments_KS-6.txt None wheatfield-crop-steve-primary_pigments_color_vertex-6-KM_layers-W_w_10.0-W_sparse_0.1-W_spatial_1.0-choice_0-blf-W_neighbors_0.0-Recursive_Yes-order1 10.0 0.1 0 1.0 0.0 blf Yes order1.txt
4. Extract PD layers and weights (Tan 2016) using KM pigments's RGB colors as primary color. It will use same order as KM layers.
$ cd new_pipeline_executable
$ python fast_energy_RGB_lap_adjusted_weights.py /wheatfield-crop wheatfield-crop-steve.png order1.txt primary_pigments_color_vertex-6.js --weights weights-poly3-opaque400-dynamic40000.js --solve-smaller-factor 2 --save-every 50
5. GUI code. Above commands will generate a "Application_Files" folder in the "wheatfield-crop" folder, which will contain all needed files for GUI.
$ cd new_pipeline_executable
$ python Editing_GUI.py
All results will saved in a created folder "Tan2016_PD_results", "/wheatfield-crop" in below command is example folder name, and "6" is palette size that user choose.
$ cd new_pipeline_executable
$ python Extract_PD_palettes.py wheatfield-crop-steve.png 6 /wheatfield-crop
Like before, you need a different "order1.txt" file for different examples, and same "weights-poly3-opaque400-dynamic40000.js" for all examples. You can just simply set "order1.txt" content as 0 1 2 3 4 5 in this example. All results will saved in a created folder "Tan2016_PD_results". Actually, below command format is same as before, I only change the code filename to "Extract_PD_layers.py" and change input palette filename to "wheatfield-crop-steve-6-PD_palettes.js".
$ cd new_pipeline_executable
$ python Extract_PD_layers.py /wheatfield-crop wheatfield-crop-steve.png order1.txt wheatfield-crop-steve-6-PD_palettes.js --weights weights-poly3-opaque400-dynamic40000.js --solve-smaller-factor 2 --save-every 50