UNPKG

@stdlib/strided

Version:
172 lines (106 loc) 5.03 kB
<!-- @license Apache-2.0 Copyright (c) 2021 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. --> # Binary Signatures > Generate a list of binary interface signatures from strided array [data types][@stdlib/strided/dtypes]. <!-- Section to include introductory text. Make sure to keep an empty line after the intro `section` element and another before the `/section` close. --> <section class="intro"> </section> <!-- /.intro --> <!-- Package usage documentation. --> <section class="usage"> ## Usage ```javascript var signatures = require( '@stdlib/strided/base/binary-dtype-signatures' ); ``` #### signatures( dtypes1, dtypes2, dtypes3\[, options] ) Generates a list of binary interface signatures from strided array [data types][@stdlib/strided/dtypes]. ```javascript var dtypes = [ 'float64', 'float32', 'int32', 'uint8' ]; var sigs = signatures( dtypes, dtypes, dtypes ); // returns [ 'float32', 'float32', 'float32', ... ] ``` The function accepts the following arguments: - **dtypes1**: list of supported [data types][@stdlib/strided/dtypes] for the first input argument. - **dtypes2**: list of supported [data types][@stdlib/strided/dtypes] for the second input argument. - **dtypes3**: list of supported [data types][@stdlib/strided/dtypes] for the output value. - **options**: options. The function accepts the following options: - **enums**: `boolean` flag indicating whether to return signatures as a list of [data type][@stdlib/strided/dtypes] enumeration constants. Default: `false`. When the `enums` options is `false`, the function returns an array of [data type][@stdlib/strided/dtypes] strings. To return [data type][@stdlib/strided/dtypes] enumeration constants, set the `enums` option to `true`. ```javascript var dtypes = [ 'float64', 'float32', 'int32', 'uint8' ]; var options = { 'enums': true }; var sigs = signatures( dtypes, dtypes, dtypes, options ); // returns [...] ``` </section> <!-- /.usage --> <!-- Package usage notes. Make sure to keep an empty line after the `section` element and another before the `/section` close. --> <section class="notes"> ## Notes - The function returns a strided array having a stride length of `3` (i.e., every `3` elements define a binary interface signature). - For each signature (i.e., set of three consecutive non-overlapping strided array elements), the first two elements are the input data types and the third element is the return data type. - All signatures follow type [promotion rules][@stdlib/ndarray/promotion-rules]. </section> <!-- /.notes --> <!-- Package usage examples. --> <section class="examples"> ## Examples <!-- eslint no-undef: "error" --> ```javascript var dtypes = require( '@stdlib/strided/dtypes' ); var replace = require( '@stdlib/string/replace' ); var signatures = require( '@stdlib/strided/base/binary-dtype-signatures' ); // Get the list of supported strided array data types: var dt = dtypes(); // Generate binary interface signatures: var sigs = signatures( dt, dt, dt ); // Format the output: var str = replace( JSON.stringify( sigs ), /("[^"]+","[^"]+","[^"]+"),/g, '$1,\n' ); console.log( str ); ``` </section> <!-- /.examples --> <!-- Section to include cited references. If references are included, add a horizontal rule *before* the section. Make sure to keep an empty line after the `section` element and another before the `/section` close. --> <section class="references"> </section> <!-- /.references --> <!-- Section for related `stdlib` packages. Do not manually edit this section, as it is automatically populated. --> <section class="related"> * * * ## See Also - <span class="package-name">[`@stdlib/strided/base/binary-signature-callbacks`][@stdlib/strided/base/binary-signature-callbacks]</span><span class="delimiter">: </span><span class="description">assign callbacks to binary interfaces according to type promotion rules.</span> </section> <!-- /.related --> <!-- Section for all links. Make sure to keep an empty line after the `section` element and another before the `/section` close. --> <section class="links"> [@stdlib/strided/dtypes]: https://github.com/stdlib-js/strided/tree/main/dtypes [@stdlib/ndarray/promotion-rules]: https://www.npmjs.com/package/@stdlib/ndarray-promotion-rules <!-- <related-links> --> [@stdlib/strided/base/binary-signature-callbacks]: https://github.com/stdlib-js/strided/tree/main/base/binary-signature-callbacks <!-- </related-links> --> </section> <!-- /.links -->