All work in progress saved
This commit is contained in:
commit
6be6982ce5
|
@ -0,0 +1,2 @@
|
|||
build/
|
||||
*.DS_Store
|
|
@ -0,0 +1,8 @@
|
|||
# Marker Separation
|
||||
|
||||
Project for palletizing images based on a limited set of marker colors.
|
||||
|
||||
Includes Python application for prototyping and C++ application for
|
||||
building a self-contained binary.
|
||||
|
||||
|
|
@ -0,0 +1 @@
|
|||
build
|
|
@ -0,0 +1,17 @@
|
|||
cmake_minimum_required(VERSION 3.1)
|
||||
PROJECT (separate)
|
||||
|
||||
set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} ${CMAKE_CURRENT_SOURCE_DIR}/cmake-modules)
|
||||
|
||||
find_package(OpenCV HINTS /usr/local/opt/opencv /usr/local/Cellar/opencv REQUIRED)
|
||||
|
||||
set( NAME_SRC
|
||||
separate.cpp
|
||||
)
|
||||
|
||||
INCLUDE_DIRECTORIES( ${CMAKE_CURRENT_SOURCE_DIR}/include )
|
||||
link_directories( ${CMAKE_BINARY_DIR}/bin)
|
||||
set(EXECUTABLE_OUTPUT_PATH ${CMAKE_BINARY_DIR}/bin)
|
||||
add_executable( separate ${NAME_SRC} ${NAME_HEADERS} )
|
||||
|
||||
target_link_libraries( separate ${OpenCV_LIBS} )
|
|
@ -0,0 +1,6 @@
|
|||
# Marker Separation
|
||||
|
||||
A C++ application with OpenCV for palletizing images to a limit set of
|
||||
marker colors.
|
||||
|
||||
Compiles on macOS and Linux.
|
|
@ -0,0 +1,173 @@
|
|||
# ===================================================================================
|
||||
# The OpenCV CMake configuration file
|
||||
#
|
||||
# ** File generated automatically, do not modify **
|
||||
#
|
||||
# Usage from an external project:
|
||||
# In your CMakeLists.txt, add these lines:
|
||||
#
|
||||
# FIND_PACKAGE(OpenCV REQUIRED)
|
||||
# TARGET_LINK_LIBRARIES(MY_TARGET_NAME ${OpenCV_LIBS})
|
||||
#
|
||||
# Or you can search for specific OpenCV modules:
|
||||
#
|
||||
# FIND_PACKAGE(OpenCV REQUIRED core imgcodecs)
|
||||
#
|
||||
# If the module is found then OPENCV_<MODULE>_FOUND is set to TRUE.
|
||||
#
|
||||
# This file will define the following variables:
|
||||
# - OpenCV_LIBS : The list of libraries to link against.
|
||||
# - OpenCV_LIB_DIR : The directory(es) where lib files are. Calling LINK_DIRECTORIES
|
||||
# with this path is NOT needed.
|
||||
# - OpenCV_INCLUDE_DIRS : The OpenCV include directories.
|
||||
# - OpenCV_COMPUTE_CAPABILITIES : The version of compute capability
|
||||
# - OpenCV_ANDROID_NATIVE_API_LEVEL : Minimum required level of Android API
|
||||
# - OpenCV_VERSION : The version of this OpenCV build. Example: "2.4.0"
|
||||
# - OpenCV_VERSION_MAJOR : Major version part of OpenCV_VERSION. Example: "2"
|
||||
# - OpenCV_VERSION_MINOR : Minor version part of OpenCV_VERSION. Example: "4"
|
||||
# - OpenCV_VERSION_PATCH : Patch version part of OpenCV_VERSION. Example: "0"
|
||||
#
|
||||
# Advanced variables:
|
||||
# - OpenCV_SHARED
|
||||
# - OpenCV_CONFIG_PATH
|
||||
# - OpenCV_LIB_COMPONENTS
|
||||
#
|
||||
# ===================================================================================
|
||||
#
|
||||
# Windows pack specific options:
|
||||
# - OpenCV_STATIC
|
||||
# - OpenCV_CUDA
|
||||
|
||||
if(CMAKE_VERSION VERSION_GREATER 2.6)
|
||||
get_property(OpenCV_LANGUAGES GLOBAL PROPERTY ENABLED_LANGUAGES)
|
||||
if(NOT ";${OpenCV_LANGUAGES};" MATCHES ";CXX;")
|
||||
enable_language(CXX)
|
||||
endif()
|
||||
endif()
|
||||
|
||||
if(NOT DEFINED OpenCV_STATIC)
|
||||
# look for global setting
|
||||
if(BUILD_SHARED_LIBS)
|
||||
set(OpenCV_STATIC OFF)
|
||||
else()
|
||||
set(OpenCV_STATIC ON)
|
||||
endif()
|
||||
endif()
|
||||
|
||||
if(NOT DEFINED OpenCV_CUDA)
|
||||
# if user' app uses CUDA, then it probably wants CUDA-enabled OpenCV binaries
|
||||
if(CUDA_FOUND)
|
||||
set(OpenCV_CUDA ON)
|
||||
endif()
|
||||
endif()
|
||||
|
||||
if(MSVC)
|
||||
if(CMAKE_CL_64)
|
||||
set(OpenCV_ARCH x64)
|
||||
set(OpenCV_TBB_ARCH intel64)
|
||||
elseif((CMAKE_GENERATOR MATCHES "ARM") OR ("${arch_hint}" STREQUAL "ARM") OR (CMAKE_VS_EFFECTIVE_PLATFORMS MATCHES "ARM|arm"))
|
||||
# see Modules/CmakeGenericSystem.cmake
|
||||
set(OpenCV_ARCH ARM)
|
||||
else()
|
||||
set(OpenCV_ARCH x86)
|
||||
set(OpenCV_TBB_ARCH ia32)
|
||||
endif()
|
||||
if(MSVC_VERSION EQUAL 1400)
|
||||
set(OpenCV_RUNTIME vc8)
|
||||
elseif(MSVC_VERSION EQUAL 1500)
|
||||
set(OpenCV_RUNTIME vc9)
|
||||
elseif(MSVC_VERSION EQUAL 1600)
|
||||
set(OpenCV_RUNTIME vc10)
|
||||
elseif(MSVC_VERSION EQUAL 1700)
|
||||
set(OpenCV_RUNTIME vc11)
|
||||
elseif(MSVC_VERSION EQUAL 1800)
|
||||
set(OpenCV_RUNTIME vc12)
|
||||
elseif(MSVC_VERSION EQUAL 1900)
|
||||
set(OpenCV_RUNTIME vc14)
|
||||
endif()
|
||||
elseif(MINGW)
|
||||
set(OpenCV_RUNTIME mingw)
|
||||
|
||||
execute_process(COMMAND ${CMAKE_CXX_COMPILER} -dumpmachine
|
||||
OUTPUT_VARIABLE OPENCV_GCC_TARGET_MACHINE
|
||||
OUTPUT_STRIP_TRAILING_WHITESPACE)
|
||||
if(OPENCV_GCC_TARGET_MACHINE MATCHES "amd64|x86_64|AMD64")
|
||||
set(MINGW64 1)
|
||||
set(OpenCV_ARCH x64)
|
||||
else()
|
||||
set(OpenCV_ARCH x86)
|
||||
endif()
|
||||
endif()
|
||||
|
||||
if(CMAKE_VERSION VERSION_GREATER 2.6.2)
|
||||
unset(OpenCV_CONFIG_PATH CACHE)
|
||||
endif()
|
||||
|
||||
if(NOT OpenCV_FIND_QUIETLY)
|
||||
message(STATUS "OpenCV ARCH: ${OpenCV_ARCH}")
|
||||
message(STATUS "OpenCV RUNTIME: ${OpenCV_RUNTIME}")
|
||||
message(STATUS "OpenCV STATIC: ${OpenCV_STATIC}")
|
||||
endif()
|
||||
|
||||
get_filename_component(OpenCV_CONFIG_PATH "${CMAKE_CURRENT_LIST_FILE}" PATH CACHE)
|
||||
if(OpenCV_RUNTIME AND OpenCV_ARCH)
|
||||
if(OpenCV_STATIC AND EXISTS "${OpenCV_CONFIG_PATH}/${OpenCV_ARCH}/${OpenCV_RUNTIME}/staticlib/OpenCVConfig.cmake")
|
||||
if(OpenCV_CUDA AND EXISTS "${OpenCV_CONFIG_PATH}/gpu/${OpenCV_ARCH}/${OpenCV_RUNTIME}/staticlib/OpenCVConfig.cmake")
|
||||
set(OpenCV_LIB_PATH "${OpenCV_CONFIG_PATH}/gpu/${OpenCV_ARCH}/${OpenCV_RUNTIME}/staticlib")
|
||||
else()
|
||||
set(OpenCV_LIB_PATH "${OpenCV_CONFIG_PATH}/${OpenCV_ARCH}/${OpenCV_RUNTIME}/staticlib")
|
||||
endif()
|
||||
elseif(EXISTS "${OpenCV_CONFIG_PATH}/${OpenCV_ARCH}/${OpenCV_RUNTIME}/lib/OpenCVConfig.cmake")
|
||||
if(OpenCV_CUDA AND EXISTS "${OpenCV_CONFIG_PATH}/gpu/${OpenCV_ARCH}/${OpenCV_RUNTIME}/lib/OpenCVConfig.cmake")
|
||||
set(OpenCV_LIB_PATH "${OpenCV_CONFIG_PATH}/gpu/${OpenCV_ARCH}/${OpenCV_RUNTIME}/lib")
|
||||
else()
|
||||
set(OpenCV_LIB_PATH "${OpenCV_CONFIG_PATH}/${OpenCV_ARCH}/${OpenCV_RUNTIME}/lib")
|
||||
endif()
|
||||
endif()
|
||||
endif()
|
||||
|
||||
if(OpenCV_LIB_PATH AND EXISTS "${OpenCV_LIB_PATH}/OpenCVConfig.cmake")
|
||||
set(OpenCV_LIB_DIR_OPT "${OpenCV_LIB_PATH}" CACHE PATH "Path where release OpenCV libraries are located" FORCE)
|
||||
set(OpenCV_LIB_DIR_DBG "${OpenCV_LIB_PATH}" CACHE PATH "Path where debug OpenCV libraries are located" FORCE)
|
||||
set(OpenCV_3RDPARTY_LIB_DIR_OPT "${OpenCV_LIB_PATH}" CACHE PATH "Path where release 3rdparty OpenCV dependencies are located" FORCE)
|
||||
set(OpenCV_3RDPARTY_LIB_DIR_DBG "${OpenCV_LIB_PATH}" CACHE PATH "Path where debug 3rdparty OpenCV dependencies are located" FORCE)
|
||||
|
||||
include("${OpenCV_LIB_PATH}/OpenCVConfig.cmake")
|
||||
|
||||
if(OpenCV_CUDA)
|
||||
set(_OpenCV_LIBS "")
|
||||
foreach(_lib ${OpenCV_LIBS})
|
||||
string(REPLACE "${OpenCV_CONFIG_PATH}/gpu/${OpenCV_ARCH}/${OpenCV_RUNTIME}" "${OpenCV_CONFIG_PATH}/${OpenCV_ARCH}/${OpenCV_RUNTIME}" _lib2 "${_lib}")
|
||||
if(NOT EXISTS "${_lib}" AND EXISTS "${_lib2}")
|
||||
list(APPEND _OpenCV_LIBS "${_lib2}")
|
||||
else()
|
||||
list(APPEND _OpenCV_LIBS "${_lib}")
|
||||
endif()
|
||||
endforeach()
|
||||
set(OpenCV_LIBS ${_OpenCV_LIBS})
|
||||
endif()
|
||||
set(OpenCV_FOUND TRUE CACHE BOOL "" FORCE)
|
||||
set(OPENCV_FOUND TRUE CACHE BOOL "" FORCE)
|
||||
|
||||
if(NOT OpenCV_FIND_QUIETLY)
|
||||
message(STATUS "Found OpenCV ${OpenCV_VERSION} in ${OpenCV_LIB_PATH}")
|
||||
if(NOT OpenCV_LIB_PATH MATCHES "/staticlib")
|
||||
get_filename_component(_OpenCV_LIB_PATH "${OpenCV_LIB_PATH}/../bin" ABSOLUTE)
|
||||
file(TO_NATIVE_PATH "${_OpenCV_LIB_PATH}" _OpenCV_LIB_PATH)
|
||||
message(STATUS "You might need to add ${_OpenCV_LIB_PATH} to your PATH to be able to run your applications.")
|
||||
if(OpenCV_LIB_PATH MATCHES "/gpu/")
|
||||
string(REPLACE "\\gpu" "" _OpenCV_LIB_PATH2 "${_OpenCV_LIB_PATH}")
|
||||
message(STATUS "GPU support is enabled so you might also need ${_OpenCV_LIB_PATH2} in your PATH (it must go after the ${_OpenCV_LIB_PATH}).")
|
||||
endif()
|
||||
endif()
|
||||
endif()
|
||||
else()
|
||||
if(NOT OpenCV_FIND_QUIETLY)
|
||||
message(WARNING
|
||||
"Found OpenCV Windows Pack but it has no binaries compatible with your configuration.
|
||||
You should manually point CMake variable OpenCV_DIR to your build of OpenCV library."
|
||||
)
|
||||
endif()
|
||||
set(OpenCV_FOUND FALSE CACHE BOOL "" FORCE)
|
||||
set(OPENCV_FOUND FALSE CACHE BOOL "" FORCE)
|
||||
endif()
|
|
@ -0,0 +1,52 @@
|
|||
#include "cmd.h"
|
||||
|
||||
inline bool Cmd::in_array(const std::string &value, const std::vector<std::string> &array)
|
||||
{
|
||||
return std::find(array.begin(), array.end(), value) != array.end();
|
||||
}
|
||||
|
||||
inline bool Cmd::file_exists (const std::string& name)
|
||||
{
|
||||
struct stat buffer;
|
||||
return (stat (name.c_str(), &buffer) == 0);
|
||||
}
|
||||
|
||||
inline bool Cmd::is_image (const std::string& name)
|
||||
{
|
||||
string ext = name.substr(name.find_last_of(".") + 1);
|
||||
return in_array(ext, supportedExt);
|
||||
}
|
||||
|
||||
string Cmd::get_input (int &argc, string argstr)
|
||||
{
|
||||
string input;
|
||||
|
||||
if (argc > 1)
|
||||
{
|
||||
input = argstr;
|
||||
}
|
||||
else if (argc < 2)
|
||||
{
|
||||
cerr << "Please provide one image." << endl;
|
||||
return;
|
||||
}
|
||||
else if (argc > 2)
|
||||
{
|
||||
cerr << "Please provide only one image." << endl;
|
||||
return;
|
||||
}
|
||||
|
||||
if (!file_exists(input))
|
||||
{
|
||||
cerr << "File " << input << " does not exist." << endl;
|
||||
return;
|
||||
}
|
||||
|
||||
if (!is_image(input))
|
||||
{
|
||||
cerr << "File " << input << " is not a valid image." << endl;
|
||||
return;
|
||||
}
|
||||
|
||||
return input;
|
||||
}
|
|
@ -0,0 +1,30 @@
|
|||
#ifndef CMD_MANAGER
|
||||
#define CMD_MANAGER
|
||||
|
||||
using namespace std;
|
||||
|
||||
#include <iostream>
|
||||
#include <opencv2/opencv.hpp>
|
||||
#include <sys/stat.h>
|
||||
#include <string>
|
||||
#include <vector>
|
||||
#include <algorithm>
|
||||
|
||||
class Cmd {
|
||||
public:
|
||||
string get_input(int &argc, string argstr);
|
||||
|
||||
private:
|
||||
std::vector<std::string> supportedExt = {
|
||||
"jpg", "JPG",
|
||||
"jpeg", "JPEG",
|
||||
"png", "PNG",
|
||||
"tif", "TIF",
|
||||
"tiff", "tiff"
|
||||
};
|
||||
bool in_array(const std::string &value, const std::vector<std::string> &array);
|
||||
bool file_exists (const std::string& name);
|
||||
bool is_image (const std::string& name);
|
||||
};
|
||||
|
||||
#endif
|
|
@ -0,0 +1,6 @@
|
|||
#!/bin/bash
|
||||
|
||||
mkdir -p build
|
||||
cd build
|
||||
cmake ..
|
||||
make -j
|
|
@ -0,0 +1,105 @@
|
|||
#include <opencv2\opencv.hpp>
|
||||
#include <opencv2\photo.hpp>
|
||||
#include <iostream>
|
||||
#include <map>
|
||||
|
||||
using namespace cv;
|
||||
using namespace std;
|
||||
|
||||
// https://stackoverflow.com/a/34734939/5008845
|
||||
void reducecolor_quantization(const mat3b& src, mat3b& dst)
|
||||
{
|
||||
uchar n = 64;
|
||||
dst = src / n;
|
||||
dst *= n;
|
||||
}
|
||||
|
||||
// https://stackoverflow.com/a/34734939/5008845
|
||||
void reducecolor_kmeans(const mat3b& src, mat3b& dst)
|
||||
{
|
||||
int k = 8;
|
||||
int n = src.rows * src.cols;
|
||||
mat data = src.reshape(1, n);
|
||||
data.convertto(data, cv_32f);
|
||||
|
||||
vector<int> labels;
|
||||
mat1f colors;
|
||||
kmeans(data, k, labels, cv::termcriteria(), 1, cv::kmeans_pp_centers, colors);
|
||||
|
||||
for (int i = 0; i < n; ++i)
|
||||
{
|
||||
data.at<float>(i, 0) = colors(labels[i], 0);
|
||||
data.at<float>(i, 1) = colors(labels[i], 1);
|
||||
data.at<float>(i, 2) = colors(labels[i], 2);
|
||||
}
|
||||
|
||||
mat reduced = data.reshape(3, src.rows);
|
||||
reduced.convertto(dst, cv_8u);
|
||||
}
|
||||
|
||||
void reducecolor_stylization(const mat3b& src, mat3b& dst)
|
||||
{
|
||||
stylization(src, dst);
|
||||
}
|
||||
|
||||
void reducecolor_edgepreserving(const mat3b& src, mat3b& dst)
|
||||
{
|
||||
edgepreservingfilter(src, dst);
|
||||
}
|
||||
|
||||
|
||||
struct lessvec3b
|
||||
{
|
||||
bool operator()(const vec3b& lhs, const vec3b& rhs) const {
|
||||
return (lhs[0] != rhs[0]) ? (lhs[0] < rhs[0]) : ((lhs[1] != rhs[1]) ? (lhs[1] < rhs[1]) : (lhs[2] < rhs[2]));
|
||||
}
|
||||
};
|
||||
|
||||
map<vec3b, int, lessvec3b> getpalette(const mat3b& src)
|
||||
{
|
||||
map<vec3b, int, lessvec3b> palette;
|
||||
for (int r = 0; r < src.rows; ++r)
|
||||
{
|
||||
for (int c = 0; c < src.cols; ++c)
|
||||
{
|
||||
vec3b color = src(r, c);
|
||||
if (palette.count(color) == 0)
|
||||
{
|
||||
palette[color] = 1;
|
||||
}
|
||||
else
|
||||
{
|
||||
palette[color] = palette[color] + 1;
|
||||
}
|
||||
}
|
||||
}
|
||||
return palette;
|
||||
}
|
||||
|
||||
|
||||
int main()
|
||||
{
|
||||
mat3b img = imread("path_to_image");
|
||||
|
||||
// reduce color
|
||||
mat3b reduced;
|
||||
|
||||
//reducecolor_quantization(img, reduced);
|
||||
reducecolor_kmeans(img, reduced);
|
||||
//reducecolor_stylization(img, reduced);
|
||||
//reducecolor_edgepreserving(img, reduced);
|
||||
|
||||
|
||||
// get palette
|
||||
map<vec3b, int, lessvec3b> palette = getpalette(reduced);
|
||||
|
||||
// print palette
|
||||
int area = img.rows * img.cols;
|
||||
|
||||
for (auto color : palette)
|
||||
{
|
||||
cout << "color: " << color.first << " \t - area: " << 100.f * float(color.second) / float(area) << "%" << endl;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
|
@ -0,0 +1,65 @@
|
|||
#include <iostream>
|
||||
#include <opencv2/opencv.hpp>
|
||||
#include <sys/stat.h>
|
||||
#include <string>
|
||||
#include <vector>
|
||||
#include <algorithm>
|
||||
|
||||
#include "cmd.h"
|
||||
|
||||
using namespace std;
|
||||
using namespace cv;
|
||||
|
||||
std::vector<std::string> supportedExt = {
|
||||
"jpg", "JPG",
|
||||
"jpeg", "JPEG",
|
||||
"png", "PNG",
|
||||
"tif", "TIF",
|
||||
"tiff", "tiff"
|
||||
};
|
||||
|
||||
inline bool in_array(const std::string &value, const std::vector<std::string> &array)
|
||||
{
|
||||
return std::find(array.begin(), array.end(), value) != array.end();
|
||||
}
|
||||
|
||||
inline bool file_exists (const std::string& name)
|
||||
{
|
||||
struct stat buffer;
|
||||
return (stat (name.c_str(), &buffer) == 0);
|
||||
}
|
||||
|
||||
inline bool is_image (const std::string& name)
|
||||
{
|
||||
string ext = name.substr(name.find_last_of(".") + 1);
|
||||
return in_array(ext, supportedExt);
|
||||
}
|
||||
|
||||
Cmd cmd;
|
||||
|
||||
int main(int argc, char** argv)
|
||||
{
|
||||
Mat image;
|
||||
Mat inverted;
|
||||
string inputcdt = argv[1];
|
||||
string input = cmd.get_input(argc, inputcdt);
|
||||
|
||||
if (input.empty()) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
|
||||
cout << "Using image " << input << "." << endl;
|
||||
|
||||
image = imread(input);
|
||||
bitwise_not(image, inverted);
|
||||
imshow("Image", inverted);
|
||||
|
||||
waitKey(0);
|
||||
|
||||
destroyAllWindows();
|
||||
|
||||
|
||||
|
||||
return 0;
|
||||
}
|
|
@ -0,0 +1,2 @@
|
|||
env
|
||||
|
|
@ -0,0 +1 @@
|
|||
opencv-python
|
|
@ -0,0 +1,12 @@
|
|||
import argparse
|
||||
|
||||
from os.path import isfile
|
||||
|
||||
parser = argparse.ArgumentParser(description='Separate an image into most similar colors specified')
|
||||
|
||||
parser.add_argument('input', type=str, help='Input image to separate')
|
||||
|
||||
args = parser.parse_args()
|
||||
|
||||
|
||||
|
Loading…
Reference in New Issue