質問
Pythonを用いて、Kerasによる機械学習の検証を行っております。
モデルの性能比較等のために計算の再現性を確保したかったため、
ネットで方法を調べ、下記コードを使用しています。
結果として、ある程度の検証結果の再現性を確保できたのですが、
若干のばらつきがあり、モデルのAccuracyが1%程度、
F1値にいたっては数%ずれることがあります。
上記の件を改善したいのですが、Pythonやコンピュータの仕様上、
完全な再現性確保は難しいのでしょうか。
ご教授いただければ幸いです。
現在使用しているコード
python
1 2import random 3import tensorflow as tf 4 5random_state = 42 6 7def seed_everything(seed=random_state): 8 random.seed(seed) 9 os.environ['PYTHONHASHSEED'] = str(seed) 10 np.random.seed(seed) 11 tf.random.set_seed(seed) 12 session_conf = tf.compat.v1.ConfigProto( 13 intra_op_parallelism_threads=1, 14 inter_op_parallelism_threads=1 15 ) 16 sess = tf.compat.v1.Session(graph=tf.compat.v1.get_default_graph(), config=session_conf) 17 tf.compat.v1.keras.backend.set_session(sess) 18 19seed_everything(random_state) 20
乱数が適応されている項目
・sklearn.model_selection.train_test_split
・keras.models.Model.fit_generator
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。