Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
Tetragramm
GitHub Repository: Tetragramm/opencv
Path: blob/master/modules/dnn/src/layers/split_layer.cpp
16337 views
1
/*M///////////////////////////////////////////////////////////////////////////////////////
2
//
3
// IMPORTANT: READ BEFORE DOWNLOADING, COPYING, INSTALLING OR USING.
4
//
5
// By downloading, copying, installing or using the software you agree to this license.
6
// If you do not agree to this license, do not download, install,
7
// copy or use the software.
8
//
9
//
10
// License Agreement
11
// For Open Source Computer Vision Library
12
//
13
// Copyright (C) 2013, OpenCV Foundation, all rights reserved.
14
// Copyright (C) 2017, Intel Corporation, all rights reserved.
15
// Third party copyrights are property of their respective owners.
16
//
17
// Redistribution and use in source and binary forms, with or without modification,
18
// are permitted provided that the following conditions are met:
19
//
20
// * Redistribution's of source code must retain the above copyright notice,
21
// this list of conditions and the following disclaimer.
22
//
23
// * Redistribution's in binary form must reproduce the above copyright notice,
24
// this list of conditions and the following disclaimer in the documentation
25
// and/or other materials provided with the distribution.
26
//
27
// * The name of the copyright holders may not be used to endorse or promote products
28
// derived from this software without specific prior written permission.
29
//
30
// This software is provided by the copyright holders and contributors "as is" and
31
// any express or implied warranties, including, but not limited to, the implied
32
// warranties of merchantability and fitness for a particular purpose are disclaimed.
33
// In no event shall the Intel Corporation or contributors be liable for any direct,
34
// indirect, incidental, special, exemplary, or consequential damages
35
// (including, but not limited to, procurement of substitute goods or services;
36
// loss of use, data, or profits; or business interruption) however caused
37
// and on any theory of liability, whether in contract, strict liability,
38
// or tort (including negligence or otherwise) arising in any way out of
39
// the use of this software, even if advised of the possibility of such damage.
40
//
41
//M*/
42
43
#include "../precomp.hpp"
44
#include "layers_common.hpp"
45
46
namespace cv
47
{
48
namespace dnn
49
{
50
51
class SplitLayerImpl CV_FINAL : public SplitLayer
52
{
53
public:
54
SplitLayerImpl(const LayerParams &params)
55
{
56
setParamsFrom(params);
57
//TODO: maybe "top_count" param is useless because it can be determined by output connections number
58
if (params.has("top_count"))
59
{
60
outputsCount = params.get<int>("top_count");
61
CV_Assert(outputsCount >= 0);
62
}
63
else
64
{
65
outputsCount = -1;
66
}
67
}
68
69
bool getMemoryShapes(const std::vector<MatShape> &inputs,
70
const int requiredOutputs,
71
std::vector<MatShape> &outputs,
72
std::vector<MatShape> &internals) const CV_OVERRIDE
73
{
74
CV_Assert(inputs.size() == 1);
75
76
Layer::getMemoryShapes(inputs, max(1, outputsCount >= 0 ? outputsCount : requiredOutputs),
77
outputs, internals);
78
return false;
79
}
80
81
void forward(InputArrayOfArrays inputs_arr, OutputArrayOfArrays outputs_arr, OutputArrayOfArrays internals_arr) CV_OVERRIDE
82
{
83
CV_TRACE_FUNCTION();
84
CV_TRACE_ARG_VALUE(name, "name", name.c_str());
85
86
std::vector<Mat> inputs, outputs;
87
inputs_arr.getMatVector(inputs);
88
outputs_arr.getMatVector(outputs);
89
for (size_t i = 0; i < outputs.size(); i++)
90
{
91
CV_Assert(inputs[0].total() == outputs[i].total());
92
inputs[0].copyTo(outputs[i]);
93
}
94
}
95
};
96
97
Ptr<SplitLayer> SplitLayer::create(const LayerParams& params)
98
{
99
return Ptr<SplitLayer>(new SplitLayerImpl(params));
100
}
101
102
}
103
}
104
105