2010年12月31日金曜日

Fedora14でrootログイン

忘れないように・・

Fedora14はデフォルトでは、GDM(GNOME Display Manager)から root でログインできない.
→デスクトップからログイン出来ないんだよね・・

なので,2つのファイルを書き換える.

・ /etc/pam.d/gdm
・ /etc/pam.d/gdm-password

次の1文をコメントアウト


auth required pam_succeed_if.so user != root quiet
#auth required pam_succeed_if.so user != root quiet
あとは,rebootして終了.
参考:
Fedora 14 で root でログイン

Linuxのコマンド(備忘録)

◆ファイル検索
>find / -name aaa.txt


◆ディレクトリごと削除
>rm -r aaa
これだと,ファイル一つずつ許可しなきゃいけないので
>rm -rf aaa
これだと,一発♪

◆ファイアウォール
>iptables -I INPUT -p tcp -m tcp --dport ポート番号/サービス名 ACCEPT
>service iptables save

◆ファイアウォール設定の裏技(自分的にw)
ファイアウォールの設定ファイルを直に書き換え
>vim /etc/sysconfig/iptables
ファイルを書き換える.
>service iptables restart
(ついでに,>service iptables save)

管理者(Postgres)のパスワード忘れたとき

Postgresqlで管理者(Postgres)のPasswordを忘れたとき,


1)パスワードなしでアクセスできるようにする
>vim /var/lib/pgsql/data/pg_hba.conf

 local all all                   md5
 host all all 127.0.0.1/32  md5 
 ↓
 local all all                   trust
 host all all 127.0.0.1/32  trust

に変更.他にhostも設定できる.(hostはTCP/IPで接続している場合(SSH))


>service postgresql restart
再起動.

2)パスワードの変更
パスワードなしで,ユーザ(postgres)でpostgresqlに接続.そして,パスワード変更.

>su -
>su - postgres
-bash-4.1$psql -U postgres
postgres# ALTER Role postgres PASSWORD '新パスワード';
postgres# \q
-bash-4.1$exit



==終了==

2010年12月27日月曜日

SSH 鍵認証接続の注意点

OS:fedora14

SSHでリモート接続するときの注意点

◆鍵のコピー
TeraTermでSSH鍵生成した公開鍵をサーバに登録するとき,
公開鍵の最後の改行は削除しておくこと!!


◆権限の付加
他人から見られないようにするために,フォルダ・ファイルに権限を付加する.


>chmod 755 ~/.ssh
>chmod 644 ~/.ssh/authorized_keys


□工程
>mkdir ~/.ssh
>vim ~/.ssh/authorized_keys
鍵のコピペ
>chmod 755 ~/.ssh
>chmod 644 ~/.ssh/authorized_keys
権限の付加
>exit
ログアウト

2010年12月26日日曜日

ntp 設定 (CentOS 5.0)

ntpの設定を行った時の備忘録

ntpで時刻同期させるためのサービスがntpdです.
そして,同期させるためには2つの方法があるって.

◆1.[例:ntpdate ntp.nict.jp]を定期的に実行(cron)
◆2.ntpdに勝手にやってもらう(ntpdデーモン)

1.はコレ見て!
技術メモ:白黒サーバーインストール記録


今回は,2.を行ったよ.

やり方は,2つのサイトを参考にしました.

CentOSにntpサーバで時刻同期設定

CentOS5.0でntpを使用して時刻を合わせる


要点は,下の①,②,③ぐらいです.(①から⑤まで順番にやってね)

①:ntpdate ntp.nict.jp(設定変更する前に,時刻同期させておく)
 
>ntpdate ntp.nict.jp

②:vim /etc/ntp.conf(ntpサーバを変更する)
/etc/ntp.conf 内 (↓)

server 0.centos.pool.ntp.org

server -4 ntp.nict.jp
 
restrict 0.centos.pool.ntp.org mask 255.255.255.255 nomodify notrap noquery
↓「コメントアウト」
#restrict 0.centos.pool.ntp.org mask 255.255.255.255 nomodify notrap noquery

③:vim /etc/sysconfig/ntpd(ハードウェアクロックも同期させる)

# Set to 'yes' to sync hw clock after successful ntpdate
SYNC_HWCLOCK=no


SYNC_HWCLOCK=yes
 
④service ntpd restart(再起動)
⑤chkconfig ntpd on (自動起動(PCを起動するときに自動で立ち上がる))
 
最後に,次はこいつをntpサーバにして,他のローカルPCを時刻同期させよう♪

2010年12月2日木曜日

気象庁Webページをスクレイピング

研究に利用しようと思って,アメダス情報をゲットしたかったんですね、phpで♪


天気情報をWebサービス(rss,api)で提供しているのは,
1)Yahoo!天気
2)goo
3)google
4)livedoor weather hacks
5)ひとくち予報 in Feed
とかがあるらしい.
今回はアメダスデータが欲しかったので,5)はなし.


◆RSSでゲットしよう♪
RSSを提供している,4)のLivedoorを使ってみたよb

http://weather.livedoor.com/amedas/point/50456.html

のデータが欲しいとーb

このRSSをゲットしようと思ったら、、

サイトのテーブルは1時間ごとに更新されるのに、RSSは6時間一度しか更新されない。
このRSSでゲットできるデータは,0・6・12・18時のいずれかでした!

6時間ごとという,大したデータが取れないので,(実地で検証www)

【実装方法】
php: simplexml(),linux:cron
simplexml()はxmlファイルを配列ぶち込んでくれる関数.
欠点があって,要素にアクセスするときパスを指定しないといけないことだね.


◆サイトのHTMLファイルからゲットしよう♪(simplexml()を使って♪)
第二の方法だよねb
HTMLファイルからゲットするんなら,もっと色々なデータを提供している気象庁(http://www.jma.go.jp/jma/index.html)のサイトからゲットしようと♪

<おぉ♪簡単じゃね?前作ったプログラムでいいんじゃね?simplexml()で>

が!失敗!!
htmlはxmlじゃないんですねー!!
http://www.atmarkit.co.jp/fxml/askxmlexpert/022xhtml/22xhtml.html
使えない文字とか,色々htmlでは使われていたり。。
俗に言う,XHTMLはhtmlファイルをxmlみたいにちゃんと整形式にしたものだってb

ほうほう♪そういうことだったのか!HTMLとXMLの違いを実地で体験ww


◆HTMLファイルのスクレイピング
第三の方法だよねb
色んな方法があるみたいだけど,今回はscrape_func.phpっていうライブラリを使いました.

スクレイピングは,Webサイトから必要な情報を切り取ることだって.
やってることは,簡単にはマッチした部分を取ってくるって感じ♪


実装したもの(↓)は,ムダにループ回ってるよww
最新の一件のアメダスデータのみDBに格納してるんだけど,ループは24時間分www

そして,Linuxのcronでスケジューリング♪♪

データも1時間ごとのリアルタイムデータが取れるようになったし,満足満足♪♪

【実行結果】




【実装したもの】
<?php
/* スクレーピング関数群のインクルード */
include( "scrape_func.php" );

/* getURL()関数を使用して、ページの生データを取得する。 */
$_rawData = getURL( "http://www.jma.go.jp/jp/amedas_h/today-50456.html?groupCode=35&areaCode=000" );

/* 生データをUTF-8に変換する。 */
//$_rawData = mb_convert_encoding($_rawData, "UTF-8", "auto");

/* 解析しやすいよう、生データを整理する。 */
$_rawData = cleanString( $_rawData );

//echo $_rawData;
/* 次は若干ややこしい。 必要な項目の開始部分と終了部分は、事前に
   HTMLから確認してある。 こういったものを利用して必要なデータを取得
   する。 */

$_rawData = getBlock( "<td class=\"time left\">","</tr> </table>", $_rawData,false );

/* これで箇条書きに必要な特定データが入手できた。
   ここでは項目を配列化した後、繰り返しで処理を行っている。 */
$_rawData = explode( "</tr>", $_rawData );    //1時間毎に分割



//現在の時刻
$date=date( "Y-m-d H:", time() )."00:00";
//echo $date;
//cronする時刻のみのデータをとってくれば良い。

//取得するデータの時刻を求める。
$what=date( "H", time() );
//echo "what:".$what;
//if($which==1)echo "OK!";        //01 =>1
$which=(int)$what;
if($which==0)$which=24;



$conn = pg_connect("データベースの接続");
if (!$conn) {
  echo "An error occured.\n";
  fwrite($handle,"connection error!\n");
  exit;
}
pg_set_client_encoding("sjis");


//echo "<hr>";
$now=0;            //時刻ではない
/* 繰り返しを行いながら、個々の項目を解析する。 */
foreach( $_rawData as $_rawBlock ) {
   //初期化
   //$time=null;
   $temp=null;
   $rainfall=null;
   $wind_direction=null;
   $wind_velocity=null;
   $sunlight=null;
   $moisture=null;
   $pressure=null;
  
   //now=0:$which=1        //ひとつずれてる
   if($now==($which)){
     $_rawBlock = explode( "</td>", $_rawBlock );//8つのデータを配列に格納...余計に1つ要素が出る..
     $str="";
     $null_count=0;
     $num_element=count($_rawBlock)-1;
     //echo "count:".count($_rawBlock);
     for($j=0;$j<$num_element;$j++){
        $_rawBlock[$j]=strip_tags($_rawBlock[$j]);    //余計なタグを除去
        $_rawBlock[$j] = trim( $_rawBlock[$j] );    //空白を除去
    //echo "j:".$j."->".$_rawBlock[$j].",";
    if(!strcmp($_rawBlock[$j],"&nbsp;")){        //"&nbsp;"=空白
       $_rawBlock[$j]=0;        //"&nbsp;"のとき、0を代入
       $null_count++;
    }
    if($j==0){
       //時間
       $str.="'".$date."',";
       //$time=$_rawBlock[$j];
       //if($time==24)$time=0;    //24時 => 0時
       //$str.=$time.",";
    }else if($j==1){
       //気温(℃)
       $temp=$_rawBlock[$j];
       $str.=$temp.",";
    }else if($j==2){
       //降水量(mm)
       $rainfall=$_rawBlock[$j];
       $str.=$rainfall.",";
    }else if($j==3){
       //風の向き(16方位)
       $wind_direction=$_rawBlock[$j];
       $str.="'".$wind_direction."',";
    }else if($j==4){
       //風の強さ(m/s)
       $wind_velocity=$_rawBlock[$j];
       $str.=$wind_velocity.",";
    }else if($j==5){
       //日照時間(hour)
       $sunlight=$_rawBlock[$j];
       $str.=$sunlight.",";
    }else if($j==6){
       //湿度(%)...少数表記
       $moisture=(double)$_rawBlock[$j];
       $moisture/=100;
       $str.=$moisture.",";
    }else if($j==7){
       //気圧(hPa)
       $pressure=$_rawBlock[$j];
       $str.=$pressure;
    }
     }
     if($null_count==$num_element-1){
         //echo "null!!";
     }
     //echo "=>".$str;
     //echo "<hr>";
    
     //DBへの登録...あるデータは無視
     $sql="insert into weather(time,temp,rainfall,wind_direction,wind_velocity,sunlight,moisture,air_pressure) VALUES (".$str.");";
     //echo "sql:".$sql."<br />";
     $result_flag = pg_query($sql);
     if (!$result_flag) {
     //fwrite($handle,"insert error!\n");
     die('INSERT fault'.pg_last_error());
     }
     pg_close($conn);        //DB.close();
   }
   $now++;
}
?>

【参考】
http://d.hatena.ne.jp/steel-plate/20080417/1208445174

2010年10月21日木曜日

サーバー公開(ダイナミックDNSで)

サーバーを公開しました.そこで必要な項目が2つあるよ.
1つはサーバのIPを固定にすること,2つ目はルータのNAT(Network Address Translation)の設定です.


◆サーバのIPを固定にするには
1)DHCPを停止(サーバPC)
2)固定IPを設定(サーバPC)

Linuxで固定IPにする方法は色々なサイトで見れるので省略.(下のサイトを参照して)
http://fedorasrv.com/fedora13.shtml
の【fedoraのネットワーク設定】

設定するものは,プライベートネットワークでサーバを固定するためのもの.
サーバのIP(プライベートIP),ルータのIP(LAN側と)

2010年10月6日水曜日

Fedoraインストール (失敗だぁww)

Fedoraをインストールするのに,

CD-ROMドライブしかない場合は,インストーラのCD版がある.
それ使ってOSインストール♪

◆問題発生
この画面で,操作できなくなる.(キーボード・マウス両方無意味にww)


原因:わかんないけど,インストールdiscが壊れてるか?それとも,ハード?
     →持ち越し♪w

対策:1)discを焼き直す.2)ボロPCを諦めて,Let's noteにLinuxを入れるか?

2010年9月22日水曜日

今はどこらへんかなぁ??

久しぶりにブログ書くなぁ.


まなは今頃どこらへんかぁ??ドイツ?スイス?


今からは,自分にかかるお金を全部自分でまかなうことが絶対です.

まぁ今まで授業料も含め色いろ世話になってきたので,当然なのかb

だから,バイトとか探さないとっbb


授業料をまかなうためには月々5万円は稼がないといけないねb

平日の昼間はムリだから,平日・休日の朝を基本にやりたいと思ってる.


今は昔と違ってコンピュータの世界で食べていきたいと思ってるから,
それと重要なのが大切な人ができたのが一番の理由だね♡

一緒に生きて行きたいから,安定した暮らしができるようにがんばるbb



話がそれたけど,新聞配達と朝のスーパーを考えてる.
それで月5万稼げるかわかんないけどね(笑)



研究の話じゃないねww

では,地クラが一段落してこれからの研究の方針・計画を詰めるかなb

◆方針
今の段階で研究の流れが2つあって,在席判定と移動の判定.

・在席判定
センサデータをある時間幅分区切った特徴量(集約値)と,そのときの状態(正解データ)を”決定木学習”させてる.
・移動の判定
同じくある時間幅分区切った特徴量(集約値)をクラスタリングして,移動の判定をする感じ.


今の段階では,どちらの特徴量(集約値)も時間幅で平均化しただけのもの.
どのような状態を経てきたのかという情報が抜けてる.

どのような状態を経てきたのかという情報が入れば,もっと正確な在席判定・移動の判定ができるのじゃないかなって思ってる.


具体的には,
1つのセンサノードから得られる時系列データをデータストリーム1つと考えてそれをある時間幅(セグメント)で区切って,それをクラスタリングする.
そして,その結果を複数のセンサノードのデータとして状態の正解データと共に決定木学習させれば,より精度のある在席判定・移動の判定ができるんじゃないかな??


それと,こうすることで”在席判定”と”移動の判定”を一緒に考えることができると思うんだ.


課題としては,各フェーズ毎にクラスタリングするから,データの特徴が失われる可能性も多いにあるね・・データの損失と,データの集約・簡略化がいい感じでできるところがあればいいね~^^


◆計画
シングルストリームの時系列クラスタリングと,それからのマルチストリームの決定木学習のプログラムを来週までに.

メインは,どんな特徴量を入れれば精度のいい判定ができるかだから,”まなみたいに”サクサクッとやらんとね♪♪


・・・日記が,徒然なるままにだなぁww

2010年9月10日金曜日

VMwareでCDマウントしてくんない!と,HMMの話

◆VMwareでCD-ROMをマウントしてくれない時の対処法





◆HMM(隠れマルコフモデル)
時系列のデータ系列から,状態推定するためのモデル.
ちなみに,なんでマルコフモデルって言うかは,次状態は1つ前の状態つまり現状態のみにしか依存しないから♪らしい.でも,あんま理解してないから調べてちょw

で,隠れマルコフってのは何か?
状態遷移確率A(*図のカッコの上)と出力シンボル確率B(状態aのときにシンボルoを出す確率)(*図のカッコの中)と初期状態確率π
で,出力シンボル系列(出力データ)が決まるよbってこと♪


もし系列aabが出力されたときの出力確率を求めたいと思ったら,(一応最終状態:S3)
系列abbを出力するのは1):(s1)->s1->s2->s3, 2):(s1)->s2->s2->s3, 3)(s1)->s1->s1->s3の3通りだから,

  • 1) (0.3*0.8)*(0.5*1.0)*(0.6*0.5)=x
  • 2) (0.5*1.0)*(0.4*0.3)*(0.6*0.5)=y
  • 3) (0.3*0.8)*(0.3*0.8)*(0.2*0.1)=z
  の合計値が出力確率♪♪案外簡単なアルゴリズム.(なんでずっと悩んでたんだ。。ww)
  出力確率が一番高い状態系列を推定するのが,Viterbiアルゴリズム(形態素解析とかで使うらしい).上の三つの中で一番出力確率が高いxが通ってきた状態系列だよね?って感じみたい♪


  計算がめんどいから,いろんなアルゴリズムが考えられてるらしい.それと,HMMモデルを構成するパラメータを推定する方法にBaum-Welchアルゴリズムってのがあるみたい.


引用:http://unicorn.ike.tottori-u.ac.jp/murakami/doctor/node13.html

2010年9月9日木曜日

Macのバッテリの儀式

Macのバッテリを初めて使うときには,儀式がいるらしいー.

目的:バッテリーに満腹状態と空腹状態を認識させるためだってb


ちなみに,BootCampでWindows使っているので,それ仕様♪w

1)満充電にして,さらに2時間程充電.

2)バッテリー起動に切り替えて,強制スリープかかる手前まで待つ.

3)強制スリープ掛かりそうになったら,MacOSに切り替える.
  -Macのスリープ機能を切っておくこと♪

4)強制スリープ掛かってから,5時間放置b

===終了♪♪


参考URL:
http://support.apple.com/kb/HT1490?viewlocale=ja_JP&locale=ja_JP
http://canopus811.air-nifty.com/blog/2006/06/post_af66.html

2010年9月7日火曜日

初ブログ♪

今回の日記が初ブログ♪♪

まぁ,自分の備忘録っすねー.


javaのJFreechartで書いたグラフをphpで書き直すって・・・

phpのxml/swf Chartっていうので書いたんだが,

使い方知らんから時間かかって.

次はもっと早く書く♪


実働時間:8月23日~9月4日(10日間ぐらい)


あんまりグラフを重ねすぎると,htmlか何かでタイムアウトする・・・


タイムアウトを延ばすか?それとも,ここのグラフ別個に・・関係ないな!


てことは,短い時間専用のグラフ。。マジ意味ねぇwww

でもだよ!webブラウザで見るグラフってもうできてるし,だいじょうぶだ.


ってことは,会議までに時系列クラスタリングを道すじ建てないと・・・




今日のおさらい.

・html
-フォーム
-table

・phpの値渡し
-$data=$_POST['data'];