13
11

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

Re:VIEW+markdown で数式の入った薄い本を書く

Last updated at Posted at 2016-12-02

軌道エレベータの本をつくる。いろいろと数式を自分でいじって計算する演習本にしようと思う。
TeXを日本語で使うには人類には早すぎる。なのでRe:VIEWでつくる。
けれども頑張ろうと思うと結局TeXをすることになる。なので人類には早すぎる。

初期化

orbitcalcというコードネームで作る。
review-init orbitcalc

雛形

解析概論1943プロジェクトから最初の1ページをコピーしてこれを雛形とする。


#基本的ノ概念
##数ノ概念及ビ四則算法
ハ既知ト彼定スル@<fn>{23-1}.始メノ中ハ實数ノミヲ取扱フカラ
一々断ラナイ.次ノ用語ハ周知デアル.

**自然数.** 1,2,3 等. 物ノ順位又ハ物ノ集合ノ個数ヲ示ス篤ニ用ヰラレル.

**整数.** 0,±1,±2等. 自然数ハ正ノ整数デアル.

**有理数.**0及ビ @<m>{\pm \dfrac {a\\} {b\\}}子,但α,b ハ自然数. b=1ナルトキ,ソレハ整数デアル.

**無理数.**有理数以外ノ責数.例ヘバ

//texequation{
\begin{array}{l}
\sqrt {2}=1.4142135\ldots,\\\
e=2.718281828…,\\\
pi=3.1415926535…
\end{array} 
//}



(但,ソレラガ有理数デナイコトハ護明ヲ要スル)
  十進法.賓数ヲ十進法デ表ハスコトモ周知デアル.有理数ヲ十進法デ表ハセバ,数字
ハ有限カ,又ハ無限ナラバ循環小数ニナル.但,有限位数ノ十進数ヲ循環小数ノ形二表ハス
コトモ出来ル.例ヘバ0.6= 0.5999….無理数ヲ十進法デ表ハスナラバ,無限ノ位数ヲ要
シ,数字ハ決シテ循環シナイ.
  吾々ガ十進法ニヨツテ数ヲ表ハズニ至ツタノハ,手指ノ数ニソノ原因ガアルノデアラ
ウガ,理論上ハ1以外ノ任意ノ自然数ヲ基本トシテ,十進法ト同様ノ方法ニヨツテ,数ヲ表
ハスコトガ出来ル.
  特ニ二進法デハ,数字ハ0ト1トダケデ足ル.有理数ヲ二進法デ表ハセバ,分母ガ2
ノ巾@<fn>{23-2}ニナルモノノ外ハ,循環二進数ニナル.
//texequation{
\left[ 例\right] \dfrac {5} {8}=\dfrac {1} {2}+\dfrac {1} {2^{3}}=\left( \begin{matrix} 0.101\end{matrix} \right)
//}

//footnote[23-1][附録(一)ヲ参照.]
//footnote[23-2][巾ハ羃ノ假字(和算ノ用例ニヨル).]

これを、orbitcalc.mdと名前をつけて保存。

md2review の制限

md2review は内部で redcarpet なるものを呼び出しているようで、それによる制限?

  • リストの入れ子ができない
  • markdownで斜体を指定 ( ないし ) したものがreファイルだと強調 (@{文} ) となる

Re:VIEWフォーマットの制限

  • tex式(//texequation{ 〜 //})に空行が入るとエラーとなる。

このほか、reファイルでは引用ブロック( //quote{ 文 } )の入れ子をするとエラーになるので、二重引用しているmarkdownをmd2reviewして作ったreファイルはエラーが出る。

TeXの機能を使って中央揃えを実現する

//raw[|latex| \begin{center} 中央揃えにしたい文 \end{center} ]
//raw[|latex| \begin{center} ]
**筆頭著者** 共著者 *所属*
//raw[|latex| \end{center} ]

のようにすればいい。しかしながら
//raw の部分がmarkdownビューの時にゴミとして出てくる。なのでここらへんはTeXコンパイル時にフィルターとして活用するなど。

qiitaの場合は以下のようにすると中央揃えとなる。

中央揃え

このようなフォーマットを通すためのフィルタは以下の通り

> ```math
> \left[ 例\right] \dfrac {5} {8}=\dfrac {1} {2}+\dfrac {1}   {2^{3}}=\left( \begin{matrix} 0.101\end{matrix} \right)
> ```

//texequation{
\left[ 例\right] \dfrac {5} {8}=\dfrac {1} {2}+\dfrac {1} {2^{3}}=\left( \begin{matrix} 0.101\end{matrix} \right)
//}

インライン命令`a-$$

$\pm \dfrac {a} {b}$

@<m>{\pm \dfrac {a\\} {b\\}}

画像を縮小するスクリプト

写真や図も入れる。写真や図を、markdownの段階でプレビューしやすい形で作りたい。
通常の書き方

![test](./images/test.png  "" )

だけど、このままだと縮小できない。なのでスクリプトで何とかする。

通常の書き方
![テスト](./images/test.png  "" )
拡張した書き方
[scale=0.5]![テスト](./images/test.png  "" )

↓md2reviewを通す

通常の書き方
//image[test][テスト]{
//}
拡張した書き方
[scale=0.5]//[test][テスト]{
//}

となる。
これを、

通常の書き方
//image[test][テスト]{
//}
拡張した書き方
//image[test][テスト][scale=0.5]{
//}

とするスクリプト。

#!/usr/bin/env ruby
while line = gets
  line.chomp!
  if md1 = line.match(/^\[.*?\]/)
    if md2 = line.match(/\/\/(.+)\]/)
      print md2[0],md1[0],"{\n"
    else
      puts line
    end
  else
    puts line
  end
end

scalemd.rb

#!/usr/bin/env ruby
while line = gets
  line.chomp!
  if md1 = line.match(/^\[.*?\]/)
    if md2 = line.match(/\/\/(.+)\]/)
      print md2[0],md1[0],"{\n"
    else
      puts line
    end
  else
    puts line
  end
end

使い方

md2review orbitcalc.md | ruby scalemd.rb > orbitcalc.re

config.ymlやcover.jpgを入れ替える

cover.jpg は1110x1,840 は2ページ目に配置された。1101x1825だとOK。

ひたすら書く

(明日から頑張る)

Tips

数式を書く

Web Equation
を使って、手書き数式をTEXに変換してくれる。
https://webdemo.myscript.com/#/demo/equation
紹介ページ
http://gigazine.net/news/20120203-latex-mathml-web-equation/

ここで書いた数式をゲット


g=r\omega ^{2}

ブロック要素として数式を入れるには

//texequation{
g=r\omega ^{2}
//}

というように囲めばいい

インライン要素として数式を入れるには

@<m>{g=r\omega ^{2\\}}

というように、閉じ大括弧の前にエスケープを2つ入れる。人類にはまだ早い。

2024/12/30 追記

@<m>|\vec{x}=a_1 \vec{e}_1 + a_2 \vec{e}_2|

のように、縦棒で囲むやり方も使えるそうです。こちらがカンタン!

コードブロック中に //} が書けない

markdown 上のコードブロック中には //} は問題なくかけるのだけれど、Re:VIEW形式に変換するとコードブロックがそこで閉じてしまい、エラーとなる。Re:VIEW のブロック構文は//} を閉じタグになっているのでRe:VIEWの構文を解説する文書が Re:VIEWで書けないということになってしまう。

これは Re:VIEW形式の仕様の問題かな。

//embedブロック命令はブロック内の文字列をそのまま文書中に埋め込みます。エスケープされる文字はありません。

「Re:VIEW フォーマットガイド」
https://github.com/kmuto/review/blob/master/doc/format.ja.md

コードブロック中の書き方でどうにかできないかと思ったけれどもエスケープできないのでこれはどうしようもない。仕方がないので、markdownの段階でフィルタを通すことにした。コードブロック中に //} が存在するようなら各行頭にスペースを入れるようにした。

slash2braceincode.rb

@<raw>{@}<fn>{23-1}
//@<raw>{}}

@<fn>{23-1}
//}

実は下の//@{}}は何も出力していない。パーサを邪魔しているだけ。

あたまの

の前に改行が無いとRe:VIEWでは

//emlist{

ではなく

@{

となる。ここにインライン命令が入るとmd2reviewが余計なエスケープをつけてコンパイルできなくなる。

なので改行をつけよう。

また、Re:VIEWの命令に誤解釈されるものを本文に書くとおかしくなる。

## markdown と Re:VIEWファイルの違い

### エンターの扱い
markdown → 改行となる
Re:VIEW → 空白となる

13
11
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
13
11

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?