59 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			59 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import { factory } from '../../utils/factory.js';
 | |
| var name = 'leafCount';
 | |
| var dependencies = ['parse', 'typed'];
 | |
| export var createLeafCount = /* #__PURE__ */factory(name, dependencies, _ref => {
 | |
|   var {
 | |
|     parse,
 | |
|     typed
 | |
|   } = _ref;
 | |
| 
 | |
|   // This does the real work, but we don't have to recurse through
 | |
|   // a typed call if we separate it out
 | |
|   function countLeaves(node) {
 | |
|     var count = 0;
 | |
|     node.forEach(n => {
 | |
|       count += countLeaves(n);
 | |
|     });
 | |
|     return count || 1;
 | |
|   }
 | |
|   /**
 | |
|    * Gives the number of "leaf nodes" in the parse tree of the given expression
 | |
|    * A leaf node is one that has no subexpressions, essentially either a
 | |
|    * symbol or a constant. Note that `5!` has just one leaf, the '5'; the
 | |
|    * unary factorial operator does not add a leaf. On the other hand,
 | |
|    * function symbols do add leaves, so `sin(x)/cos(x)` has four leaves.
 | |
|    *
 | |
|    * The `simplify()` function should generally not increase the `leafCount()`
 | |
|    * of an expression, although currently there is no guarantee that it never
 | |
|    * does so. In many cases, `simplify()` reduces the leaf count.
 | |
|    *
 | |
|    * Syntax:
 | |
|    *
 | |
|    *     leafCount(expr)
 | |
|    *
 | |
|    * Examples:
 | |
|    *
 | |
|    *     math.leafCount('x') // 1
 | |
|    *     math.leafCount(math.parse('a*d-b*c')) // 4
 | |
|    *     math.leafCount('[a,b;c,d][0,1]') // 6
 | |
|    *
 | |
|    * See also:
 | |
|    *
 | |
|    *     simplify
 | |
|    *
 | |
|    * @param {Node|string} expr    The expression to count the leaves of
 | |
|    *
 | |
|    * @return {number}  The number of leaves of `expr`
 | |
|    *
 | |
|    */
 | |
| 
 | |
| 
 | |
|   return typed(name, {
 | |
|     string: function string(expr) {
 | |
|       return this(parse(expr));
 | |
|     },
 | |
|     Node: function Node(expr) {
 | |
|       return countLeaves(expr);
 | |
|     }
 | |
|   });
 | |
| }); |