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

Latex in a plotly figure is not rendered #369

Closed
Midnighter opened this issue Dec 30, 2019 · 11 comments
Closed

Latex in a plotly figure is not rendered #369

Midnighter opened this issue Dec 30, 2019 · 11 comments

Comments

@Midnighter
Copy link

I'm working on a project that includes some notebooks in the documentation. We have both plots created with matplotlib and plotly in those. The axis titles of those plots contain latex in order to render units nicely. At the moment the matplotlib ones render properly whereas the plotly latex is not rendered in the documentation. Both render perfectly fine when used interactively.

You can reproduce this issue by checking out the corresponding branch installing the dependencies and generating the documentation.

I'm currently using the following versions:

nbsphinx==0.5.0
Sphinx==2.3.1
@mgeier
Copy link
Member

mgeier commented Dec 30, 2019

Can you please point me to an example of those axis titles?

@Midnighter
Copy link
Author

Once you have built the docs you can find an example at: docs/_build/html/example1.html#7.-Plotting-the-results.

@mgeier
Copy link
Member

mgeier commented Dec 30, 2019

BTW, you should use the Matplotlib settings recommended at https://nbsphinx.readthedocs.io/en/latest/code-cells.html#Plots

@mgeier
Copy link
Member

mgeier commented Dec 30, 2019

I don't know what I'm supposed to see there.

Can you please describe what you are expecting to see there and what you are actually seeing?

Probably some screenshots would help clarify?

@Midnighter
Copy link
Author

Midnighter commented Dec 30, 2019

So what I'm expecting is axis titles that look like the following from matplotlib:

matplotlib

What I'm seeing instead with plotly is the raw latex code:

plotly

The latter works fine in an interactive Jupyter notebook but not in the docs.

@mgeier
Copy link
Member

mgeier commented Dec 30, 2019

OK, thanks, with those screenshots your description makes more sense ...

I don't see any of this LaTeX stuff in the axis labels ... are you sure you have pushed all your changes to your branch?

@Midnighter
Copy link
Author

None of that is on readthedocs yet if that is what you mean. Everything is pushed to the branch, though, so if you build it locally you should definitely arrive at the same result.

@mgeier
Copy link
Member

mgeier commented Dec 30, 2019

OK, sorry, I've deleted the cell outputs and re-created them and the LaTeX stuff was gone.

If I use your pre-generated outputs, I see the LaTeX problem ...

@mgeier
Copy link
Member

mgeier commented Dec 30, 2019

In your generated HTML files some MathJax-related stuff seems to be missing.

I would expect the HTML to contain something like this:

    <script async="async" src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/latest.js?config=TeX-AMS-MML_HTMLorMML"></script>
    <script type="text/x-mathjax-config">MathJax.Hub.Config({"tex2jax": {"inlineMath": [["$", "$"], ["\\(", "\\)"]], "processEscapes": true, "ignoreClass": "document", "processClass": "math|output_area"}})</script>

The first tag is normally added by Sphinx when sphinx.ext.mathjax is used.

The second tag is normally added by nbsphinx, see

nbsphinx/src/nbsphinx.py

Lines 1825 to 1835 in 7a6d64f

# Work-around until https://github.com/sphinx-doc/sphinx/pull/5504 is done:
mathjax_config = app.config._raw_config.setdefault('mathjax_config', {})
mathjax_config.setdefault(
'tex2jax',
{
'inlineMath': [['$', '$'], ['\\(', '\\)']],
'processEscapes': True,
'ignoreClass': 'document',
'processClass': 'math|output_area',
}
)

I had no clue why those are missing in your case ... but then it dawned on me:

Sphinx has this feature where MathJax is only loaded if at least one equation is used on some page.
Since you apparently are not using any equations (that Sphinx is aware of), it is not loaded!

The solution is to add some equation somewhere and everything works!

Maybe there is another way to get Sphinx to load MathJax ... I don't know. You could ask the Sphinx folks.

@Midnighter
Copy link
Author

Indeed, that fixes it! Thank you very much. I will see what I can find out about always including mathjax.

@mgeier
Copy link
Member

mgeier commented Apr 5, 2021

Maybe there is another way to get Sphinx to load MathJax ... I don't know.

Now I know: #551.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants