Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix part of #4044: Add AlgebraicExpressionInput classifiers #4058

Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
269 commits
Select commit Hold shift + click to select a range
917c909
Add support for expression->polynomial conversion.
BenHenning Dec 15, 2021
961b3d0
Add NumericExpressionInput classifiers.
BenHenning Dec 15, 2021
535ae2a
Introduce ClassificationContext.
BenHenning Dec 16, 2021
fef2d97
Add classifiers for AlgebraicExpressionInput.
BenHenning Dec 16, 2021
783396f
Add missing annotation for new interaction.
BenHenning Dec 16, 2021
fe12f5b
Merge branch 'add-support-for-math-expressions-pt11-numeric-expressio…
BenHenning Dec 16, 2021
69eaf25
Add missing annotation for new interaction.
BenHenning Dec 16, 2021
86256d9
Lint fixes.
BenHenning Dec 16, 2021
42684b9
Fix provider name.
BenHenning Dec 16, 2021
59bf648
Merge branch 'add-support-for-math-expressions-pt11-numeric-expressio…
BenHenning Dec 16, 2021
aff5bc6
Fix provider name.
BenHenning Dec 16, 2021
d5dd596
Fix broken test post-refactor.
BenHenning Dec 16, 2021
ff813ad
Merge branch 'add-support-for-math-expressions-pt2-math-utility-refac…
BenHenning Dec 16, 2021
a77499c
Merge branch 'add-support-for-math-expressions-pt3-math-expression-pr…
BenHenning Dec 16, 2021
31022f0
Merge branch 'add-support-for-math-expressions-pt4-commutative-compar…
BenHenning Dec 16, 2021
028e821
Merge branch 'add-support-for-math-expressions-pt5-polynomial-protos'…
BenHenning Dec 16, 2021
c2ac696
Merge branch 'add-support-for-math-expressions-pt6-tokenizer' into ad…
BenHenning Dec 16, 2021
b75627c
Merge branch 'add-support-for-math-expressions-pt7-math-expression-pa…
BenHenning Dec 16, 2021
aceddf8
Add reasonable import for abs().
BenHenning Dec 16, 2021
2ad0b46
Merge branch 'add-support-for-math-expressions-pt8-latex-conversion-a…
BenHenning Dec 16, 2021
3cd013b
Merge branch 'add-support-for-math-expressions-pt9-commutative-compar…
BenHenning Dec 16, 2021
9f2bc2c
Merge branch 'add-support-for-math-expressions-pt10-polynomials' into…
BenHenning Dec 16, 2021
fe9419f
Merge branch 'add-support-for-math-expressions-pt11-numeric-expressio…
BenHenning Dec 16, 2021
312708c
Fix equals errors for equations.
BenHenning Jan 8, 2022
d08260b
Merge branch 'add-support-for-math-expressions-pt7-math-expression-pa…
BenHenning Jan 8, 2022
9826b11
Fix rational^rational powers.
BenHenning Jan 8, 2022
25a63bb
Merge branch 'add-support-for-math-expressions-pt8-latex-conversion-a…
BenHenning Jan 8, 2022
94536c1
Merge branch 'add-support-for-math-expressions-pt9-commutative-compar…
BenHenning Jan 8, 2022
58206b3
Ensure rational terms reduce to ints.
BenHenning Jan 8, 2022
f060640
Merge branch 'add-support-for-math-expressions-pt10-polynomials' into…
BenHenning Jan 8, 2022
e355d4a
Add partial equivalence checking for new rules.
BenHenning Jan 8, 2022
ceca976
Merge branch 'add-support-for-math-expressions-pt11-numeric-expressio…
BenHenning Jan 8, 2022
b073b44
Add partial constant checking for new rules.
BenHenning Jan 8, 2022
a1d481d
Merge branch 'develop' into add-support-for-math-expressions-pt1-fix-…
BenHenning Jan 13, 2022
7740c81
Post-merge fix.
BenHenning Jan 13, 2022
929de4f
Add regex check, docs, and resolve TODOs.
BenHenning Jan 14, 2022
e50a50f
Lint fix.
BenHenning Jan 14, 2022
c2726ac
Merge branch 'add-support-for-math-expressions-pt1-fix-proto-imports'…
BenHenning Jan 14, 2022
ec575b7
Fix failing static checks.
BenHenning Jan 14, 2022
5fe790a
Merge branch 'add-support-for-math-expressions-pt2-math-utility-refac…
BenHenning Jan 14, 2022
1268fc5
Fix broken CI checks.
BenHenning Jan 14, 2022
977eb9e
Lint fixes.
BenHenning Jan 14, 2022
a7ab1a5
Merge branch 'add-support-for-math-expressions-pt3-math-expression-pr…
BenHenning Jan 14, 2022
eed21d5
Add docs & exempted tests.
BenHenning Jan 14, 2022
b1102a3
Merge branch 'add-support-for-math-expressions-pt4-commutative-compar…
BenHenning Jan 14, 2022
080e7dd
Remove blank line.
BenHenning Jan 14, 2022
904aad8
Add docs + tests.
BenHenning Jan 19, 2022
61fbfe5
Merge branch 'add-support-for-math-expressions-pt5-polynomial-protos'…
BenHenning Jan 19, 2022
fca0cd9
Add parameterized test runner.
BenHenning Jan 21, 2022
83e800c
Add & update tests.
BenHenning Jan 21, 2022
3fa8dad
Lint fixes.
BenHenning Jan 21, 2022
87a41db
Remove internals that broke things.
BenHenning Jan 21, 2022
c0172ce
Add regex exemptions.
BenHenning Jan 21, 2022
8723ee8
Merge branch 'add-support-for-math-expressions-pt6-tokenizer' into ad…
BenHenning Jan 21, 2022
ff41eeb
Post-merge fix.
BenHenning Jan 21, 2022
f5b6571
Add error tests.
BenHenning Jan 22, 2022
b7ac054
Finish algebraic equation tests.
BenHenning Jan 22, 2022
a122515
Reimplement numeric expression tests.
BenHenning Jan 22, 2022
984e740
Finish algebraic expression tests.
BenHenning Jan 22, 2022
042a1ad
Add missing tests for better coverage.
BenHenning Jan 24, 2022
8ead9bf
Add KDocs & test exemptions.
BenHenning Jan 25, 2022
aeec35c
Lint fixes.
BenHenning Jan 25, 2022
57e6f5b
Remove temporary TODOs.
BenHenning Jan 25, 2022
10eac78
Merge branch 'add-support-for-math-expressions-pt7-math-expression-pa…
BenHenning Jan 25, 2022
07be596
Add tests.
BenHenning Jan 26, 2022
19a6425
Split StringToFractionParser.
BenHenning Jan 26, 2022
444d3d0
Merge branch 'develop' into add-support-for-math-expressions-pt1-fix-…
BenHenning Jan 26, 2022
cb5c5d1
Merge branch 'add-support-for-math-expressions-pt1-fix-proto-imports'…
BenHenning Jan 27, 2022
7a364c3
Address reviewer comments + other stuff.
BenHenning Jan 27, 2022
2c0b9cd
Merge branch 'add-support-for-math-expressions-pt2-math-utility-refac…
BenHenning Jan 27, 2022
4364d7f
Merge branch 'add-support-for-math-expressions-pt3-math-expression-pr…
BenHenning Jan 27, 2022
cfe6cab
Move StringExtensions & fraction parsing.
BenHenning Jan 27, 2022
5e83a33
Merge branch 'add-support-for-math-expressions-pt2-math-utility-refac…
BenHenning Jan 27, 2022
c6cf5f5
Merge branch 'add-support-for-math-expressions-pt3-math-expression-pr…
BenHenning Jan 27, 2022
73dccd8
Address reviewer comments.
BenHenning Jan 27, 2022
b7535fa
Alphabetize test exemptions.
BenHenning Jan 27, 2022
f4cd6cd
Merge branch 'add-support-for-math-expressions-pt4-commutative-compar…
BenHenning Jan 27, 2022
574ebb8
Merge branch 'add-support-for-math-expressions-pt5-polynomial-protos'…
BenHenning Jan 27, 2022
a00164c
Fix typo & add regex check.
BenHenning Jan 27, 2022
0287f19
Add missing KDocs.
BenHenning Jan 27, 2022
75103d5
Merge branch 'add-support-for-math-expressions-pt2-math-utility-refac…
BenHenning Jan 27, 2022
52d2605
Merge branch 'add-support-for-math-expressions-pt3-math-expression-pr…
BenHenning Jan 27, 2022
37dbc85
Merge branch 'add-support-for-math-expressions-pt4-commutative-compar…
BenHenning Jan 27, 2022
385d2d3
Merge branch 'add-support-for-math-expressions-pt5-polynomial-protos'…
BenHenning Jan 27, 2022
4bacc8a
Merge branch 'add-support-for-math-expressions-pt6-tokenizer' into ad…
BenHenning Jan 27, 2022
1e5279d
Post-merge cleanups.
BenHenning Jan 27, 2022
bbf7e2d
Add new test for negation with math symbol.
BenHenning Jan 27, 2022
cf72c8d
Merge branch 'add-support-for-math-expressions-pt7-math-expression-pa…
BenHenning Jan 27, 2022
ba4128c
Post-merge fixes.
BenHenning Jan 27, 2022
fd09758
Add KDocs.
BenHenning Jan 27, 2022
01c2326
Refactor & simplify real ext impl.
BenHenning Jan 27, 2022
98d6939
Lint fixes.
BenHenning Jan 28, 2022
928aa6f
Merge branch 'add-support-for-math-expressions-pt8-latex-conversion-a…
BenHenning Jan 28, 2022
ca412f7
Simplify operation list converter a lot.
BenHenning Jan 28, 2022
f172bcf
Prepare for new tests.
BenHenning Jan 28, 2022
65a9fe1
Remove the ComparableOperationList wrapper.
BenHenning Jan 28, 2022
fa4de34
Merge branch 'add-support-for-math-expressions-pt4-commutative-compar…
BenHenning Jan 28, 2022
e2d226f
Merge branch 'add-support-for-math-expressions-pt5-polynomial-protos'…
BenHenning Jan 28, 2022
fbd935c
Change parameterized method delimiter.
BenHenning Jan 28, 2022
5b6d1f2
Merge branch 'add-support-for-math-expressions-pt6-tokenizer' into ad…
BenHenning Jan 28, 2022
fd11a79
Merge branch 'add-support-for-math-expressions-pt7-math-expression-pa…
BenHenning Jan 28, 2022
8420c56
Use utility directly in test.
BenHenning Jan 28, 2022
047645c
Merge branch 'add-support-for-math-expressions-pt8-latex-conversion-a…
BenHenning Jan 28, 2022
b8a3e2e
Post-merge fixes.
BenHenning Jan 28, 2022
28811b3
Add first round of tests.
BenHenning Jan 28, 2022
b400176
Finish initial test suite.
BenHenning Jan 29, 2022
e6c09d8
Simplify operation sorting comparators.
BenHenning Jan 29, 2022
bebc100
Remove old tests.
BenHenning Jan 29, 2022
3cecc6c
Add remaining missing tests.
BenHenning Jan 29, 2022
573fee9
KDocs & test exemption.
BenHenning Jan 29, 2022
1970f34
Renames & lint fixes.
BenHenning Jan 29, 2022
f5abb4d
Merge branch 'add-support-for-math-expressions-pt9-commutative-compar…
BenHenning Jan 29, 2022
45b6099
Post-merge fixes.
BenHenning Jan 29, 2022
76a7887
Add tests.
BenHenning Feb 2, 2022
06ba279
KDocs + exemptions.
BenHenning Feb 2, 2022
ad3091d
Lint fixes.
BenHenning Feb 2, 2022
576d7dc
Merge branch 'add-support-for-math-expressions-pt10-polynomials' into…
BenHenning Feb 2, 2022
b8ce188
Post-merge fixes.
BenHenning Feb 2, 2022
468b565
Add extension tests.
BenHenning Feb 4, 2022
4030aa3
Add classifier tests.
BenHenning Feb 4, 2022
d20256c
Use more intentional epsilons for float comparing.
BenHenning Feb 4, 2022
cdaf778
Merge branch 'add-support-for-math-expressions-pt5-polynomial-protos'…
BenHenning Feb 4, 2022
7e97d0b
Treat en-dash as a subtraction symbol.
BenHenning Feb 4, 2022
a9c68b1
Add explicit platform selection for paramerized.
BenHenning Feb 5, 2022
a273ee6
Exemption fixes.
BenHenning Feb 5, 2022
924214d
Merge branch 'develop' into add-support-for-math-expressions-pt1-fix-…
BenHenning Feb 5, 2022
686c4b6
Merge branch 'add-support-for-math-expressions-pt1-fix-proto-imports'…
BenHenning Feb 5, 2022
1a3cba5
Merge branch 'add-support-for-math-expressions-pt2-math-utility-refac…
BenHenning Feb 5, 2022
bff824e
Merge branch 'add-support-for-math-expressions-pt3-math-expression-pr…
BenHenning Feb 5, 2022
90b05bf
Merge branch 'add-support-for-math-expressions-pt4-commutative-compar…
BenHenning Feb 5, 2022
09e2aad
Remove failing test.
BenHenning Feb 5, 2022
c7c2e4b
Merge branch 'add-support-for-math-expressions-pt5-polynomial-protos'…
BenHenning Feb 5, 2022
8bdf183
Merge branch 'add-support-for-math-expressions-pt6-tokenizer' into ad…
BenHenning Feb 5, 2022
b48d06a
Fix unary expression precedence.
BenHenning Feb 5, 2022
8ac22cb
Fixes & add more test cases.
BenHenning Feb 5, 2022
cdee008
Merge branch 'add-support-for-math-expressions-pt7-math-expression-pa…
BenHenning Feb 5, 2022
476e604
Post-merge fixes & test changes.
BenHenning Feb 5, 2022
5ed0013
Use utility directly in LaTeX tests.
BenHenning Feb 5, 2022
370dcf6
Merge branch 'add-support-for-math-expressions-pt8-latex-conversion-a…
BenHenning Feb 5, 2022
c16db64
Post-merge fixes.
BenHenning Feb 5, 2022
df4221f
Merge branch 'add-support-for-math-expressions-pt9-commutative-compar…
BenHenning Feb 5, 2022
dab330e
Post-merge fixes.
BenHenning Feb 5, 2022
7567232
Merge branch 'add-support-for-math-expressions-pt10-polynomials' into…
BenHenning Feb 5, 2022
9c70c31
Post-merge fixes.
BenHenning Feb 5, 2022
3248e84
Lint & other check fixes.
BenHenning Feb 5, 2022
43cc4e0
Merge branch 'add-support-for-math-expressions-pt11-numeric-expressio…
BenHenning Feb 5, 2022
3960220
Replace deprecated term.
BenHenning Feb 5, 2022
528e9f7
Merge branch 'add-support-for-math-expressions-pt11-numeric-expressio…
BenHenning Feb 5, 2022
f7ec751
Post-merge fixes.
BenHenning Feb 5, 2022
782e058
Add full test suites for alg exp classifiers.
BenHenning Feb 5, 2022
0a7cb69
Lint & static check fixes.
BenHenning Feb 5, 2022
fd0c0cc
Fix test on Gradle.
BenHenning Feb 5, 2022
2839e7b
Merge branch 'add-support-for-math-expressions-pt11-numeric-expressio…
BenHenning Feb 5, 2022
812b66e
Fix test for Gradle.
BenHenning Feb 5, 2022
ecc836e
Merge branch 'develop' into add-support-for-math-expressions-pt1-fix-…
BenHenning Feb 18, 2022
b183d67
Merge branch 'add-support-for-math-expressions-pt1-fix-proto-imports'…
BenHenning Feb 18, 2022
005d9a0
Merge branch 'add-support-for-math-expressions-pt2-math-utility-refac…
BenHenning Feb 18, 2022
ba198fd
Merge branch 'add-support-for-math-expressions-pt3-math-expression-pr…
BenHenning Feb 18, 2022
1f2b90d
Merge branch 'add-support-for-math-expressions-pt4-commutative-compar…
BenHenning Feb 18, 2022
86e90f7
Merge branch 'add-support-for-math-expressions-pt5-polynomial-protos'…
BenHenning Feb 18, 2022
a6dc7d4
Address reviewer comment.
BenHenning Feb 18, 2022
a6d1111
Merge branch 'add-support-for-math-expressions-pt6-tokenizer' into ad…
BenHenning Feb 18, 2022
64a1b55
Merge branch 'add-support-for-math-expressions-pt7-math-expression-pa…
BenHenning Feb 18, 2022
151e0bf
Merge branch 'add-support-for-math-expressions-pt8-latex-conversion-a…
BenHenning Feb 18, 2022
fd9ec1f
Fix broken build.
BenHenning Feb 18, 2022
960287d
Merge branch 'add-support-for-math-expressions-pt1-fix-proto-imports'…
BenHenning Feb 18, 2022
b85567e
Merge branch 'add-support-for-math-expressions-pt2-math-utility-refac…
BenHenning Feb 18, 2022
2ed67c5
Merge branch 'add-support-for-math-expressions-pt3-math-expression-pr…
BenHenning Feb 18, 2022
3744cf2
Merge branch 'add-support-for-math-expressions-pt4-commutative-compar…
BenHenning Feb 18, 2022
c57e792
Merge branch 'add-support-for-math-expressions-pt5-polynomial-protos'…
BenHenning Feb 18, 2022
056f547
Merge branch 'add-support-for-math-expressions-pt6-tokenizer' into ad…
BenHenning Feb 18, 2022
5431e27
Merge branch 'add-support-for-math-expressions-pt7-math-expression-pa…
BenHenning Feb 18, 2022
829bb16
Merge branch 'add-support-for-math-expressions-pt8-latex-conversion-a…
BenHenning Feb 18, 2022
23254ca
Merge branch 'add-support-for-math-expressions-pt9-commutative-compar…
BenHenning Feb 18, 2022
0fc8a1b
Fix broken build post-merge.
BenHenning Feb 18, 2022
e4b92e5
Merge branch 'add-support-for-math-expressions-pt2-math-utility-refac…
BenHenning Feb 18, 2022
9eb1c2d
Merge branch 'add-support-for-math-expressions-pt3-math-expression-pr…
BenHenning Feb 18, 2022
1f3fb48
Merge branch 'add-support-for-math-expressions-pt4-commutative-compar…
BenHenning Feb 18, 2022
24ac61c
Merge branch 'add-support-for-math-expressions-pt5-polynomial-protos'…
BenHenning Feb 18, 2022
c74aee0
Merge branch 'add-support-for-math-expressions-pt6-tokenizer' into ad…
BenHenning Feb 18, 2022
e814df8
Merge branch 'add-support-for-math-expressions-pt7-math-expression-pa…
BenHenning Feb 18, 2022
6df7a21
Merge branch 'add-support-for-math-expressions-pt8-latex-conversion-a…
BenHenning Feb 18, 2022
446d263
Merge branch 'add-support-for-math-expressions-pt9-commutative-compar…
BenHenning Feb 18, 2022
3cd065f
Merge branch 'add-support-for-math-expressions-pt10-polynomials' into…
BenHenning Feb 18, 2022
c59598c
Fix broken post-merge classifier.
BenHenning Feb 18, 2022
41be40e
Address reviewer comment.
BenHenning Feb 18, 2022
8070cb6
Merge branch 'add-support-for-math-expressions-pt11-numeric-expressio…
BenHenning Feb 18, 2022
1ea2241
Post-merge build fixes.
BenHenning Feb 18, 2022
c01f939
Merge branch 'develop' into add-support-for-math-expressions-pt1-fix-…
BenHenning Feb 24, 2022
14f7057
Merge branch 'add-support-for-math-expressions-pt1-fix-proto-imports'…
BenHenning Feb 24, 2022
b98e1ec
Merge branch 'add-support-for-math-expressions-pt2-math-utility-refac…
BenHenning Feb 24, 2022
b50c40f
Merge branch 'add-support-for-math-expressions-pt3-math-expression-pr…
BenHenning Feb 24, 2022
6d0cc9e
Merge branch 'add-support-for-math-expressions-pt4-commutative-compar…
BenHenning Feb 24, 2022
2217f7d
Merge branch 'add-support-for-math-expressions-pt5-polynomial-protos'…
BenHenning Feb 24, 2022
a9adda1
Merge branch 'add-support-for-math-expressions-pt6-tokenizer' into ad…
BenHenning Feb 24, 2022
ac63847
Merge branch 'add-support-for-math-expressions-pt7-math-expression-pa…
BenHenning Feb 24, 2022
3f236cb
Merge branch 'add-support-for-math-expressions-pt8-latex-conversion-a…
BenHenning Feb 24, 2022
7a76b98
Merge branch 'add-support-for-math-expressions-pt9-commutative-compar…
BenHenning Feb 24, 2022
af86921
Merge branch 'add-support-for-math-expressions-pt10-polynomials' into…
BenHenning Feb 24, 2022
ebac9b3
Merge branch 'add-support-for-math-expressions-pt11-numeric-expressio…
BenHenning Feb 24, 2022
1d74aed
Merge branch 'develop' into add-support-for-math-expressions-pt1-fix-…
BenHenning Mar 7, 2022
2ae10ec
Merge branch 'add-support-for-math-expressions-pt1-fix-proto-imports'…
BenHenning Mar 7, 2022
60670a5
Merge branch 'add-support-for-math-expressions-pt2-math-utility-refac…
BenHenning Mar 7, 2022
473b562
Merge branch 'add-support-for-math-expressions-pt3-math-expression-pr…
BenHenning Mar 7, 2022
73a052f
Merge branch 'add-support-for-math-expressions-pt4-commutative-compar…
BenHenning Mar 7, 2022
e35b13f
Merge branch 'add-support-for-math-expressions-pt5-polynomial-protos'…
BenHenning Mar 7, 2022
9aa8315
Merge branch 'add-support-for-math-expressions-pt6-tokenizer' into ad…
BenHenning Mar 7, 2022
e8b8f9f
Merge branch 'add-support-for-math-expressions-pt7-math-expression-pa…
BenHenning Mar 7, 2022
a28d87f
Merge branch 'add-support-for-math-expressions-pt8-latex-conversion-a…
BenHenning Mar 7, 2022
9c7a1cb
Merge branch 'add-support-for-math-expressions-pt9-commutative-compar…
BenHenning Mar 7, 2022
3a69df4
Merge branch 'add-support-for-math-expressions-pt10-polynomials' into…
BenHenning Mar 7, 2022
a632215
Merge branch 'add-support-for-math-expressions-pt11-numeric-expressio…
BenHenning Mar 7, 2022
8945c3a
Merge branch 'develop' into add-support-for-math-expressions-pt1-fix-…
BenHenning Mar 17, 2022
391cf22
Post-merge fix.
BenHenning Mar 17, 2022
7918001
Merge branch 'add-support-for-math-expressions-pt1-fix-proto-imports'…
BenHenning Mar 17, 2022
c29a47c
More post-merge fixes.
BenHenning Mar 17, 2022
19b3800
Merge branch 'add-support-for-math-expressions-pt2-math-utility-refac…
BenHenning Mar 17, 2022
aa4fd38
Merge branch 'add-support-for-math-expressions-pt3-math-expression-pr…
BenHenning Mar 17, 2022
eb2bcc3
Merge branch 'add-support-for-math-expressions-pt4-commutative-compar…
BenHenning Mar 17, 2022
8bd314f
Merge branch 'add-support-for-math-expressions-pt5-polynomial-protos'…
BenHenning Mar 17, 2022
429ee02
Merge branch 'add-support-for-math-expressions-pt6-tokenizer' into ad…
BenHenning Mar 17, 2022
445664a
Fix TODO comment.
BenHenning Mar 17, 2022
b82b158
Merge branch 'add-support-for-math-expressions-pt7-math-expression-pa…
BenHenning Mar 17, 2022
4dd551b
Merge branch 'add-support-for-math-expressions-pt8-latex-conversion-a…
BenHenning Mar 17, 2022
4b9b9ac
Merge branch 'add-support-for-math-expressions-pt9-commutative-compar…
BenHenning Mar 17, 2022
af405aa
Merge branch 'add-support-for-math-expressions-pt10-polynomials' into…
BenHenning Mar 17, 2022
5d797b0
Merge branch 'add-support-for-math-expressions-pt11-numeric-expressio…
BenHenning Mar 17, 2022
52862d6
Merge branch 'develop' into add-support-for-math-expressions-pt1-fix-…
BenHenning Mar 25, 2022
cd31247
Merge branch 'develop' into add-support-for-math-expressions-pt1-fix-…
BenHenning Mar 25, 2022
4dbd838
Merge branch 'add-support-for-math-expressions-pt1-fix-proto-imports'…
BenHenning Mar 25, 2022
deabf3a
Merge branch 'develop' into add-support-for-math-expressions-pt2-math…
BenHenning Mar 26, 2022
8bd89e6
Merge branch 'add-support-for-math-expressions-pt2-math-utility-refac…
BenHenning Mar 26, 2022
06f9cfd
Merge branch 'develop' into add-support-for-math-expressions-pt3-math…
BenHenning Mar 26, 2022
a1284a1
Merge branch 'add-support-for-math-expressions-pt3-math-expression-pr…
BenHenning Mar 26, 2022
2c2328b
Merge branch 'develop' into add-support-for-math-expressions-pt4-comm…
BenHenning Mar 26, 2022
feb901b
Merge branch 'add-support-for-math-expressions-pt4-commutative-compar…
BenHenning Mar 26, 2022
783aaf0
Merge branch 'develop' into add-support-for-math-expressions-pt5-poly…
BenHenning Mar 26, 2022
7306faa
Merge branch 'add-support-for-math-expressions-pt5-polynomial-protos'…
BenHenning Mar 26, 2022
d59437c
Merge branch 'develop' into add-support-for-math-expressions-pt6-toke…
BenHenning Mar 26, 2022
be04055
Merge branch 'add-support-for-math-expressions-pt6-tokenizer' into ad…
BenHenning Mar 26, 2022
88ecf9e
Merge branch 'develop' into add-support-for-math-expressions-pt7-math…
BenHenning Mar 26, 2022
7cb991a
Merge branch 'add-support-for-math-expressions-pt7-math-expression-pa…
BenHenning Mar 26, 2022
b94f94f
Merge branch 'develop' into add-support-for-math-expressions-pt8-late…
BenHenning Mar 26, 2022
3229bae
Merge branch 'add-support-for-math-expressions-pt8-latex-conversion-a…
BenHenning Mar 26, 2022
d31a403
Merge branch 'develop' into add-support-for-math-expressions-pt9-comm…
BenHenning Mar 26, 2022
67c53ec
Merge branch 'add-support-for-math-expressions-pt9-commutative-compar…
BenHenning Mar 26, 2022
ff2df48
Merge branch 'develop' into add-support-for-math-expressions-pt10-pol…
BenHenning Mar 26, 2022
c41bda8
Merge branch 'add-support-for-math-expressions-pt10-polynomials' into…
BenHenning Mar 26, 2022
e34c52a
Merge branch 'develop' into add-support-for-math-expressions-pt11-num…
BenHenning Mar 26, 2022
78935c3
Merge branch 'add-support-for-math-expressions-pt11-numeric-expressio…
BenHenning Mar 26, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ class AnswerClassificationController @Inject constructor(
interaction.defaultOutcome,
interactionClassifier,
interaction.id,
writtenTranslationContext
ClassificationContext(writtenTranslationContext, interaction.customizationArgsMap)
)
}

Expand All @@ -54,7 +54,7 @@ class AnswerClassificationController @Inject constructor(
defaultOutcome: Outcome,
interactionClassifier: InteractionClassifier,
interactionId: String,
writtenTranslationContext: WrittenTranslationContext
classificationContext: ClassificationContext
): ClassificationResult {
for (answerGroup in answerGroups) {
for (ruleSpec in answerGroup.ruleSpecsList) {
Expand All @@ -65,7 +65,7 @@ class AnswerClassificationController @Inject constructor(
" has: ${interactionClassifier.getRuleTypes()}"
}
try {
if (ruleClassifier.matches(answer, ruleSpec.inputMap, writtenTranslationContext)) {
if (ruleClassifier.matches(answer, ruleSpec.inputMap, classificationContext)) {
// Explicit classification matched.
return if (!answerGroup.hasTaggedSkillMisconception()) {
ClassificationResult.OutcomeOnly(answerGroup.outcome)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ kt_android_library(
],
visibility = ["//:oppia_api_visibility"],
deps = [
":classification_context",
":classification_result",
":interaction_classifier",
"//model/src/main/proto:exploration_java_proto_lite",
Expand All @@ -21,6 +22,18 @@ kt_android_library(
],
)

kt_android_library(
name = "classification_context",
srcs = [
"ClassificationContext.kt",
],
visibility = ["//:oppia_api_visibility"],
deps = [
"//model/src/main/proto:exploration_java_proto_lite",
"//model/src/main/proto:translation_java_proto_lite",
],
)

kt_android_library(
name = "classification_result",
srcs = [
Expand All @@ -38,6 +51,7 @@ kt_android_library(
"GenericInteractionClassifier.kt",
],
deps = [
":classification_context",
":interaction_classifier",
":rule_classifier",
],
Expand Down Expand Up @@ -77,6 +91,7 @@ kt_android_library(
],
visibility = ["//:__subpackages__"],
deps = [
":classification_context",
"//model/src/main/proto:interaction_object_java_proto_lite",
"//model/src/main/proto:translation_java_proto_lite",
],
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
package org.oppia.android.domain.classify

import org.oppia.android.app.model.SchemaObject
import org.oppia.android.app.model.WrittenTranslationContext

/**
* Represents the context provided to classifiers when they're classifying an answer.
*
* This object provides context for the interaction and learner settings to help classifiers
* properly categorize and process answers.
*
* @property writtenTranslationContext the [WrittenTranslationContext] currently used by the learner
* @property customizationArgs the customization arguments defined by the current interaction
*/
data class ClassificationContext(
val writtenTranslationContext: WrittenTranslationContext =
WrittenTranslationContext.getDefaultInstance(),
val customizationArgs: Map<String, SchemaObject> = mapOf()
)
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
package org.oppia.android.domain.classify

import org.oppia.android.app.model.InteractionObject
import org.oppia.android.app.model.WrittenTranslationContext

/** An answer classifier for a specific interaction rule. */
interface RuleClassifier {
Expand All @@ -12,6 +11,6 @@ interface RuleClassifier {
fun matches(
answer: InteractionObject,
inputs: Map<String, InteractionObject>,
writtenTranslationContext: WrittenTranslationContext
classificationContext: ClassificationContext
): Boolean
}
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
package org.oppia.android.domain.classify.rules

import org.oppia.android.app.model.InteractionObject
import org.oppia.android.app.model.WrittenTranslationContext
import org.oppia.android.domain.classify.ClassificationContext
import org.oppia.android.domain.classify.RuleClassifier
import javax.inject.Inject

Expand All @@ -15,15 +15,15 @@ import javax.inject.Inject
*/
// TODO(#1580): Re-restrict access using Bazel visibilities
class GenericRuleClassifier constructor(
val expectedAnswerObjectType: InteractionObject.ObjectTypeCase,
val orderedExpectedParameterTypes: LinkedHashMap<
private val expectedAnswerObjectType: InteractionObject.ObjectTypeCase,
private val orderedExpectedParameterTypes: LinkedHashMap<
String, InteractionObject.ObjectTypeCase>,
val matcherDelegate: MatcherDelegate
private val matcherDelegate: MatcherDelegate
) : RuleClassifier {
override fun matches(
answer: InteractionObject,
inputs: Map<String, InteractionObject>,
writtenTranslationContext: WrittenTranslationContext
classificationContext: ClassificationContext
): Boolean {
check(answer.objectTypeCase == expectedAnswerObjectType) {
"Expected answer to be of type ${expectedAnswerObjectType.name} " +
Expand All @@ -34,7 +34,7 @@ class GenericRuleClassifier constructor(
.map { (parameterName, expectedObjectType) ->
retrieveInputObject(parameterName, expectedObjectType, inputs)
}
return matcherDelegate.matches(answer, parameterInputs, writtenTranslationContext)
return matcherDelegate.matches(answer, parameterInputs, classificationContext)
}

private fun retrieveInputObject(
Expand All @@ -58,27 +58,23 @@ class GenericRuleClassifier constructor(
* Returns whether the validated and extracted answer matches the expectations per the
* specification of this classifier.
*/
fun matches(answer: T, writtenTranslationContext: WrittenTranslationContext): Boolean
fun matches(answer: T, classificationContext: ClassificationContext): Boolean
}

interface SingleInputMatcher<T> {
/**
* Returns whether the validated and extracted answer matches the single validated and extracted
* input parameter per the specification of this classifier.
*/
fun matches(answer: T, input: T, writtenTranslationContext: WrittenTranslationContext): Boolean
fun matches(answer: T, input: T, classificationContext: ClassificationContext): Boolean
}

interface MultiTypeSingleInputMatcher<AT, IT> {
/**
* Returns whether the validated and extracted answer matches the single validated and extracted
* input parameter per the specification of this classifier.
*/
fun matches(
answer: AT,
input: IT,
writtenTranslationContext: WrittenTranslationContext
): Boolean
fun matches(answer: AT, input: IT, classificationContext: ClassificationContext): Boolean
}

interface MultiTypeDoubleInputMatcher<AT, ITF, ITS> {
Expand All @@ -90,7 +86,7 @@ class GenericRuleClassifier constructor(
answer: AT,
firstInput: ITF,
secondInput: ITS,
writtenTranslationContext: WrittenTranslationContext
classificationContext: ClassificationContext
): Boolean
}

Expand All @@ -103,7 +99,7 @@ class GenericRuleClassifier constructor(
answer: T,
firstInput: T,
secondInput: T,
writtenTranslationContext: WrittenTranslationContext
classificationContext: ClassificationContext
): Boolean
}

Expand All @@ -112,7 +108,7 @@ class GenericRuleClassifier constructor(
abstract fun matches(
answer: InteractionObject,
inputs: List<InteractionObject>,
writtenTranslationContext: WrittenTranslationContext
classificationContext: ClassificationContext
): Boolean

class NoInputMatcherDelegate<T : Any>(
Expand All @@ -122,10 +118,10 @@ class GenericRuleClassifier constructor(
override fun matches(
answer: InteractionObject,
inputs: List<InteractionObject>,
writtenTranslationContext: WrittenTranslationContext
classificationContext: ClassificationContext
): Boolean {
check(inputs.isEmpty())
return matcher.matches(extractObject(answer), writtenTranslationContext)
return matcher.matches(extractObject(answer), classificationContext)
}
}

Expand All @@ -136,11 +132,11 @@ class GenericRuleClassifier constructor(
override fun matches(
answer: InteractionObject,
inputs: List<InteractionObject>,
writtenTranslationContext: WrittenTranslationContext
classificationContext: ClassificationContext
): Boolean {
check(inputs.size == 1)
return matcher.matches(
extractObject(answer), extractObject(inputs.first()), writtenTranslationContext
extractObject(answer), extractObject(inputs.first()), classificationContext
)
}
}
Expand All @@ -153,11 +149,11 @@ class GenericRuleClassifier constructor(
override fun matches(
answer: InteractionObject,
inputs: List<InteractionObject>,
writtenTranslationContext: WrittenTranslationContext
classificationContext: ClassificationContext
): Boolean {
check(inputs.size == 1)
return matcher.matches(
extractAnswerObject(answer), extractInputObject(inputs.first()), writtenTranslationContext
extractAnswerObject(answer), extractInputObject(inputs.first()), classificationContext
)
}
}
Expand All @@ -169,14 +165,14 @@ class GenericRuleClassifier constructor(
override fun matches(
answer: InteractionObject,
inputs: List<InteractionObject>,
writtenTranslationContext: WrittenTranslationContext
classificationContext: ClassificationContext
): Boolean {
check(inputs.size == 2)
return matcher.matches(
extractObject(answer),
extractObject(inputs[0]),
extractObject(inputs[1]),
writtenTranslationContext
classificationContext
)
}
}
Expand All @@ -190,14 +186,14 @@ class GenericRuleClassifier constructor(
override fun matches(
answer: InteractionObject,
inputs: List<InteractionObject>,
writtenTranslationContext: WrittenTranslationContext
classificationContext: ClassificationContext
): Boolean {
check(inputs.size == 2)
return matcher.matches(
extractAnswerObject(answer),
extractFirstParamObject(inputs[0]),
extractSecondParamObject(inputs[1]),
writtenTranslationContext
classificationContext
)
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -78,3 +78,10 @@ annotation class RatioExpressionInputRules
*/
@Qualifier
annotation class NumericExpressionInputRules

/**
* Corresponds to [org.oppia.android.domain.classify.RuleClassifier]s that can be used by the
* algebraic expression input interaction.
*/
@Qualifier
annotation class AlgebraicExpressionInputRules
Original file line number Diff line number Diff line change
@@ -0,0 +1,78 @@
package org.oppia.android.domain.classify.rules.algebraicexpressioninput

import org.oppia.android.app.model.InteractionObject
import org.oppia.android.app.model.Polynomial
import org.oppia.android.domain.classify.ClassificationContext
import org.oppia.android.domain.classify.RuleClassifier
import org.oppia.android.domain.classify.rules.GenericRuleClassifier
import org.oppia.android.domain.classify.rules.RuleClassifierProvider
import org.oppia.android.util.logging.ConsoleLogger
import org.oppia.android.util.math.MathExpressionParser.Companion.MathParsingResult
import org.oppia.android.util.math.MathExpressionParser.Companion.parseAlgebraicExpression
import org.oppia.android.util.math.isApproximatelyEqualTo
import org.oppia.android.util.math.toPolynomial
import javax.inject.Inject

/**
* Provider for a classifier that determines whether an algebraic expression is mathematically
* equivalent to the creator-specific expression defined as the input to this interaction.
*
* Note that both expressions are assumed and parsed as polynomials.
*
* See this class's tests for a list of supported cases (both for matching and not matching).
*/
class AlgebraicExpressionInputIsEquivalentToRuleClassifierProvider @Inject constructor(
private val classifierFactory: GenericRuleClassifier.Factory,
private val consoleLogger: ConsoleLogger
) : RuleClassifierProvider, GenericRuleClassifier.SingleInputMatcher<String> {
override fun createRuleClassifier(): RuleClassifier {
return classifierFactory.createSingleInputClassifier(
expectedObjectType = InteractionObject.ObjectTypeCase.MATH_EXPRESSION,
inputParameterName = "x",
matcher = this
)
}

override fun matches(
answer: String,
input: String,
classificationContext: ClassificationContext
): Boolean {
val allowedVariables = classificationContext.extractAllowedVariables()
val answerExpression = parsePolynomial(answer, allowedVariables) ?: return false
val inputExpression = parsePolynomial(input, allowedVariables) ?: return false
return answerExpression.isApproximatelyEqualTo(inputExpression)
}

private fun parsePolynomial(rawExpression: String, allowedVariables: List<String>): Polynomial? {
return when (val expResult = parseAlgebraicExpression(rawExpression, allowedVariables)) {
is MathParsingResult.Success -> {
expResult.result.toPolynomial().also {
if (it == null) {
consoleLogger.w(
"AlgebraExpEquivalent", "Expression is not a supported polynomial: $rawExpression."
)
}
}
}
is MathParsingResult.Failure -> {
consoleLogger.e(
"AlgebraExpEquivalent",
"Encountered expression that failed parsing. Expression: $rawExpression." +
" Failure: ${expResult.error}."
)
null
}
}
}

private companion object {
private fun ClassificationContext.extractAllowedVariables(): List<String> {
return customizationArgs["customOskLetters"]
?.schemaObjectList
?.schemaObjectList
?.map { it.normalizedString }
?: listOf()
}
}
}
Loading