Time Modeling
Periods
Start and End Time
Bars have a start and end time that represent the time period of which the bar aggregates data. LEAN passes the bar to your algorithm at the end time so that you don't receive the bar before it was actually available. Free online data providers commonly timestamp their bars to the start time of the bar and include the bar close price, making your research prone to look ahead bias.
Carefully consider the end-time of data to avoid one-off errors when you import the data into QC or compare indicator values across different platforms. Generally, bar timestamps can be represented as follows: bar.EndTime = bar.Time + bar.Period
bar.end_time = bar.time + bar.period
.
Period Values
Bars aggregate data across a period of time into a single object. We make this easy for you by pre-aggregating billions of raw trade-ticks into TradeBar
objects and quote-ticks into QuoteBar
objects.
We don't know the close of an intraday bar until the start of the next bar, which can sometimes be confusing. For daily bars, the bar will include all the ticks from market open to market close, but LEAN will emit it to your algorithm at market close. As a result, if you analyze the Friday data and then place an order, LEAN sends the order to your brokerage on Friday after the market close.
When there are no ticks during a period, LEAN emits the previous bar. This is the default behavior for bar data and it's referred to as "filling the data forward". You can enable and disable this setting when you create the security subscription.
We provide bar data in second, minute, hour, and daily bar formats. To create other periods of bars, see Consolidating Data.
Daily Periods
LEAN emits daily bars at market close or midnight, depending on your DailyPreciseEndTime
daily_precise_end_time
setting. To be notified when a security has finished trading for the day, add an OnEndOfDay
on_end_of_day
method to your algorithm. LEAN calls this method for each security every day.
# Perform end-of-day logic for a given symbol. def on_end_of_day(self, symbol: Symbol) -> None: pass
// Perform end-of-day logic for a given symbol. public override void OnEndOfDay(Symbol symbol) { }
Point Values
Point values have no period because they occur at a singular point in time. Examples of point data includes ticks, open interest, and news releases. Tick data represents a single trade or quote in the market. It's a discrete event with no period, so the Time
time
and EndTime
end_time
properties are the same. LEAN emits ticks as soon as they arrive and doesn't fill them forward.