LaTeX to CAS translator

Jump to navigation Jump to search

This mockup demonstrates the concept of TeX to Computer Algebra System (CAS) conversion.

The demo-application converts LaTeX functions which directly translate to CAS counterparts.

Functions without explicit CAS support are available for translation via a DRMF package (under development).

The following LaTeX input ...

{\displaystyle \operatorname{Ci}(x)= \gamma+\ln x+\sum_{n=1}^{\infty}\frac{(-1)^{n}x^{2n}}{2n(2n)!}=\gamma+\ln x-\frac{x^2}{2!\cdot2}+\frac{x^4}{4! \cdot4}\mp\cdots}

... is translated to the CAS output ...

Semantic latex: \operatorname{Ci}(x) = \EulerConstant + \ln x + \sum_{n=1}^{\infty} \frac{(-1)^{n}x^{2n}}{2n(2n)!} = \EulerConstant + \ln x - \frac{x^2}{2!\cdot2} + \frac{x^4}{4! \cdot4} \mp \cdots

Confidence: 0

Mathematica

Translation: Ci[x] == EulerGamma + Log[x]+ Sum[Divide[(- 1)^(n)* (x)^(2*n),2*n*(2*n)!], {n, 1, Infinity}, GenerateConditions->None] == EulerGamma + Log[x]-Divide[(x)^(2),(2)! * 2]+Divide[(x)^(4),(4)! * 4] \[MinusPlus] \[Ellipsis]

Information

Sub Equations

  • Ci[x] = EulerGamma + Log[x]+ Sum[Divide[(- 1)^(n)* (x)^(2*n),2*n*(2*n)!], {n, 1, Infinity}, GenerateConditions->None]
  • EulerGamma + Log[x]+ Sum[Divide[(- 1)^(n)* (x)^(2*n),2*n*(2*n)!], {n, 1, Infinity}, GenerateConditions->None] = EulerGamma + Log[x]-Divide[(x)^(2),(2)! * 2]+Divide[(x)^(4),(4)! * 4]- \[Ellipsis]
  • Ci[x] = EulerGamma + Log[x]+ Sum[Divide[(- 1)^(n)* (x)^(2*n),2*n*(2*n)!], {n, 1, Infinity}, GenerateConditions->None]
  • EulerGamma + Log[x]+ Sum[Divide[(- 1)^(n)* (x)^(2*n),2*n*(2*n)!], {n, 1, Infinity}, GenerateConditions->None] = EulerGamma + Log[x]-Divide[(x)^(2),(2)! * 2]+Divide[(x)^(4),(4)! * 4]+ \[Ellipsis]

Free variables

  • x

Symbol info

  • was translated to: *
  • Was interpreted as a function call because of a leading \operatorname.
  • was translated to: \[MinusPlus]
  • Euler-Mascheroni constant was translated to: EulerGamma
  • Natural logarithm; Example: \ln@@{z}

Will be translated to: Log[$0] Constraints: z != 0 Branch Cuts: (-\infty, 0] Relevant links to definitions: DLMF: http://dlmf.nist.gov/4.2#E2 Mathematica: https://reference.wolfram.com/language/ref/Log.html

Tests

Symbolic

Test expression: (Ci[x])-(EulerGamma + Log[x]+ Sum[Divide[(- 1)^(n)* (x)^(2*n),2*n*(2*n)!], {n, 1, Infinity}, GenerateConditions->None])

ERROR:

{
    "result": "ERROR",
    "testTitle": "Simple",
    "testExpression": null,
    "resultExpression": null,
    "wasAborted": false,
    "conditionallySuccessful": false
}

Test expression: (EulerGamma + Log[x]+ Sum[Divide[(- 1)^(n)* (x)^(2*n),2*n*(2*n)!], {n, 1, Infinity}, GenerateConditions->None])-(EulerGamma + Log[x]-Divide[(x)^(2),(2)! * 2]+Divide[(x)^(4),(4)! * 4]- \[Ellipsis])

ERROR:

{
    "result": "ERROR",
    "testTitle": "Simple",
    "testExpression": null,
    "resultExpression": null,
    "wasAborted": false,
    "conditionallySuccessful": false
}

Test expression: (Ci[x])-(EulerGamma + Log[x]+ Sum[Divide[(- 1)^(n)* (x)^(2*n),2*n*(2*n)!], {n, 1, Infinity}, GenerateConditions->None])

ERROR:

{
    "result": "ERROR",
    "testTitle": "Simple",
    "testExpression": null,
    "resultExpression": null,
    "wasAborted": false,
    "conditionallySuccessful": false
}

Test expression: (EulerGamma + Log[x]+ Sum[Divide[(- 1)^(n)* (x)^(2*n),2*n*(2*n)!], {n, 1, Infinity}, GenerateConditions->None])-(EulerGamma + Log[x]-Divide[(x)^(2),(2)! * 2]+Divide[(x)^(4),(4)! * 4]+ \[Ellipsis])

ERROR:

{
    "result": "ERROR",
    "testTitle": "Simple",
    "testExpression": null,
    "resultExpression": null,
    "wasAborted": false,
    "conditionallySuccessful": false
}
Numeric

SymPy

Translation:

Information

Symbol info

  • (LaTeX -> SymPy) An unknown or missing element occurred: Cannot translate operation \mp

Tests

Symbolic
Numeric

Maple

Translation: Ci(x) = gamma + ln(x)+ sum(((- 1)^(n)* (x)^(2*n))/(2*n*factorial(2*n)), n = 1..infinity) = gamma + ln(x)-((x)^(2))/(factorial(2) * 2)+((x)^(4))/(factorial(4) * 4) &-+ ..

Information

Sub Equations

  • Ci(x) = gamma + ln(x)+ sum(((- 1)^(n)* (x)^(2*n))/(2*n*factorial(2*n)), n = 1..infinity)
  • gamma + ln(x)+ sum(((- 1)^(n)* (x)^(2*n))/(2*n*factorial(2*n)), n = 1..infinity) = gamma + ln(x)-((x)^(2))/(factorial(2) * 2)+((x)^(4))/(factorial(4) * 4)- ..
  • Ci(x) = gamma + ln(x)+ sum(((- 1)^(n)* (x)^(2*n))/(2*n*factorial(2*n)), n = 1..infinity)
  • gamma + ln(x)+ sum(((- 1)^(n)* (x)^(2*n))/(2*n*factorial(2*n)), n = 1..infinity) = gamma + ln(x)-((x)^(2))/(factorial(2) * 2)+((x)^(4))/(factorial(4) * 4)+ ..

Free variables

  • x

Symbol info

  • was translated to: *
  • Was interpreted as a function call because of a leading \operatorname.
  • was translated to: &-+
  • Euler-Mascheroni constant was translated to: gamma
  • Natural logarithm; Example: \ln@@{z}

Will be translated to: ln($0) Constraints: z != 0 Branch Cuts: (-\infty, 0] Relevant links to definitions: DLMF: http://dlmf.nist.gov/4.2#E2 Maple: https://www.maplesoft.com/support/help/maple/view.aspx?path=ln

Tests

Symbolic
Numeric

Dependency Graph Information

Includes

Description

  • series
  • many term for high precision

Complete translation information:

{
  "id" : "FORMULA_9f24d93fe07cf7b15d34189dc282155b",
  "formula" : "\\operatorname{Ci}(x)= \\gamma+\\ln x+\\sum_{n=1}^{\\infty}\\frac{(-1)^{n}x^{2n}}{2n(2n)!}=\\gamma+\\ln x-\\frac{x^2}{2!\\cdot2}+\\frac{x^4}{4! \\cdot4}\\mp\\cdots",
  "semanticFormula" : "\\operatorname{Ci}(x) = \\EulerConstant + \\ln x + \\sum_{n=1}^{\\infty} \\frac{(-1)^{n}x^{2n}}{2n(2n)!} = \\EulerConstant + \\ln x - \\frac{x^2}{2!\\cdot2} + \\frac{x^4}{4! \\cdot4} \\mp \\cdots",
  "confidence" : 0.0,
  "translations" : {
    "Mathematica" : {
      "translation" : "Ci[x] == EulerGamma + Log[x]+ Sum[Divide[(- 1)^(n)* (x)^(2*n),2*n*(2*n)!], {n, 1, Infinity}, GenerateConditions->None] == EulerGamma + Log[x]-Divide[(x)^(2),(2)! * 2]+Divide[(x)^(4),(4)! * 4] \\[MinusPlus] \\[Ellipsis]",
      "translationInformation" : {
        "subEquations" : [ "Ci[x] = EulerGamma + Log[x]+ Sum[Divide[(- 1)^(n)* (x)^(2*n),2*n*(2*n)!], {n, 1, Infinity}, GenerateConditions->None]", "EulerGamma + Log[x]+ Sum[Divide[(- 1)^(n)* (x)^(2*n),2*n*(2*n)!], {n, 1, Infinity}, GenerateConditions->None] = EulerGamma + Log[x]-Divide[(x)^(2),(2)! * 2]+Divide[(x)^(4),(4)! * 4]- \\[Ellipsis]", "Ci[x] = EulerGamma + Log[x]+ Sum[Divide[(- 1)^(n)* (x)^(2*n),2*n*(2*n)!], {n, 1, Infinity}, GenerateConditions->None]", "EulerGamma + Log[x]+ Sum[Divide[(- 1)^(n)* (x)^(2*n),2*n*(2*n)!], {n, 1, Infinity}, GenerateConditions->None] = EulerGamma + Log[x]-Divide[(x)^(2),(2)! * 2]+Divide[(x)^(4),(4)! * 4]+ \\[Ellipsis]" ],
        "freeVariables" : [ "x" ],
        "tokenTranslations" : {
          "\\cdot" : "was translated to: *",
          "Ci" : "Was interpreted as a function call because of a leading \\operatorname.",
          "\\mp" : "was translated to: \\[MinusPlus]",
          "\\EulerConstant" : "Euler-Mascheroni constant was translated to: EulerGamma",
          "\\ln" : "Natural logarithm; Example: \\ln@@{z}\nWill be translated to: Log[$0]\nConstraints: z != 0\nBranch Cuts: (-\\infty, 0]\nRelevant links to definitions:\nDLMF:         http://dlmf.nist.gov/4.2#E2\nMathematica:  https://reference.wolfram.com/language/ref/Log.html"
        }
      },
      "numericResults" : {
        "overallResult" : "SKIPPED",
        "numberOfTests" : 0,
        "numberOfFailedTests" : 0,
        "numberOfSuccessfulTests" : 0,
        "numberOfSkippedTests" : 0,
        "numberOfErrorTests" : 0,
        "wasAborted" : false,
        "crashed" : false,
        "testCalculationsGroups" : [ ]
      },
      "symbolicResults" : {
        "overallResult" : "ERROR",
        "numberOfTests" : 4,
        "numberOfFailedTests" : 0,
        "numberOfSuccessfulTests" : 0,
        "numberOfSkippedTests" : 0,
        "numberOfErrorTests" : 4,
        "crashed" : false,
        "testCalculationsGroup" : [ {
          "lhs" : "Ci[x]",
          "rhs" : "EulerGamma + Log[x]+ Sum[Divide[(- 1)^(n)* (x)^(2*n),2*n*(2*n)!], {n, 1, Infinity}, GenerateConditions->None]",
          "testExpression" : "(Ci[x])-(EulerGamma + Log[x]+ Sum[Divide[(- 1)^(n)* (x)^(2*n),2*n*(2*n)!], {n, 1, Infinity}, GenerateConditions->None])",
          "testCalculations" : [ {
            "result" : "ERROR",
            "testTitle" : "Simple",
            "testExpression" : null,
            "resultExpression" : null,
            "wasAborted" : false,
            "conditionallySuccessful" : false
          } ]
        }, {
          "lhs" : "EulerGamma + Log[x]+ Sum[Divide[(- 1)^(n)* (x)^(2*n),2*n*(2*n)!], {n, 1, Infinity}, GenerateConditions->None]",
          "rhs" : "EulerGamma + Log[x]-Divide[(x)^(2),(2)! * 2]+Divide[(x)^(4),(4)! * 4]- \\[Ellipsis]",
          "testExpression" : "(EulerGamma + Log[x]+ Sum[Divide[(- 1)^(n)* (x)^(2*n),2*n*(2*n)!], {n, 1, Infinity}, GenerateConditions->None])-(EulerGamma + Log[x]-Divide[(x)^(2),(2)! * 2]+Divide[(x)^(4),(4)! * 4]- \\[Ellipsis])",
          "testCalculations" : [ {
            "result" : "ERROR",
            "testTitle" : "Simple",
            "testExpression" : null,
            "resultExpression" : null,
            "wasAborted" : false,
            "conditionallySuccessful" : false
          } ]
        }, {
          "lhs" : "Ci[x]",
          "rhs" : "EulerGamma + Log[x]+ Sum[Divide[(- 1)^(n)* (x)^(2*n),2*n*(2*n)!], {n, 1, Infinity}, GenerateConditions->None]",
          "testExpression" : "(Ci[x])-(EulerGamma + Log[x]+ Sum[Divide[(- 1)^(n)* (x)^(2*n),2*n*(2*n)!], {n, 1, Infinity}, GenerateConditions->None])",
          "testCalculations" : [ {
            "result" : "ERROR",
            "testTitle" : "Simple",
            "testExpression" : null,
            "resultExpression" : null,
            "wasAborted" : false,
            "conditionallySuccessful" : false
          } ]
        }, {
          "lhs" : "EulerGamma + Log[x]+ Sum[Divide[(- 1)^(n)* (x)^(2*n),2*n*(2*n)!], {n, 1, Infinity}, GenerateConditions->None]",
          "rhs" : "EulerGamma + Log[x]-Divide[(x)^(2),(2)! * 2]+Divide[(x)^(4),(4)! * 4]+ \\[Ellipsis]",
          "testExpression" : "(EulerGamma + Log[x]+ Sum[Divide[(- 1)^(n)* (x)^(2*n),2*n*(2*n)!], {n, 1, Infinity}, GenerateConditions->None])-(EulerGamma + Log[x]-Divide[(x)^(2),(2)! * 2]+Divide[(x)^(4),(4)! * 4]+ \\[Ellipsis])",
          "testCalculations" : [ {
            "result" : "ERROR",
            "testTitle" : "Simple",
            "testExpression" : null,
            "resultExpression" : null,
            "wasAborted" : false,
            "conditionallySuccessful" : false
          } ]
        } ]
      }
    },
    "SymPy" : {
      "translation" : "",
      "translationInformation" : {
        "tokenTranslations" : {
          "Error" : "(LaTeX -> SymPy) An unknown or missing element occurred: Cannot translate operation \\mp"
        }
      }
    },
    "Maple" : {
      "translation" : "Ci(x) = gamma + ln(x)+ sum(((- 1)^(n)* (x)^(2*n))/(2*n*factorial(2*n)), n = 1..infinity) = gamma + ln(x)-((x)^(2))/(factorial(2) * 2)+((x)^(4))/(factorial(4) * 4)  &-+ ..",
      "translationInformation" : {
        "subEquations" : [ "Ci(x) = gamma + ln(x)+ sum(((- 1)^(n)* (x)^(2*n))/(2*n*factorial(2*n)), n = 1..infinity)", "gamma + ln(x)+ sum(((- 1)^(n)* (x)^(2*n))/(2*n*factorial(2*n)), n = 1..infinity) = gamma + ln(x)-((x)^(2))/(factorial(2) * 2)+((x)^(4))/(factorial(4) * 4)- ..", "Ci(x) = gamma + ln(x)+ sum(((- 1)^(n)* (x)^(2*n))/(2*n*factorial(2*n)), n = 1..infinity)", "gamma + ln(x)+ sum(((- 1)^(n)* (x)^(2*n))/(2*n*factorial(2*n)), n = 1..infinity) = gamma + ln(x)-((x)^(2))/(factorial(2) * 2)+((x)^(4))/(factorial(4) * 4)+ .." ],
        "freeVariables" : [ "x" ],
        "tokenTranslations" : {
          "\\cdot" : "was translated to: *",
          "Ci" : "Was interpreted as a function call because of a leading \\operatorname.",
          "\\mp" : "was translated to:  &-+ ",
          "\\EulerConstant" : "Euler-Mascheroni constant was translated to: gamma",
          "\\ln" : "Natural logarithm; Example: \\ln@@{z}\nWill be translated to: ln($0)\nConstraints: z != 0\nBranch Cuts: (-\\infty, 0]\nRelevant links to definitions:\nDLMF:  http://dlmf.nist.gov/4.2#E2\nMaple: https://www.maplesoft.com/support/help/maple/view.aspx?path=ln"
        }
      }
    }
  },
  "positions" : [ {
    "section" : 9,
    "sentence" : 0,
    "word" : 1
  } ],
  "includes" : [ "Ci", "\\gamma", "Ci(x)", "x" ],
  "isPartOf" : [ ],
  "definiens" : [ {
    "definition" : "series",
    "score" : 0.8869384888466118
  }, {
    "definition" : "many term for high precision",
    "score" : 0.5816270233429564
  } ]
}

Specify your own input