日付:2024-11-24
名前:小林 大輔
学生番号:HT12A038
指導教員:兼宗 進
年度:2014
所属:総合情報学部 メディアコンピュータシステム学科
論文執筆等の文章作成を行う時に使用するソフトにおいて、それぞれに弱点があるのではないかと考える。例えば、LaTeXというソフトを扱うとする。このソフトは、各自が様々なエディタを用いてLaTeX命令や文章を書き、LaTeXを実行してPDFファイルを得るという方法である。 しかし、LaTeX初学者にとってLaTeXの命令等を、参考書やWebサイト等で調べながら、文章やPDFファイルを作成するのは、文章作成以外に労力を取られてしまう。そのため、文章作成自体に集中できず、作業効率が悪いのではないか、と考える。 そこで今回「論文作成時に必要である命令を直感的に記述できないか」という課題の元に、それを実現するためのプログラムの作成を行った。 課題を実現する為にPukiwikiを用いた。これはWeb上で命令や文章を作成し、プレビューボタンを押すだけで出力結果を見ることが可能である。命令も直感的に記述することが出来る為、Pukiwikiを用いた。 PukiwikiとLaTeX命令の対照表を作成し、その表を元にプログラムを作成した。 その際、Pukiwikiで対照する命令がない事があった為、自身で考え対応させた。 対応時にはプレビューした際に、PDFにした時のイメージが掴めるように行った。 結果、プレビューボタンで完成時のイメージが掴める様になり、文章作成への集中が向上したのではないかと考える。
文章を作成する為のソフトの一つに「LaTeX」というソフトがある。
このソフトは、各自様々なエディタにLaTeXの命令や本文を記述し、コマンドプロンプトなどを用いてコンパイルし、pdfファイルを得る事が可能。数式を扱うのに長けており、複雑な数式を美しく記述可能であるのが特徴である。そのため、理系の文章作成において重宝されている。 しかし、LaTeXの命令には複雑なものが多く、初学者が扱う際にはLaTeXの命令をいちいち参考書やインターネットなどで調べながら、本文を書かなければならない。そのため、文章作成のみに集中できないのではないかと考えた。
そこで今回、Pukiwiki記法をTeX形式の命令へ変換するプログラムを作成した。 論文作成において必要であるLaTeXの命令と、Pukiwikiの項目を対応させることで、ユーザへの入力負担を軽減できるのではと考えた。Pukiwikiを仕様する利点としては、プレビューボタンを押すだけで、出力結果が見れることや、命令の項目が直感的な点である。
「Wiki2LaTeXフィルターの開発」
吉井了平(関西学院大学)
LaTeXで文章作成する際に必要で、頻出する命令をPukiwikiの記法とその他に自身で設定した記号に置き換えることにより、LaTeX命令の入力作業の軽減を実現している(図【【wiki2tex】】)。
PukiWiki記法をTeX命令へ変換するために既存のフィルターである「pukipa.rb」を改良している。「pukipa.rb」はPukiwikiの独自文法を、HTMLに変換するプログラムである。HTMLに出力する部分をそれぞれに対応するLaTeX命令へ変更している。
現在、文章作成ソフトには「Word」、「Writter」等があり、これらは「視覚マークアップ言語」と呼ばれ、テキスト中の「手掛かり」から文書構造を推論しようというものである。
例えば、テキストファイルの文書のタイトルの前にいくつか改行やスペースを入れることで、行送りの調整や中央寄せを暗示させている。
これらの作業は、ユーザが入力した内容、つまり画面に出力される内容が印刷などの出力と一致するという利点がある。これはユーザにとってわかりやすい仕様であるが、ユーザーがすべてのレイアウト作業を行わなければいけない為、文章作成のみに集中することが出来ず、執筆以外にも労力が必要となる。
図や表を入れ替えた際に、番号を振り直す必要が生じることや、全体的に構成を変更した際に目次も変更しなければならない等、弱点と呼べる点が多々ある。
他にも、卒業論文や研究論文など理系の論文を執筆する際の多くは「LaTeX」という文章作成ソフトを使用することがある。
「LaTeX」の特徴としては、
手続きマークアップ言語というのは、書式を整えるために、書式指定の命令を文章の直前に並べ、中央揃えモードに移る、書体を大きくさせる、などの指示を出す。文章の後には、それらの効果を打ち消す命令が並ぶ、という言語である。出力した際には非常に整っていて見やすい。
しかし、これらの文章作成ソフトは、文章作成時に、レイアウトに気を遣ったり、命令を調べながらでないと文章を作成できない、等の問題もある。
本学の卒業論文の執筆方法は、各自様々なエディタを用いて、LaTeXの命令や本文を記述し、コマンドプロンプトなどを用いてコンパイルし、pdfファイルを得るという方法である。しかし、LaTeXの命令には複雑なものが多く、初学者が扱う際にはLaTeXの命令をいちいち参考書やインターネットなどで調べながら、本文を書かなければならない。そのため、文章作成のみに集中できないのではないかと考える。 そこで、Pukiwiki記法でLaTeXのように文章作成をすることが出来ないか、と考えた。
従来のLaTeXでの文章作成方法(図【【tex】】)と、今回提案するPukiwik記法での文章作成方法(図【【wiki1】】と図【【wiki2】】)をそれぞれ示す。
PukiwikiとはPHP言語で動作するWikiの一種である。
Pukiwikiの文法は直感的な記述が可能である。見出しは「*」「**」「***」で表現されている。他にも、箇条書きは「-」や「+」を使用し表現される。 「-」が記号付きの箇条書きで「+」は番号付の箇条書きである。
プレビューボタンを押すだけで、ページの完成度を見る事が出来る。
LaTeX を扱うのは容易ではなく負担がかかるため、今回は直感的に箇条書きや表などの記述が可能であるpukiwiki記法を記述し、それをLaTeX命令へ変換することで、ユーザの負担を軽減することは出来ないかと考えた。
今回Pukiwikiのページを扱う利点としては、プレビュー時にPDFにした時のイメージが掴める、という点である。しかし、PukiwikiとLaTeXではそれぞれ利用目的が違うため、対応する項目は限られている。今回はそれぞれの項目の対応から行った。
対応時に考えたのは、プレビュー時にどれだけ自然に見せることが出来るか、という点である。
まず、LaTeX で文章作成を行う際に頻出する項目をリストアップしPukiwikiとの対応表を作成した。 それを図【【lists】】に示す。
LaTeXに存在し、Pukiwikiに存在しない項目については、命令同士の意味が異なる場合でも対応させている。その時に考えたのは、Pukiwikiでのプレビュー時に、それの文章をPDFにした時にどのように出力されるのかイメージできるか、という点である。
PukiwikiとLaTeX、お互いに対応する語が存在しない項目をリストアップし、Webブラウザ上(Pukiwiki)で様々な項目を使用し、プレビューを行いながら対応付けを行った。 全ての項目を対応させるのは困難な為、今回の研究では、論文を作成する際に一般的に使用すると思われる項目と、卒業論文に使用するであろう項目に絞り対応付けを行う。 下記は一般的に使用すると思われる項目である。
下記は卒業論文のサンプルに記述されていたため、特別に必要であると思われる項目である。
例えば、LaTeX には「章立て(\chapter)」や「見出し(\section)」という命令があるが、Pukiwiki記法には「章立て」というのはなく「見出し(*)」しかない、そのため自身で考え対応させる必要があった。Pukiwiki上では「*」を使用しなければ目次に表示されない為、見出しと章立てを「*」を用いた記述方法にした。しかし、Pukiwiki記法では「***(LaTeXでいう\subsubsection)」までしか対応されていない。そのため、文頭に「*~」と記述すると「章立て」とし、「見出し(*)」部分と区別するようにした(図【【chapsec】】参照)。
Pukiwkiには文章や画像・表などにラベルを付け、参照するという記述法はなく、それぞれにアンカーやリンクを付けるといった項目しかない。 この様な対応する項目がない場合は難しく、Pukiwikiのページ上・文章中に存在しても違和感がなく、かつ、文章作成中に使用しない記号を使用する必要があった。 今回、ラベル(\label)と参照(\ref)には、すみつきカッコ(【 】)を用いた(図【【labref】】参照)。
図を挿入する際には、一度Pukiwiki上にアップロードし(#ref(画像ファイル名),図の位置)などと記述するとPukiwiki上に図が表示される。TeX命令へ変換しPDFにする場合にはTeXファイル(*.tex)と同じフォルダ内に画像ファイルを挿入しておく必要がある。
Pukiwikiではファイル名がその図の表示名になってしまう為、表示名を出力する命令を自身で考え追加した。
LaTeXでの図の挿入の命令は複雑で、図を表示させる、図の場所を指定する、図の名前を出力する命令、場合によってラベルを付与する必要がある。
それらの対応方法を図【【lab1】】と図【【lab2】】を用いて説明する。
Pukiwikiでの入力を図【【lab2】】のようにTeX命令へ当てはめていく。
論文には、もちろんタイトルや著者名や日付が必要である。他にも、今回の卒業論文では、学生番号や指導教員名、所属学科などを記述する必要がある。タイトルは最上の中央部に太字で出力し、日付はPukiwikiが標準で扱えるものを使用する。それら以外の記述方式は似せるようにした(【【title】】)。
下記は図【【item】】のプログラムの処理方法である。
箇条書きや表組、画像貼り付け等、LaTeX側で複数行に渡り命令をする場合は図【【item】】のような処理方法を行っている。
その他のタイトル(\title)や目次(\tableofcontents)等、一行で判別が可能な命令については、図【【pl2】】のように文頭や文中に特定の項目がが存在した際に、LaTeXの命令に変換している。
Pukiwikiではページ更新をした際に、見出し(*)を使用した際にアンカーが付属してしまう(図【【ancer】】参照)。アンカーを放置したままTeX形式に変換しターミナルなどでコンパイルするとエラーが出てしまうため、TeX形式へ変換する際にそのアンカーを削除する必要があった。文章作成時にアンカーのような文章を記述してしまうと、アンカーと同様に削除してしまう恐れがあった為、文頭が「*」で文末に特定の文字列が存在した場合のみアンカーを削除するプログラムを作成した(図【【texanc】】参照)。
LaTeXは「プリアンブル」をテキストファイルに記述しなければコンパイルすることが出来ない。そのため、今回は卒業論文で使用するプリアンブルを変換プログラムにかけた際に自動で付与している(図【【puri】】参照)。その際に\begin{document}も一緒に付与している。\end{document}は文章の最後に付与している。これによりコンパイルが可能になる。しかし、パッケージの追加などには未対応であるため、決められた形式の論文を作成することしかできない。
論文を印刷した際に、表紙やページ番号がついていないと非常に見にくくなってしまう。しかしPukiwiki記法はWebページを作成する言語なので、表紙やページ番号を付与させるような命令はない。そのため、LaTeX形式に変換した際に特定の命令の前後にページ番号などの命令を付与させるようにした。概要を記述すると、表紙と概要ページのページ番号、目次を記述すると、目次以下のページ番号を決められた書式で出力される(図【【pagenumber】】参照)。
しかし、プログラムが自動的に決められたページ番号を出力するようにした為、現在はページ番号の書式の設定などは出来ていない。
上記を図に示したものが図【【activity】】である。
筆者自身がPukiwikiを用いて卒業論文の文章を作成した。本論文が本研究の成果である。
本研究ではPukiwikiを用いてその編集画面でPukiwikiの項目を使用し、文章を作成した。 Pukiwikiでの文章とその文章をTeX命令に変換した一部をそれぞれ図に示す。 筆者自身の感想だが、LaTeXで記述するよりも、論文作成における文章の記述に対する集中力は向上したのではないかと考える。
本論文をPukiwikiで作成した。それにより課題をいくつも発見することが出来た。
課題の一部の問題に対する改良案として、プログラムの見直しが必要であると考える。
スクロールや行番号問題に対してはPukiwiki自体のプログラムを変更することで解決可能ではないかと考える。 PDFへする作業については、Pukiwiki上にボタンなどを追加で表示しそのボタンを押すことで、今回作成したプログラムが起動し、TeX命令へ変換、その後自動的にPDFファイルとしてダウンロードすることが可能になれば、少しでも作業の軽減ができるのではないか、と考える。
本研究によりPukiwiki記法をLaTeX命令へ変換することが可能になった。
本研究、本論文を終えるにあたり、御指導・御教授を頂いた兼宗進教授に深く感謝いたします。
また、学生生活における基礎的な学問、学問に取り組む姿勢をご教授頂いた、メディアコンピュータシステム学科の先生方に深く感謝致します。
本研究期間中、本研究に対する貴重な御意見、御協力を頂きました島袋舞子さんに心から感謝致します。そして、卒業研究に共に励んだ兼宗研究室メンバー一同にも深く感謝します。
付録には実験のデータやプログラムリストを付ける