前提
MATLAB でPythonファイルの実行方法について
MATLABを使用してPythonファイルを実行し、その結果を出力しようと考えています。
MATLABで"ex1.mat"を保存し、Pythonで”ex1.mat"を保存し、pyhtonプログラムを実行し、pythonの結果をエクセル'予測結果.xls'に出力し、MATLABでその結果を出力しようとしています。
実現したいこと
ここに実現したいことを箇条書きで書いてください。
- [MATLABを使用しPythonファイルを実行
発生している問題・エラーメッセージ
"N-beats forecast.py"
No Python documentation found for 'data'.
Use help() to get the interactive help utility.
Use help(str) for help on the str class.
該当のソースコード
MATLAB
1pyExec = 'C:\Users\....\PycharmProjects\pythonProject6\venv\Scripts\python.exe'; 2ex1 = trainX(:,1); 3 4save C:/Users/takaa/PycharmProjects/pythonProject6/ex1 ex1 5%pythonのプログラムの実行 6scriptname="N-beats forecast.py" 7 8status = dos(scriptname); 9 10M = readmatrix('C:/Users/.../PycharmProjects/pythonProject6/予測結果.xls'); 11YPredStandardized(1,:)=M(2:end,2);
Python
1import pandas as pd 2import numpy as np 3from nbeats_forecast import NBeats 4from torch import optim 5#現在のパス取得 6import os 7cwd = os.getcwd() 8print(cwd) 9from scipy.io import loadmat 10 11data = loadmat("ex1.mat") 12data = np.array(data['ex1']) #ex1.mat ファイルの"ex1"の名前を検索し 13print(data) 14#print(data.shape) 15model = NBeats(data=data, period_to_forecast=24)#タイムステップ12 12時間予測している 16 17model.fit(epoch=10,optimiser=optim.AdamW(model.parameters, lr=0.001, betas=(0.9, 0.999), eps=1e-08, weight_decay=0.01, amsgrad=False)) 18 19#model.fit() 20forecast = model.predict() 21print('forecast',forecast) 22print('forecastのタイプ',type(forecast)) 23 24 25df = pd.DataFrame(forecast) 26#df = pd.DataFrame([forecast]) #index横、colummns列名 27print('forecastのタイプ',type(df)) 28 29#pythonの結果をエクセルに出力 30with pd.ExcelWriter('予測結果.xls') as writer: 31 df.to_excel(writer, sheet_name='forecast')
試したこと
ここに問題に対して試したことを記載してください。
補足情報(FW/ツールのバージョンなど)
pyhton3.8 MATLAB2021b
回答2件
あなたの回答
tips
プレビュー