2018-09-27 02:50:39 +08:00
|
|
|
// This file is part of OpenCV project.
|
|
|
|
// It is subject to the license terms in the LICENSE file found in the top-level directory
|
|
|
|
// of this distribution and at http://opencv.org/license.html.
|
|
|
|
//
|
2021-03-10 23:58:34 +08:00
|
|
|
// Copyright (C) 2018-2021 Intel Corporation
|
2018-09-27 02:50:39 +08:00
|
|
|
|
|
|
|
|
2018-09-28 23:42:09 +08:00
|
|
|
#include "precomp.hpp"
|
2018-09-27 02:50:39 +08:00
|
|
|
#include <iostream> // cerr
|
|
|
|
#include <functional> // hash
|
|
|
|
#include <numeric> // accumulate
|
|
|
|
|
|
|
|
#include <ade/util/algorithm.hpp>
|
|
|
|
|
|
|
|
#include "logger.hpp"
|
2019-06-15 00:27:19 +08:00
|
|
|
#include <opencv2/gapi/gkernel.hpp>
|
2018-09-27 02:50:39 +08:00
|
|
|
|
|
|
|
#include "api/gbackend_priv.hpp"
|
|
|
|
|
|
|
|
// GKernelPackage public implementation ////////////////////////////////////////
|
2021-12-24 23:04:11 +08:00
|
|
|
void cv::GKernelPackage::remove(const cv::gapi::GBackend& backend)
|
2018-09-27 02:50:39 +08:00
|
|
|
{
|
2019-05-22 19:53:44 +08:00
|
|
|
std::vector<std::string> id_deleted_kernels;
|
|
|
|
for (const auto& p : m_id_kernels)
|
|
|
|
{
|
|
|
|
if (p.second.first == backend)
|
|
|
|
{
|
|
|
|
id_deleted_kernels.push_back(p.first);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (const auto& kernel_id : id_deleted_kernels)
|
|
|
|
{
|
|
|
|
m_id_kernels.erase(kernel_id);
|
|
|
|
}
|
2018-09-27 02:50:39 +08:00
|
|
|
}
|
|
|
|
|
2021-12-24 23:04:11 +08:00
|
|
|
void cv::GKernelPackage::include(const cv::gapi::GFunctor& functor)
|
|
|
|
{
|
|
|
|
m_id_kernels[functor.id()] = std::make_pair(functor.backend(), functor.impl());
|
|
|
|
}
|
|
|
|
|
|
|
|
void cv::GKernelPackage::include(const cv::gapi::GBackend& backend, const std::string& kernel_id)
|
|
|
|
{
|
|
|
|
removeAPI(kernel_id);
|
|
|
|
m_id_kernels[kernel_id] = std::make_pair(backend, GKernelImpl{{}, {}});
|
|
|
|
}
|
|
|
|
|
|
|
|
bool cv::GKernelPackage::includesAPI(const std::string &id) const
|
2018-09-27 02:50:39 +08:00
|
|
|
{
|
2019-05-22 19:53:44 +08:00
|
|
|
return ade::util::contains(m_id_kernels, id);
|
2018-09-27 02:50:39 +08:00
|
|
|
}
|
|
|
|
|
2021-12-24 23:04:11 +08:00
|
|
|
void cv::GKernelPackage::removeAPI(const std::string &id)
|
2018-11-15 23:12:36 +08:00
|
|
|
{
|
2019-05-22 19:53:44 +08:00
|
|
|
m_id_kernels.erase(id);
|
2018-11-15 23:12:36 +08:00
|
|
|
}
|
|
|
|
|
2021-12-24 23:04:11 +08:00
|
|
|
std::size_t cv::GKernelPackage::size() const
|
2018-09-27 02:50:39 +08:00
|
|
|
{
|
2019-05-22 19:53:44 +08:00
|
|
|
return m_id_kernels.size();
|
2018-09-27 02:50:39 +08:00
|
|
|
}
|
|
|
|
|
2021-12-24 23:04:11 +08:00
|
|
|
const std::vector<cv::GTransform> &cv::GKernelPackage::get_transformations() const
|
2019-06-17 21:26:28 +08:00
|
|
|
{
|
|
|
|
return m_transformations;
|
|
|
|
}
|
|
|
|
|
2021-12-24 23:04:11 +08:00
|
|
|
std::vector<std::string> cv::GKernelPackage::get_kernel_ids() const
|
2021-03-10 23:58:34 +08:00
|
|
|
{
|
|
|
|
std::vector<std::string> ids;
|
|
|
|
for (auto &&id : m_id_kernels)
|
|
|
|
{
|
|
|
|
ids.emplace_back(id.first);
|
|
|
|
}
|
|
|
|
return ids;
|
|
|
|
}
|
|
|
|
|
2021-12-24 23:04:11 +08:00
|
|
|
cv::GKernelPackage cv::gapi::combine(const cv::GKernelPackage &lhs,
|
|
|
|
const cv::GKernelPackage &rhs)
|
2018-09-27 02:50:39 +08:00
|
|
|
{
|
|
|
|
|
2019-05-22 19:53:44 +08:00
|
|
|
// If there is a collision, prefer RHS to LHS
|
2018-11-15 23:12:36 +08:00
|
|
|
// since RHS package has a precedense, start with its copy
|
2021-12-24 23:04:11 +08:00
|
|
|
cv::GKernelPackage result(rhs);
|
2018-09-27 02:50:39 +08:00
|
|
|
// now iterate over LHS package and put kernel if and only
|
|
|
|
// if there's no such one
|
2019-05-22 19:53:44 +08:00
|
|
|
for (const auto& kernel : lhs.m_id_kernels)
|
2018-09-27 02:50:39 +08:00
|
|
|
{
|
2019-05-22 19:53:44 +08:00
|
|
|
if (!result.includesAPI(kernel.first))
|
2018-09-27 02:50:39 +08:00
|
|
|
{
|
2019-05-22 19:53:44 +08:00
|
|
|
result.m_id_kernels.emplace(kernel.first, kernel.second);
|
2018-09-27 02:50:39 +08:00
|
|
|
}
|
|
|
|
}
|
2019-06-17 21:26:28 +08:00
|
|
|
for (const auto &transforms : lhs.m_transformations){
|
|
|
|
result.m_transformations.push_back(transforms);
|
|
|
|
}
|
2018-09-27 02:50:39 +08:00
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
std::pair<cv::gapi::GBackend, cv::GKernelImpl>
|
2021-12-24 23:04:11 +08:00
|
|
|
cv::GKernelPackage::lookup(const std::string &id) const
|
2018-09-27 02:50:39 +08:00
|
|
|
{
|
2019-05-22 19:53:44 +08:00
|
|
|
auto kernel_it = m_id_kernels.find(id);
|
|
|
|
if (kernel_it != m_id_kernels.end())
|
2018-09-27 02:50:39 +08:00
|
|
|
{
|
2019-05-22 19:53:44 +08:00
|
|
|
return kernel_it->second;
|
2018-09-27 02:50:39 +08:00
|
|
|
}
|
2019-05-22 19:53:44 +08:00
|
|
|
// If reached here, kernel was not found.
|
2018-09-27 02:50:39 +08:00
|
|
|
util::throw_error(std::logic_error("Kernel " + id + " was not found"));
|
|
|
|
}
|
|
|
|
|
2021-12-24 23:04:11 +08:00
|
|
|
std::vector<cv::gapi::GBackend> cv::GKernelPackage::backends() const
|
2018-09-27 02:50:39 +08:00
|
|
|
{
|
2019-05-22 19:53:44 +08:00
|
|
|
using kernel_type = std::pair<std::string, std::pair<cv::gapi::GBackend, cv::GKernelImpl>>;
|
|
|
|
std::unordered_set<cv::gapi::GBackend> unique_set;
|
|
|
|
ade::util::transform(m_id_kernels, std::inserter(unique_set, unique_set.end()),
|
|
|
|
[](const kernel_type& k) { return k.second.first; });
|
|
|
|
|
|
|
|
return std::vector<cv::gapi::GBackend>(unique_set.begin(), unique_set.end());
|
2018-09-27 02:50:39 +08:00
|
|
|
}
|