4372
Comment:
|
4708
|
Deletions are marked like this. | Additions are marked like this. |
Line 22: | Line 22: |
1. HTML for in-browser previewing | |
Line 26: | Line 25: |
== Examples == 1. A short sample article: [[http://buzzard.ups.edu/mathbook/calculus-article.html|XML Source-Author Format]] [[http://buzzard.ups.edu/mathbook/calculus-article.html|HTML Output]] [[http://buzzard.ups.edu/mathbook/calculus-article.pdf|PDF Output]] 1. A skeletal mock book: [[http://buzzard.ups.edu/mathbook/graph-theory-book.html|XML Source-Author Format]] [[http://buzzard.ups.edu/mathbook/graph-theory-book.html|HTML Output]] [[http://buzzard.ups.edu/mathbook/graph-theory-book.pdf|PDF Output]] |
|
Line 33: | Line 37: |
== Commentary == High-level commentary is recorded on my [[http://www.beezers.org/blog/bb|blog]]. == Implemented Features == * Article structure with numbered sections and subsections * Book structure with numbered chapters, sections and subsections * Mathematics: normal LaTeX for PDF, !MathJax in HTML, macros in source '''only once''' * Numbered theorems and definitions (needs work, subject to changes) * Sage input/output: live Sage cells in HTML, styled in LaTeX * Bibliography + citations: as knowls in HTML version * Basic CSS for HTML version |
|
Line 36: | Line 54: |
Updated: June 25, 2013 | Updated: June 29, 2013 |
Line 38: | Line 56: |
(Use your browser to save these files locally, do not simply click on them) | HTML output: !MathJax does the math, Sage Cell Server does the code, knowls do the citations. Use the following command and files below to create (X)HTML output and view in your browser by opening the output file. {{{ xsltproc mathbook-html.xsl calculus-article.xml > calculus-article.html }}} |
Line 40: | Line 61: |
1. [[http://buzzard.ups.edu/mathbook/calculus-article.xml|Example XML source document]] 1. [[http://buzzard.ups.edu/mathbook/article-latex.xsl|XSL transform to LaTeX]] 1. [[http://buzzard.ups.edu/mathbook/article-html.xsl|XSL transform to XHTML]] 1. [[http://buzzard.ups.edu/mathbook/freebsd-docbook.css|FreeBSD documentation CSS]] 1. [[http://buzzard.ups.edu/mathbook/mathbook.css|MathBook CSS]] Easiest: it would be nice if you could view the source file (calculus-article.xml) by opening it in a web browser with the stylesheet (article-html.xsl) in the same directory. This did work on some browsers, and not on others. I've added enough nontrivial features now that this is not working in Firefox. Easy: use the following command to create XHTML output and view in your browser by opening the output file. You might just want to view the [[http://buzzard.ups.edu/mathbook/calculus-article.html|XHTML Output]]. !MathJax does the math, Sage Cell Server does the code, knowls do the citations. |
PDF: Same XML source file. Use a different XSLT file to process. View PDF as you please. Issue the following to produce. |
Line 51: | Line 64: |
xsltproc article-html.xsl calculus-article.xml > calculus-article.html }}} Alternate: issue the following to produce [[http://buzzard.ups.edu/mathbook/calculus-article.pdf|PDF Output]]. Sage cells are being styled now. {{{ xsltproc article-latex.xsl calculus-article.xml > calculus-article.tex |
xsltproc mathbook-latex.xsl calculus-article.xml > calculus-article.tex |
Line 61: | Line 68: |
More: repeat above with the mock book, {{{graph-theory-book.xml}}}, linked above. |
|
Line 63: | Line 72: |
== Features == | Files: Use your browser to save these files locally, do not simply click on them. If you are an author, the only file you need to understand is the first one, the XML source. |
Line 65: | Line 74: |
* Article structure with numbered sections (subsections will be easy) * Numbered theorems * Sage input/output: live Sage cells in HTML, styled in LaTeX * Bibliography + citations: knowls in HTML version * Math: normal LaTeX for PDF, !MathJax in HTML, macros in source '''once''' |
1. [[http://buzzard.ups.edu/mathbook/mathbook-html.xsl|XSL transform to HTML]] 1. [[http://buzzard.ups.edu/mathbook/mathbook-latex.xsl|XSL transform to LaTeX]] |
Line 74: | Line 80: |
* Table of Contents in HTML as sidebar * Definitions |
MathBook: An XML Application
A specification for XML tags and stylesheets to create usable output.
Rob Beezer, [email protected]
Design Goals:
- Simple for authors to use - no more complicated logically than LaTeX
- Capture the structure of writing about mathematics and Sage
- Processing into a variety of formats
- A limited number of rational tags, with simple names
- Minimal use of external shell scripts
- XSLT 1.0 compatible: ideally the only required tool is xsltproc
Output Formats:
HTML web pages, enhanced with MathJax, Sage Cell server, knowls
LaTeX input to create PDFs and print with pdflatex
- Doctesting of Sage code examples
- E-Books, once technically feasible
Maybe a DocBook representation for conversion to other outputs
Examples
A short sample article: XML Source-Author Format HTML Output PDF Output
A skeletal mock book: XML Source-Author Format HTML Output PDF Output
Project Status:
- Funding: Shuttleworth Foundation Flash Grant, National Science Foundation UTMOST Grant
- Late-June 2013: Good basic functionality for HTML, LaTeX output
- Mid-June 2013: initiated, not mature or stable
Commentary
High-level commentary is recorded on my blog.
Implemented Features
- Article structure with numbered sections and subsections
- Book structure with numbered chapters, sections and subsections
Mathematics: normal LaTeX for PDF, MathJax in HTML, macros in source only once
- Numbered theorems and definitions (needs work, subject to changes)
- Sage input/output: live Sage cells in HTML, styled in LaTeX
- Bibliography + citations: as knowls in HTML version
- Basic CSS for HTML version
Files and Examples
Updated: June 29, 2013
HTML output: MathJax does the math, Sage Cell Server does the code, knowls do the citations. Use the following command and files below to create (X)HTML output and view in your browser by opening the output file.
xsltproc mathbook-html.xsl calculus-article.xml > calculus-article.html
PDF: Same XML source file. Use a different XSLT file to process. View PDF as you please. Issue the following to produce.
xsltproc mathbook-latex.xsl calculus-article.xml > calculus-article.tex pdflatex calculus-article.tex
More: repeat above with the mock book, graph-theory-book.xml, linked above.
Advanced: create a Sage Cloud worksheet from the same source. I have this working in the lab. Posted soon.
Files: Use your browser to save these files locally, do not simply click on them. If you are an author, the only file you need to understand is the first one, the XML source.
To Do
- Cross-references
- Table of Contents in HTML as sidebar
- Definitions
- Index for book structure
- Options for numbering sections, theorem-like structures
- Improved CSS for HTML
- Doctesting framework for Sage code
- Sage notebook, Sage Math Cloud output formats
- HTML chunking (one HTML file per section, chapter, etc)
- Customization options (layers, HTML head insertions)
- LaTeX spacing hints
Other Projects
tbook looks very much like what I am imagining. I have hacked a bit of it to work with the xsltproc processor with mixed success. Only 80 elements. But for a very short article, I have found cross-references broken and manufacturing a bibliography begins with BibTeX, so that requires some research (and shell scripts). Maybe some examples later.
DocBook is big, complicated and full of features. But the emphasis is on technical documentation and support for mathematics and academic publishing is very lacking. The extensive structure is intimidating if you just have small project.