2014年5月7日水曜日

EPSのbounding boxを自動調節

論文作成時に,画像を載せるためにEPSファイルを使う場合について.
WindowsでpptxからEPSを作る場合,EPSプリンタでファイル出力した後にGhostviewからbounding boxを設定するという方法があるが,毎回Ghostviewを開くのはけっこう面倒.

Epstoolというのを使えばコマンドラインから自動調節できるらしいが,自分の環境ではうまく動かなかった.
そこで,ghostscriptのコマンドを使ってbounding boxを自動調節するバッチを作った.

ghostscriptのオプションで「-sDEVICE=bbox」とすると,指定したソースファイルのbounding boxを(必要最小限な領域で)計算して返してくれる.

gswin32c -q -dNOPAUSE -dBATCH -sDEVICE=bbox <ファイル名>

その結果を使って,EPSファイルの中身を書き換えれば良い.
書き換えはただのテキスト置換なので,いくらでもやりようはあると思う

@echo off
setlocal enabledelayedexpansion

set currentpath=%cd%
set /p src_filename="Source File Name: "
set /p dst_filename="New File Name: "

gswin32c -q -dNOPAUSE -dBATCH -sDEVICE=bbox %src_filename% 2> tmp.txt
set /p bbox=”” < tmp.txt
del tmp.txt

<src_filename内の「%%BoundingBox:」で始まる行を変数bboxの値で置き換えてdst_filenameに書き出す処理>

endlocal
pause

EPSファイル書き換えの注意点として,EPSファイル冒頭部に「%%BoundingBox: (atend)」から始まる行がある場合,bounding boxはファイル末尾に記載されているため,そちらを書き換える必要がある.(冒頭部は書き換えない)

2014年2月24日月曜日

Outlookの予定表をAndroidのカレンダーから読めるようにする

会社の予定表はOutlookで管理されているのだけど,これを社外でも確認できるようにしたい.
というわけで,

  • Outlookからサーバにカレンダーを定期upload
  • Android上でサーバから定期read

という感じのことがやりたい.

準備として,フリーのWebDAVサーバのアカウントを作る.
今回は,Driveeを使った.
アカウントを作ると,以下がWebDAVサーバのURLとなる.

 https://ユーザ名.drivee.jp/

次に,Outlookの「ホーム」タブにある「オンラインで公開」から上記WebDAVサーバのURLを設定する.
すると,Driveeにicsファイルがuploadされる.

Android側では,今回はICSSyncというアプリを使った.
Playストアからインストールして,アプリを起動し,「Add feed」からuploadしたicsファイルのURLを設定する.
URLは,Outlookの「オンラインで公開」から「発行オプションの変更」を選ぶと確認できる.

 https://ユーザ名.drivee.jp/****_の予定表.ics

のようになっているはず.

閲覧は,Androidのカレンダーアプリから行なう.
カレンダーアプリのメニューから「カレンダーを表示する」を選ぶと,一覧の中に「ICSSync」のカレンダーがあるはず.
チェックが入っているのに表示されない場合は,一度チェックを外してカレンダー画面に戻ってから,再度「カレンダーを表示する」でチェックを入れると表示されるかも.


2014年2月7日金曜日

IEEEのLaTeXテンプレート

IEEEはLaTeXのテンプレートを公開している.

http://www.ieee.org/conferences_events/conferences/publishing/templates.html

が,これが意外とくせもので,

・図のキャプションが強制的に左寄せになる
・paragraphの間に余分なスペースが入る

といった問題が生じることがある.
CTANで配布している版を使うと,解消される.

http://www.ctan.org/tex-archive/macros/latex2e/contrib/IEEEtran/

バージョン番号は変わらない(2014/2/7時点でどちらも1.8)が,CTANのほうが微妙に新しくてあちこち修正されているみたい.

subfigのキャプションを括弧付きで参照する

LaTeXで図を縦方向や横方向に2つ以上並べたい場合,subfig.styを使用する.
例えば縦に2つ並べる時は,以下のような感じ.


\usepackage[caption=false]{subfig}

  :
  :

\begin{figure}[!t]
  \centering
  \subfloat[副キャプション1]{
    \includegraphics[width=\linewidth]{****.eps}
    \label{fig_sub1}
  }
  \\
  \subfloat[副キャプション2]{
    \includegraphics[width=\linewidth]{****.eps}
    \label{fig_sub2}
  }
  \caption{全体キャプション}
  \label{fig_1}
\end{figure}

で,図の番号を参照する時に,普通に

図\ref{fig_sub1}

とか書くと,「図1a」「図1b」のように出てきたりするが,これを「図1(a)」「図1(b)」のように括弧付きにしたい場合にどうしたら良いかという話.

前置きが長くなったが,やり方は簡単で,

図\ref{fig_1}\subref{fig_sub1}

とすればOK.


参考ページ: http://tex.stackexchange.com/questions/16291/adding-parentheses-around-subfig-references

2014年2月6日木曜日

英文論文でマルバツ表を作る

英語で論文を書く際,こんな感じの表を書きたくなることがある.

機能1機能2
手法1×
手法2×

LaTeXだと「\begin{table}~」で表を作ればいいのだが,問題はセルの中身で,英語だと普通○×は使わない.
じゃ何を使うのかというと,以下のようなパターンがあるらしい.(いずれも前者が該当,後者が非該当の意味)

・チェックマーク(「レ」みたいなやつ)とバツマーク(×)
・チェックマークと空欄
・「yes」と「no」

今回は,チェックマークとバツマークを使う場合について.
LaTeXの場合,チェックマークについては

\usepackage{amssymb}

しておいて「\checkmark」で表示できる.
バツマークは「\times」が使えるので,これで表をつくると下のような感じになる.


なんかイマイチだな・・・という人は,pifont.styを使うのもオススメ.

pifont.styは以下からDLできる.


ダウンロードして解凍したら,コマンドプロンプトで解凍先フォルダに移動し,以下のコマンドを実行する.

platex pifont.ins

すると,解凍先フォルダにpifont.styができあがっているので,これをtexファイルと同じ場所に突っ込んでおく.で,

\usepackage{pifont}
\newcommand{\cmark}{\ding{51}}%
\newcommand{\xmark}{\ding{55}}%

としておくと,「\cmark」「\xmark」でそれぞれいい感じのチェックマークとバツマークが使えるようになる.
例えば下のような感じ.





2014年1月16日木曜日

PC再起動時に,前回開いていたPower Pointファイルをまとめて開く

Windows Updateをかけると,PCの再起動を迫られることがよくある.
何の因果かPower Pointを5枚も10枚も開いていた場合,再起動した後にそれらをひとつひとつ開き直すのはめんどくさい. 特にファイルの保管場所がバラバラだとこの上なくめんどくさい.
そこで,現在開いているPower Pointファイルの場所(ファイルパス)を記憶しておいて,再起動後にそれらをまとめて開くためのプログラムを書いた. 言語はC#.(実はC#触るの初めてなので環境構築からだった)
仕様は,
  • 起動するとコンソール上に「save」「open」のメニューが出る
  • saveを選ぶと,現在開いているpptファイルのパス一覧を表示し,ユーザのデスクトップフォルダに保存する.
  • openを選ぶと,前回デスクトップに保存したファイルからパスを読み込んで,まとめて開いてくれる
という感じ.で,コードは以下. 命名とか色々適当なのはスルーで.

using System;
using System.Text;
using System.IO;
using System.Collections.Generic;
using PowerPoint = Microsoft.Office.Interop.PowerPoint;
using Microsoft.VisualBasic;

namespace PPTSO{
    class PPT{
        private string save_file = "C:\\Users\\" + System.Environment.UserName + "\\Desktop\\PPTSO.txt";

        static void Main(string[] args){
            PPT ppt = new PPT();
            if (!File.Exists(ppt.save_file)){
                File.Create(ppt.save_file).Close();
            }
            while (true){
                Console.Clear();
                Console.WriteLine("s: save current ppt files");
                Console.WriteLine("o: open previous ppt files");
                Console.WriteLine("q: quit");
                Console.Write("input: ");
                string menu = Console.ReadLine();
                Console.WriteLine(menu);
                if (menu.Equals("s")){
                    ppt.savePPT();
                }else if (menu.Equals("o")){
                    ppt.openPPT();
                }else if (menu.Equals("q")){
                    break;
                }else{
                    Console.WriteLine("input error. press any key...");
                    Console.ReadKey();
                }
            }
        }

        public void savePPT(){
            Interaction.CreateObject("PowerPoint.Application", "");
            PowerPoint.Application pApp = (PowerPoint.Application)Interaction.GetObject(null, "PowerPoint.Application");
            foreach (PowerPoint.DocumentWindow dw in pApp.Windows){
                Console.WriteLine("{0}", dw.Presentation.FullName);
            }
            string yn;
            Console.WriteLine("--------------------");
            Console.WriteLine("are you sure to save? y/n");
            while (true){
                yn = Console.ReadLine();
                if (yn.Equals("n")){
                    return;
                }else if (yn.Equals("y")){
                    break;
                }else{
                    Console.WriteLine("input error. press \"y\" or \"n\":");
                }
            }
            FileStream fs = new FileStream(save_file, FileMode.Create);
            StreamWriter sw = new StreamWriter(fs);
            foreach (PowerPoint.DocumentWindow dw in pApp.Windows){
                sw.Write(dw.Presentation.FullName + "\r\n");
            }
            sw.Close();
            fs.Close();
        }

        public void openPPT(){
            string path;
            List<string> pathList = new List<string>();
            FileStream fs = new FileStream(save_file, FileMode.Open);
            StreamReader sr = new StreamReader(fs);
            while ((path = sr.ReadLine()) != null){
                pathList.Add(path);
                Console.WriteLine(path);
            }
            sr.Close();
            fs.Close();
            string yn;
            Console.WriteLine("--------------------");
            Console.WriteLine("are you sure to open? y/n");
            while (true){
                yn = Console.ReadLine();
                if (yn.Equals("n")){
                    return;
                }else if (yn.Equals("y")){
                    break;
                }else{
                    Console.WriteLine("input error. press \"y\" or \"n\":");
                }
            }
            List<string> openedPathList = new List<string>();
            Interaction.CreateObject("PowerPoint.Application", "");
            PowerPoint.Application pApp = (PowerPoint.Application)Interaction.GetObject(null, "PowerPoint.Application");
            foreach (PowerPoint.DocumentWindow dw in pApp.Windows){
                openedPathList.Add(dw.Presentation.FullName);
            }
            PowerPoint.Presentations pPt = new PowerPoint.Application().Presentations;
            foreach (string str in pathList){
                if (openedPathList.Contains(str)) continue;
                pPt.Open(str);
            }
        }
    }
}








相関係数の検定

論文を書く時など,シミュレーション実験の結果から相関係数を算出することがある.
参考程度であれば相関係数を出しただけで終えても良いのだが,論文等に載せる場合は算出した相関係数に意味があるか否かを調べる必要がある.
どういうことかと言うと,相関係数の算出に用いたデータはあくまでもサンプルであり,真の相関係数が求まっているわけではない.

つまり,母集団から標本を取り出して計算した結果に過ぎないので,もし使用した標本が外れ値だらけで,母相関係数との間に大きなずれがあれば,意味のない値ということになってしまう.
そこで,母相関係数ρ=0であるという帰無仮説をたてて,有意性の検定を行なう.
これを無相関検定と呼ぶ.手順は次の通り.(rは相関係数,nはサンプル数)
  1. 帰無仮説をたてる:「相関が無い(ρ=0)」
  2. 対立仮説をたてる:「相関がある(ρ≠0)
  3. 有意水準を決める:通常は1%か5%
  4. 自由度*を求める:自由度=サンプル数-2
  5. t値を計算する:t=r * ((n-2)/(1-r^2))^(1/2)
  6. t分布表を見て,該当する自由度の箇所の水準値をt値が上回っていれば,帰無仮説は棄却(対立仮説を採択)
  7. 6.と逆の場合には,帰無仮説を採択
エクセルで求める場合,まず以下でt値を計算する.

 t=ABS(相関係数*SQRT(サンプル数-2)/SQRT(1-相関係数^2))
次に,以下でp値を計算する.

 p=TDIST(t値, 自由度, 2)
pが有意水準を下回っていれば,帰無仮説を棄却できる(相関係数が有意であると言える).


※参照ページ

※自由度
 母集団からサンプル数nで標本を取り出す場合について考える.標本平均を母平均と一致させるためには,n-1個のサンプルは自由に選んでも良いが,残りの1つで標本平均を調節しなければならない.この,自由に選べる数「n-1」が自由度.
 大雑把な理解としては,相関係数の場合は,相関を見る対象である2つの母集団が存在するため,自由度が2減る.従って,「サンプル数-2」が自由度となる.


2014年1月14日火曜日

jEditにスペルチェック機能を追加する

jEditにはSpell Checkというスペルチェック用のプラグインが用意されている.
Spell Checkを使うには,事前にAspellをインストールしておく必要がある.
Aspellはオープンソースのスペルチェッカーで,Spell CheckはjEdit側からこのAspellの機能を呼び出すためのプログラム.
Aspellのインストール方法についてはTeX Wikiに詳しい説明がある.
Windowsの場合,Aspell Win32版の配布ページから本体と辞書をダウンロードして,順にインストールする.記事執筆時点(2014.1.15)では,
  • 本体: Aspell-0-50-3-3-Setup.exe
  • 辞書: aspell-en-0.50-2-3.exe
なお,英語以外の言語の辞書もあるので必要に応じてインストールする.
Aspellをインストールしてbinフォルダにパスを通すと,コマンドプロンプトから以下のコマンドでテキストファイルのスペルチェックが可能.

aspell --lang=en -c ファイル名

例えば,以下のようなテキストファイルを用意する.

test text.
tets text.

これに対し,コマンドプロンプトで上記のコマンドを実行すると,下図のようになる.



画面下に出ている選択肢から例えば「1」を選ぶと,当該箇所が「test」に書き換えられる.

さて,jEdit側.
Spell Check pluginをインストールして,plugin optionsからSpell Checkのオプション画面を開く.
「Aspell Engine」という項目があるのでそこを開き,aspell.exeの場所を指定しておく.
(例えば,C:\Program Files (x86)\Aspell\bin\aspell.exe)

「General」という項目で,「Spell-checking engine」のところを「Aspell」に設定する.
その下にある「Refresh list」を押してから辞書として「en」を選択する.

これで準備はひとまず完了.
テキストファイルを開いた状態で,プラグインメニューからSpell Checkを選び「Spell check selection」を実行すると,スペルチェックしてくれる.
他にもいくつかメニューがあるので,状況に応じて使い分けすると良い.

なお,「Browse user dictionaries」を実行するとファイルブラウザ側でユーザ辞書のディレクトリが開く.
間違って変な単語をAdd(ユーザ辞書に追加)してしまった場合は,この辞書を修正する.
ただし,jEdit上で修正しても,反映されなかった.
たぶん,jEdit側で起動時に読み込んで,終了後に変更されていたら書き戻す感じになっている? jEditを終了した状態で修正し,修正後にjEditを再起動したらうまくいった.