preview
データ ストアからデータのサブセットを返す
説明
例
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
オブジェクトとして指定します。
出力引数
バージョン履歴
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)