2015年8月2日日曜日

共有するGitリポジトリを作成する方法

共有するGitリポジトリを設定する方法をメモしておきます.

$ groupadd group
$ usermod -G group user
$ mkdir /path/to/repository.git
$ git init --bare --shared /path/to/repository.git
$ chown -R user:group /path/to/repository.git

2015年6月13日土曜日

GEAのDataNucleus Enhancerが異常終了する問題

GEAのDataNucleus Enhancerが「java.lang.NoClassDefFoundError: org/w3c/dom/ElementTraversal」という例外で異常終了する問題に出くわしました.この問題の解決方法をメモしておきます.

  • 「/WEB-INF/lib」(別のフォルダでもいいかもしれない)に「xml-apis-X.X.X.jar」と「xercesImpl-X.X.X.jar」を配置する(Xは適当な数字).
  • それら二つのJARファイルを「Java Build Path」の「Libraries」に追加する.

今回は,[1]の質問に対する回答を参考にしました.

[1] AppEngine Error [ java.lang.NoClassDefFoundError: org/w3c/dom/ElementTraversal ], http://stackoverflow.com/questions/10234201/appengine-error-java-lang-noclassdeffounderror-org-w3c-dom-elementtraversal

2015年4月22日水曜日

CSSではみ出した部分を「…」にする方法

CSSではみ出した部分を「…」にする方法をメモしておきます.

.hogehoge {
    width: 4em;
    white-space: nowrap; 
    overflow: hidden;
    text-overflow: ellipsis;
}
<div class="hogehoge">どうしてプログラムのサンプルに使うテキストは「ほげほげ」なんだろう?</div>

「text-overflow: ellipsis;」と記せば,「…」にならなかったので,何でだろうとずっと悩んでいたのですが, このプロパティは,先の例のように他の3つのプロパティといっしょに使わないと効果が発揮されないんですね. ようやく謎が解けた.\(^O^)/

2015年4月19日日曜日

ロジスティック回帰をJavaで実装

文献[1]で紹介されているロジスティック回帰をJavaで実装してみました.

ロジスティック回帰は,分類問題に適用できる機械学習手法の1つです(確率化したパーセプトロンという理解でいいのかな). 文献で紹介されているとおりあらかじめ用意したデータを分類する関数を求めてみました. グラフにした結果は次の図のとおりです. 青の点が正解,赤の点が不正解,黄色の直線がそれらを分類するために推定された関数,オレンジが正解になる確率が0の領域で,緑が1の領域です. 直線付近は,正解と不正解の境界になっているので,正解になる確率がどんと落ちてます.

ちなみに,これまでグラフはExcelで描いてきたのですが,今回は難しかったので,d3.jsを使ってみました(かなりゴリ押しですけど). 使ってみて思いましたが,大本の文献で使っているPythonがやっぱり一番簡単そうですね.

[1] 中谷 秀洋: ロジスティック回帰を実装してみよう, 機械学習はじめよう 第20回, http://gihyo.jp/dev/serial/01/machine-learning/0020

2015年4月16日木曜日

パーセプトロンをJavaで実装

文献[1]で紹介されているパーセプトロンをJavaで実装してみました.

パーセプトロンは,分類問題に適用できる機械学習手法の1つです. 文献で紹介されているとおりあらかじめ用意したデータを正解(1)と不正解(-1)に分類する関数を求めてみました. グラフにした結果は次の図のとおりです. そうなるようにデータを作ってあるので,当たり前なのですが, 正解と不正解をうまく仕分ける関数を求めることができました.

[1] 中谷 秀洋: パーセプトロンを実装してみよう, 機械学習はじめよう 第17回, http://gihyo.jp/dev/serial/01/machine-learning/0017

2015年4月11日土曜日

ベイズ線形回帰をJavaで実装

文献[1]で紹介されているベイズ線形回帰を記事[2]で作成したプログラムを元にしてJavaで実装してみました.

ベイズ線形回帰は,線形回帰を確率化してベイジアンで関数を求める手法です. 文献で紹介されているとおり基底関数をベイズ基底にして関数を求めてみました. 結果は次の図のとおりです. ベイズ線形回帰なので,関数だけでなく,確率密度も求めることができます.

[1] 中谷 秀洋: ベイズ線形回帰を実装してみよう, 機械学習はじめよう 第14回, http://gihyo.jp/dev/serial/01/machine-learning/0014
[2] mizo0409: 線形回帰をJavaで実装, http://mizo0409.blogspot.jp/2014/01/java.html

2015年2月10日火曜日

[読了]良い習慣悪い習慣

「良い習慣悪い習慣」を読みました.

Jeremy Dean: 良い習慣悪い習慣, 東洋経済, 2014-09 [アマゾン, 楽天]

本書についてのメモを以下に記しておきます.

行動を習慣化させるには,どのくらいの時間がかかるか?本書は.この疑問の答えを探すところから始まる.巷によると21日が有力な説であるが,学術的な研究成果によると平均で66日になるらしい.行動によって短くなったり,長くなったりするが,行動を習慣化するにはどうも2ヶ月ぐらいかかるみたいだ.

習慣とは,自動化された行動である.行動の習慣化は,意図的にそうすることもできるし,経験からそうなってしまうこともある.いずれにせよ一旦行動が習慣化されれば,結果の善し悪しにかかわらず,無意識が周囲の状況に基づきその実行をコントロールするようになる.

行動を習慣化するためのポイントは次のとおりである.

  • 達成する価値のある最終目標を持つ.
  • 最終目標までの具体的なプロセスを考える.
  • 同じ状況下で繰り返す.
  • 進捗をモニタリングする.
  • 行動して得られるものが報酬となるようにする.
  • 不満に対処する.
  • 心理的対比(夢想と現実を比較すること)と実行意図(「〜ならば〜する」と定めること)を組み合わせて行動する.
  • 生活に組み込むのが難しい運動などは,既存の生活習慣に付随させる.