プログラミングが得意な方お願いします。
下図のリンクのページランクをPerlで実装したいのですが、
まずPDLモジュールをダウンロードし、リンク隣接行列を下記のように定義しました。
use PDL::Lite;
my $mat1 = pdl [
[0, 1, 1/2, 0, 1/4, 1/2, 0],
[1/5, 0, 1/2, 1/3, 0, 0, 0],
[1/5, 0, 0, 1/3, 1/4, 0, 0],
[1/5, 0, 0, 0, 1/4, 0, 0],
[1/5, 0, 0, 1/3, 0, 1/2, 1],
[0, 0, 0, 0, 1/4, 0, 0],
[1/5, 0, 0, 0, 0, 0, 0]
];
そして下記の列ベクトルと上記の行列をかけてその答えと上記の行列をかけてさらにその答えと上記の行列をかけて・・・を繰り返し、掛けても答えが変わらなくなったところでその列ベクトルの値を取り出し正規化して出力するという方法を考えました。
my $mat2 = pdl [
[1],
[1],
[1],
[1],
[1],
[1],
[1]
];
ここで質問ですが、上記の処理をwhile文で実行したいのですが掛けても答えが変わらなくなったところでwhileからループを抜ける処理はどのように書いたら良いのでしょうか?
Perlは初心者で、行列同士の比較はwhileの条件文ではできないでしょうし、列ベクトルの要素を一つ一つ比較する方法も分かりません。
以上写真のページランクをperlで取得する方法、宜しくお願い致します。
No.5ベストアンサー
- 回答日時:
use PDL::Ufunc;
を追加し、次でループ脱出
if(all $ans_now == $ans_before){last;}
ただし、$ans_nowは今回の演算結果, $ans_beforeは前回の演算結果
PDLのhelp allより:
=======================
Module PDL::Ufunc
all
Return true if all elements in piddle set
...(snip)
=======================
No.3
- 回答日時:
表示がくずれるので、空白2文字を全角空白にしていることに注意。
use feature 'say';
use PDL;
my $matrix1 = pdl( [ [ 1, 2 ], [ 3, 4 ] ] );
print '--- matrix1', $matrix1;
# --- matrix1
# [
# [1 2]
# [3 4]
# ]
my $vector1 = pdl( [ [5], [6] ] );
print '--- vector1', $vector1;
# --- vector1
# [
# [5]
# [6]
# ]
my $answer = $matrix1 x $vector1;
print '--- answer', $answer;
# --- answer
# [
# [17]
# [39]
# ]
my $vector2 = pdl( [ [7], [8] ] );
print '--- vector2', $vector2;
if ( compare_vector($vector1,$vector2) ) {
say '$vector1 == $vector2';
}
else {
say '$vector1 != $vector2';
}
# --- vector2
# [
# [7]
# [8]
# ]
# $vector1 != $vector2
my $vector3 = pdl( [ [5], [6] ] );
print '--- vector3', $vector3;
if ( compare_vector($vector1, $vector3) ) {
say '$vector1 == $vector3';
}
else {
say '$vector1 != $vector3';
}
# --- vector3
# [
# [5]
# [6]
# ]
# $vector1 == $vector3
sub compare_vector {
my $v1 = shift;
my $v2 = shift;
if ($v1->getndims != $v2->getndims) {
return 0;
}
my $dims = $v1->getndims;
for (my $i = 0; $i < $dims; $i++) {
if ($v1->at(0, $i) != $v2->at(0, $i)) {
return 0;
}
}
return 1;
}
No.1
- 回答日時:
課題なのか何なのかよくわかりませんが、
ここで聞いてバレたら面倒なことになるとは想像できないんですか?
この回答への補足
課題ではありません。
mat1×mat2を実行し、その答え(当然7行1列)にさらにmat1をかけ、その掛けた答えにさらにmat1を掛けるという動作を繰り返していくと、いずれその答えがほとんど変わらなくなります。その部分で、whileなりfor文から抜け出してその変わらなくなった答え(当然7行1列)を出力したいのです。
そのプログラムを教えて頂ければ幸いです。
PDLをダウンロードしました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
画像が表示でnull; this.src
-
テキストファイルで提出とは?
-
INDIRECT 横に再度抽出したい
-
アルファベットに付いて質問し...
-
Perl 特定のフォルダ以外削除
-
Perl言語について。
-
ファイルをディレクトリ分配の...
-
#!/usr/bin/perlで書きだしたCG...
-
Perlのエラーについてご教授く...
-
perlのflock関数でロックをかけ...
-
AI sisterとは、偽物の人ですか?
-
bashスクリプト
-
ファイルアイコンの左下に緑の□...
-
perlプログラミング 空白行削除
-
perlでリテラル値はメモリにど...
-
perlで2次元配列をサブルーチ...
-
Perlで時間の計算
-
perlについて
-
perlのrequireの動き方について...
-
perlの構文でカンマの意味が分...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Perlで複数の値を返す良い方法...
-
【perl】Net pingの結果をHTML...
-
print <<"_HTML_"の中でサブル...
-
Perlで足し算をするには
-
icmp socket error
-
プロトタイプ宣言のワーニング...
-
ハノイの塔の問題で困っており...
-
Perlで自分自身の関数名を知る...
-
perlのスクリプトどこが間違っ...
-
連想配列とforeach
-
Net::Telnetでタイムアウト時間...
-
内部処理形式が日付型 (Date) ...
-
[perl] next と return 同じ意...
-
HASH(0xほげほげ)
-
CGIから複数の別プログラムを同...
-
Perlのプログラミングに困って...
-
LISPで連想配列の操作?
-
Rubyのgets関数について
-
perl XMLの入れ子取得方法
-
for文の中でのforeachの問題
おすすめ情報