Interval Metrics (e.g., VWAP)#
import onetick.py as otp
query = otp.DataSource('US_COMP_SAMPLE', tick_type='TRD')
query = query.agg({'market_vwap': otp.agg.vwap('PRICE', 'SIZE')})
otp.run(
    query,
    symbols=['AAPL'],
    start=otp.dt(2024, 2, 1, 9, 30),
    end=otp.dt(2024, 2, 1, 9, 30, 1),
    timezone='EST5EDT',
)
| Time | market_vwap | |
|---|---|---|
| 0 | 2024-02-01 09:30:01 | 183.901435 | 
Computing market VWAP for every order’s arrival/exit interval#
start = otp.dt(2024, 2, 1, 9, 30)
end = otp.dt(2024, 2, 1, 9, 30, 1)
orders = otp.Ticks(arrival=[start, start + otp.Milli(7934)],
                   exit=[end, end + otp.Milli(9556)],
                   sym=['AAPL', 'MSFT'])
otp.run(orders, start=start, end=start + otp.Day(1))
| Time | arrival | exit | sym | |
|---|---|---|---|---|
| 0 | 2024-02-01 09:30:00.000 | 2024-02-01 09:30:00.000 | 2024-02-01 09:30:01.000 | AAPL | 
| 1 | 2024-02-01 09:30:00.001 | 2024-02-01 09:30:07.934 | 2024-02-01 09:30:10.556 | MSFT | 
def vwap(symbol):
    q = otp.DataSource('US_COMP_SAMPLE', tick_type='TRD')
    q = q.agg({'market_vwap': otp.agg.vwap('PRICE','SIZE')})
    return q
orders = orders.join_with_query(vwap, start=orders['arrival'], end=orders['exit'], symbol=orders['sym'])
otp.run(orders, start=start, end=end + otp.Day(1))
| Time | market_vwap | arrival | exit | sym | |
|---|---|---|---|---|---|
| 0 | 2024-02-01 09:30:00.000 | 183.901435 | 2024-02-01 09:30:00.000 | 2024-02-01 09:30:01.000 | AAPL | 
| 1 | 2024-02-01 09:30:00.001 | 402.840416 | 2024-02-01 09:30:07.934 | 2024-02-01 09:30:10.556 | MSFT | 
A more efficient implementation is also available with symbol parameters.