From 537427895c64df37b144a8aa5760f839495c34d2 Mon Sep 17 00:00:00 2001 From: Duane Nykamp Date: Wed, 11 Dec 2024 09:54:22 -0600 Subject: [PATCH] improve equality checks involving tuples, vectors, intervals, and arrays (#270) --- package-lock.json | 8 ++++---- package.json | 2 +- .../test/math/mathExpressionsEquality.test.ts | 16 ++++++++++++++++ .../src/test/tagSpecific/math.test.ts | 14 +++++++------- .../doenetml-worker/src/utils/checkEquality.js | 11 ++++++----- 5 files changed, 34 insertions(+), 17 deletions(-) diff --git a/package-lock.json b/package-lock.json index 865628710..1032bfbc9 100644 --- a/package-lock.json +++ b/package-lock.json @@ -23,7 +23,7 @@ "./packages/*" ], "dependencies": { - "math-expressions": "^2.0.0-alpha71", + "math-expressions": "^2.0.0-alpha73", "react-router-dom": "^6.26.2" }, "devDependencies": { @@ -13748,9 +13748,9 @@ } }, "node_modules/math-expressions": { - "version": "2.0.0-alpha71", - "resolved": "https://registry.npmjs.org/math-expressions/-/math-expressions-2.0.0-alpha71.tgz", - "integrity": "sha512-NMTjBbuzchbEBId1VDP0VzB3qNiqu+sJHS34MyH5ONQtJFzxqXzKH7nqsvemdsTpnlFWMjFzHEPEa524E9oo2A==", + "version": "2.0.0-alpha73", + "resolved": "https://registry.npmjs.org/math-expressions/-/math-expressions-2.0.0-alpha73.tgz", + "integrity": "sha512-Ic0vNYU9/fh+beBFNGhm3ZaYUKLWq2zxPyEwmqaJ9MYEwh8nDlB0gIMf6WnYoQdIWQ/op4pENpe6j9iN6O3rMw==", "license": "(GPL-3.0 OR Apache-2.0)", "dependencies": { "@babel/cli": "^7.25.7", diff --git a/package.json b/package.json index 84bb74743..932fa9ac3 100644 --- a/package.json +++ b/package.json @@ -98,7 +98,7 @@ } }, "dependencies": { - "math-expressions": "^2.0.0-alpha71", + "math-expressions": "^2.0.0-alpha73", "react-router-dom": "^6.26.2" } } diff --git a/packages/doenetml-worker/src/test/math/mathExpressionsEquality.test.ts b/packages/doenetml-worker/src/test/math/mathExpressionsEquality.test.ts index 9d8bb2bef..9709fdf7e 100644 --- a/packages/doenetml-worker/src/test/math/mathExpressionsEquality.test.ts +++ b/packages/doenetml-worker/src/test/math/mathExpressionsEquality.test.ts @@ -947,6 +947,22 @@ describe("Math expressions equality tests", async () => { symbolicSimplifyEqual: false, symbolicSimplifyExpandEqual: false, }, + { + expr1: "(1,2) union (3,4)", + expr2: "(1,2) union (3,4)", + equal: true, + symbolicEqual: true, + symbolicSimplifyEqual: true, + symbolicSimplifyExpandEqual: true, + }, + { + expr1: "(1,2) union [3,4]", + expr2: "(1,2) union [3,4]", + equal: true, + symbolicEqual: true, + symbolicSimplifyEqual: true, + symbolicSimplifyExpandEqual: true, + }, ]; let doenetML = ""; diff --git a/packages/doenetml-worker/src/test/tagSpecific/math.test.ts b/packages/doenetml-worker/src/test/tagSpecific/math.test.ts index 7f11833cd..036640cb6 100644 --- a/packages/doenetml-worker/src/test/tagSpecific/math.test.ts +++ b/packages/doenetml-worker/src/test/tagSpecific/math.test.ts @@ -4142,19 +4142,19 @@ describe("Math tag tests", async () => { "(a,b)+(e,f)", ); expect(cleanLatex(stateVariables["/t2isumSimp"].stateValues.latex)).eq( - "(e,f)+(a,b)", + "(a,b)+(e,f)", ); expect(cleanLatex(stateVariables["/v2isum"].stateValues.latex)).eq( "(c,d)+(e,f)", ); expect(cleanLatex(stateVariables["/v2isumSimp"].stateValues.latex)).eq( - "(e,f)+(c,d)", + "(c,d)+(e,f)", ); expect(cleanLatex(stateVariables["/a2isum"].stateValues.latex)).eq( "\\langlep,q\\rangle+(e,f)", ); expect(cleanLatex(stateVariables["/a2isumSimp"].stateValues.latex)).eq( - "\\langlep,q\\rangle+(e,f)", + "(e,f)+\\langlep,q\\rangle", ); expect(cleanLatex(stateVariables["/st2mul"].stateValues.latex)).eq( "m(a,b)", @@ -4517,25 +4517,25 @@ describe("Math tag tests", async () => { ); expect( cleanLatex(stateVariables["/m21t2sumSimp"].stateValues.latex), - ).eq("\\begin{bmatrix}e\\\\f\\end{bmatrix}+(i,j)"); + ).eq("(i,j)+\\begin{bmatrix}e\\\\f\\end{bmatrix}"); expect(cleanLatex(stateVariables["/m21v2sum"].stateValues.latex)).eq( "\\begin{bmatrix}e\\\\f\\end{bmatrix}+(k,l)", ); expect( cleanLatex(stateVariables["/m21v2sumSimp"].stateValues.latex), - ).eq("\\begin{bmatrix}e\\\\f\\end{bmatrix}+(k,l)"); + ).eq("(k,l)+\\begin{bmatrix}e\\\\f\\end{bmatrix}"); expect(cleanLatex(stateVariables["/m12t2sum"].stateValues.latex)).eq( "\\begin{bmatrix}g&h\\end{bmatrix}+(i,j)", ); expect( cleanLatex(stateVariables["/m12t2sumSimp"].stateValues.latex), - ).eq("\\begin{bmatrix}g&h\\end{bmatrix}+(i,j)"); + ).eq("(i,j)+\\begin{bmatrix}g&h\\end{bmatrix}"); expect(cleanLatex(stateVariables["/m12v2sum"].stateValues.latex)).eq( "\\begin{bmatrix}g&h\\end{bmatrix}+(k,l)", ); expect( cleanLatex(stateVariables["/m12v2sumSimp"].stateValues.latex), - ).eq("\\begin{bmatrix}g&h\\end{bmatrix}+(k,l)"); + ).eq("(k,l)+\\begin{bmatrix}g&h\\end{bmatrix}"); expect(cleanLatex(stateVariables["/m22m21sum"].stateValues.latex)).eq( "\\begin{bmatrix}a&b\\\\c&d\\end{bmatrix}+\\begin{bmatrix}e\\\\f\\end{bmatrix}", ); diff --git a/packages/doenetml-worker/src/utils/checkEquality.js b/packages/doenetml-worker/src/utils/checkEquality.js index 26c797e96..2becf26eb 100644 --- a/packages/doenetml-worker/src/utils/checkEquality.js +++ b/packages/doenetml-worker/src/utils/checkEquality.js @@ -358,7 +358,8 @@ export default function checkEquality({ return { fraction_equal: 0 }; } else if (vectorOperators.includes(object2_operator)) { // since we can convert tuple to vector - // change object2 to array of selements + // change object2 to array of elements + // (we also allow vectors and altVectors to be equal to each other. Is that OK?) object2 = object2.tree.slice(1); } else { // since can convert singleton to a vector of length 1 @@ -378,7 +379,7 @@ export default function checkEquality({ return { fraction_equal: 0 }; } else if (object1_operator === "tuple") { // since can convert tuple to vector - // change object2 to array of elements + // change object1 to array of elements object1 = object1.tree.slice(1); } else { // since can convert singleton to a vector of length 1 @@ -412,16 +413,16 @@ export default function checkEquality({ return { fraction_equal: 0 }; } } else if (object2_operator === "array") { - let operands = object2.tree.slice(1); + let operands2 = object2.tree.slice(1); if ( - operands.length === 2 && + operands2.length === 2 && leftClosed === true && rightClosed === true ) { // since can convert array to closed interval // and object1 is closed interval // make object2 be array of endpoints - object2 = operands; + object2 = operands2; } else { return { fraction_equal: 0 }; }