parent
b413f3de47
commit
531893d1c5
1 changed files with 66 additions and 0 deletions
@ -0,0 +1,66 @@ |
||||
<?xml version='1.0' encoding='UTF-8'?> |
||||
<root> |
||||
<tabbed_widget parent="main_window" name="Main Window"> |
||||
<Tab tab_name="tab1" containers="1"> |
||||
<Container> |
||||
<DockSplitter orientation="-" sizes="0.24977;0.250689;0.24977;0.24977" count="4"> |
||||
<DockArea name="..."> |
||||
<plot flip_y="false" flip_x="false" style="Lines" mode="TimeSeries"> |
||||
<range left="0.000000" right="1678.753571" bottom="-0.025000" top="1.025000"/> |
||||
<limitY/> |
||||
<curve name="/gpsLocationExternal/hasFix" color="#1f77b4"/> |
||||
</plot> |
||||
</DockArea> |
||||
<DockArea name="..."> |
||||
<plot flip_y="false" flip_x="false" style="Lines" mode="TimeSeries"> |
||||
<range left="0.000000" right="1678.753571" bottom="-0.425000" top="17.425000"/> |
||||
<limitY/> |
||||
<curve name="/gpsLocationExternal/satelliteCount" color="#d62728"/> |
||||
</plot> |
||||
</DockArea> |
||||
<DockArea name="..."> |
||||
<plot flip_y="false" flip_x="false" style="Lines" mode="TimeSeries"> |
||||
<range left="0.000000" right="1678.753571" bottom="0.000000" top="3.000000"/> |
||||
<limitY max="3" min="0"/> |
||||
<curve name="/gpsLocationExternal/horizontalAccuracy" color="#1ac938"/> |
||||
</plot> |
||||
</DockArea> |
||||
<DockArea name="..."> |
||||
<plot flip_y="false" flip_x="false" style="Lines" mode="TimeSeries"> |
||||
<range left="0.000000" right="1678.753571" bottom="-17.262000" top="766.374004"/> |
||||
<limitY/> |
||||
<curve name="/gpsLocationExternal/horizontalAccuracy" color="#1ac938"/> |
||||
</plot> |
||||
</DockArea> |
||||
</DockSplitter> |
||||
</Container> |
||||
</Tab> |
||||
<currentTabIndex index="0"/> |
||||
</tabbed_widget> |
||||
<use_relative_time_offset enabled="1"/> |
||||
<!-- - - - - - - - - - - - - - - --> |
||||
<!-- - - - - - - - - - - - - - - --> |
||||
<Plugins> |
||||
<plugin ID="DataLoad CSV"> |
||||
<default time_axis="" delimiter="0"/> |
||||
</plugin> |
||||
<plugin ID="DataLoad Rlog"/> |
||||
<plugin ID="DataLoad ULog"/> |
||||
<plugin ID="Cereal Subscriber"/> |
||||
<plugin ID="UDP Server"/> |
||||
<plugin ID="WebSocket Server"/> |
||||
<plugin ID="ZMQ Subscriber"/> |
||||
<plugin ID="Fast Fourier Transform"/> |
||||
<plugin ID="Quaternion to RPY"/> |
||||
<plugin ID="Reactive Script Editor"> |
||||
<library code="--[[ Helper function to create a series from arrays

 new_series: a series previously created with ScatterXY.new(name)
 prefix: prefix of the timeseries, before the index of the array
 suffix_X: suffix to complete the name of the series containing the X value. If [nil], use the index of the array.
 suffix_Y: suffix to complete the name of the series containing the Y value
 timestamp: usually the tracker_time variable
 
 Example:
 
 Assuming we have multiple series in the form:
 
 /trajectory/node.{X}/position/x
 /trajectory/node.{X}/position/y
 
 where {N} is the index of the array (integer). We can create a reactive series from the array with:
 
 new_series = ScatterXY.new("my_trajectory") 
 CreateSeriesFromArray( new_series, "/trajectory/node", "position/x", "position/y", tracker_time );
--]]

function CreateSeriesFromArray( new_series, prefix, suffix_X, suffix_Y, timestamp )
 
 --- clear previous values
 new_series:clear()
 
 --- Append points to new_series
 index = 0
 while(true) do

 x = index;
 -- if not nil, get the X coordinate from a series
 if suffix_X ~= nil then 
 series_x = TimeseriesView.find( string.format( "%s.%d/%s", prefix, index, suffix_X) )
 if series_x == nil then break end
 x = series_x:atTime(timestamp)	 
 end
 
 series_y = TimeseriesView.find( string.format( "%s.%d/%s", prefix, index, suffix_Y) )
 if series_y == nil then break end 
 y = series_y:atTime(timestamp)
 
 new_series:push_back(x,y)
 index = index+1
 end
end

--[[ Similar to the built-in function GetSeriesNames(), but select only the names with a give prefix. --]]

function GetSeriesNamesByPrefix(prefix)
 -- GetSeriesNames(9 is a built-in function
 all_names = GetSeriesNames()
 filtered_names = {}
 for i, name in ipairs(all_names) do
 -- check the prefix
 if name:find(prefix, 1, #prefix) then
 table.insert(filtered_names, name);
 end
 end
 return filtered_names
end

--[[ Modify an existing series, applying offsets to all their X and Y values

 series: an existing timeseries, obtained with TimeseriesView.find(name)
 delta_x: offset to apply to each x value
 delta_y: offset to apply to each y value 
 
--]]

function ApplyOffsetInPlace(series, delta_x, delta_y)
 -- use C++ indeces, not Lua indeces
 for index=0, series:size()-1 do
 x,y = series:at(index)
 series:set(index, x + delta_x, y + delta_y)
 end
end
"/> |
||||
<scripts/> |
||||
</plugin> |
||||
<plugin ID="CSV Exporter"/> |
||||
</Plugins> |
||||
<!-- - - - - - - - - - - - - - - --> |
||||
<customMathEquations/> |
||||
<snippets/> |
||||
<!-- - - - - - - - - - - - - - - --> |
||||
</root> |
||||
|
Loading…
Reference in new issue