latexifier


Namelatexifier JSON
Version 1.0.7 PyPI version JSON
download
home_pagehttps://github.com/Guillaume-Garrigos/latexify
SummaryA package to convert python objects into latex strings
upload_time2021-02-26 10:00:06
maintainer
docs_urlNone
authorGuillaume Garrigos
requires_python>=3.7
licenseMIT
keywords
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # latexify

Install with `pip install latexifier`

Use with `from latexifier import latexify`

This module aims to turn python objects into latex strings. For instance:

- Integers: `latexify(20)` returns `"20"`
- Python Fractions: `latexify(Fraction(1,3))` returns `"\frac{1}{3}"`
- Approximate Fractions: `latexify(0.25)` returns `"\frac{1}{4}"`
- Approximate combination of radicals: `latexify(0.5 - 3 * numpy.sqrt(5), numbertype='algebraic')` returns `"\frac{1}{2} - 3\sqrt{5}"`
- Complex numbers: `latexify(2 + 3.5j)` returns `"2+\frac{7}{2}i"`
- numpy.arrays: `latexify(numpy.eye(2))` returns `"\begin{pmatrix} 1&0\\0&1 \end{pmatrix}"` 
- tuples: `latexify((1,2,3))` returns `"\left(1,2,3\right)"`
- lists: `latexify([1,2,3])` returns `"1,2,3"`
- sympy polynomials: `latexify(x**2 - y*z/3)` returns `"x^2 - \frac{yz}{3}"`
- All those objects can be combined and nested: list of arrays, arrays of polynomials, etc.

When given integer-based values (such as Integers or Fractions), `latexify` returns a string without any ambiguity. 
When given a float, `latexify` tries to approximate this float by means of fractions and radicals. To do so, the search is limited to "small" fractions and "small" radicals. What "small" means can be specified with some parameters (see below).

### Options

The behavior of latexify can be changed on-the-fly by passing arguments to the function, like `latexify(0.25, parameter_name=parameter_value)`, or can be set once-for-all with the function `latexifier.parameters(parameter_name=parameter_value)`. Here are is a list of such parameters:

| parameter_name | default value | purpose |
| -------------- | :-: | ------- |
| style_fraction | 'frac'  | Sets how fraction should be displayed. Given `0.5`, the option 'frac' returns `\frac{1}{2}`. The option 'dfrac' returns `\dfrac{1}{2}`. The option 'inline' returns `1/2`. |
| newline | False | Some Latex expressions usually contain newlines (for arrays for instance). By default latexify returns a string with no such newlines, but you can turn it on. | 
| arraytype | 'pmatrix' | np.arrays can be converted in many latex flavours, of the form `\begin{arraytype} ... \end{arraytype}` |
| mathmode | 'raw' | latexify returns by default the latex expression of a number or a matrix, etc. If you want to display it correctly in a document, this string must be placed in a math environment. You can optionally ask latexify to do it for you. With the option 'inline', the expression is returned in between `$ $`. With the option 'equation'  the expression is returned inside a `equation*` environment. With the option 'display' the expression is returned in between `\[ ... \]`. |
| denominator_max | 10           | Maximal denominator allowed to appear in fractions (in absolute value) |
| numbertype | 'rational' | Controls which kind of number you expect to have. By default latexify looks only for formal expression of rationals. With the option 'root' it will look for a rational multiplied with the square root of some integer (see `root_max` below). With the option 'algebraic' it will look for a rational linear combination of square roots. Be careful though, these two options are more time consuming. |
| root_max | 7 | The expression can contain sqrt(n) to show up, with n no greater than root_max |
| tol | 1e-12 | Any formal expression must satisfy \vert x_{formal} - x_{float} \vert < tol. If not, the float is rounded.  |
| frmt | '{:3.6f}' | When no formal expression can be found, the floats will be rounded. This parameters specifies which rounding/formating rules must be applied (this is a [pythonic](https://pyformat.info/) syntax). |
            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/Guillaume-Garrigos/latexify",
    "name": "latexifier",
    "maintainer": "",
    "docs_url": null,
    "requires_python": ">=3.7",
    "maintainer_email": "",
    "keywords": "",
    "author": "Guillaume Garrigos",
    "author_email": "guillaume.garrigos@lpsm.paris",
    "download_url": "https://files.pythonhosted.org/packages/ad/bb/dc7a37e1eb61b9e6aa50804aad7fd572e7e254f1f3f1b01b0d164f46b2ab/latexifier-1.0.7.tar.gz",
    "platform": "",
    "description": "# latexify\n\nInstall with `pip install latexifier`\n\nUse with `from latexifier import latexify`\n\nThis module aims to turn python objects into latex strings. For instance:\n\n- Integers: `latexify(20)` returns `\"20\"`\n- Python Fractions: `latexify(Fraction(1,3))` returns `\"\\frac{1}{3}\"`\n- Approximate Fractions: `latexify(0.25)` returns `\"\\frac{1}{4}\"`\n- Approximate combination of radicals: `latexify(0.5 - 3 * numpy.sqrt(5), numbertype='algebraic')` returns `\"\\frac{1}{2} - 3\\sqrt{5}\"`\n- Complex numbers: `latexify(2 + 3.5j)` returns `\"2+\\frac{7}{2}i\"`\n- numpy.arrays: `latexify(numpy.eye(2))` returns `\"\\begin{pmatrix} 1&0\\\\0&1 \\end{pmatrix}\"` \n- tuples: `latexify((1,2,3))` returns `\"\\left(1,2,3\\right)\"`\n- lists: `latexify([1,2,3])` returns `\"1,2,3\"`\n- sympy polynomials: `latexify(x**2 - y*z/3)` returns `\"x^2 - \\frac{yz}{3}\"`\n- All those objects can be combined and nested: list of arrays, arrays of polynomials, etc.\n\nWhen given integer-based values (such as Integers or Fractions), `latexify` returns a string without any ambiguity. \nWhen given a float, `latexify` tries to approximate this float by means of fractions and radicals. To do so, the search is limited to \"small\" fractions and \"small\" radicals. What \"small\" means can be specified with some parameters (see below).\n\n### Options\n\nThe behavior of latexify can be changed on-the-fly by passing arguments to the function, like `latexify(0.25, parameter_name=parameter_value)`, or can be set once-for-all with the function `latexifier.parameters(parameter_name=parameter_value)`. Here are is a list of such parameters:\n\n| parameter_name | default value | purpose |\n| -------------- | :-: | ------- |\n| style_fraction | 'frac'  | Sets how fraction should be displayed. Given `0.5`, the option 'frac' returns `\\frac{1}{2}`. The option 'dfrac' returns `\\dfrac{1}{2}`. The option 'inline' returns `1/2`. |\n| newline | False | Some Latex expressions usually contain newlines (for arrays for instance). By default latexify returns a string with no such newlines, but you can turn it on. | \n| arraytype | 'pmatrix' | np.arrays can be converted in many latex flavours, of the form `\\begin{arraytype} ... \\end{arraytype}` |\n| mathmode | 'raw' | latexify returns by default the latex expression of a number or a matrix, etc. If you want to display it correctly in a document, this string must be placed in a math environment. You can optionally ask latexify to do it for you. With the option 'inline', the expression is returned in between `$ $`. With the option 'equation'  the expression is returned inside a `equation*` environment. With the option 'display' the expression is returned in between `\\[ ... \\]`. |\n| denominator_max | 10           | Maximal denominator allowed to appear in fractions (in absolute value) |\n| numbertype | 'rational' | Controls which kind of number you expect to have. By default latexify looks only for formal expression of rationals. With the option 'root' it will look for a rational multiplied with the square root of some integer (see `root_max` below). With the option 'algebraic' it will look for a rational linear combination of square roots. Be careful though, these two options are more time consuming. |\n| root_max | 7 | The expression can contain sqrt(n) to show up, with n no greater than root_max |\n| tol | 1e-12 | Any formal expression must satisfy \\vert x_{formal} - x_{float} \\vert < tol. If not, the float is rounded.  |\n| frmt | '{:3.6f}' | When no formal expression can be found, the floats will be rounded. This parameters specifies which rounding/formating rules must be applied (this is a [pythonic](https://pyformat.info/) syntax). |",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "A package to convert python objects into latex strings",
    "version": "1.0.7",
    "split_keywords": [],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "md5": "1e6d13fdbc0361ff88ee996748a720cc",
                "sha256": "ac1e3ecf7d7c30b501e293fdc0cffaae91807482ea381b07482f18af6bfca228"
            },
            "downloads": -1,
            "filename": "latexifier-1.0.7-py3.7.egg",
            "has_sig": false,
            "md5_digest": "1e6d13fdbc0361ff88ee996748a720cc",
            "packagetype": "bdist_egg",
            "python_version": "3.7",
            "requires_python": ">=3.7",
            "size": 26548,
            "upload_time": "2021-02-26T10:00:05",
            "upload_time_iso_8601": "2021-02-26T10:00:05.438790Z",
            "url": "https://files.pythonhosted.org/packages/2e/37/06764e3957169124baf0302ec72c470b0f2bf3ca42f626c64c0e36d3ac63/latexifier-1.0.7-py3.7.egg",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "md5": "da645cf088069eebb25f40207466ab73",
                "sha256": "47312fe3f05cb1ccd4d745f224bdf79b193541a0e88b55e747f23663051aaa37"
            },
            "downloads": -1,
            "filename": "latexifier-1.0.7.tar.gz",
            "has_sig": false,
            "md5_digest": "da645cf088069eebb25f40207466ab73",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.7",
            "size": 11497,
            "upload_time": "2021-02-26T10:00:06",
            "upload_time_iso_8601": "2021-02-26T10:00:06.935289Z",
            "url": "https://files.pythonhosted.org/packages/ad/bb/dc7a37e1eb61b9e6aa50804aad7fd572e7e254f1f3f1b01b0d164f46b2ab/latexifier-1.0.7.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2021-02-26 10:00:06",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "github_user": null,
    "github_project": "Guillaume-Garrigos",
    "error": "Could not fetch GitHub repository",
    "lcname": "latexifier"
}
        
Elapsed time: 0.32145s