Weave
Weave is a scientific report generator/literate programming tool for the Julia programming language. It resembles Pweave, knitr, R Markdown, and Sweave.
You can write your documentation and code in input document using Markdown, Noweb or ordinal Julia script syntax,
and then use weave
function to execute code and generate an output document while capturing results and figures.
Current features
- Publish markdown directly to HTML and PDF using Julia or Pandoc
- Execute code as in terminal or in a unit of code chunk
- Capture Plots.jl or Gadfly.jl figures
- Supports various input format: Markdown, Noweb, Jupyter Notebook, and ordinal Julia script
- Conversions between those input formats
- Supports various output document formats: HTML, PDF, GitHub markdown, Jupyter Notebook, MultiMarkdown, Asciidoc and reStructuredText
- Simple caching of results
Citing Weave: Pastell, Matti. 2017. Weave.jl: Scientific Reports Using Julia. The Journal of Open Source Software. http://dx.doi.org/10.21105/joss.00204
Installation
You can install the latest release using Julia package manager:
using Pkg
Pkg.add("Weave")
Usage
using Weave
# add depencies for the example
using Pkg; Pkg.add(["Plots", "DSP"])
filename = normpath(Weave.EXAMPLE_FOLDER, "FIR_design.jmd")
weave(filename, out_path = :pwd)
If you have LaTeX installed you can also weave directly to pdf.
filename = normpath(Weave.EXAMPLE_FOLDER, "FIR_design.jmd")
weave(filename, out_path = :pwd, doctype = "md2pdf")
NOTE: Weave.EXAMPLE_FOLDER
just points to examples
directory.
Documentation
Documenter.jl with MKDocs generated documentation:
Editor support
Install language-weave to add Weave support to Juno. It allows running code from Weave documents with usual keybindings and allows preview of html and pdf output.
The Julia extension for Visual Studio Code adds Weave support to Visual Studio Code.
Contributing
You can contribute to this package by opening issues on GitHub or implementing things yourself and making a pull request. We'd also appreciate more example documents written using Weave.
Contributors
You can see the list of contributors on GitHub: https://github.com/JunoLab/Weave.jl/graphs/contributors . Thanks for the important additions, fixes and comments.
Example projects using Weave
- DiffEqTutorials.jl uses Weave to output tutorials (
.jmd
documents) to html, pdf and Jupyter notebooks. - TuringTutorials uses Weave to convert notebooks to html.
Related packages
- Literate.jl can be used to generate Markdown and Jupyter notebooks directly from Julia source files with markdown in comments.