time-to-botec/squiggle/node_modules/@stdlib/ndarray/ctor/src/set.c
NunoSempere b6addc7f05 feat: add the node modules
Necessary in order to clearly see the squiggle hotwiring.
2022-12-03 12:44:49 +00:00

320 lines
11 KiB
C

/**
* @license Apache-2.0
*
* Copyright (c) 2018 The Stdlib Authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://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.
*/
#include "stdlib/ndarray/ctor/set.h"
#include "stdlib/ndarray/ctor/set_ptr.h"
#include "stdlib/ndarray/ctor/get_ptr.h"
#include "stdlib/ndarray/ctor/ndarray.h"
#include <stdlib.h>
#include <stdint.h>
#include <stdbool.h>
#include <complex.h>
/**
* Sets an ndarray data element.
*
* ## Notes
*
* - The function returns `-1` if unable to set an element and `0` otherwise.
* - The function requires a pointer to a data value `v` in order to provide a generic API supporting ndarrays having different data types.
* - The function has no way of determining whether `v` actually points to a memory address compatible with the underlying input ndarray data type. Accordingly, accessing **unowned** memory is possible, and this function **assumes** you know what you are doing.
*
* @param arr input ndarray
* @param sub ndarray subscripts
* @param v value to set
* @return status code
*/
int8_t stdlib_ndarray_set( const struct ndarray *arr, const int64_t *sub, const void *v ) {
uint8_t *idx = stdlib_ndarray_get_ptr( arr, sub );
if ( idx == NULL ) {
return -1;
}
return stdlib_ndarray_set_ptr_value( arr, idx, v );
}
/**
* Sets a double-precision floating-point ndarray data element.
*
* ## Notes
*
* - The function does **not** verify that the type of `v` matches the underlying input ndarray data type, and, thus, overwriting **unowned** memory is possible. The function **assumes** that you know what you are doing.
* - The function returns `-1` if unable to set an element and `0` otherwise.
*
* @param arr input ndarray
* @param sub ndarray subscripts
* @param v value to set
* @return status code
*/
int8_t stdlib_ndarray_set_float64( const struct ndarray *arr, const int64_t *sub, const double v ) {
uint8_t *idx = stdlib_ndarray_get_ptr( arr, sub );
if ( idx == NULL ) {
return -1;
}
return stdlib_ndarray_set_ptr_float64( idx, v );
}
/**
* Sets a single-precision floating-point ndarray data element.
*
* ## Notes
*
* - The function does **not** verify that the type of `v` matches the underlying input ndarray data type, and, thus, overwriting **unowned** memory is possible. The function **assumes** that you know what you are doing.
* - The function returns `-1` if unable to set an element and `0` otherwise.
*
* @param arr input ndarray
* @param sub ndarray subscripts
* @param v value to set
* @return status code
*/
int8_t stdlib_ndarray_set_float32( const struct ndarray *arr, const int64_t *sub, const float v ) {
uint8_t *idx = stdlib_ndarray_get_ptr( arr, sub );
if ( idx == NULL ) {
return -1;
}
return stdlib_ndarray_set_ptr_float32( idx, v );
}
/**
* Sets an unsigned 64-bit integer ndarray data element.
*
* ## Notes
*
* - The function does **not** verify that the type of `v` matches the underlying input ndarray data type, and, thus, overwriting **unowned** memory is possible. The function **assumes** that you know what you are doing.
* - The function returns `-1` if unable to set an element and `0` otherwise.
*
* @param arr input ndarray
* @param sub ndarray subscripts
* @param v value to set
* @return status code
*/
int8_t stdlib_ndarray_set_uint64( const struct ndarray *arr, const int64_t *sub, const uint64_t v ) {
uint8_t *idx = stdlib_ndarray_get_ptr( arr, sub );
if ( idx == NULL ) {
return -1;
}
return stdlib_ndarray_set_ptr_uint64( idx, v );
}
/**
* Sets a signed 64-bit integer ndarray data element.
*
* ## Notes
*
* - The function does **not** verify that the type of `v` matches the underlying input ndarray data type, and, thus, overwriting **unowned** memory is possible. The function **assumes** that you know what you are doing.
* - The function returns `-1` if unable to set an element and `0` otherwise.
*
* @param arr input ndarray
* @param sub ndarray subscripts
* @param v value to set
* @return status code
*/
int8_t stdlib_ndarray_set_int64( const struct ndarray *arr, const int64_t *sub, const int64_t v ) {
uint8_t *idx = stdlib_ndarray_get_ptr( arr, sub );
if ( idx == NULL ) {
return -1;
}
return stdlib_ndarray_set_ptr_int64( idx, v );
}
/**
* Sets an unsigned 32-bit integer ndarray data element.
*
* ## Notes
*
* - The function does **not** verify that the type of `v` matches the underlying input ndarray data type, and, thus, overwriting **unowned** memory is possible. The function **assumes** that you know what you are doing.
* - The function returns `-1` if unable to set an element and `0` otherwise.
*
* @param arr input ndarray
* @param sub ndarray subscripts
* @param v value to set
* @return status code
*/
int8_t stdlib_ndarray_set_uint32( const struct ndarray *arr, const int64_t *sub, const uint32_t v ) {
uint8_t *idx = stdlib_ndarray_get_ptr( arr, sub );
if ( idx == NULL ) {
return -1;
}
return stdlib_ndarray_set_ptr_uint32( idx, v );
}
/**
* Sets a signed 32-bit integer ndarray data element.
*
* ## Notes
*
* - The function does **not** verify that the type of `v` matches the underlying input ndarray data type, and, thus, overwriting **unowned** memory is possible. The function **assumes** that you know what you are doing.
* - The function returns `-1` if unable to set an element and `0` otherwise.
*
* @param arr input ndarray
* @param sub ndarray subscripts
* @param v value to set
* @return status code
*/
int8_t stdlib_ndarray_set_int32( const struct ndarray *arr, const int64_t *sub, const int32_t v ) {
uint8_t *idx = stdlib_ndarray_get_ptr( arr, sub );
if ( idx == NULL ) {
return -1;
}
return stdlib_ndarray_set_ptr_int32( idx, v );
}
/**
* Sets an unsigned 16-bit integer ndarray data element.
*
* ## Notes
*
* - The function does **not** verify that the type of `v` matches the underlying input ndarray data type, and, thus, overwriting **unowned** memory is possible. The function **assumes** that you know what you are doing.
* - The function returns `-1` if unable to set an element and `0` otherwise.
*
* @param arr input ndarray
* @param sub ndarray subscripts
* @param v value to set
* @return status code
*/
int8_t stdlib_ndarray_set_uint16( const struct ndarray *arr, const int64_t *sub, const uint16_t v ) {
uint8_t *idx = stdlib_ndarray_get_ptr( arr, sub );
if ( idx == NULL ) {
return -1;
}
return stdlib_ndarray_set_ptr_uint16( idx, v );
}
/**
* Sets a signed 16-bit integer ndarray data element.
*
* ## Notes
*
* - The function does **not** verify that the type of `v` matches the underlying input ndarray data type, and, thus, overwriting **unowned** memory is possible. The function **assumes** that you know what you are doing.
* - The function returns `-1` if unable to set an element and `0` otherwise.
*
* @param arr input ndarray
* @param sub ndarray subscripts
* @param v value to set
* @return status code
*/
int8_t stdlib_ndarray_set_int16( const struct ndarray *arr, const int64_t *sub, const int16_t v ) {
uint8_t *idx = stdlib_ndarray_get_ptr( arr, sub );
if ( idx == NULL ) {
return -1;
}
return stdlib_ndarray_set_ptr_int16( idx, v );
}
/**
* Sets an unsigned 8-bit integer ndarray data element.
*
* ## Notes
*
* - The function returns `-1` if unable to set an element and `0` otherwise.
*
* @param arr input ndarray
* @param sub ndarray subscripts
* @param v value to set
* @return status code
*/
int8_t stdlib_ndarray_set_uint8( const struct ndarray *arr, const int64_t *sub, const uint8_t v ) {
uint8_t *idx = stdlib_ndarray_get_ptr( arr, sub );
if ( idx == NULL ) {
return -1;
}
return stdlib_ndarray_set_ptr_uint8( idx, v );
}
/**
* Sets a signed 8-bit integer ndarray data element.
*
* ## Notes
*
* - The function returns `-1` if unable to set an element and `0` otherwise.
*
* @param arr input ndarray
* @param sub ndarray subscripts
* @param v value to set
* @return status code
*/
int8_t stdlib_ndarray_set_int8( const struct ndarray *arr, const int64_t *sub, const int8_t v ) {
uint8_t *idx = stdlib_ndarray_get_ptr( arr, sub );
if ( idx == NULL ) {
return -1;
}
return stdlib_ndarray_set_ptr_int8( idx, v );
}
/**
* Sets a double-precision complex floating-point ndarray data element.
*
* ## Notes
*
* - The function does **not** verify that the type of `v` matches the underlying input ndarray data type, and, thus, overwriting **unowned** memory is possible. The function **assumes** that you know what you are doing.
* - The function returns `-1` if unable to set an element and `0` otherwise.
*
* @param arr input ndarray
* @param sub ndarray subscripts
* @param v value to set
* @return status code
*/
int8_t stdlib_ndarray_set_complex128( const struct ndarray *arr, const int64_t *sub, const double complex v ) {
uint8_t *idx = stdlib_ndarray_get_ptr( arr, sub );
if ( idx == NULL ) {
return -1;
}
return stdlib_ndarray_set_ptr_complex128( idx, v );
}
/**
* Sets a single-precision complex floating-point ndarray data element.
*
* ## Notes
*
* - The function does **not** verify that the type of `v` matches the underlying input ndarray data type, and, thus, overwriting **unowned** memory is possible. The function **assumes** that you know what you are doing.
* - The function returns `-1` if unable to set an element and `0` otherwise.
*
* @param arr input ndarray
* @param sub ndarray subscripts
* @param v value to set
* @return status code
*/
int8_t stdlib_ndarray_set_complex64( const struct ndarray *arr, const int64_t *sub, const float complex v ) {
uint8_t *idx = stdlib_ndarray_get_ptr( arr, sub );
if ( idx == NULL ) {
return -1;
}
return stdlib_ndarray_set_ptr_complex64( idx, v );
}
/**
* Sets a boolean floating-point ndarray data element.
*
* ## Notes
*
* - The function does **not** verify that the type of `v` matches the underlying input ndarray data type, and, thus, overwriting **unowned** memory is possible. The function **assumes** that you know what you are doing.
* - The function returns `-1` if unable to set an element and `0` otherwise.
*
* @param arr input ndarray
* @param sub ndarray subscripts
* @param v value to set
* @return status code
*/
int8_t stdlib_ndarray_set_bool( const struct ndarray *arr, const int64_t *sub, const bool v ) {
uint8_t *idx = stdlib_ndarray_get_ptr( arr, sub );
if ( idx == NULL ) {
return -1;
}
return stdlib_ndarray_set_ptr_bool( idx, v );
}