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

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

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

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Python

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

Q&A

解決済

1回答

963閲覧

各行のpythonコードの意味を知りたいです。(時系列データのクロスバリデーション)

退会済みユーザー

退会済みユーザー

総合スコア0

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Python

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

0グッド

0クリップ

投稿2022/04/25 06:42

編集2022/04/25 06:53

以下のコードの中身を理解したいです。 自分なりの解釈は##に記載しました。
不明点と間違っている点を教えて頂きたいです。

参考URL:https://scikit-learn.org/stable/modules/generated/sklearn.model_selection.TimeSeriesSplit.html

どうぞ、ご教授の程よろしくお願いいたします。

python3

1 # sklearnライブラリーからTimeSeriesSplitのダウンロード。# 2>>> import numpy as np 3>>> from sklearn.model_selection import TimeSeriesSplit 4 # 配列の整理。# 5>>> X = np.array([[1, 2], [3, 4], [1, 2], [3, 4], [1, 2], [3, 4]]) 6>>> y = np.array([1, 2, 3, 4, 5, 6]) 7 # tscv関数の設定# 8>>> tscv = TimeSeriesSplit() 9 # tscvの表示# 10>>> print(tscv) 11 # gap=0  テストセット前に、分割部分の後ろから除外するデータ数# 12 # max train size = None 単一の訓練データの最大サイズ# 13 # n_split=5 時系列データを5分割にする。# 14 # test size = None 試験サイズはなし。# 15TimeSeriesSplit(gap=0, max_train_size=None, n_splits=5, test_size=None) 16 17#それぞれのXとYに指定のデータを挿入する# 18>>> for train_index, test_index in tscv.split(X): 19... print("TRAIN:", train_index, "TEST:", test_index) 20... X_train, X_test = X[train_index], X[test_index] 21... y_train, y_test = y[train_index], y[test_index] 22#TRAINデータでモデルを作り、TESTで試算する # 23TRAIN: [0] TEST: [1] 24TRAIN: [0 1] TEST: [2] 25TRAIN: [0 1 2] TEST: [3] 26TRAIN: [0 1 2 3] TEST: [4] 27TRAIN: [0 1 2 3 4] TEST: [5] 28 #Fix test size to 2 with 12 samples の意味がわからない# 29>>> # Fix test_size to 2 with 12 samples 30 #Xのデータをランダムで12分割して、2個取り出すということ?# 31>>> X = np.random.randn(12, 2) 32 #ここの意味がわからない。# 33>>> y = np.random.randint(0, 2, 12) 34 #tscvの中の計算式で、3分割して、試験用データのサイズは2.2のサイズは?2個?# 35>>> tscv = TimeSeriesSplit(n_splits=3, test_size=2) 36#それぞれのXとYに指定のデータを挿入する# 37>>> for train_index, test_index in tscv.split(X): 38... print("TRAIN:", train_index, "TEST:", test_index) 39... X_train, X_test = X[train_index], X[test_index] 40... y_train, y_test = y[train_index], y[test_index] 41TRAIN: [0 1 2 3 4 5] TEST: [6 7] 42TRAIN: [0 1 2 3 4 5 6 7] TEST: [8 9] 43TRAIN: [0 1 2 3 4 5 6 7 8 9] TEST: [10 11] 44>>> # Add in a 2 period gap 45>>> tscv = TimeSeriesSplit(n_splits=3, test_size=2, gap=2) 46>>> for train_index, test_index in tscv.split(X): 47... print("TRAIN:", train_index, "TEST:", test_index) 48... X_train, X_test = X[train_index], X[test_index] 49... y_train, y_test = y[train_index], y[test_index] 50TRAIN: [0 1 2 3] TEST: [6 7] 51TRAIN: [0 1 2 3 4 5] TEST: [8 9] 52TRAIN: [0 1 2 3 4 5 6 7] TEST: [10 11]

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

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

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

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

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

guest

回答1

0

ベストアンサー

一通りコメントしました。

基本的なpythonの文法やクラスなどの構成要素の理解が足りていないと思います。
また、参照しているページはTimeSeriesSplitクラスの説明ですが、ここでは、何かを処理するようなことが書いてあるのでなく、そのクラスをどのように振る舞うのかが書いてあるということがわかっていないので、解釈ミスになっているように思います。


「TimeSeriesSplitのダウンロード。」
インポートとダウンロードは異なります。

「配列の整理。」
整理でなく生成です。この場合は特定の値を与えています。

「tscv関数の設定」
tscvは関数でなく変数です。変数にTimeSeriesSplitクラスのオブジェクトを作って束縛しています。

「それぞれのXとYに指定のデータを挿入する」
ここはfor文で回してsplitメソッドがどのようなことをするのかを見せているだけで特に何もしていません。

「Fix test_size to 2 with 12 samples」
ここまで使っていた Xとyは捨てて、テスト用のデータをを2つにするために、以下の部分で新しくXとyを設定しなおす。

「tscvの中の計算式で...」
tscvをテストが2つになるように再設定する。

「それぞれのXとYに指定のデータを挿入する」
tscvを作りなおしたので、for文で回してsplitメセッドがどのような値を生成するようになったか確認する。
テストデータが2つになってますよね。

「Add in a 2 period gap」
こんどはgapがどのように作用するのかを見ている。

投稿2022/04/25 11:01

TakaiY

総合スコア12765

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

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

退会済みユーザー

退会済みユーザー

2022/04/26 00:53

とてもご丁寧な解説をくださってありがとうございました。 ご指摘の通り、pythonは初級の本を1冊終わらせた程度であり、理解力が大きくかけています。 また、解釈ミスのご指摘ありがとうございました。 わからないまま、業務上対応しなければならず、頭を抱えていたのですが、ご教授頂き、大変助かりました。 本当にありがとうございました。 とても理解できました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問