<!--
This file is generated by a tool. Do not edit directly.
For open-source contributions the docs will be updated automatically.
-->

*Last updated: 2023-03-16.*

<div itemscope itemtype="http://developers.google.com/ReferenceObject">
<meta itemprop="name" content="tf_quant_finance.black_scholes.implied_vol_approx" />
<meta itemprop="path" content="Stable" />
</div>

# tf_quant_finance.black_scholes.implied_vol_approx

<!-- Insert buttons and diff -->

<table class="tfo-notebook-buttons tfo-api" align="left">
</table>

<a target="_blank" href="https://github.com/paolodelia99/tf-quant-finance/blob/main/tf_quant_finance/black_scholes/implied_vol_approximation.py">View source</a>



Approximates the implied vol using the Stefanica-Radiocic algorithm.

```python
tf_quant_finance.black_scholes.implied_vol_approx(
    *, prices, strikes, expiries, spots=None, forwards=None, discount_factors=None,
    is_call_options=None, validate_args=False, polya_factor=0.6366197723675814,
    dtype=None, name=None
)
```



<!-- Placeholder for "Used in" -->

Finds an approximation to the implied vol using the Polya approximation for
the Normal CDF. This algorithm was described by Stefanica and Radiocic in
ref [1]. They show that if the Normal CDFs appearing in the Black Scholes
formula for the option price are replaced with Polya's approximation, the
implied vol can be solved for analytically. The Polya approximation produces
absolute errors of less than 0.003 and the resulting implied vol is fairly
close to the true value. For practical purposes, this may not be accurate
enough so this result should be used as a starting point for some method with
controllable tolerance (e.g. a root finder).

#### References:
[1]: Dan Stefanica and Rados Radoicic. An explicit implied volatility formula.
  International Journal of Theoretical and Applied Finance,
  Vol. 20, no. 7, 2017.
  https://papers.ssrn.com/sol3/papers.cfm?abstract_id=2908494
[2]: Omar Eidous, Samar Al-Salman. One-term approximation for Normal
  distribution function. Mathematics and Statistics 4(1), 2016.
  http://www.hrpub.org/download/20160229/MS2-13405192.pdf

#### Args:


* <b>`prices`</b>: A real `Tensor` of any shape. The prices of the options whose
  implied vol is to be calculated.
* <b>`strikes`</b>: A real `Tensor` of the same dtype as `prices` and a shape that
  broadcasts with `prices`. The strikes of the options.
* <b>`expiries`</b>: A real `Tensor` of the same dtype as `prices` and a shape that
  broadcasts with `prices`. The expiry for each option. The units should
  be such that `expiry * volatility**2` is dimensionless.
* <b>`spots`</b>: A real `Tensor` of any shape that broadcasts to the shape
  of the `prices`. The current spot price of the underlying. Either this
  argument or the `forwards` (but not both) must be supplied.
* <b>`forwards`</b>: A real `Tensor` of any shape that broadcasts to the shape of
  `prices`. The forwards to maturity. Either this argument or the `spots`
  must be supplied but both must not be supplied.
* <b>`discount_factors`</b>: An optional real `Tensor` of same dtype as the `prices`.
  If not None, these are the discount factors to expiry (i.e. e^(-rT)).
  If None, no discounting is applied (i.e. it is assumed that the
  undiscounted option prices are provided ). If `spots` is supplied and
  `discount_factors` is not None then this is also used to compute the
  forwards to expiry.
  Default value: None, equivalent to discount factors = 1.
* <b>`is_call_options`</b>: A boolean `Tensor` of a shape compatible with `prices`.
  Indicates whether the option is a call (if True) or a put (if False).
  If not supplied, call options are assumed.
* <b>`validate_args`</b>: A Python bool. If True, indicates that arguments should be
  checked for correctness before performing the computation. The checks
  performed are: (1) Forwards/spots and strikes are positive. (2) The prices
    satisfy the arbitrage bounds (i.e. for call options, checks the
    inequality `max(F-K, 0) <= Price <= F` and for put options, checks that
    `max(K-F, 0) <= Price <= K`.). (3) Checks that the prices are not too
    close to the bounds. It is numerically unstable to compute the implied
    vols from options too far in the money or out of the money.
  Default value: False
* <b>`polya_factor`</b>: A real scalar. The coefficient to use in the
  approximation for the Normal CDF. The approximation is: `N(x) ~ 0.5 + 0.5
    * sign(x) * sqrt[ 1 - exp(-k * x**2) ]` where `k` is the coefficient
    supplied with `polya_factor`. The original Polya approximation has the
    value `2 / pi` and this is approximation used in Ref [1]. However, as
    described in Ref [2], a slightly more accurate approximation is achieved
    if we use the value of `k=5/8`).
* <b>`dtype`</b>: `tf.Dtype` to use when converting arguments to `Tensor`s. If not
  supplied, the default TensorFlow conversion will take place. Note that
  this argument does not do any casting for `Tensor`s or numpy arrays.
  Default value: None.
* <b>`name`</b>: (Optional) Python str. The name prefixed to the ops created by this
  function. If not supplied, the default name 'implied_vol' is
  used.
  Default value: None


#### Returns:


* <b>`implied_vols`</b>: A `Tensor` of the same dtype as `prices` and shape as the
  common broadcasted shape of `(prices, spots/forwards, strikes, expiries)`.
  The approximate implied total volatilities computed using the Polya
  approximation method.


#### Raises:


* <b>`ValueError`</b>: If both `forwards` and `spots` are supplied or if neither is
  supplied.