b0ea1aed0152017ff0efb4aa405560fd36ad6cb0
[platform/upstream/opencv.git] / modules / dnn / src / layers / split_layer.cpp
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 }