This repository builds upon the concept of the Tufte-themed Jekyll site, which you can explore here. By integrating JSXGraph, Q.js,quantastica circuit simulator, and Quirk, it introduces a remarkable dimension to visualizing intricate mathematical concepts. Moreover, Ruby plugins have been developed, enabling the creation of Markdown content enriched with Latex-like elements, thereby enhancing the overall appearance of the content.
Before running the steps below, make sure you have ruby/gem and jekyll ready.
cd path/to/code
jekyll build
jekyll serve -w
And voila, a self-host website is up and running at localhost:4000
.
If you want to deploy the blog as Github Pages, please follow the instructions here to
The information in this section explains how to make a customized copy of this project.
_sass/_settings.scss
file if you want to customize base styles._data/social.yml
file to put in your own information for the footer links_includes/header.html
and _includes/footer.html
for header and footer formatsWe provide two ways of displaying comments: uteranc.es or giscus. Uteranc makes comments as github issues while giscus reports all comments in repo discussion. giscus supports insertion of MathJAX expression and online image, but uteranc loads more quickly. If you want to use uteranc, please replace repo
attribute with your own repository name in the following element that you can find at _layouts/post.html
:
<script src="https://utteranc.es/client.js"
repo="[GITHUB-USERNAME/REPO-NAME]"
issue-term="pathname"
label="comment"
theme="github-light"
crossorigin="anonymous"
async>
</script>
To use giscus, please replace the script
element above with generated element configured directly on the website here.
Blogs are markdown files stored at _posts
folder with their names formatted as year-mm-dd-post-name.md
. Each markdown file starts with a head that specifies its name, date, layout type, and tags. An example of such head is shown below. Notice how the information starts and ends with ---
and each tag has words separated by -
.
---
layout: post
title: "Your awesome blog title"
date: 2023-08-22 11:35:00
categories: post
tags: [quantum-mechanics, quantum-algorithms]
---
*THE EXCERPT OF YOUR ARTICLE GOES HERE*<!--more-->
Your main content starts here.
It is recommended to create an excerpt before the main content of your blog article. The example above shows that your excerpt should ALWAYS ends with <!--more-->
. The content before the symbol will be shown on the main list of articles.
|
in your MathJax expression. If you find a paragraph formulated like a table near a math expression, you should consider remove |
in the expression.Q.js
does NOT support gates that apply to more than two qubits, and SWAP
gate is also not implemented correctly. See the issure here."
to wrap arguments to the ruby classes introduced below if your arguments contain "'
".\\\\
when creating multi-line equation using eqn
class introduced below.You can take a look at the posts created recently in the _post
folder to learn how to use the classes introduced here. The general principles are:
<ref>
) and mathjax expressions($$
)\label
finds its counterpart in HTML with the id
attribute of the <div>
element here.If you're using VS code as your post editor, then just install the Markdown All in One
extension to generate a list of links to sections in your post. the settings in tufte.css
will convert the list into a fullwidth
formulated table of contents, with subsections indented.
To add a new equation with a numbered tag(automatically ordered), you can do the following
{%eqn 'a+b=1' 'dumb-id'%}
which will create a div
element that wraps the equation. Note that if the last argument is omitted, the id
of <div>
is automatically set as eqn-x
, in which x
is a post-wise count of equation rendering.
So far we only support three rendering types: static img
, dynamic jsx
graph, Q.js
quantum circuit diagram qc
, and circuit svg image qcsvg
. For each rendering type you can set the figure type as fullwidth
or marginnote
. Like the display equation, defining image id is not required but it is recommended to give your images meaningful IDs. Here image ID is defined by default as fig-x
. Finally, you're required to define its caption.
To show a static image, please use the following two commands in your markdown:
<!-- fullwidth image -->
{%fig `img` `fullwidth` `url/to/your/img` `dumb figure caption` `dumb-fig-id`%}
<!-- margin image -->
{%fig `img` `url/to/your/img` `dumb figure caption` `dumb-fig-id`%}
<!-- margin image with automatic id definition -->
{%fig `img` `url/to/your/img` `dumb figure caption`%}
If you need to add a mathematical graph, then please follow the conventions below:
<!-- fullwidth graph -->
{%fig `jsx` `fullwidth` `caption text` `dumb-fig-id`%}
<script>
// your js code here
</script>
<!-- margin square graph -->
{%fig `jsx` `caption text` `dumb-fig-id`%}
<script>
// your js code here
</script>
<!-- margin square graph with automatic id definition -->
{%fig `jsx` `caption text`%}
<script>
// your js code here
</script>
Each jsx
graph is paired with a script
element, in which you draw graphic elements through javascript coding. As a starter, your jsx
graph script should initialize canvas by referring the correct figure id. The code snippet below gives you an example of how to make sure the line you draw is visualized in the figure with its id being dumb-fig-id
.
JXG.Options.text.useMathJax = true;
const board = JXG.JSXGraph.initBoard("dumb-fig-id", {
boundingbox: [-0.5, 1.5, 1.5, -0.5],
keepaspectratio: true,
axis:true
});
board.create('line', [[1,0.8],[1.4,0.8]],
{color:'red',straightFirst:false, straightLast:false});
When you have multiple jsx
graphs in one post, it is required to assign returned values of JXG.JSXGraph.initBoard
to const
variables of distinct names.
For quantum circuits, we only provide one figure type: fullwidth circuit diagram with its title and probability distribution in a marginnote. To show preformatted diagram, you can use the following syntax:
{%fig 'qc' 'circuit caption' 'no_palette' 'qc-dumb-id'%}
<script>
qc=Q`
I H I
`
eval_draw(qc,'qc-dumb-id',use_palette=false)
</script>
The example <script>
above defines a simple circuit using the string of
qc=Q`
I H I
`
which has one qubit(one row) to which a identity gate, a Hadamard, and another idensity gate are applied. The last command in <script>
above tells Q.js to draw diagram in a <div>
with its ID being qc-dumb-id
. Also, it turns down the interactive palette. The palette is a simple web-GUI for you to change circuit cnfiguration. And change made in the circuit will modify its probability distribution, which is updated right below the circuit caption in real time. You can turn on the palette using the syntax below:
{%fig 'qc' 'circuit caption' 'palette' 'qc-dumb-id'%}
<script>
qc=Q`
I H I
`
eval_draw(qc,'qc-dumb-id',use_palette=true)
</script>
Notice how the no_palette
argument is replaced with the palette
above.
The last rendering type is qcsvg
, for which we prepare the following format to draw SVG images:
{%fig `qcsvg` 'caption' 'fig-id'%}
<script>
// your code here
</script>
Please explore quantatica
's github repo for how to create quantum circuit.
For big fans of Latex, the lack of references in MD documents is unfortunate. Here we provide a simple solution by adding <ref/>
flags at the places where you need to refer to figures or equations. However, please Do NOT use the flag at the beginning of a paragraph. It will breaks the format. To refer to a figure, please use
<ref fig='dumb-fig-id'/>
which create a link to the figure with its ID being dumb-fig-id
. Both jsx
graphs and img
pictures can be referred this way. To refer to an equation, simply use the following.
<ref eqn='dumb-eqn-id'/>
Note that this only supports the equations created by the eqn
plugin introduced above.
Perhaps the most unique feature of the Tufte style is its sidenotes and marginnotes. The only difference between the two is that sidenote
is preceded by numbered index while marginnote
has no index. We simplified the original implementation, and provides the following ways to create sidenotes and marginnotes:
<!-- sidenote -->
{%sidenote 'note content' %}
<!-- marginnode -->
{%marginnote 'note content'%}
To create indices to keywords in the main content, you need to
## Index
, the text must be exactly the same;***keyword***
.The createIndex
function in Q/Q-utils.js
will then generate a table within which keywords are sorted alphabetically. Each entry in the table is a link to the place where corresponding keyword first appears, and you can use these links later in other posts.