質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

1823閲覧

pythonで疑似乱数をつくりたい

benigmaet

総合スコア19

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2016/11/20 15:18

python ```###前提・実現したいこと 0から1までの疑似乱数を発生させ、発生させた乱数をχ二乗検定したい。 階級は0~0.1,0.1~0.2......0.9~1.0 ###発生している問題・エラーメッセージ f_kx[j]+=1 IndexError:list index out of range 階級ごとの度数をもとめられない ###該当のソースコード ```ここに言語を入力 ```ここに言語を入力 N=10000 #乱数の数 M=10 x=[] f_kx=[] a=1229 c=351750 m=1664501 s=r=300 for i in range(N): #乱数発生 r=float((a*r+c)%m) x.append(r/m) for j in range(M): if (x[i]>j*0.1) and (x[i]<=j*0.1+0.1):#階級ごとに f_kx[j]+=1 for j in range(M):print(f_kx[j])

###試したこと
cでは疑似乱数を発生することができた

#define N 10000 #define M 10 int main(void){ int i,j; int f_kx[M]; int a=1229,c=351750,m=1664501,s=300,r=300; double x[N]; double kai,e_k; for(j=0;j<M;j++){//f_kxの初期化 f_kx[i]=0; } for(i=0;i<N;i++){//乱数発生 r=(a*r+c)%m; x[i]=r/m; for(j=0;j<M;j++){ if(x[i]>j*0.1&&x[i]<=j*0.1+0.1{ //階級ごとに f_kx[j]++; } } } for(i=0;i<M;i++){ //χ二乗検定 e_k=N*(i*0.1+0.1-i*0.1){ kai=((f_kx[i]-e_k)*(f_kx[i]-e_k)/e_k)+kai; } printf("χ^2=%f\n",kai); }

###補足情報(言語/FW/ツール等のバージョンなど)

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

KSwordOfHaste

2016/11/20 15:32

import randomすればrandom.random()で0.0~1.0の疑似乱数が得られるようです。f_kx[j]で要素にアクセスする前に要素をappendしないといけないように見えます。ちなみにコード開始タグ```の直後に言語名を書きましょう。```pythonとか```cといった感じです。
MasahikoHirata

2016/11/20 16:48

cでの例の’if(x[i]>j*0.1&&x[i]<=j*0.1+0.1{ //階級ごとに ’にてif文の')'が無いのですが。これ動きました?
benigmaet

2016/11/20 17:41

すみません。ご指摘ありがとうございます。今月pythonを始めたばかりで、できればどうf_kxの要素をappendを用いて書けばいいのか教えてもらえないでしょうか。
KSwordOfHaste

2016/11/21 04:31

すみません!pythonをよく知らずにコメントしてました。上で使っているのは配列じゃなくてlistですね。listへの要素の追加はご質問のコード中にもあるappendメソッドを使うようです。
guest

回答1

0

ベストアンサー

PythonのソースにCのソースで言う

C

1for(j=0;j<M;j++){//f_kxの初期化 2 f_kx[i]=0; 3}

に相当する部分がないため、f_kxは長さ0のリストになっており、f_kx[j]+=1で長さを超えるインデックスアクセスを行うため、インデックスエラーになるようです。

全ての値が0で長さMの配列が必要であれば、このように書きます。

Python

1f_kx = [0] * M

これを適当に追加すれば動くようになるでしょう。

投稿2016/11/20 22:17

raccy

総合スコア21735

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問