UNPKG

mathjs

Version:

Math.js is an extensive math library for JavaScript and Node.js. It features a flexible expression parser with support for symbolic computation, comes with a large set of built-in functions and constants, and offers an integrated solution to work with dif

40 lines (35 loc) 1.19 kB
import { broadcastSizes, broadcastTo } from '../../../utils/array.js'; import { deepStrictEqual } from '../../../utils/object.js'; /** * Broadcasts two matrices, and return both in an array * It checks if it's possible with broadcasting rules * * @param {Matrix} A First Matrix * @param {Matrix} B Second Matrix * * @return {Matrix[]} [ broadcastedA, broadcastedB ] */ export function broadcast(A, B) { if (deepStrictEqual(A.size(), B.size())) { // If matrices have the same size return them return [A, B]; } // calculate the broadcasted sizes var newSize = broadcastSizes(A.size(), B.size()); // return the array with the two broadcasted matrices return [A, B].map(M => _broadcastTo(M, newSize)); } /** * Broadcasts a matrix to the given size. * * @param {Matrix} M - The matrix to be broadcasted. * @param {number[]} size - The desired size of the broadcasted matrix. * @returns {Matrix} The broadcasted matrix. * @throws {Error} If the size parameter is not an array of numbers. */ function _broadcastTo(M, size) { if (deepStrictEqual(M.size(), size)) { return M; } return M.create(broadcastTo(M.valueOf(), size), M.datatype()); }