/* ****************************************************************************** * * * 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. * * See the NOTICE file distributed with this work for additional * information regarding copyright ownership. * 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 Yurii Shyrma (iuriish@yahoo.com), created on 17.05.2018 // #include #include #include namespace sd { namespace ops { namespace helpers { ////////////////////////////////////////////////////////////////////////// template static void _percentile(const NDArray& input, NDArray& output, std::vector& axises, const float q, const int interpolation) { const int inputRank = input.rankOf(); if(axises.empty()) for(int i=0; i shapeOfSubArr(listOfSubArrs.at(0)->rankOf()); for(int i=0; ishapeOf()[i]; auto flattenedArr = NDArrayFactory::create('c', shapeOfSubArr, input.dataType(), input.getContext()); const int len = flattenedArr.lengthOf(); const float fraction = 1.f - q / 100.; Nd4jLong position = 0; switch(interpolation) { case 0: // lower position = static_cast(math::nd4j_ceil((len - 1) * fraction)); break; case 1: // higher position = static_cast(math::nd4j_floor((len - 1) * fraction)); break; case 2: // nearest position = static_cast(math::nd4j_round((len - 1) * fraction)); break; } position = len - position - 1; // FIXME: our sort impl should be used instead, so this operation might be implemented as generic // FIXME: parallelism ! for(int i=0; i(flattenedArr.buffer()); flattenedArr.assign(listOfSubArrs.at(i)); std::sort(buff, buff + len); output.p(i, flattenedArr.e(position)); } } void percentile(sd::LaunchContext * context, const NDArray& input, NDArray& output, std::vector& axises, const float q, const int interpolation) { BUILD_SINGLE_SELECTOR(input.dataType(), _percentile, (input, output, axises, q, interpolation), LIBND4J_TYPES); } BUILD_SINGLE_TEMPLATE(template void _percentile, (const NDArray& input, NDArray& output, std::vector& axises, const float q, const int interpolation), LIBND4J_TYPES); } } }