First-Order Trade Greeks
Fetch first-order Greeks on each trade for an option contract.
- Returns the data for all contracts that share the same provided symbol and expiration.
- Calculates greeks for every trade reported by OPRA.
- The underlying price represents whatever the last underlying price was at the
timestampfield. You can read more about how Theta Data calculates greeks here. - Multi-day requests are limited to 1 month of data, and must specify an expiration.
pub fn option_history_trade_greeks_first_order(
&self,
symbol: &str,
expiration: &str,
date: &str,
) -> OptionHistoryTradeGreeksFirstOrderBuilder<'_>Optional parameters chain on the builder: .strike(&str), .right(&str), .start_time(&str), .end_time(&str), .annual_dividend(f64), .rate_type(&str), .rate_value(f64), .version(&str), .max_dte(i32), .strike_range(i32), .start_date(&str), .end_date(&str). Execute with .await → Result<Vec<TradeGreeksFirstOrderTick>, Error>, or decode chunk-by-chunk with .stream(handler).
Example
let rows = tdx
.option_history_trade_greeks_first_order("SPY", "20250321", "20250303")
.strike("570")
.right("C")
.await?;
for t in &rows {
println!("ms_of_day={} price={} delta={} theta={}", t.ms_of_day, t.price, t.delta, t.theta);
}Parameters
| Name | Type | Required | Default | Description |
|---|---|---|---|---|
symbol | string | yes | — | Ticker symbol (e.g. AAPL) |
expiration | date | yes | — | Expiration date YYYYMMDD |
date | date | yes | — | Date YYYYMMDD |
strike | string | no | * | Strike price in dollars as a string (e.g. 500 or 17.5). Use * for wildcard selection. |
right | string | no | both | Option side. Accepted values: call, put, both. |
start_time | string | no | 09:30:00 | Start time filter |
end_time | string | no | 16:00:00 | End time filter |
annual_dividend | float | no | — | Annualized expected dividend amount, in dollars per share, used in the Greeks calculation (e.g. 2.5 is $2.50 per share per year). |
rate_type | string | no | sofr | Risk-free-rate source used in the Greeks calculation. Accepted values: sofr, treasury_m1, treasury_m3, treasury_m6, treasury_y1, treasury_y2, treasury_y3, treasury_y5, treasury_y7, treasury_y10, treasury_y20, treasury_y30. |
rate_value | float | no | — | Interest rate as a percent (4.36 means 4.36%, matching the InterestRateTick.rate convention) used in the Greeks calculation. Applied when rate_type selects a manual rate. |
version | string | no | latest | Greeks model version. Accepted values: latest, 1. |
max_dte | int | no | — | Maximum days to expiration |
strike_range | int | no | — | Strike range filter |
start_date | date | no | — | Start date YYYYMMDD |
end_date | date | no | — | End date YYYYMMDD |
timeout_ms | int | no | — | Per-request deadline in milliseconds. 0 means no deadline. |
Response
Rows of TradeGreeksFirstOrderTick:
| Field | Type | Description |
|---|---|---|
ms_of_day | i32 | Milliseconds since midnight Eastern Time. |
sequence | i32 | Exchange-assigned trade sequence number. |
ext_condition1 | i32 | Additional trade condition code. |
ext_condition2 | i32 | Additional trade condition code. |
ext_condition3 | i32 | Additional trade condition code. |
ext_condition4 | i32 | Additional trade condition code. |
condition | i32 | Trade condition code. |
size | i32 | Number of contracts or shares traded. |
exchange | i32 | Exchange code where the trade executed. |
price | f64 | Trade price. |
delta | f64 | Sensitivity of the option value to a one-dollar move in the underlying. |
theta | f64 | Sensitivity of the option value to the passage of time. |
vega | f64 | Sensitivity of the option value to a change in implied volatility. |
rho | f64 | Sensitivity of the option value to the risk-free rate. |
epsilon | f64 | Sensitivity of the option value to the dividend yield. |
lambda | f64 | Percent change in the option value per percent change in the underlying. |
implied_volatility | f64 | Implied volatility solved from the option price. |
iv_error | f64 | Residual pricing error of the implied-volatility solve. |
underlying_ms_of_day | i32 | Timestamp of the underlying price, milliseconds since midnight ET. |
underlying_price | f64 | Underlying price used in the calculation (midpoint of the underlying). |
date | i32 | Trading date as a YYYYMMDD integer. |
Wildcard requests additionally populate expiration (YYYYMMDD), strike (dollars), and right ("C" / "P") on every row to identify the contract; on single-contract requests these are absent (None / null / undefined; the Rust and C rows carry the documented 0 / 0.0 / '\0' fills).
Example response
ms_of_day | sequence | ext_condition1 | ext_condition2 | ext_condition3 | ext_condition4 | condition | size | exchange | price | delta | theta | vega | rho | epsilon | lambda | implied_volatility | iv_error | underlying_ms_of_day | underlying_price | date |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 34372940 | 1846852600 | 255 | 255 | 255 | 255 | 18 | 1 | 31 | 61.05 | 0.7045 | -0.1037 | 164.371 | 239.2069 | -282.5279 | 6.5217 | 0.2001 | 0 | 34372000 | 565.13 | 20250502 |
Decoded from a captured production response; 1 of 1 rows shown.