readall
データ ストアのすべてのデータの読み取り
説明
例
matlab.io.datastore.sdidatastore オブジェクトは、シミュレーション データ インスペクター リポジトリ内の信号データを参照します。信号が大きすぎてメモリに入りきらない場合、sdidatastore オブジェクトを使用して手動でデータをインクリメンタルに処理するか、インクリメンタル処理をユーザーに代わって実行する、信号の tall timetable を作成します。
信号の sdidatastore の作成
sldemo_fuelsys モデルのシミュレーションを実行します。このモデルは、複数の信号をログに記録して、シミュレーション データ インスペクター リポジトリ内にデータを作成するよう構成されています。
mdl = "sldemo_fuelsys";
sim(mdl);ログに記録された信号データは、sldemo_fuelsys_output という名前の Simulink.SimulationData.Dataset オブジェクトに返されます。
sldemo_fuelsys_output
sldemo_fuelsys_output =
Simulink.SimulationData.Dataset 'sldemo_fuelsys_output' with 10 elements
Name BlockPath
______________ ________________________________________
1 [1x1 Signal] '' sldemo_fuelsys/EGO Fault Switch
2 [1x1 Signal] air_fuel_ratio sldemo_fuelsys/Engine Gas Dynamics
3 [1x1 Signal] '' sldemo_fuelsys/Engine Speed Fault Switch
4 [1x1 Signal] speed sldemo_fuelsys/Engine_Speed_Selector
5 [1x1 Signal] '' sldemo_fuelsys/MAP Fault Switch
6 [1x1 Signal] map sldemo_fuelsys/MAP_Selector
7 [1x1 Signal] ego sldemo_fuelsys/O2_Voltage_Selector
8 [1x1 Signal] '' ...o_fuelsys/Throttle Angle Fault Switch
9 [1x1 Signal] throttle sldemo_fuelsys/Throttle_Angle_Selector
10 [1x1 Signal] fuel sldemo_fuelsys/To Plant
- Use braces { } to access, modify, or add elements using index.
シミュレーション データ インスペクターのプログラムによるインターフェイスを使用して、speed という名前の信号の信号 ID を取得します。
runCount = Simulink.sdi.getRunCount;
latestRunID = Simulink.sdi.getRunIDByIndex(runCount);
latestRun = Simulink.sdi.getRun(latestRunID);
speedSigID = getSignalIDsByName(latestRun,"speed");信号 ID を使用して、speed 信号の sdidatastore オブジェクトを作成します。
speedSDIds = matlab.io.datastore.sdidatastore(speedSigID);
データストアの内容の確認
sdidatastore オブジェクトの Name プロパティをチェックして、想定のとおりの内容であることを確認します。
speedSDIds.Name
ans = 'speed'
また、関数 preview を使用して、信号内の最初の 10 個のサンプルを確認することもできます。
preview(speedSDIds)
ans=10×1 timetable
Time Data
______________ ______
0 sec 314.16
0.00056195 sec 314.16
0.0033717 sec 314.16
0.01 sec 314.16
0.02 sec 314.16
0.03 sec 314.16
0.04 sec 314.16
0.043098 sec 314.16
0.043098 sec 314.16
0.043098 sec 314.16
sdidatastore オブジェクトによる信号データの処理
信号が大きすぎてメモリに入りきらない場合、関数 read を使用して、シミュレーション データ インスペクター リポジトリからデータのチャンクを読み取り、データをインクリメンタルに処理することができます。関数 hasdata を、信号全体をインクリメンタルに処理する際の while ループの条件として使用します。たとえば、信号の最大値を見つけます。
latestMax = []; while hasdata(speedSDIds) speedChunk = read(speedSDIds); speedChunkData = speedChunk.Data; latestMax = max([speedChunkData; latestMax]); end latestMax
latestMax = 314.1593
各読み取り操作で、関数 read は、読み取り位置を次の読み取り操作の開始位置に更新します。sdidatastore オブジェクトの一部またはすべてを読み取った後、読み取り位置をリセットして、信号の先頭から再度開始できます。
reset(speedSDIds)
メモリ内の信号データの処理
sdidatastore オブジェクトで参照された信号がメモリに収まる場合、関数 read でデータをインクリメンタルに読み取って処理する代わりに、関数 readall を使用してすべての信号データをメモリに読み取って処理することができます。関数 readall は、すべての信号データを含む timetable を返します。
speedTimetable = readall(speedSDIds); speedMax = max(speedTimetable.Data)
speedMax = 314.1593
シミュレーションからのビッグ データをログに記録し、matlab.io.datastore.SimulationDatastore オブジェクトを操作してそのデータの一部を検査および解析できます。
モデルからのビッグ データのログ記録
モデル sldemo_fuelsys を開きます。
mdl = "sldemo_fuelsys";
open_system(mdl)[コンフィギュレーション パラメーター]、[データのインポート/エクスポート]、[データセットのデータをファイルにログ] を選択して、データを永続ストレージに記録します。あるいは、Dataset 形式を使用して、ワークスペースの代わりに MAT ファイルにプログラムによってデータを記録することができます。
set_param(mdl,"LoggingToFile","on")
モデルのシミュレーションを実行します。
sim(mdl);
現在のフォルダーに MAT ファイル out.mat が表示されます。ログに記録された信号データは、変数名 sldemo_fuelsys_out を使用して MAT ファイルに格納されます。
ログに記録された信号データを参照する DatasetRef オブジェクトを作成します。
DSRef = Simulink.SimulationData.DatasetRef("out.mat","sldemo_fuelsys_output");
ビッグ データのプレビュー
中かっこを使用して、fuel 信号の SimulationDatastore 表現を返します。これは、DatasetRef オブジェクト DSRef の 10 番目の要素になります。SimulationDatastore オブジェクトは、返される Signal オブジェクトの Values プロパティに存在します。
SimDataSig = DSRef{10};
DStore = SimDataSig.Values;関数 preview を使用して、fuel 信号のログに記録されたデータの最初の 10 個のサンプルを検査します。
preview(DStore)
ans=10×1 timetable
Time Data
______________ ______
0 sec 1.2855
0.00056195 sec 1.2855
0.0033717 sec 1.2855
0.01 sec 1.2398
0.02 sec 1.199
0.03 sec 1.1628
0.04 sec 1.1309
0.043098 sec 1.1309
0.043098 sec 1.1309
0.043098 sec 1.1309
特定のサンプルの検査
ログに記録された fuel データの 603 番目のサンプルを検査するとします。DStore の ReadSize プロパティを、メモリ リソースを考慮して、コンピューターで許容できる数値に設定します。たとえば、ReadSize を 200 に設定します。
DStore.ReadSize = 200;
データ ストアから 3 回読み取りを実行します。各読み取り操作で、読み取り位置は 200 サンプル進みます。
read(DStore); read(DStore); read(DStore);
603 番目のサンプルに近くなったため、ReadSize を小さい数値に設定して、ターゲット サンプルを見つけやすくします。たとえば、ReadSize を 5 に設定します。
DStore.ReadSize = 5;
データ ストアからの読み込みを再度実行します。読み取られたデータの 3 番目のサンプルは、データ ストアの 603 番目のサンプルになります。
read(DStore)
ans=5×1 timetable
Time Data
________ ______
5.83 sec 1.6609
5.84 sec 1.6733
5.85 sec 1.6831
5.86 sec 1.691
5.87 sec 1.6975
以前のサンプルの検査
以前のサンプルを検査することもできます。たとえば、ログに記録された fuel データの 403 番目のサンプルを検査します。前の読み取り操作により、データストアは 606 番目のサンプルから読み取りを開始します。
関数 reset を使用して、DStore をリセットします。その後、最初のサンプルから 403 番目のサンプルまでを読み取ります。
reset(DStore);
ReadSize を 200 に設定します。
DStore.ReadSize = 200;
データ ストアから 2 回読み取り、読み取り位置を 401 番目のサンプルに進めます。
read(DStore); read(DStore);
ReadSize を 5 に設定してデータストアから読み取ります。ここで、読み取られたデータの 3 番目のサンプルが、データストアの 403 番目のサンプルになります。
DStore.ReadSize = 5; read(DStore)
ans=5×1 timetable
Time Data
________ _______
3.86 sec 0.9895
3.87 sec 0.98253
3.88 sec 0.97559
3.89 sec 0.96867
3.9 sec 0.96178
複数のサンプルの抽出
関数 read を使用して、複数のサンプルを抽出することもできます。たとえば、サンプル 1001 ~ 1020 を抽出します。
データ ストアをリセットします。次に、ReadSize プロパティを 200 に設定してデータストアを 5 回読み取り、サンプル 1001 に進みます。
reset(DStore) DStore.ReadSize = 200; for i = 1:5 read(DStore); end
ReadSize を 20 に設定して、データストアから 20 サンプルを抽出します。
DStore.ReadSize = 20;
サンプル 1001 ~ 1020 を抽出します。抽出したデータを targetSamples という名前の変数に格納します。
targetSamples = read(DStore)
targetSamples=20×1 timetable
Time Data
________ ______
9.77 sec 1.68
9.78 sec 1.6856
9.79 sec 1.6905
9.8 sec 1.6948
9.81 sec 1.6812
9.82 sec 1.6714
9.83 sec 1.6642
9.84 sec 1.659
9.85 sec 1.6553
9.86 sec 1.6527
9.87 sec 1.6684
9.88 sec 1.6806
9.89 sec 1.6904
9.9 sec 1.6982
9.91 sec 1.7047
9.92 sec 1.7101
⋮
データ ストア内のデータの最大値の検出
関数 hasdata を while ループの条件として使用し、200 サンプルのチャンク単位でデータをインクリメンタルに解析します。
reset(DStore); DStore.ReadSize = 200; runningMax = []; while hasdata(DStore) tt = read(DStore); rawChunk = tt.Data; runningMax = max([rawChunk; runningMax]); end
変数 runningMax にはデータストア全体における最大値が格納されます。
runningMax
runningMax = 1.7291
入力引数
読み取るデータストア。matlab.io.datastore.sdidatastore オブジェクトまたは matlab.io.datastore.SimulationDatastore オブジェクトとして指定します。
代替方法
信号がメモリに収まる場合、Simulink.sdi.Signal オブジェクトや Simulink.SimulationData.Signal オブジェクトなど、他のオブジェクトや関数を使用して、シミュレーション データにアクセスし、処理することができます。
バージョン履歴
R2017b で導入
MATLAB Command
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
Web サイトの選択
Web サイトを選択すると、翻訳されたコンテンツにアクセスし、地域のイベントやサービスを確認できます。現在の位置情報に基づき、次のサイトの選択を推奨します:
また、以下のリストから Web サイトを選択することもできます。
最適なサイトパフォーマンスの取得方法
中国のサイト (中国語または英語) を選択することで、最適なサイトパフォーマンスが得られます。その他の国の MathWorks のサイトは、お客様の地域からのアクセスが最適化されていません。
南北アメリカ
- América Latina (Español)
- Canada (English)
- United States (English)
ヨーロッパ
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)