目的としては、為替の予測をLSTMを用いて行いたいです。
その際に、訓練データは2018.7.2から2019.6.15のデータを用いて2019.7.1から2週間分の予測を行いたいです。

訓練データとテストデータの間の期間を空けて予測したいです。
このようなことは可能なのでしょうか。

フィッティングまでのコードを以下のように書いてみました。
LSTM初心者なので何かアドバイスもあれば嬉しいです。

訓練データとテストデータが時系列的に繋がっていれば予測はできるのですが、今回は空白の期間があった時の予測についてアドバイスが欲しいです。
よろしくお願いします。

空白にする意図としては、最終的にはリアルタイムで予測したいので空白の期間を設けて予測しようと考えています。

使用したデータは以下のリンクからダウンロードしました。

https://jp.investing.com/currencies/usd-jpy-historical-data

import pandas as pd
import datetime as dt
import matplotlib.pyplot as plt
import numpy as np
import time

# 為替データ読み込み
usd_jpy = pd.read_csv("USD_JPY.csv")
usd_jpy.columns = ['Date', 'Close', 'Open', 'High', 'Low', 'Volume']
#Datetime型に変換
usd_jpy['Date'] = pd.to_datetime(usd_jpy['Date'], format='%Y年%m月%d日')
#日付の古い順にソート
usd_jpy = usd_jpy.sort_values(by='Date')

#訓練データ
train = usd_jpy[(usd_jpy['Date'] >= dt.datetime(2018,7,2)) & (usd_jpy['Date'] < dt.datetime(2019,6,15))]

#テストデータ
test = usd_jpy[(usd_jpy['Date'] >= dt.datetime(2019,6,30))]

#LSTMのウィンドウサイズ
window_len = 10

del train['Date']
del test['Date']
del train['Volume']
del test['Volume']

# LSTMへの入力用に処理(訓練)
train_lstm_in = []
for i in range(len(train) - window_len):
    temp = train[i:(i + window_len)].copy()
    for col in train:
        temp.loc[:, col] = temp[col] / temp[col].iloc[0] - 1
    train_lstm_in.append(temp)
lstm_train_out = (train['Close'][window_len:].values / train['Close'][:-window_len].values)-1

# LSTMへの入力用に処理(テスト)
test_lstm_in = []
for i in range(len(test) - window_len):
    temp = test[i:(i + window_len)].copy()
    for col in test:
        temp.loc[:, col] = temp[col] / temp[col].iloc[0] - 1
    test_lstm_in.append(temp)
lstm_test_out = (test['Close'][window_len:].values / test['Close'][:-window_len].values)-1

# PandasのデータフレームからNumpy配列へ変換
train_lstm_in = [np.array(train_lstm_input) for train_lstm_input in train_lstm_in]
train_lstm_in = np.array(train_lstm_in)
test_lstm_in = [np.array(test_lstm_input) for test_lstm_input in test_lstm_in]
test_lstm_in = np.array(test_lstm_in)

# ランダムシードの設定
np.random.seed(202)

# 初期モデルの構築
yen_model = build_model(train_lstm_in, output_size=1, neurons = 20)

# フィッティング
yen_history = yen_model.fit(train_lstm_in, lstm_train_out, 
                            nb_epoch=50, batch_size=1, verbose=2, shuffle=True)