f_l.c (2253B)
1 /** 2 * @license Apache-2.0 3 * 4 * Copyright (c) 2020 The Stdlib Authors. 5 * 6 * Licensed under the Apache License, Version 2.0 (the "License"); 7 * you may not use this file except in compliance with the License. 8 * You may obtain a copy of the License at 9 * 10 * http://www.apache.org/licenses/LICENSE-2.0 11 * 12 * Unless required by applicable law or agreed to in writing, software 13 * distributed under the License is distributed on an "AS IS" BASIS, 14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 15 * See the License for the specific language governing permissions and 16 * limitations under the License. 17 */ 18 19 #include "stdlib/strided/base/unary/f_l.h" 20 #include "stdlib/strided/base/unary/typedefs.h" 21 #include "stdlib/strided/base/unary/macros.h" 22 #include <stdint.h> 23 24 /** 25 * Applies a unary callback accepting a single-precision floating-point number and returning a signed 64-bit integer to a single-precision floating-point strided input array and assigns results to elements in a signed 64-bit integer strided output array. 26 * 27 * @param arrays array whose first element is a pointer to a strided input array and whose last element is a pointer to a strided output array 28 * @param shape array whose only element is the number of elements over which to iterate 29 * @param strides array containing strides (in bytes) for each strided array 30 * @param fcn callback 31 * 32 * @example 33 * #include "stdlib/strided/base/unary/f_l.h" 34 * #include <stdint.h> 35 * #include <math.h> 36 * 37 * // Create underlying byte arrays: 38 * uint8_t x[] = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; 39 * uint8_t out[] = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; 40 * 41 * // Define a pointer to an array containing pointers to strided arrays: 42 * uint8_t *arrays[] = { x, out }; 43 * 44 * // Define the strides: 45 * int64_t strides[] = { 4, 8 }; // 4 bytes per float, 8 bytes per int64 46 * 47 * // Define the number of elements over which to iterate: 48 * int64_t shape[] = { 3 }; 49 * 50 * // Apply the callback: 51 * stdlib_strided_f_l( arrays, shape, strides, (void *)llrintf ); 52 */ 53 void stdlib_strided_f_l( uint8_t *arrays[], int64_t *shape, int64_t *strides, void *fcn ) { 54 UnaryFcnFloat32Int64 *f = (UnaryFcnFloat32Int64 *)fcn; 55 STDLIB_STRIDED_UNARY_LOOP_CLBK( float, int64_t ) 56 }