Main Content



Read all data from an sdidatastore


data = sdi_ds.readall


data = sdi_ds.readall reads all the data in the, sdi_ds, into memory, returning the timetable, data. Use readall only when the signal referenced by the fits into memory.

Output Arguments

expand all

All the data in the, returned in a timetable.


expand all

A references signal data in the Simulation Data Inspector repository. When the signal is too large to fit into memory, you can use the to incrementally process the data manually or to create a tall timetable for the signal that handles the incremental processing for you. This example shows how to process data using a

Create a for a Signal

Simulate the sldemo_fuelsys model, which is configured to log several signals, to create data in the Simulation Data Inspector repository.


Use the Simulation Data Inspector programmatic interface to get the signal ID for the signal.

runCount = Simulink.sdi.getRunCount;

latestRunID = Simulink.sdi.getRunIDByIndex(runCount);

latestRun = Simulink.sdi.getRun(latestRunID);

speedSigID = latestRun.getSignalIDByIndex(4);

Use the signal ID to create a for the speed signal.

speedSDIds =;

Verify the Contents of the Datastore

Check the Name property of the to verify that it matches your expectations.

ans = 

You can also use the preview method to check that the first ten samples in the signal look correct.

ans=10×1 timetable
         Time          Data  
    ______________    _______

    0 sec               0.589
    0.00056199 sec    0.58772
    0.0033719 sec     0.58148
    0.01 sec          0.56765
    0.02 sec          0.54897
    0.03 sec          0.53264
    0.04 sec          0.51837
    0.05 sec          0.50594
    0.055328 sec          0.5
    0.055328 sec          0.5

Process Signal Data with the

When your signal is too large to fit into memory, you can use the readData method to read chunks of data from the Simulation Data Inspector repository to incrementally process your data. Use the hasdata method as the condition for a while loop to incrementally process the whole signal. For example, find the maximum signal value.

latestMax = [];

while speedSDIds.hasdata
    speedChunk =;
    speedChunkData = speedChunk.Data;
    latestMax = max([speedChunkData; latestMax]);

latestMax = 0.8897

On each read operation, the read method updates the read position for the start of the next read operation. After reading some or all of the, you can reset the read position to start again from the beginning of the signal.


Process Signal Data in Memory

When the signal referenced by your fits into memory, you can use the readall method to read all the signal data into memory for processing, rather than reading and processing the data incrementally with the read method. The readall method returns a timetable with all the signal data.

speedTimetable = speedSDIds.readall;

speedMax = max(speedTimetable.Data)
speedMax = 0.8897


When your signals fit into memory, you can use other classes and functions of the Simulation Data Inspector programmatic interface, like the Simulink.sdi.Signal class, to access and process simulation data.

Version History

Introduced in R2017b