/*******************************************************************************
 * Copyright (c) 2020 Konduit K.K.
 *
 * 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 AbdelRauf
//

#include <ops/declarable/helpers/reductions.h>

namespace sd {
    namespace ops {
        namespace helpers {
            //////////////////////////////////////////////////////////////////////////
            template<typename X, typename Z>
            void  argMax_(const NDArray& input, NDArray& output, const std::vector<int>& dimensions);

            template<typename X, typename Z>
            void  argMin_(const NDArray& input, NDArray& output, const std::vector<int>& dimensions);

            template<typename X, typename Z>
            void  argAbsMax_(const NDArray& input, NDArray& output, const std::vector<int>& dimensions);

            template<typename X, typename Z>
            void  argAbsMin_(const NDArray& input, NDArray& output, const std::vector<int>& dimensions);

            //////////////////////////////////////////////////////////////////////////
            void  argMax(const NDArray& input, NDArray& output, const std::vector<int>& dimensions) {
                BUILD_DOUBLE_SELECTOR(input.dataType(), output.dataType(), argMax_, (input, output, dimensions), LIBND4J_TYPES, INDEXING_TYPES);
            }

            void  argMin(const NDArray& input, NDArray& output, const std::vector<int>& dimensions) {
                BUILD_DOUBLE_SELECTOR(input.dataType(), output.dataType(), argMin_, (input, output, dimensions), LIBND4J_TYPES, INDEXING_TYPES);
            }

            void  argAbsMax(const NDArray& input, NDArray& output, const std::vector<int>& dimensions) {
                BUILD_DOUBLE_SELECTOR(input.dataType(), output.dataType(), argAbsMax_, (input, output, dimensions), LIBND4J_TYPES, INDEXING_TYPES);
            }

            void  argAbsMin(const NDArray& input, NDArray& output, const std::vector<int>& dimensions) {
                BUILD_DOUBLE_SELECTOR(input.dataType(), output.dataType(), argAbsMin_, (input, output, dimensions), LIBND4J_TYPES, INDEXING_TYPES);
            }
        }
    }
}