/* * @license Apache-2.0 * * Copyright (c) 2020 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. */ // TypeScript Version: 4.1 /// import { NumericArray } from '@stdlib/types/array'; /** * Interface describing `gscal`. */ interface Routine { /** * Multiplies a vector `x` by a constant `alpha`. * * @param N - number of indexed elements * @param alpha - constant * @param x - input array * @param stride - stride length * @returns input array * * @example * var x = [ -2.0, 1.0, 3.0, -5.0, 4.0, 0.0, -1.0, -3.0 ]; * * gscal( x.length, 5.0, x, 1 ); * // x => [ -10.0, 5.0, 15.0, -25.0, 20.0, 0.0, -5.0, -15.0 ] */ ( N: number, alpha: number, x: NumericArray, stride: number ): NumericArray; /** * Multiplies a vector `x` by a constant `alpha` using alternative indexing semantics. * * @param N - number of indexed elements * @param alpha - constant * @param x - input array * @param stride - stride length * @param offset - starting index * @returns input array * * @example * var x = [ -2.0, 1.0, 3.0, -5.0, 4.0, 0.0, -1.0, -3.0 ]; * * gscal.ndarray( x.length, 5.0, x, 1, 0 ); * // x => [ -10.0, 5.0, 15.0, -25.0, 20.0, 0.0, -5.0, -15.0 ] */ ndarray( N: number, alpha: number, x: NumericArray, stride: number, offset: number ): NumericArray; } /** * Multiplies a vector `x` by a constant `alpha`. * * @param N - number of indexed elements * @param alpha - constant * @param x - input array * @param stride - stride length * @returns input array * * @example * var x = [ -2.0, 1.0, 3.0, -5.0, 4.0, 0.0, -1.0, -3.0 ]; * * gscal( x.length, 5.0, x, 1 ); * // x => [ -10.0, 5.0, 15.0, -25.0, 20.0, 0.0, -5.0, -15.0 ] * * @example * var x = [ -2.0, 1.0, 3.0, -5.0, 4.0, 0.0, -1.0, -3.0 ]; * * gscal.ndarray( x.length, 5.0, x, 1, 0 ); * // x => [ -10.0, 5.0, 15.0, -25.0, 20.0, 0.0, -5.0, -15.0 ] */ declare var gscal: Routine; // EXPORTS // export = gscal;