/******************************************************************************* * Copyright (c) 2015-2018 Skymind, Inc. * * This program and the accompanying materials are made available under the * terms of the Apache License, Version 2.0 which is available at * https://www.apache.org/licenses/LICENSE-2.0. * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the * License for the specific language governing permissions and limitations * under the License. * * SPDX-License-Identifier: Apache-2.0 ******************************************************************************/ // // @author raver119@gmail.com // #ifndef DEV_TESTS_CONSTANTDESCRIPTOR_H #define DEV_TESTS_CONSTANTDESCRIPTOR_H #include #include #include #include #include #include namespace nd4j { class ND4J_EXPORT ConstantDescriptor { private: std::vector _integerValues; std::vector _floatValues; public: ConstantDescriptor(double* values, int length); ConstantDescriptor(Nd4jLong* values, int length); ConstantDescriptor(std::initializer_list values); explicit ConstantDescriptor(std::vector &values); explicit ConstantDescriptor(std::vector &values); ~ConstantDescriptor() = default; // equal to operator bool operator==(const ConstantDescriptor &other) const; // less than operator bool operator<(const ConstantDescriptor &other) const; bool isInteger() const; bool isFloat() const; Nd4jLong length() const; const std::vector& integerValues() const; const std::vector& floatValues() const; }; } #endif //DEV_TESTS_CONSTANTDESCRIPTOR_H