TSView Time Series Viewing Tools
- Overview
- Time Series Terminology
- Time Series Properties Interface
- Time Series Traces
- Time Series Views- Time Series Graph View
- Time Series Product Properties- Product Properties - General
- Product Properties - Titles
- Product Properties - Layout
- Graph Properties - General
- Graph Properties - Graph Type
- Graph Properties - Titles
- Graph Properties - X Axis
- Graph Properties - Y Axis
- Graph Properties - Data Point Label
- Graph Properties - Legend
- Graph Properties - Zoom
- Graph Properties - Analysis
- Graph Properties - Annotations
- Time Series Properties - General
- Time Series Properties - Graph Type
- Time Series Properties - Axes
- Time Series Properties - Symbol
- Time Series Properties - Label
- Time Series Properties - Legend
- Time Series Properties - Analysis
 
- Changing a Graph Page Layout
- Time Series Summary View
- Time Series Table View
 
- Time Series Product Reference
- Time Series Graph Templates
Overview
The TSView package contains integrated software components that can be used with software applications to enable time series viewing capabilities. The main purpose of the TSView package is to provide simple, consistent, and flexible displays that can be used in a variety of applications with little or no reconfiguration. TSView also provides features to configure and process time series products (e.g., graphs), where the time series data are stored separately from the configuration information.
The TSView package has been developed using Java technology. TSView interfaces can be embedded in Java applications and can be used in web pages either as embedded applets or stand-alone windows. TSView tools operate similarly on various operating systems.
This appendix describes general TSView features and can be used as a reference for how to configure and use TSView components. Software program documentation may include specific information about using TSView features.
Time Series Terminology
The TSView package treats time series as objects that can be read, manipulated, and output in various formats. A time series is defined as having header information (attributes) and data, which usually consists of a series of date/time versus data pairs. Internally, time series are considered to have either regular interval (equal spacing of date/time) or irregular interval (e.g., occasional observations). Regular time series lend themselves to simpler storage and faster processing because date/time information can be stored only for the endpoints. The following basic attributes are stored for each time series:
- Data interval as an interval base (e.g., Month,Hour) and multiplier (e.g.,1for month, or24for hour) - in many cases, the multiplier is1and is not shown in output (e.g.,Monthrather than1Month)
- Data type (e.g., Streamflow), which ideally can be checked to determine whether a time series contains mean, instantaneous, or accumulated values
- Units (e.g., CFS), which ideally can be used to make units conversions and look up precision for output
- Period of record, using dates that are of an appropriate precision for the interval
- Data limits (the maximum, minimum, etc.)
- Description (generally a station, structure, or sensor name)
- Missing data value (used internally to mark missing data and trigger data filling, often -999,NaN, etc.)
- Comments (often station comments, if available)
- Genesis history (a list of comments about how the time series was created)
In order to uniquely and consistently identify time series, a multi-part time series identifier is employed, having the following parts:
- Location type (optional)
- Location (or location-sublocation)
- Data source
- Data type (or datatype-subdatatype)
- Data interval (time step)
- Scenario
and optionally:
- Sequence number for ensemble
- Datastore identifier (or legacy input type)
- Input name
These time series attributes are typically concatenated into a time series identifier string. The following example illustrates how the basic identifier parts can be used (without input type and name):
12345678.USGS.Streamflow.DAY.HIST
The above example identifies a USGS streamflow gage identified as location 12345678,
at which historic average daily flow data are available.
If possible, data types appropriate for the input type should be used to avoid confusion;
however, time series file input types often do not contain a simple data type
abbreviation (see the input type appendices for more information).
The above example illustrates that the scenario can be used to qualify the
data (in this case as historic data, HIST).  The scenario is often omitted.
When the scenario is used, it often indicates some specific condition
(e.g., FLOOD, DROUGHT, HIST, FILLED).
The optional datastore identifier (or input type and input name) are used to specify the time series input format and storage location, especially in cases where the identifier is saved in a file and the input type is needed for later processing. For example:
12345678.USGS.Streamflow.DAY.HIST~USGSNWIS~C:\data\12345678.txt
12345678.USGS.Streamflow.DAY~HydroBase
The first example illustrates a time series identifier for a USGS National Water Information System data file. The second example illustrates the identifier for the same time series, in the HydroBase database. Using the input parts of the identifier allows software to transparently locate the data, and for the above examples, would allow the time series to be read from each input source and compared.
The use of the datastore is being phased into TSView and related components. The TSTool appendices describe supported datastores and input type, and identify issues with compatibility. Using the above time series identifier convention omits use of time series attributes like the period of record and the units, even though these attributes could conceivably be used to distinguish between time series that are otherwise the same. Instead, it is assumed that the period of record and units can be determined from the input and do not need to be part of the identifier. If necessary, different input files can be used to further differentiate time series.
The TSView components use the time series identifiers extensively to locate and manage time series. For example, graph properties for each time series are cross-referenced to time series by using the identifiers. Perhaps most importantly, the time series identifiers as simple strings can be stored in files and can be used by a variety of software to consistently and reliably locate data for processing.
The following table summarizes important time series terminology.
Time Series Terminology (listed alphabetically)
| Term | Description | 
|---|---|
| Data Interval | Time interval between time series data values.  If a regular time series, the interval is constant.  If an irregular time series, the interval can vary.  Intervals are represented as an optional multiplier followed by a base interval string (e.g., 1MONTH,24HOUR) orIRREGULARfor irregular time series. | 
| Data Source | A string abbreviation for a data source, which is part of the time series identifier and typically indicates the origin of the data (e.g., an agency abbreviation, or a model name if the result of a simulation). | 
| Data Type | A string abbreviation for a data type, which is part of the time series identifier (e.g., Streamflow). | 
| Date/Time Precision | Date/time objects used with time series have a precision that corresponds to the time series data interval. The precision is typically handled transparently but it is important that the precision is consistent (e.g., monthly data should not use date/time objects with daily precision). Displaying time series with various precision usually results in the smallest time unit being used for labels. | 
| Datastore | A datastore identifier, corresponding to a database, web service, etc., used for new functionality instead of input type. | 
| Input Name | A string input name corresponding to an input type, which is part of a time series identifier.  For database input types, the name may be omitted or may be the name of the database connection (e.g., ARCHIVE).  For input files, the name is typically the name of the file. | 
| Input Type | A string abbreviation that indicates the input type (persistent format) for a time series, and is part of a time series identifier.  This is often the name of a database (e.g., HydroBase) or a standard data file format type (e.g.,StateMod,MODSIM,RiverWare). | 
| Location | A string identifier that is part of a time series identifier and typically identifies a time series as being associated with a location (e.g., a stream gage or sensor identifier). The location may be used with certain input types to determine additional information (e.g., station characteristics may be requested from a database table using the location). | 
| Scenario | A string label that is part of a time series identifier, and serves as a modifier for the identifier (e.g., HISTfor historical). | 
| Sequence Number | A number indicating the sequence position of a time series in a series. For example, possible time series traces may be identified with a sequence number matching the historical year for the data. The use of sequence numbers with traces is being evaluated. | 
| Time Series Product | A graph or report that can be defined and reproduced. See the Time Series Product Reference section. | 
| Time Step | See Data Interval. | 
Time Series Properties Interface
Time series properties are displayed in a tabbed panel as appropriate in applications (e.g., the TSTool application can display the properties after time series are read and listed in the TSTool interface). Differences between time series input types may result in variations in the properties (e.g., some input types do not have descriptions for time series). The following figures describe the properties tabs. The size of each tabbed panel is set to the size of the largest tab; therefore, some tabbed panels are not completely filled.
Time Series Properties - General

Time Series Properties - General
General time series properties are as follows:
- Identifier - The five-part time series identifier without the input type and name. This identifier is often used internally in applications to manage time series. See the Time Series Terminology section for a complete explanation of time series identifiers.
- Identifier (with input) - The full identifier, including the input type and name (if available). The datastore identifier (or input type and name) indicate the format and storage of the data.
- Alias - A time series may be assigned an alias to facilitate processing (e.g., the alias is used by the TSTool application in time series commands).
- Sequence (ensemble trace) ID - If the time series is part of a series of traces, the sequence number is used to identify the trace. Often it is the year for the start of the trace.
- Description - The description is a mid-length phrase (i.e.,
longer than the location but shorter than comments) describing the time series (e.g., XYZ RIVER AT ABC).
- Units (Current) - The units that are currently used for data. The units may have been converted from the original.
- Units (Original) - The units in the original data source.
Time Series Properties - (Dynamic) Properties

Time Series Properties – (Dynamic) Properties
Whereas the other properties tabs show built-in time series properties, the Properties tab lists dynamic properties that are associated with a time series. For example, a TSTool command file may assign properties to time series from the original data source, or based on quality control or other analysis.
Time Series Properties - Comments

Time Series Properties - Comments
Comments for time series can be created a number of ways and may be formatted specifically for an application. Common ways of creating comments are:
- Read comments from the original data source - this is ideal; however, electronic comments may not be available (e.g., the USGS previously published comments for data stations in hard copy water reports; however, comments may not be available electronically),
- Format comments from existing data (e.g., the figure illustrates a standard set of comments for State of Colorado data, using the HydroBase input type).
In the future, the time series dynamic properties may be used more and text comments less.
Time Series Properties - Period

Time Series Properties - Period
Properties related to the period are as follows:
- Current (reflects manipulation) - The current period is used to allocate computer memory for the time series data. This period may be set by an application (e.g., when creating model input files a specific period may be used). The precision of the date/time objects should generally be consistent with the time series data interval.
- Original (from input) - The original period can be used to indicate the full period available from a database. Setting the original period can sometimes be complicated by how missing data are handled (e.g., a database or file may indicate a certain period but a much shorter period is actually available).
- Total Points - Total number of data points. If a regular time series, this is computed from the period. If an irregular time series, the number of points is the count of all data values. The data points may include missing data – see the data limits for additional information.
Time Series Properties - Limits

Time Series Properties - Limits
Time series limits are determined for both the current data (top in figure) and the original data (bottom in figure). This is useful because the original data may contain missing data, which are later filled. The data limits are displayed consistent with the data interval. In the example shown, limits are computed for each month. For other time series having other intervals, only overall data limits may be computed. The monthly limits are used for filling with historical averages, but this does not make as much sense for smaller time series data intervals.
Theoretically, it is possible that a daily time series could have day limits (e.g., max/min values for each day of the year), month limits (e.g., computed as an average of the daily values by month), and year limits (e.g., computed as an average of all daily values in a year). However, automatically including this level of detail decreases performance and it is difficult to automatically make the right decisions (e.g., about whether to average or total values). Consequently, the limits are currently computed in a basic fashion on the raw data (no interval changes).
Time Series Properties - History

Time Series Properties - History
The time series history (sometimes called the genesis history) is a list of comments indicating how the time series has been processed. The completeness of this history is totally dependent on the time series input/output and manipulation software. Although efforts have been made to add appropriate comments as time series are processed, enhancements to the history comments are always being considered.
At the bottom of the history list (see Read From) is the input name that was actually used to read the data.
This input name may or may not be exactly the same as the input name in the time series identifier.
For example, if reading from a HydroBase database,
the time series identifier may specify an input type of HydroBase and no input name
(because the software knows from the other parts of the time series identifier which database tables to read).
However, it is also useful to know the actual table that is read
in order to help users and developers understand the data flow, and reference documentation.
If reading from a file input type, the Read From information will show the full path to the file;
however, the input name in the time series identifier may only include a relative path.
Time Series Properties - Data Flags

Time Series Properties - Data Flags
Time series data flags contain information that describe the quality of a data point.
The missing data value indicates a special value that is used to
indicate that a data value is missing at a point.
Currently only floating point values are recognized; however the NaN (not a number)
value is generally supported for input types that use the convention and is being
phased in where possible because there is less potential that a value such as -999 could be an actual value.
All time series are typically assigned a missing data value.
The Has Data Flags checkbox indicates whether the time series has data flags.
Data flags will generally be used, based on whether an input type supports data flags.
The USGS NWIS RDB file format is an example
of an input type that supports data flags (e.g., e is used to indicate estimated data).
The data flags can be displayed as labels on graphs and as superscript (or similar) on tabular data.
Unfortunately, data flags are not universally consistent and care
must be taken to understand their meaning, especially when using data from multiple sources.
Time Series Traces
In general, the term time series traces refers to a group of time series, often shown in overlapping fashion. Common uses of time series traces are:
- Separate a full time series into annual traces and plot them on top of each other, shifted so that they all start at the same date/time,
- Run a model or analytical tool multiple times, with input being a series of input traces, and generating a series of output traces, in order to produce probabilistic simulations.
The power of using traces is that a large amount of data can be used to visualize and study statistical qualities of the data, as shown in the following figure.

Example Graph for Time Series Traces
The TSView package supports time series traces at various levels.
Time series properties include a sequence number that can be used to
identify a time series as being in a group of traces, shown as [SequenceNumber] in time series identifiers.
Many TSTool commands process ensembles in addition to individual time series.
Leap year is handled by specific commands and visualization tools,
depending on whether the data sequence should be preserved, or should adhere to historical day.
For example, if data are represented in a non-leap year, then February 29 may be discarded.
If data are represented in a leap-year, missing values may be shown for February 29 for traces that did not occur in leap years.
Currently, applications like TSTool include features to create time series traces and TSView tools can be used to view the time series as if they were separate time series.
The following sections describe the different time series views that are available in TSView. Although most illustrations use simple time series, most features also are available for use with ensemble traces.
Time Series Views
The main components of the TSView package are configured to provide multiple views for time series data. The three main views that are available are:
- Graph - line, bar, or other graph
- Summary - text report suitable for the data type and interval
- Table - spreadsheet-like table with scrolling, suitable for export to other tools
The initial view for a time series list is typically determined from the actions of the software user. For example, a Graph button may be displayed on a screen, which when pressed will result in a graph being displayed. The time series that are displayed in the view can typically contain one or more time series (some graph types may have a restriction on the number of graph types). To increase performance and capacity, the TSView package as much as possible uses a single copy of the time series data for visualization. For example, to generate graphs, the data for the time series objects are used directly rather than being copied into a graphing tool's data space. This also allows TSView to more easily display different data intervals on the same view because the data do not need to be forced into a consistent grid data structure.
The following sections describe the three time series views. The graph view type requires more extensive explanation due to the variety of graph properties.
Time Series Graph View
The graph view for time series supports a variety of graph types. The features of the various graph types will be discussed in detail in the following sections, starting with basic graph types, followed by more specific types.
Typically, the graph type is selected in the application (e.g., menus are available in TSTool for selecting the graph type for a list of time series). In many applications, the graph type often defaults to a line graph. The following figure illustrates a line graph for two monthly streamflow time series showing the default appearance. Additional properties such as titles can be defined by editing product properties.

Example Line Graph for Monthly Streamflow
The graph view is divided into the following main areas:
- Graph Page - The graph page (drawing canvas) is the area where the graph and legend are drawn. This area is used to interact with the graph via the mouse cursor. More than one graph can be drawn in the page (see the Time Series Product Reference section for additional details). If zooming is supported for the graph, a box can be drawn with the mouse to zoom in to a shorter period. Right-click over a graph of interest to show the popup menu for graph properties and analysis details (e.g., regression results). The graph page is essentially a preview of a printed graph.
- Overview Graph - The overview (also called reference) graph below the main graph canvas shows the current view extent (the white area in reference graph in the figure above). The overview graph is only shown for graph types that support zooming. If shown, it can be used for zooming, similar to the main graph. The time series with the longest period of record is drawn in the reference graph to illustrate variations in the data over time.
- Page/Zoom Buttons - Under the graph areas is a layer of buttons used for zooming.
The buttons facilitate paging (scrolling) through data as described below.
For all paging operations, the visible graph extent (or page) is maintained during the paging.
Paging can use the buttons or keys described below.
To use the keyboard, first click in the main graph canvas to shift focus to that area.- |< or Start - Scroll the visible window to the start of the period.
- << or Page Down - Scroll the visible window one full page to the left (earlier in time).
- < or Left Arrow - Scroll the visible window 1/2 page to the left.
- > or Right Arrow - Scroll the visible window 1/2 page to the right (later in time).
- >> or Page Up - Scroll the visible window a full page to the right.
- >| or End - Scroll the visible window to the end of the period.
- Zoom Out - Zoom to the full time period.
 
- Tracker - Indicate the main behavior of the mouse tracker.  See also the time series product tracker properties to control features.- Nearest – highlight the nearest point to the mouse.
- NearestTime – highlight the nearest point to the mouse on each time series, considering only time for proximity.
- None – do not show tracker.
 
- Main Buttons The bottom row of buttons provides features for displaying other views, printing, and exporting:- Summary Display the summary view for the time series (see the Time Series Summary View section).
- Table Display the table view for the time series (see the Time Series Table View section).
- Print Print the graph. Because the physical extents of the printed page are different from the visible window, the printed graph may not exactly match the viewed version (e.g., more or less axis labels may be used).
- Save Save the graph as a Portable Network Graphic (PNG), JPEG graphic, a DateValue file (a useful time series format), Time Series Product file (see the Time Series Product Reference section), or other formats, by selecting from the choices. Depending on the main application, saving to a database as a time series product may also be enabled.
- Close Close the graph window. If related summary or table windows are still visible, the graph view can be quickly re-displayed by pressing the Graph button on the other view windows. If the graph properties have been changed but have not been saved, a warning will be displayed asking whether to save the changes.
 
- Status Message Area The lower-left status message area is used to provide general user instructions and feedback.
- Mouse Tracker Area The lower-right status message area is used to indicate the position of the mouse on a graph, in data units. The coordinates are typically shown using an appropriate precision as determined from the time series date/time precision and data units. If a right y-axis is enabled in the graph, then both left and right y-axis tracker information will be shown.
Within each graph page it is possible to draw more than one graph, each with its own titles, legend, etc. The Time Series Product Properties section (below) provides an example and discusses how to edit graph properties. The Time Series Product Reference section describes in detail the format of Time Series Product files. These files, when saved from the graph view, can be used to recreate a graph interactively or in batch mode, at a later time.
Because TSView is a general tool, a number of rules are in place when viewing time series in graphs (see the Time Series Product Properties section for information on changing specific graph properties to override the defaults):
- Time series plotted on the same graph should generally have the same units or have units that can be readily converted. If the units are not consistent, a warning will be displayed and the units will be displayed in the legend rather on the axis.
- Time series can have different data intervals (e.g., daily data can be plotted with monthly data). However, other output options, such as reports, may not allow the same flexibility. It is important to understand the data type characteristics. For example, some data are instantaneous (e.g., real-time streamflow) whereas other data are accumulated (e.g., precipitation) or mean (e.g., mean temperature). Therefore, the representation of the data may need to be selected with care to ensure consistency. For example, some data intervals and types may be better represented as bars and others as lines or points.
- Data values are plotted at exactly the point that they are recorded. The plot positions are determined using the year as the whole number and months, days, etc. to determine the fractional part of the plot position. The numerical positions are typically not evident because labeling uses data units, including dates. The plot positions are determined from the dates associated with data and no adjustments are made to plot in the middle an interval. For example, monthly data are plotted at the first day of the month (not day 15). Properties to override this convention may be implemented in the future. Bar graph properties can be used to indicate whether the bars are drawn to the left or right of the date, or centered on the date. This allows flexibility to show a period over which a value was recorded, if appropriate.
- The mouse coordinates that are displayed by the mouse tracker
are computed by interpolating screen pixels back to data coordinates
(which involves a conversion of the plot position to date/time notation).
Consequently, the values shown may be rounded off (depending on the zoom extent and data precision).
The mouse coordinates are displayed based on the precision of the time series data.
When moved, the mouse will display the same date until the date changes within the given precision.
For example, for monthly data, moving the mouse left to right,
the mouse coordinate will display as 1999-01as soon as the date changes from1998-12to1999-01. The label will remain at1999-01until1999-02is encountered. Because data values are drawn at points, to ensure that the date/time is correctly displayed, position the mouse slightly to the right of the point to see the date corresponding to the value. This is very important for bar graphs because the bar may extend over several dates. If specific values need to be determined, use the summary or table views.
- Labels for axes are determined automatically in most cases based on the font requirements, available display space, and data range. Major and minor tic marks are drawn to help determine the data coordinates. Labels are redrawn as the visible period is changed.
- The legend lists the time series in the graph. Left and right y-axis legends are shown. Clicking on a time series in the legend will highlight the time series in the graph and clicking on again will un-highlight. This feature is implemented for line graphs and will be expanded to other graph types in the future.
- Graphs that can be zoomed do not allow the vertical axis to be re-scaled on the fly. This capability is being evaluated.
- Currently, graph types cannot be universally mixed for time series on a graph. In other words, a graph cannot contain a bar graph for one time series and a line graph for another time series. However, this functionality is being added over time. For example time series can be drawn using line graph type on top of stacked area graph. A work-around is to use multiple graphs on a page or right y-axis (see the Time Series Product Properties section for an example).
- The precision used to format graph labels is determined from data unit information provided by the application. This generally produces acceptable graphs. However, in some cases, the range of values being plotted results in inappropriate labels where label values are truncated and/or repeated.
- Graph types can be changed after the initial display, with limitations. Graphs can be switched between simple types like line and bar graphs; however, simple graphs cannot be changed to more complex types. Additional functionality is being added to allow complete flexibility in the product properties editor.
The following sections describe various graph types supported by the TSView package. Graph properties are mentioned in some sections. The discussion of how to change graph properties is included in the Time Series Product Properties section after the graph type descriptions.
Area Graph
An area graph draws each time series by filling in the area under the graph with a solid color. The time series are drawn in the order that they are specified and therefore this graph is most suitable for cases where the first time series has values that are larger than subsequent time series.
An alternative to the area graph is a bar graph where BarOverlap=True
(by default multiple time series in a bar graph shows bars that are parallel at a point in time).

Area (Stacked) Graph
A stacked area graph is similar to the simple area graph in that it draws each time series by filling in the area under the graph with a solid color. However, instead of drawing the original data values (as per area graph), the cumulative values of the time series are used for the plotting coordinates. The time series are drawn in the order that they are specified (first on bottom). The legend order agrees with the representation of the graph. The following example is for reservoir storage and also indicates data issues on the right side.
 
 
Bar Graph
The bar graph type by default produces a graph with parallel vertical bars, as shown in the following example:

Example Bar Graph showing Daily Precipitation
The above example illustrates that at the given zoom extent (which is a small part of the full period - see the white area in the reference graph), labels are drawn for months. Zooming in more would display the day in the labels. The mouse tracker in all cases shows days since that is the precision of the data. Characteristics of the bar graph are as follows:
- Bars can be plotted centered on, to the left of, or to the right of the dates. If multiple time series are plotted, the overall total width of the bars will correspond to one data interval. If drawn to the left of the date, the bars for all graphed time series are drawn to the left of the date. If drawn to the right of the date, the bars for all graphed time series are drawn to the right of the date. If centered on the date, half the bars are drawn to the left of the date, and half to the right
- Bar widths are determined based on the number of time series being plotted. Monthly time series use a slightly narrower bar (larger gap between bars) because the number of days in a month varies. To make bars stand out better, a white line may be drawn to separate adjacent bars. If bars are very narrow the line is not drawn. Bars will always be drawn at least one pixel wide, even if this obscures neighboring bars (zoom in to see more detail). Round-off in drawing bars may result in some bars being slightly wider or narrower than other bars.
- Bars always end at the zero value on the Y axis. In other words, bars extend up or down from zero.
- The mouse cursor display dates relative to the axis and does not determine the data value relative to edges of the bars. For example, if bars are plotted centered on dates, 1/2 of the bar will actually be in the previous date, according to the mouse tracker.
Double Mass Curve
Double mass curves are currently disabled. An alternative is to use the TSTool application and generate cumulative time series, which can be viewed in a line graph. Double mass graphs may be enabled in the future.
Duration Graph
A duration graph indicates the range of values in a time series and how often they occur, as shown in the following example:

Example Duration Graph showing Maximum Daily Air Temperatures
The algorithm for calculating and graphing a duration curve was taken from the book Handbook of Applied Hydrology (edited by Ven Te Chow): “When the values of a hydrologic event are arranged in the order of their descending magnitude, the percent of time for each magnitude to be equaled or exceeded can be computed. A plotting of the magnitudes as ordinates against the corresponding percents of time as abscissas results in a so-called duration curve. If the magnitude to be plotted is the discharge of a stream, the duration curve is known as a flow-duration curve.” Features of duration graphs are as follows:
- The zoom feature is disabled for this graph type.
- Although duration curves have traditionally been applied to streamflow or reservoir data, duration graphs can be created for any time series data.
- Noticeable breaks in the curve are caused by a limited number of data points and/or values that are measured as rounded values.
Line Graph
Line graph features have been illustrated in previous discussion.
The line graph type is also used to generate graphs with only points by setting the
line style to None (for example, software that displays daily data where gaps are expected may default to using symbols and no line).

Line Graph (Log Y Axis)
Log-axis line graphs are similar to simple line graphs. The following figure illustrates a typical graph.

Example Log Y Axis Graph showing Monthly Streamflow
Characteristics of the log plot are:
- If the minimum data value is <= 0.0, then .001is used for the minimum plotting value (the original value is retained in the time series data for table, summary, and other output).
Period of Record Graph
The period of record graph is used to display the availability of data over a period, as shown in the following figure:

Example Period of Record Graph showing Monthly Streamflow
Characteristics of the period of record graph type are:
- Horizontal lines are drawn for each time series, with breaks in the line indicating missing data.
- Zooming is fully enabled, however, it may be difficult to see small breaks in the lines – it may be necessary to display symbols at the data points. The data limits properties of each time series can also be used to check for missing data. The TSTool application provides reporting features to summarize data coverage.
- Because data values are not plotted, the y-axis is labeled with a legend index number. This also allows the graph window to be compressed vertically, if desired.
Predicted Value Graph
The Predicted Value graph uses ordinary least squares regression to estimate the
equation of best fit and then calculates the dependent value for the entire period.
This plot has limited value because functionality like the TSTool
FillRegression command provides
parameters to control the calculations,
but it is difficult to provide all of these options in the graph properties.
In the future, the predicted value time series may be created by this command
and then it can be processed and visualized using other software features.
Predicted Value Residual Graph
The Predicted Value Residual graph uses ordinary least squares
regression to estimate the equation of best fit, calculates the dependent value for the entire period,
and then computes the difference between the actual value and the estimated value,
to given an indication of errors in the estimate.
This plot has limited value because functionality like the TSTool
FillRegression command provides
parameters to control the calculations,
but it is difficult to provide all of these options in the graph properties.
In the future, the predicted value time series may be created by this command
and then it can be processed and visualized using other software features.
Raster Graph
The Raster Graph provides a visualization technique for monthly and daily interval data (other small intervals may be added in the future), where the entire period of record is displayed in a grid with “pixels” colored according to a scale. The following are characteristics of the raster graph:
- Time is represented on both axes, with one axis representing years, and the other time within the year.
- The colors represent time series values. The default is to use decile values. Additional functionality will be enabled in the future to control the legend scale.

Example Raster Graph showing Daily Streamflow
XY-Scatter Graph
The XY-Scatter graph type can be used to compare data having the same data interval (units can be different). This graph type is often used for the following comparisons:
- The dependent time series (Y) requires filling and multiple independent time series (X) are analyzed to find the best time series to use as the independent time series. One or more independent time series can be plotted on the same graph.
- The dependent time series (Y) contains observed data and one or more independent simulated time series (X) are analyzed to determine which simulation is closed to actual observations.
- The independent (X) and dependent (Y) time series are compared to determine whether any time of relationship exists between data points. In this case, a single dependent time series may be compared with multiple independent time series on the same graph.
Currently the XY-Scatter graph can have only a single dependent time series but can have one or more independent time series. The following figure shows a typical graph.

Example XY Scatter Graph showing Monthly Streamflow
Characteristics of the XY Scatter graph are:
- Labels and legend are automatically generated. See the Time Series Product Properties section below for information about changing the appearance of the graph.
- Simple linear regression is initially performed to determine a line of best fit. See the Analysis tab in the Time Series Product Properties section below for information about curve fit methods.
- A 45-degree line is currently not displayed because time series of different types and units may be compared. Graph properties do allow the line of best fit to be forced to zero. The limits on the axes are not automatically set to equal values for the same reason; however, a property to force the values to be the same will be added.
- Zooming is disabled.
- Two or more time series must be specified and must have the same interval.
- Confidence intervals can be turned on, as shown in the following figure:

The confidence intervals provide a useful way for assessing the quality of a point estimate. When a regression line is of interest, the confidence interval on the line as a whole permits one to make confidence statements about a number of values of the predictor variables simultaneously. Confidence limits for the line are a function of the level of confidence (e.g., gamma = 95% or 99%), and the F-test statistic (2, n-2 degrees of freedom, and level of significance =1-gamma). The equations used to plot the confidence intervals are shown below (note that because the curves depend on the data points, the shape and smoothness of the curves will depend on the number of points; the points are sorted to generate a continuous line).

- The best-fit line can be turned off.
- Right-clicking on the graph displays the Analysis Details menu, that, if selected, displays curve fit information about the time series, as illustrated in the following figure:

Example Analysis Details
The RMS error (or RMSE) is calculated in the following way:
SSE = Σ(Xi – Yi)2 = Sum of Square Errors
MSE = SSE/N = Mean of Sum of Square Errors
RMSE = √MSE = Square Root of the MSE
The RMSE can have different meanings, depending on how the data are being analyzed:
- If a measured (X) and a simulated (Y) time series are being compared to determine, for example, to determine how well a model is simulating actual observations, then the RMSE indicates the error of a simulation when compared to the actual (comparing the values).
- If two time series are evaluated to determine if the relationship between the time series can be used to estimate missing values in one of the time series, then the difference between estimated values (Yest) and the line of best fit (e.g., A + BX) is used to compute the RMSE. For a perfect fit, the RMSE would be zero. Values of RMSE can be used to evaluate the estimator for data filling.
To provide as much information as possible for multiple uses, the XY-Scatter Graph Analysis Details provides both RMSE values. The default is to display a line of best fit, which is usually desirable information. The graph properties allow the analysis to be done for data filling, if desired.
Time Series Product Properties
A time series product is one or more time series graphs, tables, or reports on a “page”, although currently TSView focuses on graph products. Time series product properties can be displayed by right clicking on a graph of interest and selecting the Properties menu item from the popup menu. Interactively changing properties allows graphs to be configured as desired. The following figure illustrates a time series product that has two graphs (see the Time Series Product Reference section for information about how to define time series product files, which can be used to save a product).

Example Graph Product showing Precipitation and Streamflow
In many cases, a graph product will consist of only a single graph (which may show one or more time series). However, it is also useful to display multi-graph products, especially when related data types are used. The TSView interface includes features to construct multi-graph products interactively, and the product files described in the Time Series Product Reference section can be created and processed. The TSTool application, for example, can interactively create or read a product file and display a graph similar to the one shown above. Important considerations for multi-graph products are:
- The product page has its own set of properties (e.g., titles and size).
- Each graph area has its own properties (e.g., titles, labels, graph type, legend). These properties comprise most of the properties for a product.
- Each time series has its own properties (e.g., symbol, color).
- If zooming is enabled (the default), then zooming in one graph causes the same zoom to occur in related graphs. Each graph (and the reference graph) is assigned a zoom group number. This is used to indicate which graphs should zoom together. Currently, all graphs are in the same zoom group.
Right clicking on a graph and pressing the Properties item in the popup menu will display the properties for the graph. The following figures illustrate the properties tabbed panel:

Tabbed Panel to Edit Time Series Product Properties
The time series product properties display as three layers of tabbed panels. Characteristics of the properties window are:
- The window is divided into a layout area (top-left) and tabs for different groups of properties. The layout window shows the overall layout of graphs on a page and allows manipulation of the time series product by dropping time series onto the layout.
- The top layer of tabs (Product Properties) is associated with product properties (the page).
- The middle layer of tabs (Graph Properties) is associated with subproduct properties (graphs on the page). The graph of interest is selected using the drop-down choice that shows the graph number and graph main title. When initially displayed, the selected graph is the one that was clicked on to display the Properties menu.
- The bottom layer of tabs (Time Series Properties) is associated with data (time series) properties. A time series within a graph is selected using the drop-down choice that shows the time series number within the graph, and the time series identifier. When initially displayed, the first time series for the selected graph is selected.
- The Apply button will apply the current properties and update the graph(s). It is generally best to press Apply before changing tables or selecting new graphs or time series because auto-saving properties does not occur (this may be enhanced in the future).
- The Close button will apply the current properties, update the graph(s), and close the properties window.
- Only properties read from an original time series product file or that are set by the user will be saved if a time series product is saved. Internal defaults are not saved. This minimizes the size and complexity of product definition files.
The remaining discussion in this section illustrates each of the tabbed panels. The text-based properties that are displayed in the panels are described in the Time Series Product Reference section.
Product Properties - General

Example Product General Properties
The above figure illustrates the product General properties. The Product Enabled checkbox indicates whether the product is enabled (currently view-only). The Product ID is used when saving the product definition to a database. The Product Name is also used to when displaying lists of products.
Product Properties - Titles

Example Product Title Properties
Product Titles properties include title and subtitle. If blank, no title will be shown. Because graphs (subproducts) also have a title and subtitle, the product titles are often only used when multiple graphs are included on a page.
Product Properties - Layout

Example Product Layout Properties
Product Layout properties describe how graphs are laid out on the page.
Currently, graphs can only be organized in a vertical stack, although the design will support multiple columns.
The layout properties are updated automatically as graphs are added to or deleted from the layout window at the left.
The relative size of each graph on the page is controlled by using the
LayoutYPercent general property for each graph on the page (see below).
Product Properties - Developer

Example Product Developer Properties
Product Developer properties provide useful tools for software developers:
- Show drawing area outline – will draw boxes on the graph showing drawing area locations for different components
- Show Product Properties – will display all the product properties, rather than just the ones that are saved by the Save button
- Show Drawing Area Properties – will display drawing area properties such as the location of the drawing areas in the window
Graph Properties - General

Example Graph General Properties
The above figure illustrates graph General properties. The Graph Enabled checkbox indicates whether the graph is enabled (currently view-only). The vertical size of the graph on the page (percent) can also be specified (the default is to size all the graphs on the page equally).
Graph Properties - Graph Type

Example Graph Graph Type Properties
Graph Type properties control the overall display of the data. The graph type can be changed after the initial display only when switching between simple graph types (e.g., line and bar graphs). Some graph types may have specific properties (e.g., bar width for bar graphs). If necessary, to change the graph type, select the type from a main application, and generate a new graph. The right y-axis graph type will be the default for how time series are displayed for the right y-axis. Use time series properties to indicate which axis is associated with the time series.
Graph Properties - Titles

Example Graph Title Properties
Graph Titles properties include title and subtitle. If blank, no title will be shown. Font properties can also be specified. After applying a change to the main title, the title will be added in the list of graphs.
Graph Properties - X Axis

Example Graph X Axis (Bottom) Properties
Graph X Axis (Bottom) properties include title, label, and grid properties. The Major grid color can be specified by selecting from the available choices, which then fill in the text field with the given color selection.
Graph Properties - Y Axis

Example Graph Y Axis (Left) Properties
Graph Y Axis (Left) properties include the following:
- Title – this may be set to the data units but can be specified (the Y axis title is currently always placed at the top of the Y axis).
- Position – the location of axis title
- Rotation – the rotation (clockwise degrees) of the title text (generally use 270for left, if specified)
- Label - the font for labels and precision of numerical labels can be specified.
- Axis Type - currently this is view-only.
- Min Value, Max Value - currently this is view-only but can be set in time series product definition files (see the Time Series Product Reference section).
- Units, Ignore Units - currently these are view-only. If time series with incompatible units are graphed, Ignore Units will be checked and the units may be shown in the legend.
Graph Properties - Y Axis (Right)

Example Graph Y Axis (Right) Properties
Graph Y Axis (Right) properties include the following, and will only be used if the Graph Type for the right y-axis is other than None:
- Title – this may be set to the data units but can be specified (the Y axis title is currently always placed at the top of the Y axis).
- Position – the location of axis title
- Rotation – the rotation (clockwise degrees) of the title text (generally use 90for right, if specified)
- Label - the font for labels and precision of numerical labels can be specified.
- Axis Type - currently this is view-only.
- Min Value, Max Value - currently this is view-only but can be set in time series product definition files (see the Time Series Product Reference section).
- Units, Ignore Units - currently these are view-only. If time series with incompatible units are graphed, Ignore Units will be checked and the units may be shown in the legend.
Graph Properties - Data Point Label

Example Data Point Label Properties
Data points are not labeled by default because there are usually too many data labels to be legible.
However, for plots with limited data, or after zooming in, labels can be useful to
identify points without referring to tabular data.
The label format can be defined using the choices next to the text field or by entering literal text.
For an XY Scatter plot, repeat the %v format (e.g., %v, %v) to show the independent (X) and dependent (Y) data values.
See the DataLabel properties in the
Time Series Product Reference section for label options.
Graph Properties - Legend

Example Graph Legend Properties
Graph Legend properties include format and font properties.
If the Legend Format is Auto, a default legend format will be constructed from the time series description,
identifier, and period of record.  See the LegendFormat property in the
Time Series Product Reference section for legend formatting options.
The right legend will only be drawn if the Graph Type properties specify that the right y-axis type is other than None.
Graph Properties - Zoom

Example Graph Zoom Properties
Graph Zoom properties are currently view-only. Zoom will be enabled for graph types that support it (e.g., duration graphs do not). The Zoom group indicates how graphs should respond when other related graphs on a page are zoomed and currently defaults to 1 for all graphs.
Graph Properties - Analysis

Example Graph Analysis Properties
Graph Analysis properties are available if the graph requires some type of analysis to produce the result (e.g., curve fitting). See also the analysis tab for individual time series. For help with input, place the mouse cursor over a field and a tool tip will be shown.
Graph Properties - Annotations

Example Graph Annotation Properties
Graph Annotations properties are used to add annotation objects to a graph. Annotations are text, line, or other simple shapes and are stored as simple text properties in time series products (see the Time Series Product Reference section below for more information). Annotations are placed on a graph using data units or a percent of the graph dimension. This allows annotations to move if a graph uses real-time data.
To add an annotation, press the Add Annotation button. Then select the Shape Type and specify annotation properties, as appropriate. It may be necessary to use annotations in combination, for example to draw a horizontal line for a critical level, and a second annotation with the label.
Graph Properties - Developer

Example Graph Developer Properties
Graph Developer properties are currently view-only and provide information useful to software developers.
Time Series Properties - General

Example Time Series General Properties
Time series General properties are currently view-only and indicate whether the time series is enabled for the graph.
Time Series Properties - Graph Type

Example Time Series Graph Type Properties
Time series Graph Type properties are currently disabled. Currently all time series in a graph must have the same graph type, although graph type can be edited in the product properties file to override, in particular for area (stacked) graphs.
Time Series Properties - Axes

Example Time Series Axes Properties
Time series Axes properties indicate the graph axes to which a time series is associated. Currently only bottom x-axis is allowed but the time series can be associated with the right y-axis graph if appropriate.
Time Series Properties - Symbol

Example Time Series Symbol Properties
Time series Symbol properties define the graphical appearance of time series data.
Properties are enabled/disabled based on the graph type (e.g., the Symbol Style will be disabled if the graph type is Bar).
Time Series Properties - Data Point Label

Example Time Series Label Properties
Time series Data Point Label properties allow the data label to be changed.
Data points are not labeled by default because there are usually too many data labels to be legible.
However, for plots with limited data, or after zooming in, labels can be useful
to identify points without referring to tabular data.
The label format can be defined using the choices next to the text field or by entering literal text.
For an XY Scatter plot, repeat the %v format to show the independent (X) and dependent (Y) data values.
See the DataLabel properties in the
Time Series Product Reference section for label options.
Time Series Properties - Legend

Example Time Series Legend Properties
Time series Legend properties allow the legend format to be changed.
This is useful if the time series is to have different legend labeling that the other time series in the graph.
If the Legend Format is Auto, a default legend format will be constructed from the time series description, identifier, and period of record.
See the LegendFormat property in the
Time Series Product Reference section for legend formatting options.
Time Series Properties - Analysis

Example Graph Analysis Properties
Time series Analysis properties are available if the graph requires some type of analysis to produce the result (e.g., curve fitting).
Changing a Graph Page Layout
The default page layout for graphs is to display all time series in one graph. In this configuration, the layout area at the top-left corner of the time series product window will display as shown below:

Layout Window Showing One Graph
The layout area can be used to split the single graph into multiple graphs on the page. For example, two graphs may be needed because of different units, time step, or graph type. Left clicking on a graph in the layout area will select the graph – the selected graph is shown in gray. Right clicking on the layout area displays a menu with available options:

Layout Window Menu
The actions taken by the menus are described below:
- 
Add Graph Above Selected - Add a new graph above the selected graph, renumbering the graphs as needed. 
- 
Add Graph - Add a new graph below the selected graph, renumbering the graphs as needed. 
- 
Add Graph at Bottom - Add a new graph below all existing graphs, giving the new graph the next number in the sequence. 
- 
Remove Graph - Remove the selected graph, renumbering the graphs as needed. 
- 
Move Graph Up - Move the graph up one in the sequence, renumbering the graphs as needed. The menu is enabled only when multiple graphs are available. 
- 
Move Graph Down - Move the graph down one in the sequence, renumbering the graphs as needed. The menu is enabled only when multiple graphs are available. 
When a new graph is added, it will not have any specific properties, time series data, or annotations,
other than the default properties that are assigned (e.g., the default graph type is Line),
and when drawn it will appear as a blank area.
To see the graph, it will be necessary to set the graph’s properties
and provide it with data (and optionally, annotations).
Properties and annotations are defined using the properties tabs as documented in previous sections –
use the Apply button to apply and view the changes.
To set graph properties, the graph to be modified should be selected from the choices at the
top of the Graph Properties tab panel (or by selecting the graph in the layout window).
To add time series data to the new graph (or an existing graph), two approaches can be taken:
- Find the time series to be moved using the list in the time series properties panel.
It may be necessary to select a graph to find the time series – selecting a graph
will not impact the ability to move the time series to a different graph.
In the list of time series, hold the left mouse button down over a time series choice and
drag the time series to a graph on the layout area.  During this process, the cursor will change to a new shape, as shown below:
  
 Release the mouse over the graph in the layout area that is to receive the time series. The time series will then be removed from the original graph and will be inserted into the new graph as the last time series in the list.
- Some software programs will allow dragging a time series from a display to the time series product properties window. Similar to above, drag the time series onto the receiving graph in the layout area. Refer to documentation for the specific software program for additional information about whether this feature is available.
After adding a new graph and moving time series, it may be necessary to change the graph type for a graph. For example, the top graph may show precipitation and the bottom graph may show streamflow resulting from the precipitation. Precipitation is normally shown as bars and streamflow as a line. The graph will initially be shown using the graph type that was originally selected. Change the graph type in the new configuration, as appropriate, by selecting the graph to be changed and then use the Graph Type tab.
Time Series Summary View
The time series summary view can be selected from the graph or table view using the Summary button. Additionally, applications that use the TSView package may allow displaying a summary from a menu or button option. A time series summary view can usually be produced quickly, whereas the table view uses more resources. The following figure illustrates a typical summary view.

Example Summary View showing Monthly Streamflow
The summary view has the following characteristics:
- The graph view can be displayed using the Graph button and the table view can be displayed using the Table button.
- Each time series interval (e.g., Month,Day,Hour) has a default summary report format suitable for the interval. This format may be made more specific if time series are read from specific data types (e.g., if daily diversion time series are read from the HydroBase input type, the summary report will use the State of Colorado diversion coding report format).
- The contents of the view can be printed.
- The summary can be saved as a text file or DateValue time series file.
- Limited search capabilities are available to search for a string in the text area.
Time Series Table View
The time series table view can be selected from the graph or summary view using the Table button. Additionally, applications that use the TSView package may allow displaying a table from a menu or button option. The table view is useful for viewing date and data values in a spreadsheet-like display. A time series table view for a long period or many time series may require extra time to display (especially if irregular interval time series), but usually only a few seconds are required. The following figure illustrates a typical table view.

Example Table View showing Monthly Streamflow
Characteristics of the table view are:
- The summary view can be displayed using the Summary button and the graph view can be displayed using the Graph button.
- If any of the time series have data flags, the Flags choice will be enabled and allow showing the time series values with flags.
- The precision of date/times in the first column matches the data interval for the time series. For irregular time series the precision will match that of the time series start date/time.
- If time series with different intervals are selected, multiple tables will be displayed in the window. For irregular time series, a separate table will be shown for each date/time precision.
- The table contents can be saved as delimited or DateValue file.
- Column headings by default indicate alias if set (or location otherwise),
sequence number (used with ensembles), data type and units.
If the TableViewHeaderFormattime series property is set, it will be used to format the header. The format can contain%specifiers and${ts:Property}properties.
- For irregular time series:- Prior to displaying time series, a unique list of date/times is created for all the time series values. This is cached to allow fast lookups of data. Long irregular time series periods will take longer to determine the list of date/times.
- The starting date/time is used to determine the date/time precision and whether a time zone is used. If the date/times have precision of hour or minute and time zones are the same, the time zone is displayed with the date/time column. If multiple time zones are found (including no time zone), then no time zone is displayed in the date/time column. In any case, the time zone can be displayed by mousing over the column headings.
 
Time Series Product Reference
A time series product is a report, table, or graph, although currently TSView focuses on graph products. Examples of time series products and their use are:
- Reports and graphs generated from a database to perform quality checks.
- Reports and graphs generated from model input and output to check a calibration or model results.
- Reports and graphs generated from a database for real-time data products, to monitor current conditions or to create products for a web site.
The TSView package contains features to process time series product files in interactive and batch mode to produce time series products. Currently, only graph products are supported. The time series graph view allows a graph to be saved as a time series product file. This file describes the layout and contents of the product but does not include the time series data itself; therefore, the time series product is relatively small.
Time Series Product File Format
The time series product definition file format consists of comments (lines that start with #),
sections (indicated by [   ]), and simple property=value pairs.
The following example illustrates the parts of a product file:  
# Example Time Series Product file
# Comments start with #
# Sections are enclosed in [] and must be included
[Product]
# product properties - surround with double quotes if values contain spaces
xxxxx="xxxxxx   xx"
[SubProduct 1]
# "sub-product", e.g., a graph on a page (page is product and may have
# multiple graphs)
[Data 1.1]
# First data item in the SubProduct (e.g., first time series).
TSID = ...
[Data 1.2]
# Second data item in the SubProduct (e.g., first time series).
TSID = ...
[SubProduct 2]
[Data 2.1]
# Annotations are associated with a SubProduct
[Annotation 2.1]
Annotation properties...
... etc. ...
Example Time Series Product File
Most properties, if not specified in the file, will default to reasonable values.
The most important property is TSID, which indicates time series identifier to be read for data.
The time series identifier follows the conventions described in the Time Series Terminology section.
Some tools, like TSTool, will match the TSID against time series that have already been read into memory,
or, if necessary, read the time series from a file or database if not in memory.
The normal convention is to use a .tsp extension for time series product file names.
The list of properties that can be used in a time series product definition file is
quite extensive and new properties are added as new features are enabled.
As shown in the previous section, properties are defined as simple property=value pairs.
These properties are used internally by the graph view (and its properties window)
regardless of whether the graph originated from a product file or interactively.
The following tables list the properties that are currently
supported or envisioned to be enabled in the future.
The first set of properties are used to define the overall product (the full page).
Top-level Time Series Product Properties
| Product Property | Description | Default | 
|---|---|---|
| CurrentDateTime | The current date and time to be drawn as a vertical line on all graphs. If the property is not specified, no current date/time line will be drawn. If specified as Auto, the current system time will be used for the date/time. If specified as a valid date/time string (e.g., 2002-02-05 15), the string will be parsed to obtain the date/time.  This property is often specified internally by the application at run time. | Not drawn. | 
| CurrentDateTimeColor | Color to use to draw the current date and time.  Colors can be specified as named colors (e.g., red), hexadecimal RGB values (e.g.,0xFF0000), integer triplets (e.g.,255,0,0) or floating point triplets (e.g.,1.0,0.0,0.0). | Green | 
| Enabled | Indicates whether the product should be processed. Specify as TrueorFalse. | True | 
| LayoutNumberOfColumns | The number of columns in the product. | Currently always 1. | 
| LayoutNumberOfRows | The number of rows in the product. | Currently equal to the number of graphs. | 
| LayoutType | Indicates how the graphs in a product are laid out.  Only Gridis supported. | Grid | 
| MainTitleFontName | Name of font to use for main title ( Arial,Courier,Helvetica,TimesRoman). | Arial | 
| MainTitleFontSize | Size, in points, for main title. | 20 | 
| MainTitleFontStyle | Font style ( Bold,BoldItalic,Plain,PlainItalic). | Plain | 
| MainTitleString | Main title for the product, centered at the top of the page. | No main title. | 
| OutputFile | Output file when graph product is generated in batch mode.  This property is often set at run time by the application.  This property is ignored for ProductType=Reportand must be specified at a subproduct level. | C:\TEMP\tmp.pngon windows,/tmp/tmp.pngon Linux. | 
| Owner | An identifier that indicates the owner of the TSProduct, used internally when saving TSProduct definitions to a database that implements permissions. | None – can be blank if permissions are not important. | 
| PeriodEnd | Ending date for time series data in the product. The date should be formatted according to common conventions (e.g., YYYY-MM-DD HH:mm), and should ideally be of appropriate precision for the data being queried.  This property is often set at run time by the application.  SeeVisibleStart. | Full period is read. | 
| PeriodStart | Starting date for time series data in the product. The date should be formatted according to common conventions (e.g., YYYY-MM-DD HH:mm), and should ideally be of appropriate precision for the data being queried.  This property is often set at run time by the application.  SeeVisibleEnd. | Full period is read. | 
| PreviewOutput | Indicates whether the product should be visually previewed before output. This property is often set at run time by the application and is used to override generation of the OutputFile. | False | 
| ProductType | Time series product type, one of: 
 | Graph | 
| ShowDrawingAreaOutline | Indicate whether drawing area outlines should be shown. Drawing areas are the logical areas on a graph where content is drawn. This property is useful for development and troubleshooting. | False | 
| SubTitleFontName | Name of font to use for subtitle (see MainTitleFontName for font list). | Arial | 
| SubTitleFontSize | Size, in points, for subtitle. | 10 | 
| SubTitleFontStyle | Font style (see MainTitleFontStylefor style list). | Plain | 
| SubTitleString | Subtitle for the product. | No subtitle. | 
| TemplateProcessCommandFile | This property is used by TSTool when processing time series results further before displaying in graphs. See the Time Series Graph Templates section of this appendix for more information. | No time series preprocessing will occur. | 
| TotalHeight | Height of the total drawing space, which may include multiple graphs, pixels. | 400 | 
| TotalWidth | Width of the total drawing space, which may include multiple graphs, pixels. | 400 | 
| TrackerType | Indicate the type of tracker to use for the display window: 
 | None | 
| VisibleStart | The product visualization will be limited to the specified start date/time ( YYYY-MM-DD HH:mmto appropriate precision). | Full period is visualized. | 
| VisibleEnd | The product visualization will be limited to the specified date/time ( YYYY-MM-DD HH:mmto appropriate precision). | Full period is visualized. | 
The subproduct properties are associated with the graphs on a page or report files. There can be one or more graphs on a page, each with different properties. It is envisioned that graphs can be grouped into several zoom groups, where zooming in on one graph will cause all graphs to scale similarly. However, at this time, all graphs in a product are placed in a single zoom group. It is also envisioned that graphs could be placed anywhere on the page; however, at this time, multiple graphs on a page can only be stacked vertically, each using the full width of the page.
The following tables describe the subproduct (graph) properties.
Subproduct (Graph) Properties
| Subproduct (Graph) Property | Description | Default | 
|---|---|---|
| BarOverlap | For use with bar graphs (left axis). This property controls how bars are positioned relative to each other, one of: 
 | False | 
| BarPosition | For use with bar graphs (left axis). This property controls how bars are positioned relative to the date and can have the values CenteredOnDate,LeftOfDate, orRightOfDate. | CenteredOnDate | 
| BottomXAxisLabelFontName | Name of font for bottom x-axis labels (see Product MainLabelFontName). | Arial | 
| BottomXAxisLabelFontSize | Bottom x-axis labels font size, points. | 10 | 
| BottomXAxisLabelFontStyle | Bottom x-axis labels font style (see Product MainLabelFontStyle). | Plain | 
| BottomXAxisTitleFontName | Name of font for bottom x-axis title (see Product MainTitleFontName). | Helvetica | 
| BottomXAxisTitleFontSize | Bottom x-axis title font size, points. | 12 | 
| BottomXAxisTitleFontStyle | Bottom x-axis title font style (see Product MainTitleFontStyle). | Plain | 
| BottomXAxisLabelFormat | Format for X-axis labels.  Currently this is confined to date/time axes and only MM-DDis recognized. | Determined automatically. | 
| BottomXAxisMajorGridColor | Color to use for the major grid. | Most graph types automatically set to None. | 
| BottomXAxisMinorGridColor | Color to use for the minor grid. This property is not implemented. | None | 
| BottomXAxisTitleString | Bottom X-axis title string. | As appropriate for the graph type (often Noneif dates). | 
| DataLabelFontName | Name of font for data labels (see Product MainLabelFontName). | Arial | 
| DataLabelFontSize | Data label font size, points. | 10 | 
| DataLabelFontStyle | Data label font style (see Product MainLabelFontStyle). | Plain | 
| DataLabelFormat | Format specifiers to use for labeling data points.  If blank, no labels will be drawn.  If specified, labels are drawn for line graphs and XY scatter plots.  The following format specifiers are available (all other text in the format is treated literally).  The last three specifiers are related to time series data and all others are related to the date for a point.  The %v specifier can be specified twice for XY Scatter plots to display the X and Y values.  If specified and the time series data property is not specified, the graph property will be used. 
 | Blank (no data point labels). | 
| DataLabelPosition | Indicates the position of data labels, relative to the data point: UpperRight,Right,LowerRight,Below,LowerLeft,Left,UpperLeft,Above,Center.  If specified and the time series data property is not specified, the graph property will be used. | Right | 
| Enabled | Indicates whether the sub-product should be processed. Specify as TrueorFalse. | True | 
| GraphHeight | Graph height in pixels.  Currently this property is ignored (use Product TotalHeightinstead). | Product TotalHeight(minus space for titles, etc.) if one graph, or an even fraction of ProductTotalHeight(minus space for titles, etc.) if multiple graphs. | 
| GraphType | Indicates the left y-axis graph type for all data in a graph product (left axis). Available options are: Area,AreaStacked,Bar,Duration,Line,PeriodOfRecord,Point,Raster,XY-Scatter. | Line | 
| GraphWidth | Graph width in pixels.   Currently this property is ignored (use Product TotalWidthinstead). | Product TotalWidth(minus space for titles, etc.). | 
| LayoutXPercent | For the product grid layout, the width of the graph as a total width of the product, percent. | 100 divided by the number of columns in the layout. | 
| LayoutYPercent | For the product grid layout, the height of the graph as a total width of the product, percent. | 100 divided by the number of rows in the layout. | 
| LeftYAxisIgnoreUnits | Indicates whether to ignore units for the left Y-axis.  Normally, units are checked to make sure that data can be plotted consistently. If this property is set, then the user will not be prompted at run-time to make a decision.  Specify as TrueorFalse. | If not specified, the units will be checked at run-time and, if not compatible, the user will be prompted to indicate whether to ignore units in the graphs. The property will not be reset automatically but will be handled internally using the interactively supplied value. | 
| LeftYAxisDirection | Use Normalto indicate normal direction (minimum y-value at bottom) andReverseto indicate reversed y-axis (maximum value at bottom). | Normal | 
| LeftYAxisLabelFontName | Name of font for left y-axis labels (see Product MainLabelFontName). | Arial | 
| LeftYAxisLabelFontSize | Left y-axis labels font size, points. | 10 | 
| LeftYAxisLabelFontStyle | Left y-axis labels font style (see Product MainLabelFontStyle). | Plain | 
| LeftYAxisLabelPrecision | If numeric data, the number of digits after the decimal point in labels. | Automatically determined from graph type and/or data units. | 
| LeftYAxisLabel1000Separator | The character to use for number 1000’s separator: 
 In the future a locale setting may be added. | None | 
| LeftYAxisMajorGridColor | Color to use for the major grid. | Most graph types automatically set to lightgray. | 
| LeftYAxisMajorTickColor | Color to use for the major ticks. | Typically Nonebecause grid is used instead. | 
| LeftYAxisMax | Maximum value for the left Y-Axis. | Auto, automatically determined. If the actual data exceed the value, the property will be ignored. | 
| LeftYAxisMin | Minimum value for the left Y-Axis. | Auto, automatically determined. If the actual data exceed the value, the property will be ignored. | 
| LeftYAxisMinorGridColor | Color to use for the minor grid. This property is not implemented. | None | 
| LeftYAxisTitleFontName | Name of font for left y-axis title (see Product MainTitleFontName). | Arial | 
| LeftYAxisTitleFontSize | Left y-axis title font size, points. | 12 | 
| LeftYAxisTitleFontStyle | Left y-axis title font style (see Product MainTitleFontStyle). | Plain | 
| LeftYAxisTitlePosition | Position of the left y-axis title: AboveAxis, orLeftOfAxis. | AboveAxis | 
| LeftYAxisTitleRotation | Clockwise rotation from horizontal for y-axis title.  Typical values are 0for horizontal and270for vertical. | 0 | 
| LeftYAxisTitleString | Left y-axis title string. | As appropriate for the graph type (often the data units). | 
| LeftYAxisType | Left y-axis type ( Log, orLinear). | Linear | 
| LeftYAxisUnits | Left y-axis units. See also LeftYAxisIgnoreUnits. | Units from first valid time series, or as appropriate for the graph type. | 
| LegendFontName | Name of font for legend (see Product MainTitleFontName). | Arial | 
| LegendFontSize | Legend font size, points. | 10 | 
| LegendFormat | The legend format is composed of literal characters and/or time series data format specifiers, as follows. | Auto, which usesDescription,Identifier,Units,Period | 
| LegendPosition | Position of the legend relative to the graph: Bottom,InsideLowerLeft,InsideLowerRight,InsideUpperLeft,InsideUpperRight,Left,None,Right. | Bottom | 
| MainTitleFontName | Name of font to use for graph main title (see Product MainTitleFontName). | Arial | 
| MainTitleFontSize | Size, in points, for graph main title. | 10 | 
| MainTitleFontStyle | Graph main title font style (see Product MainTitleFontStyle). | Plain | 
| MainTitleString | Main title for the graph. | None, or appropriate for graph type. | 
| PeriodEnd | Ending date for time series data in the sub-product. The date should be formatted according to common conventions (e.g., YYYY-MM-DD HH:mm), and should ideally be of appropriate precision for the data being queried.  This property is often set at run time. | Full period is read. | 
| PeriodStart | Starting date for time series data in the sub-product. The date should be formatted according to common conventions (e.g., YYYY-MM-DD HH:mm), and should ideally be of appropriate precision for the data being queried.  This property is often set at run time. | Full period is read. | 
| RightYAxisBarOverlap | For use with bar graphs (right axis). This property controls how bars are positioned relative to each other, one of: 
 | False | 
| RightYAxisBarPosition | For use with bar graphs (right axis). This property controls how bars are positioned relative to the date and can have the values CenteredOnDate,LeftOfDate, orRightOfDate. | CenteredOnDate | 
| RightYAxisDirection | Use Normalto indicate normal direction (minimum y-value at bottom) andReverseto indicate reversed y-axis (maximum value at bottom). | Normal | 
| RightYAxisGraphType | Graph type for right y-axis, used for drawing time series unless the time series GraphTypeproperty specifies a different graph type.  Allowed values are:Area,Bar,Line,Point | Line | 
| RightYAxisIgnoreUnits | Indicates whether to ignore units for the right Y-axis.  Normally, units are checked to make sure that data can be plotted consistently. If this property is set, then the user will not be prompted at run-time to make a decision.  Specify as TrueorFalse. | If not specified, the units will be checked at run-time and, if not compatible, the user will be prompted to indicate whether to ignore units in the graphs. The property will not be reset automatically but will be handled internally using the interactively supplied value. | 
| RightYAxisLabelFontName | Name of font for right y-axis labels (see Product MainLabelFontName). | Arial | 
| RightYAxisLabelFontSize | Right y-axis labels font size, points. | 10 | 
| RightYAxisLabelFontStyle | Right y-axis labels font style (see Product MainLabelFontStyle). | Plain | 
| RightYAxisTitlePosition | Position of the right y-axis title: AboveAxis,None, orRightOfAxis. | None | 
| RightYAxisTitleRotation | Clockwise rotation from horizontal for y-axis title.  Typical values are 0for horizontal and90for vertical. | 0 | 
| RightYAxisMajorGridColor | Color to use for the major grid. | None | 
| RightYAxisMajorTickColor | Color to use for the major ticks. | None | 
| RightYAxisMax | Maximum value for the right Y-Axis. | Auto, automatically determined. If the actual data exceed the value, the property will be ignored. | 
| RightYAxisMin | Minimum value for the right Y-Axis. | Auto, automatically determined. If the actual data exceed the value, the property will be ignored. | 
| RightYAxisTitleFontName | Name of font for right y-axis title (see Product MainTitleFontName). | Arial | 
| RightYAxisTitleFontSize | Right y-axis title font size, points. | 12 | 
| RightYAxisTitleFontStyle | Right y-axis title font style (see Product MainTitleFontStyle). | Plain | 
| RightYAxisTitleString | Right y-axis title string. | |
| RighttYAxisType | Right y-axis type ( Log, orLinear). | Linear | 
| RightYAxisUnits | Right y-axis units. See also RightYAxisIgnoreUnits. | Units from first valid time series, or as appropriate for the graph type. | 
| SelectedTimeSeriesLineWidth | If a time series has been selected by clicking on the legend, then this property is used to adjust the original LineWidthproperty to highlight the time series:
 | |
| SubTitleFontName | Name of font to use for graph Sub title (see Product MainTitleFontName). | Arial | 
| SubTitleFontSize | Size, in points, for graph sub title. | 10 | 
| SubTitleFontStyle | Graph sub title font style (see Product MainTitleFontStyle). | Plain | 
| SubTitleString | Sub title for the graph. | No subtitle. | 
| TopXAxisLabelFontName | Name of font for Top x-axis labels (see Product MainLabelFontName).  This property is not enabled. | Arial | 
| TopXAxisLabelFontSize | Top x-axis labels font size, points. This property is not enabled. | 10 | 
| TopXAxisLabelFontStyle | Top x-axis labels font style (see Product MainLabelFontStyle).  This property is not enabled. | Plain | 
| TopXAxisTitleFontName | Name of font for Top x-axis title (see Product MainTitleFontName).  This property is not enabled. | Arial | 
| TopXAxisTitleFontSize | Top x-axis title font size, points. This property is not enabled. | 12 | 
| TopXAxisTitleFontStyle | Top x-axis title font style (see Product MainTitleFontStyle).  This property is not enabled. | Plain | 
| TopXAxisTitleString | Top X axis title string. This property is not enabled. | As appropriate for the graph type. | 
| XYScatterAnalyzeForFilling | Indicate whether the analysis should be used to analyze for filling.  If true, then the XYScatterIntercept,XYScatterFillPeriodStart, andXYScatterFillPeriodEndproperties may be specified. | False | 
| XYScatterDependentAnalysisPeriodEnd | Specify the ending date/time for the period to analyze the dependent time series data, to determine the best-fit line. | Blank (analyze full period). | 
| XYScatterDependentAnalysisPeriodStart | Specify the starting date/time for the period to analyze the dependent time series data, to determine the best-fit line. | Blank (analyze full period). | 
| XYScatterFillPeriodEnd | When XYScatterAnalyzeForFilling=true, indicates the ending date/time of the period to fill, using standard date/time string. | Blank (fill full period). | 
| XYScatterFillPeriodStart | When XYScatterAnalyzeForFilling=true, indicates the starting date/time of the period to fill, using standard date/time string. | Blank (fill full period). | 
| XYScatterIndependentAnalysisPeriodEnd | Specify the ending date/time for the period to analyze the independent time series data, to determine the best-fit line. | Blank (analyze full period). | 
| XYScatterIndependentAnalysisPeriodStart | Specify the starting date/time for the period to analyze the independent time series data, to determine the best-fit line. | Blank (analyze full period). | 
| XYScatterIntercept | The value of Ain the best-fit equationA + bX.  If specified, the value of B is adjusted accordingly.  This property cannot be used with transformed data and if specified must be0. | Blank (do not force the intercept). | 
| XYScatterMethod | Curve fit method used when analyzing data for the XY Scatter graph ( OLSRegressionorMOVE2). | OLSRegression | 
| XYScatterMonth | One or more month numbers used when analyzing data for the XY Scatter graph, separated by commas or spaces ( 1=Jan). | Blank (analyze all) | 
| XYScatterNumberOfEquations | Number of equations used when analyzing data for the XY Scatter graph ( OneEquationorMonthlyEquations). | OneEquation | 
| XYScatterTransformation | Data transformation used when analyzing data for the XY Scatter graph ( NoneorLog).  This property is not enabled. | None | 
| ZoomEnabled | Indicates whether the graph can be zoomed ( true) or not (`false). | Graph types are evaluated and the property is automatically set. XY-Scatter and Duration graphs can't zoom. | 
| ZoomGroup | Indicate a group identifier that is used to associate graphs for zooming purposes. For example, there may be more than one distinct group of graphs, each with its own overall period or data limits. The graph types may also be incompatible for zooming. This is an experimental feature and should currently not be specified in product files. | All graphs are assigned to zoom group 1. | 
Report Subproduct Properties
The following table describes the subproduct (report) properties. Limited support for report products are currently enabled. Reports are defined as any format other than graphical output, including raw data formats like delimited and DateValue files. The number of properties for reports will continue to be expanded as additional features are enabled. An example of a report product file is as follows (in this case for NWSRFS FS5Files input type time series):
[Product]
ProductType = Report
Enabled = true
[SubProduct 1]
OutputFile = C:\Report_6_Hour
ReportType = DateValue
[Data 1.1]
TSID = FZRDR.NWSRFS.SPEL.6HOUR~NWSRFS_FS5Files
[SubProduct 2]
OutputFile = C:\Report_24_Hour
ReportType = DateValue
[Data 2.1]
TSID = FZRDR.NWSRFS.PELV.24HOUR~NWSRFS_FS5Files
Subproduct (Report) Properties
| Subproduct (Report) Property | Description | Default | 
|---|---|---|
| OutputFile | Output file when report product is generated in batch mode. If a relative path is given, the file will be written relative to the working directory for the software. This property is often set at run time by the application. | C:\TEMP\tmp_report_Non windows,/tmp/tmp_report_Non UNIX | 
| Enabled | Indicates whether the sub-product should be processed.  Specify as trueorfalse. | true | 
Time Series Properties
Each subproduct (graph) includes time series data, and the presentation of each time series can be configured using data (time series) properties. In some cases, properties are layered, allowing a property to be defined for the subproduct (graph) for use by all time series (e.g., legend text).
The following tables list data (time series) properties.
Data (Time Series) Properties
| Data (Time Series) Property | Description | Default | 
|---|---|---|
| Color | Color to use when drawing the data. Examples are named colors (e.g., red), RGB triplets (e.g.,255,0,128), and hexadecimal RGB (e.g.,0xFF0088). | Repeating, using common colors. | 
| DataLabelFormat | Data label format specifiers. See the graph DataLabelFormat property. If the graph property is specified and the time series property is not, the graph property will be used. | Blank (no labels). | 
| DataLabelPosition | Data label position.  See the graph DataLabelPositionproperty.  If the graph property is specified and the time series property is not, the graph property will be used. | Right | 
| Enabled | Indicates whether the data should be processed. Specify as trueorfalse. | true | 
| FlaggedDataSymbolStyle | Symbol style for data points that have non-empty data flag string.  See the SymbolStyleproperty for possible values. | Same as SymbolStyle | 
| FlaggedDataSymbolTable | It is envisioned that this property will be enabled in the future to allow fine-grained control of symbols when data flags are used. | Property not enabled. | 
| GraphType | Indicates the graph type for the data in a graph product. Available options are: Area,AreaStacked,Bar,Duration,Line,PeriodOfRecord,Point,XY-Scatter. This functionality is being phased in, with initial development focusing on allowing lines to be drawn on area graphs. | Property enabled only for area graphs. | 
| LegendFormat | The legend for the data can be specified and will override the SubProduct LegendFormatproperty (see that property for details).  The time series propertytsp:LegendFormatwill be used if found. | Auto | 
| LineStyle | Line style. Currently only None(e.g., for symbols only) andSolidare allowed. | Solid | 
| LineWidth | Line width, pixels. | 1 | 
| PeriodEnd | Ending date for time series data in the data item. The date should be formatted according to common conventions (e.g., YYYY-MM-DD HH:mm), and should ideally be of appropriate precision for the data being queried.  This property is often set at run time. | Full period is read. | 
| PeriodStart | Starting date for time series data in the data item. The date should be formatted according to common conventions (e.g., YYYY-MM-DD HH:mm), and should ideally be of appropriate precision for the data being queried. This property is often set at run time. | Full period is read. | 
| RegressionLineEnabled | Indicates whether the regression line should be shown (currently only used with the XY-Scatter graph type). The line is drawn in black (there is currently not a property to set the line color). | true | 
| SymbolSize | Symbol size in pixels. | 0(no symbol) | 
| SymbolStyle | Symbol style. Recognized styles are: 
 | None | 
| TSAlias | Time series alias to match, will override TSID. | Specify TSAliasorTSID. | 
| TSID | Time series identifier to match, will be overrules by TSAlias. | Specify TSAliasorTSID. | 
| XAxis | X-axis to use (Bottom or Top). This currently always defaults to bottom. | Bottom | 
| XYScatterConfidenceInterval | This property is only used with XY scatter plots.  If not blank, the value indicates that confidence level lines should be drawn on the XY Scatter plot for the given confidence interval, percent.  Currently only 99 and 95 percent confidence intervals are supported.  The lines will only be drawn if the curve fit line is drawn (see RegressionLineEnabled). | Blank (do not draw). | 
| YAxis | Y-axis to use ( LeftorRight). | Left | 
Annotation Properties
Annotations are associated with subproducts (graphs) and are implemented as simple shapes that are drawn on normal graphs. It is envisioned that all shapes supported by the drawing package will eventually be supported but currently only text labels and lines can be specified as annotations.
To allow flexibility, annotations can be placed using two coordinate systems.
For example, if a product is generated using real-time data, the date/time axis will have a different range over time.
Therefore, placing an annotation using a fixed coordinate would cause the annotation to scroll off the graph as time passes.
To resolve this issue and still allow absolute positioning of annotations, as appropriate,
the following coordinate systems are supported, as specified by the XAxisSystem and YAxisSystem properties:
- Data - When using the data coordinate system, it is expected that the coordinates used to define the annotation will agree with the data units being drawn. For example, for a normal time series graph, the x-axis coordinate would be specified as a date/time to the necessary precision and the y-axis coordinate would be specified using data values.
It is envisioned that a notation +NNN and –NNN will be implemented in the future to allow offsets from the edges of the graph, in data units.
- Percent - When using the percent coordinate system,
it is expected that the coordinates used to define the annotation are specified
as a percent of the graph width or height, with 0being the lower/left and100being the upper/right.
Each axis can have a different coordinate system (e.g., the y-axis value can be set using data units and the x-axis value can be set using percent).
The following tables list annotation properties.
Annotation Properties (All Shape Types)
| Annotation Property | Description | Default | 
|---|---|---|
| AnnotationID | A string that identifies the annotation, to be used in software displays. If there are many annotations, this helps identify them when editing. | Annotation + annotation number (1+) (e.g., Annotation1). | 
| AnnotationName | May be implemented in future since shown in the property editor. | |
| AnnotationTableID | The table identifier that annotation data should be taken from.  Annotation tables allow many annotations to be provided in a table using shared configuration properties.  If specified, the corresponding table must have been passed in from the software application.  The PointandPointsproperty for the annotation can be specified using the form${tablecolumnvalue:ColumnName}, which will cause a look-up of the points in the table column.  Any table annotations that fall within the viewable graph will be drawn. | If not specified then normal annotation properties are used for annotation data. | 
| Color | Color to use when drawing the annotation. Examples are named colors (e.g., red), RGB triplets (e.g.,255,0,128), and hexadecimal RGB (e.g.,0xFF0088). | Black | 
| Order | The drawing order for the annotation: 
 | OnTopOfData | 
| ShapeType | The type of shape to be drawn for the annotation.  Currently accepted values are Line, Rectangle,Symbol, andText.  See the following tables for properties for each annotation shape type. | None – must be specified. | 
| XAxisSystem | Indicates the system for X coordinates: 
 | Data | 
| YAxis | Indicate which axis the annotation is associated with, either Left or Right. | Left | 
| YAxisSystem | Indicates the system for Y coordinates: 
 | Data | 
Annotation Properties (ShapeType=Line)
| Annotation Property | Description | Default | 
|---|---|---|
| LineStyle | Line style.  Currently only NoneandSolidare allowed. | Solid | 
| LineWidth | Line width, pixels. | 1 | 
| Points | X and Y coordinates for the line endpoints, as follows: X1,Y1,X2,Y2. | None– must be specified. | 
Annotation Properties (ShapeType=Rectangle)
| Annotation Property | Description | Default | 
|---|---|---|
| FillPattern | Envisioned for future. Pattern to use other than default solid fill. | |
| OutlineColor | Envisioned for future.  The Colorproperty is used for fill color. | |
| Points | X and Y coordinates for the rectangle corners, as follows: X1,Y1,X2,Y2. | None – must be specified. | 
| Transparency | Envisioned for future. | 
Annotation Properties (ShapeType=Symbol)
| Annotation Property | Description | Default | 
|---|---|---|
| Point | X and Y coordinates for the symbol position, as follows: X1,Y1 | None – must be specified. | 
| SymbolPosition | Indicates the position of symbol, relative to the point: UpperRight,Right,LowerRight,Below,LowerLeft,Left,UpperLeft,Above,Center. | Center | 
| SymbolSize | Size of symbol in pixels. | 0 | 
| SymbolStyle | Symbol style from provided choices. | None | 
Annotation Properties (ShapeType=Text)
| Annotation Property | Description | Default | 
|---|---|---|
| FontSize | Annotation text font size, points. | 10 | 
| FontStyle | Annotation text font style (see Product MainLabelFontStyle). | Plain | 
| FontName | Annotation font name (see Product MainTitleFontName). | Arial | 
| Point | X and Y coordinates for the text position, as follows: X1,Y1 | None – must be specified. | 
| Text | The string to display. | Blank | 
| TextPosition | Indicates the position of text, relative to the point: UpperRight,Right,LowerRight,Below,LowerLeft,Left,UpperLeft,Above,Center. | Right | 
Time Series Graph Templates
TSTool version 12.00.00 implemented a new graph template feature, which provides flexibility for creating default graphs that can be generally applied as well as the ability to create specialized graph types. The main benefit of graph templates is that they allow time series result to be displayed in full products without having to edit graph properties each time. The TSTool features can be implemented similarly in other software that uses the TSView software. The following discussion focuses on TSTool as an example of graph template implementation. For example, assume that one or more time series have been generated and are listed in the Time Series Results area, as shown below.

Graph templates utilizes the following process:
- Normal TSTool command features are used to create time series. The command file can be very basic, using only time series identifiers or commands to read time series. Or, the command file can be more complex, as needed for a workflow process.
- One or more time series (or time series ensembles) are selected in the TSTool Results
area and the Graph with template button is used, with a corresponding graph template.
The graph template is a time series product file (*.tsp) containing properties described in the previous sections, but typically will also contain Freemarker template syntax as described below. Graph templates need to be stored in the folder in the user's files (/home/useron Linux orC:\Users\useron Windows).- TSTool 13+:  .tstool/NN/template-graphsfolder under the user’s files, whereNNis the TSTool major version
- TSTool 13+:  .tstool/template-graphfolder under the user’s files
 
- TSTool 13+:  
- If the specified graph template includes a TemplatePreprocessCommandFileproperty, then the specified command file will be run with the selected time series as input (all other time series in TSTool’s main interface will NOT be used), and properties passed as described below. If the property is not defined, then the time series are used as is in the following steps with no additional processing.
- The resulting processed results are passed to the Freemarker template engine
to expand the graph template file to a temporary file.
This step is similar to the ExpandTemplateFileTSTool command.
- The expanded temporary time series product file is used with the time series from step 3 to produce the graph.
Graph templates processed in step 4 from above use the FreeMarker templating software.
Freemarker is also used by the TSTool
ExpandTemplateFile command.
The main benefit of FreeMarker is that it provides advanced template processing features
and minimizes the need to develop such features in the TSTool software.
TSTool currently uses a simple FreeMarker data model to pass data to the Freemarker data model, as follows:
- TSTool processor properties are passed to FreeMarker in their native form. These properties are listed in TSTool in the results area in the Properties tab. To pass additional properties, define them in the main TSTool command file.
- To facilitate template processing, TSTool passes the following additional properties to Freemarker:- Currently none but can be added if appropriate.
 
- TSTool also passes a number of lists to Freemarket, which can be used with the Freemarker <#list>directive. These lists are of general use for graph templates:- TemplateTSIDList– the list of TSID for the time series that are provided to the graph template. These identifiers DO include the trailing datastore name or input type.
- TemplateTSIDShortList– the list of TSID for the time series that are provided to the graph template. These identifiers DO NOT include the trailing datastore name or input type.
- TemplateTSAliasList– the list of time series alias for the time series that are provided to the graph template.
- TemplateTSLocationIDList– the list of location identifiers for the time series that are provided to the graph template.
- TemplateTSDescriptionList– the list of descriptions for the time series that are provided to the graph template, which are useful to set the graph title.
- TemplateTSUnitsList– the list of data units for the time series that are provided to the graph template, which are useful for graph title and labeling axes.
- TemplateTSEnsembleIDList– the list of time series ensemble identifiers for ensembles that are provided to the graph template.
- TemplateTSEnsembleNameList– the list of time series ensemble names for ensembles that are provided to the graph template.
 
The above data can be referenced in Freemarker templates using its variable syntax
(variable name is used as in within a FreeMarker directive, and as ${variable} in other template file text).
The following sections provide examples of using the graph templates.
These examples (or similar versions) are available in the TSTool software installation folder
under the examples/template-graphs folder (version 13 and later, and examples/template-graph for version 12)
and can be copied to the user’s files as described above.
Time Series Graph Template
The following example illustrates the configuration of a graph template for a single time series, in order to create a standard time series graph.
The following graph template file .tstool/template-graphs/TSDefault.tsp describes the graph for a single time series,
serving mainly to pick a proper title and y-axis label.
# TSDefault.tsp
#
# Default graph template to be used with individual time series.
# Select a time series in TSTool and use the "Graph with template:" button with
#  "TSDefault.tsp" template.
[Product]
ProductType = "Graph"
TotalWidth = "600"
TotalHeight = "400"
<#assign TemplateTSDescription = TemplateTSDescriptionList[0]>
<#assign TemplateTSLocationID = TemplateTSLocationIDList[0]>
MainTitleString = "${TemplateTSDescription} (${TemplateTSLocationID})"
# This is probably not needed by default for single time series
#TemplatePreprocessCommandFile = "TSDefault.TSTool"
[SubProduct 1]
GraphType = "Line"
LeftYAxisTitlePosition = "LeftOfAxis"
LeftYAxisTitleRotation = "270"
RightYAxisGraphType = "None"
RightYAxisIgnoreUnits = "false"
# The following uses TSID without the trailing ~DataStore (or ~InputType)
# so read is not attempted
<#list TemplateTSAliasList as TemplateTSAlias>
[Data 1.${TemplateTSAlias_index + 1}]
<#assign TemplateTSIDShort = TemplateTSIDShortList[TemplateTSAlias_index]>
TSID = "${TemplateTSIDShort}"
TSAlias = "${TemplateTSAlias}"
</#list>
The above template does not use the TemplatePreprocessCommandFile property because the
single time series is already in a form that can be directly used to produce the graph.
The lists that are passed in are used to reference properties using array notation [0],
since Freemarker lists use 0-index reference.  The following is an example of the resulting graph.

Example Time Series Graph Created using Graph Template
Time Series Ensemble Graph Template – Time Series as Input
The following example illustrates the configuration of a graph template for a single time series, converted to an ensemble, in order to create a standard ensemble graph.
The following graph template file .tstool/template-graphs/TSAsEnsembleCalcStatsDefault.tsp
describes the ensemble graph for a single time series,
serving mainly to pick a proper title and y-axis label, and legend position.
# TSAsEnsembleCalcStatsDefault.tsp
#
# Default graph template to be used with times series converted to an ensemble on
# the fly.
# Select a time series in TSTool and use the "Graph with template: 
# TSAsEnsembleDefault.tsp" choice.
# The TSAsEnsembleCalcStatsDefault.TSTool command file will be run to convert the
# time series to an ensemble, and also calculate some standard statistics.
# The resulting time series traces will be graphed using this template.
[Product]
ProductType = "Graph"
TotalWidth = "700"
TotalHeight = "550"
<#assign TemplateTSDescription = TemplateTSDescriptionList[0]>
<#assign TemplateTSLocationID = TemplateTSLocationIDList[0]>
#MainTitleString = "${TemplateTSDescription} (${TemplateTSLocationID})"
# The TemplateGraphTitle property is set in TSAsEnsembleCalcStatsDefault.TSTool
MainTitleString = "${TemplateGraphTitle}"
TemplatePreprocessCommandFile = "TSAsEnsembleCalcStatsDefault.TSTool"
[SubProduct 1]
GraphType = "Line"
LeftYAxisLegendPosition = "Right"
LeftYAxisTitlePosition = "LeftOfAxis"
LeftYAxisTitleRotation = "270"
LegendFormat = "%z"
LeftYAxisLabelPrecision = "0"
RightYAxisGraphType = "None"
RightYAxisIgnoreUnits = "false"
<#list TemplateTSAliasList as TemplateTSAlias>
[Data 1.${TemplateTSAlias_index + 1}]
<#assign TemplateTSID = TemplateTSIDList[TemplateTSAlias_index]>
TSID = "${TemplateTSID}"
TSAlias = "${TemplateTSAlias}"
</#list>
Note in the above case that the TemplatePreprocessCommandFile is specified.
Consequently, the file ./tstool/template-graphs/TSAsEnsembleCalcStatsDefaul.TSTool (shown below)
must exist and will be run to preprocess the graph time series into an ensemble that is used by the template.
Note also that the following command file uses commands to set processor properties that are useful to the template.
The following command file calculates mean and median statistic time series for use in the graph product.
The combination of the preprocess command file and the graph template provides flexibility in processing the data and configuring the graph.
# Command file to convert single time series into ensemble for use by TSAsEnsembleCalcStatsDefault.tsp
# This command file is intended to operate on a single input time series that can be selected with TSList=AllTS (default).
#
# Set properties that will be available in the graph template
# - main graph title that does not have "trace" or other extra information
# - taken from the selected time series passed to this command file, which is the original (not a trace)
SetPropertyFromTimeSeries(TSList=FirstMatchingTSID,TSID="*",PropertyName="TemplateGraphTitle",PropertyValue="%D")
#
# Set properties needed below to implement a generic template
# - TSID for the first time series since it is used as input below
SetPropertyFromTimeSeries(TSList=FirstMatchingTSID,TSID="*",PropertyName="TemplateGraphFirstTSID",PropertyValue="%F")
# ----------------------------------------------------------------------------------
# Set the start of the water year for the reference date.
# - Could simplify this with additional TSTool enhancement but for now use logic below
SetProperty(PropertyName="CurrentDayDate",PropertyType=DateTime,PropertyValue="CurrentToDay")
FormatDateTimeProperty(PropertyName="CurrentDateYearAsString",DateTimePropertyName="CurrentDayDate",Format="%Y")
FormatDateTimeProperty(PropertyName="CurrentDateMonthAsString",DateTimePropertyName="CurrentDayDate",Format="%m")
SetProperty(PropertyName="CurrentDateMonth",PropertyType=Integer,PropertyValue="${CurrentDateMonthAsString}")
If(Name="If_WaterYearStartIsLastCalendarYear",Condition="${CurrentDateMonth} < 10")
# In months January-September, so water year start needs to shift to use previous year.
SetProperty(PropertyName="CurrentWaterYearStartDate",PropertyType=DateTime,PropertyValue="${CurrentDateYearAsString}-10-01")
SetProperty(PropertyName="CurrentWaterYearStartDate",PropertyType=DateTime,PropertyValue="${CurrentWaterYearStartDate}",Subtract="1Year")
EndIf(Name="If_WaterYearStartIsLastCalendarYear")
If(Name="If_WaterYearStartIsThisCalendarYear",Condition="${CurrentDateMonth} >= 10")
# In months October-December, so water year start is OK using the current year
SetProperty(PropertyName="CurrentWaterYearStartDate",PropertyType=DateTime,PropertyValue="${CurrentDateYearAsString}-10-01")
EndIf(Name="If_WaterYearStartIsThisCalendarYear")
# ----------------------------------------------------------------------------------
#
# Create an ensemble from the one time series that was selected and passed to this command file
# - different parameters, such as TraceLength=1Month can be set in a copy of the file
CreateEnsembleFromOneTimeSeries(TSID="${TemplateGraphFirstTSID}",TraceLength=1Year,EnsembleID="TemplateEnsembleID",EnsembleName="TemplateEnsemble",ReferenceDate="2016-10-01",OutputYearType=Water,ShiftDataHow=ShiftToReference)
#
# Calculate statistics as desired, using the ensemble as input
# - specifying [Mean] for the sequence ID is necessary to use in the graph legend
NewStatisticTimeSeriesFromEnsemble(EnsembleID="TemplateEnsembleID",Statistic=Mean,NewTSID="${TemplateGraphFirstTSID}[Mean]",Alias="%L-Mean")
NewStatisticTimeSeriesFromEnsemble(EnsembleID="TemplateEnsembleID",Statistic=Median,NewTSID="${TemplateGraphFirstTSID}[Median]",Alias="%L-Median")
#
# Free the original input time series since don't want it shown on the ensemble graph
# - This should always work, and if there was an error creating the ensemble
#   no time series may be visible (graph may shut down)
Free(TSList=TSPosition,TSPosition=1)
The following is an example of the resulting graph:

Example Ensemble Graph Created using Graph Template
Time Series Ensemble Graph Template – Ensemble as Input
The following example illustrates the configuration of a graph template for a single ensemble, in order to create a standard ensemble graph.
The following graph template file .tstool/template-graphs/EnsembleCalcStatsDefault.tsp
describes the ensemble graph for a single time series, serving mainly to pick a proper title and y-axis label, and legend position.
# EnsembleCalcStatsDefault.tsp
#
# Default graph template to be used with time series ensembles,
# when preprocessing command file should run.
#
# Select an ensemble in TSTool results and use the "Graph with Template:
# EnsembleCalcStatsDefault.tsp" choice.
# Statistics will be calculated for the ensemble and added as time series.
[Product]
ProductType = "Graph"
TotalWidth = "700"
TotalHeight = "550"
<#if TemplateTSEnsembleNameList?size != 0>
<#assign TemplateTSEnsembleName = TemplateTSEnsembleNameList[0]>
MainTitleString = "${TemplateTSEnsembleName}"
<#else>
<#assign TemplateTSDescription = TemplateTSDescriptionList[0]>
<#assign TemplateTSLocationID = TemplateTSLocationIDList[0]>
MainTitleString = "${TemplateTSDescription} (${TemplateTSLocationID})"
</#if>
# Run the preprocessor command file to calculate statistics on the ensemble.
TemplatePreprocessCommandFile = "EnsembleCalcStatsDefault.TSTool"
[SubProduct 1]
GraphType = "Line"
LeftYAxisLegendPosition = "Right"
LeftYAxisTitlePosition = "LeftOfAxis"
LeftYAxisTitleRotation = "270"
LegendFormat = "%z"
LeftYAxisLabelPrecision = "0"
RightYAxisGraphType = "None"
RightYAxisIgnoreUnits = "false"
<#list TemplateTSAliasList as TemplateTSAlias>
[Data 1.${TemplateTSAlias_index + 1}]
<#assign TemplateTSID = TemplateTSIDList[TemplateTSAlias_index]>
TSID = "${TemplateTSID}"
TSAlias = "${TemplateTSAlias}"
</#list>
The ensemble that is input to the template has been previously created. However, it does not provide statistic time series. Therefore, the following command file is used to add statistic time series for mean and median, which are used in the graph.
# Command file to calculate statistics for ensemble for use by
# EnsembleCalcStatsDefault.tsp
# This command file is intended to operate on a single input ensemble.
#
# Set properties that will be available in the graph template
# - main graph title that does not have "trace" or other extra information
SetPropertyFromEnsemble(EnsembleID="*",PropertyName="TemplateGraphTitle",PropertyValue="${tsensemble:EnsembleName}")
#
# Set properties needed below to implement a generic template
# - Ensemble for the first time series since it is used as input below
SetPropertyFromEnsemble(EnsembleID="*",PropertyName="TemplateEnsembleID",PropertyValue="${tsensemble:EnsembleID}")
SetPropertyFromTimeSeries(FirstMatchingTSID,TSID="*",PropertyName="TemplateGraphFirstTSID",PropertyValue="%F")
#
# Calculate statistics as desired, using the ensemble as input
# - specifying [Mean] for the sequence ID is necessary to use %z in the graph legend
#   similar to the traces
# - TODO sam 2017-04-10 need to allow NewTSID to accept properties so can properly
#   specify below
# - maybe allow an ensemble property lookup on the trace TSID without
#   sequence number?
NewStatisticTimeSeriesFromEnsemble(EnsembleID="${TemplateEnsembleID}",Statistic=Mean,NewTSID="${TemplateGraphFirstTSID}[Mean]",Alias="%L-Mean")
NewStatisticTimeSeriesFromEnsemble(EnsembleID="${TemplateEnsembleID}",Statistic=Median,NewTSID="${TemplateGraphFirstTSID}[Median]",Alias="%L-Median")