Skip to main content

Price Simulator

When this is provided and the prices field is not set, the Price Simulator will automatically generate values to populate the prices field before the simulation is performed.

The Price Simulator offers many settings. For detailed information, please refer to the Price Simulator section of the documentation.

Ensure you follow the formatting in the example below when configuring these settings.

Format

nametype
typeobject
requiredtrue

Example

priceSimulator:
maturity: 1.0
random_seed_price: 42
random_seed_sigma: 42
random_seed_black_swan: 42
volatility_mode: "cccgarch"
historicalDataBlockRange: [16085600, 16100000]
granularity: 60
settings:
market_drift: [0, 1]
enable_black_swan_event: false
black_swan_must_happen_by: 0.8
black_swan_cannot_happen_before: 0.3
black_swan_range: [0.3, 0.5]
black_swan_step_length: 100
black_swan_kappa: 0.3
black_swan_theta: 0.02
black_swan_xi: 0.1
volatility_scale: 1.0
max_percentage_change: 0.2
max_value_percentage: 1.0
min_value_percentage: 1.0
postprocessing:
- name: "aggregate"
content:
steps:
0: 60
is_ohlc: true

In the above example:

  • The three random seeds are set to 42 to ensure reproducible output.
  • The CCC-GARCH method is used for modeling volatility. For longer time horizons, EWMA may be used instead, as it is more scalable at size.
  • The granularity of 60 means that each time step in the price simulator will be in one-minute intervals. This value is represented in seconds. A value of 0 or less (the default value if undefined) will use block-level time steps.
  • The settings map one-to-one with the price simulator's internal settings configuration and key-value mapping.
  • The postprocessing object defines postprocessing directives. In this case, the aggregate postprocessing directive is being requested. These settings indicate that every 60 time steps in the price simulator's output should be aggregated, and since the granularity is 60, this means that each time step in the final output will represent one hour. Setting is_ohlc to true will mean that data will be output in the [open, high, low, close] format for each time step rather than a single close value. Note that this aggregation will also be done for historical data in the response in order to ensure consistency in the representation of data and consistency in custom simulation code that may be making use of lookback at each time step. Also note that all postprocessing directives will run in the order that they are defined, from first to last.
Price Scenarios via the UI Platform

We encourage you to use the Price Simulator via the UI to generate your price trajectories and then use the Price IDs in your configuration. See the [Start Simulation Tutorial]