Taxas a Termo
forward(bday1, bday2, rate1, rate2)
Calcula a taxa a termo entre dois prazos (dias úteis).
Utiliza a fórmula:
f₁→₂ = (f₂^(du₂/252) / f₁^(du₁/252))^(252/(du₂ - du₁)) - 1
Onde
- f₁ é o fator de capitalização do primeiro prazo (f₁ = 1 + tx₁).
- f₂ é o fator de capitalização do segundo prazo (f₂ = 1 + tx₂).
- tx₁ é a taxa zero para o primeiro prazo (du₁).
- tx₂ é a taxa zero para o segundo prazo (du₂).
- du₁ é o número de dias úteis até a primeira data.
- du₂ é o número de dias úteis até a segunda data.
- A constante 252 representa o número de dias úteis no ano.
Como au = du/252 (tempo em anos úteis), a fórmula pode ser simplificada para:
f₁→₂ = (f₂^au₂ / f₁^au₁)^(1/(au₂ - au₁)) - 1
Que em latex fica:
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
bday1
|
int
|
Número de dias úteis do primeiro ponto (prazo menor). |
required |
bday2
|
int
|
Número de dias úteis do segundo ponto (prazo maior). |
required |
rate1
|
float
|
Taxa zero para o prazo |
required |
rate2
|
float
|
Taxa zero para o prazo |
required |
Returns:
| Name | Type | Description |
|---|---|---|
float |
float
|
A taxa a termo calculada entre |
Examples:
>>> # Exemplo válido: du₂ > du₁
>>> yd.forward(10, 20, 0.05, 0.06)
0.0700952380952371
>>> # Exemplo inválido: du₁ >= du₂
>>> print(yd.forward(20, 10, 0.06, 0.05))
nan
Notes
du₂ precisa ser necessariamente maior que du₁ para que
o cálculo da taxa a termo seja matematicamente válido.
Source code in pyield/fwd.py
forwards(bdays, rates, group_by=None)
Calcula taxas a termo a partir de taxas zero.
A taxa a termo no vértice 'n' é definida como:
fwdₖ = fwdⱼ→ₖ (a taxa a termo de j para k)
Definindo o fator de capitalização no vértice k como:
fₖ = 1 + txₖ
A fórmula utilizada é:
fwdₖ = (fₖ^(duₖ/252) / fⱼ^(duⱼ/252))^(252/(duₖ - duⱼ)) - 1
Como au = du/252 (tempo em anos úteis), a fórmula pode ser simplificada para:
fwdₖ = (fₖ^auₖ / fⱼ^auⱼ)^(1/(auₖ - auⱼ)) - 1
Em LaTeX, a fórmula é representada como:
Onde: - fⱼ é o fator de capitalização no vértice anterior (fⱼ = 1 + txⱼ). - fₖ é o fator de capitalização no vértice atual (fₖ = 1 + txₖ). - txⱼ é a taxa zero para o vértice anterior. - txₖ é a taxa zero para o vértice atual. - auⱼ é o prazo em anos úteis no vértice anterior (auⱼ = duⱼ/252). - auₖ é o prazo em anos úteis no vértice atual (auₖ = duₖ/252). - A constante 252 representa o número de dias úteis no ano.
A função preserva a ordem original dos dados de entrada e lida com valores nulos de forma apropriada. Valores nulos nas entradas resultarão em valores nulos nas taxas a termo calculadas.
A primeira taxa a termo de cada grupo é definida como a taxa zero desse primeiro vértice (fwd₁ = tx₁), dado que não existe um vértice anterior a tx₁ para se calcular a taxa a termo no primeiro ponto.
A função também lida com agrupamentos opcionais, permitindo calcular taxas
a termo para diferentes grupos de datas. O agrupamento é feito com base em group_by.
Se este argumento for None, todos os dados serão tratados como um único grupo.
A função calcula as taxas a termo para todos os pontos, exceto o primeiro de cada grupo, que é tratado separadamente.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
bdays
|
ArrayLike
|
Número de dias úteis (du) para cada taxa zero. |
required |
rates
|
ArrayLike
|
Taxas zero (tx) correspondentes aos dias úteis. |
required |
group_by
|
Sequence[str | int | date] | Series | None
|
Critério de agrupamento para os cálculos (ex: datas de referência, tickers de títulos). Pode ser uma lista/série de strings, inteiros ou datas. Se None, todos os dados são tratados como um único grupo. Padrão None. |
None
|
Returns:
| Type | Description |
|---|---|
Series
|
pl.Series: Série contendo as taxas a termo calculadas (tipo Float64). A primeira taxa de cada grupo corresponde à taxa zero inicial. |
Raises:
| Type | Description |
|---|---|
ShapeError
|
Se os comprimentos de |
Examples:
>>> bdays = [10, 20, 30]
>>> rates = [0.05, 0.06, 0.07]
>>> yd.forwards(bdays, rates)
shape: (3,)
Series: 'fwd' [f64]
[
0.05
0.070095
0.090284
]
>>> # Exemplo com agrupamento (a última está isolada em outro grupo)
>>> group_by = ["LTN", "LTN", "NTN-F"]
>>> yd.forwards(bdays, rates, group_by)
shape: (3,)
Series: 'fwd' [f64]
[
0.05
0.070095
0.07
]
>>> # Exemplo com taxas indicativas de NTN-B em 16-09-2025
>>> from pyield import ntnb
>>> df = ntnb.data("16-09-2025")
>>> yd.forwards(df["dias_uteis"], df["taxa_indicativa"])
shape: (13,)
Series: 'fwd' [f64]
[
0.0943
0.071549
0.072439
0.069558
0.076614
…
0.068105
0.071278
0.069117
0.070373
0.073286
]
>>> # Valores nulos são descartados no cálculo e retornados como nulos
>>> du = [230, 415, 730, None, 914]
>>> tx = [0.0943, 0.084099, 0.079052, 0.1, 0.077134]
>>> yd.forwards(du, tx)
shape: (5,)
Series: 'fwd' [f64]
[
0.0943
0.071549
0.072439
null
0.069558
]
>>> # O algoritmo ordena os dados de entrada antes do cálculo e retorna
>>> # os resultados na ordem original. Valores duplicados são tratados
>>> # como um único ponto no cálculo da taxa a termo (último valor é mantido).
>>> du = [230, 730, 415, 230]
>>> tx = [0.1, 0.079052, 0.084099, 0.0943]
>>> yd.forwards(du, tx)
shape: (4,)
Series: 'fwd' [f64]
[
0.0943
0.072439
0.071549
0.0943
]
Notes
- A função ordena os dados de entrada primeiro por
group_by, se for fornecido, e depois porbdayspara garantir a ordem cronológica correta no cálculo das taxas a termo. - Valores nulos em
bdaysouratessão ignorados no cálculo, resultando em valores nulos nas posições correspondentes na saída. - Os resultados são retornados na mesma ordem dos dados de entrada.
Source code in pyield/fwd.py
9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 | |