Skip to main content

Symbolic math verification utilities built on SymPy.

Project description

Symbolic Math Verify

Symbolic math verification utilities built on SymPy.

This project checks whether equations are equivalent, whether a substitution step is valid, whether a uniform subscript rename is valid, whether a numeric calculation matches an expected value, and whether a YAML proof file is valid.

Install

pip install sympy pyyaml

Public API

from symbolic_math_verify import extract_variables
from symbolic_math_verify import is_calculation_correct
from symbolic_math_verify import is_equation_equal
from symbolic_math_verify import is_subscript_substitution_correct
from symbolic_math_verify import is_substitution_correct
from symbolic_math_verify import verify_yaml_file

What It Does

  • is_equation_equal(symbol_list, lhs_equation, rhs_equation) -> bool Proves whether two equations define the same zero relation.
  • is_substitution_correct(symbol_list, equation_before, substitute_equation, equation_after) -> bool Proves whether equation_after is a valid substitution result.
  • is_subscript_substitution_correct(symbol_list, equation_before, subscript, equation_after) -> bool Proves whether the same suffix such as _i was applied consistently to every declared symbol.
  • is_calculation_correct(symbol_list, symbol_val, equation, expected_value, tolerance) -> bool Evaluates an expression or equation residual numerically and compares it to an expected value.
  • extract_variables(math_expression) -> list[str] Extracts variable names from math-like text while skipping known functions and constants.
  • verify_yaml_file(file_path) -> str Validates YAML axioms, proof chains, substitution steps, subscript-substitution steps, and calculations.

Examples

Equation equivalence:

from symbolic_math_verify import is_equation_equal

is_equation_equal(["x"], "x + 2 = 5", "x = 3")
# True

Substitution:

from symbolic_math_verify import is_substitution_correct

is_substitution_correct(
    ["x", "y", "z"],
    "y = 1/x + 5*z",
    "x = z^3",
    "y = 1/(z^3) + 5*z",
)
# True

Subscript substitution:

from symbolic_math_verify import is_subscript_substitution_correct

is_subscript_substitution_correct(
    ["E", "m", "v"],
    "E = (1/2)*m*(v^2)",
    "_i",
    "E_i = (1/2)*m_i*(v_i^2)",
)
# True

Calculation:

from symbolic_math_verify import is_calculation_correct

is_calculation_correct(
    ["x", "y", "z"],
    [0.5, -0.2, 14.0],
    "x + y^2 + 1/z",
    0.61142,
    0.001,
)
# True

Variable extraction:

from symbolic_math_verify import extract_variables

extract_variables("P = I*V ; V = I*R -> P = R*I^2")
# ['P', 'I', 'V', 'R']

YAML verification:

from symbolic_math_verify import verify_yaml_file

verify_yaml_file("test_yaml/valid_11_prompt_with_calculation.yaml")
# "Math proofs are valid"

YAML Support

verify_yaml_file() validates YAML files containing:

  • axioms
  • theorem/proof sections with ->, ;, and : proof steps
  • optional calculations

For axioms and theorem sections, vars may be omitted and will be auto-detected from the math text. For calculations, vars is required.

Notes

  • The checker is conservative: True means proven, while False means wrong, invalid, ambiguous, or not proven.
  • Equations may be written as lhs = rhs or as zero expressions such as x^2 - 1.
  • Common Unicode math characters such as , ×, ÷, and π are normalized before parsing.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

symbolic_math_verify-0.1.0.tar.gz (47.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

symbolic_math_verify-0.1.0-py3-none-any.whl (41.0 kB view details)

Uploaded Python 3

File details

Details for the file symbolic_math_verify-0.1.0.tar.gz.

File metadata

  • Download URL: symbolic_math_verify-0.1.0.tar.gz
  • Upload date:
  • Size: 47.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for symbolic_math_verify-0.1.0.tar.gz
Algorithm Hash digest
SHA256 17b45a62a2bfe2d2196aa5b13f4a25ceba9d47ec1e5ce78b8b6714d83120ba14
MD5 cbb43d9210b077ea956521333afa1917
BLAKE2b-256 82826e365f9d5fa8c7db578811b843bec7a27b64ac8206b7852dd3b752f5122a

See more details on using hashes here.

File details

Details for the file symbolic_math_verify-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for symbolic_math_verify-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 4671e9ad7f61a25f82da0bc8492a95db8307c561c0b911307dbd2e1858823881
MD5 995332c3fea15e73e98d9f6d79345489
BLAKE2b-256 ff6a3339ef2c680b4b3b68af3502cd10101fe41d3a746d628680094fea89ef35

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page