From 1d29c273c24601abf819da09615617e0011caa3b Mon Sep 17 00:00:00 2001 From: David Contreras Date: Wed, 2 Oct 2024 01:42:56 -0600 Subject: [PATCH] docs: document the syntax of `map` and `forEach` in the expression parser (#3272) --- docs/expressions/syntax.md | 62 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 62 insertions(+) diff --git a/docs/expressions/syntax.md b/docs/expressions/syntax.md index 618dcbb7ea..e9f09d334a 100644 --- a/docs/expressions/syntax.md +++ b/docs/expressions/syntax.md @@ -250,6 +250,68 @@ Note that math.js embodies a preference for the operator forms, in that calling `simplify` (see [Algebra](./algebra.md)) converts any instances of the function form into the corresponding operator. +## Map and forEach + +The `map` and `forEach` functions can be used to apply a callback function to each element of an array or matrix. + +The callback functions can be functions, typed functions, inline functions (only in the parser) or compiled inline functions (only in the parser). + +The callback can have the follwoing inputs: +- **value**: the current value in the array or matrix. +- **index**: the index of the current value expressed as an array of numbers. +- **array**: the array or matrix being iterated. + +Below is the syntax for both functions: + +### map + +The `map` function applies a function to each element of an array and returns a new array with the results. + +```js +const parser = math.parser() + +// Define a square function +parser.evaluate('square(x) = x ^ 2') + +// Apply the square function to each element of the array +parser.evaluate('result = map([1, 2, 3, 4], square)') +// result: [1, 4, 9, 16] + +// Apply an inline function to each element of the array +parser.evaluate('result = map([1, 2, 3, 4], f(x) = x ^ 2)') +// result: [1, 4, 9, 16] + +// Apply a compiled inline function to each element of the array +parser.evaluate('result = map([1, 2, 3, 4], x ^ 2)') +// result: [1, 4, 9, 16] +``` + +### forEach +The `forEach` function applies a function to each element of an array or matrix but does not return a new array. It is useful for executing side effects. + +```js +// Define a function that prints each element +math.import({consoleLog: x => console.log(x)}) +const parser = math.parser() + +// Define a squareConsleLog function +parser.evaluate('squareConsoleLog(x) = consoleLog(x ^ 2)') + +// Apply the squareConsleLog function to each element of the array +parser.evaluate('forEach([1, 2, 3, 4], squareConsleLog)') +// Prints: 1, 4, 9, 16 + +// Apply an inline function to each element of the array +parser.evaluate('forEach([1, 2, 3, 4], f(x) = consoleLog(x ^ 2))') +// Prints: 1, 4, 9, 16 + +// Apply a compiled inline function to each element of the array +parser.evaluate('forEach([1, 2, 3, 4], consoleLog(x ^ 2))') +// Prints: 1, 4, 9, 16 +``` + +These functions are useful for performing element-wise operations on arrays or matrices. + ## Constants and variables Math.js has a number of built-in constants such as `pi` and `e`.