Files
egutierrez 47fac22230 chore: auto-commit (799 archivos)
- .claude/CLAUDE.md
- .claude/commands/subagentes.md
- .claude/rules/INDEX.md
- .mcp.json
- bash/functions/cybersecurity/analyze_dns.md
- bash/functions/cybersecurity/audit_http_headers.md
- bash/functions/cybersecurity/audit_ssh_config.md
- bash/functions/cybersecurity/check_firewall.md
- bash/functions/cybersecurity/detect_suspicious_users.md
- bash/functions/cybersecurity/encrypt_file.md
- ...

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-14 00:28:20 +02:00

44 lines
1.4 KiB
Markdown

---
name: sharpe_ratio
kind: function
lang: py
domain: finance
version: "1.0.0"
purity: pure
signature: "def sharpe_ratio(returns: list, risk_free_rate: float, periods_per_year: float) -> float"
description: "Calcula el Sharpe Ratio anualizado de una serie de retornos."
tags: [finance, sharpe, risk, performance, python, pendiente-usar]
uses_functions: []
uses_types: []
returns: []
returns_optional: false
error_type: ""
imports: [math]
params:
- name: returns
desc: "lista de retornos en la misma periodicidad (ej: retornos diarios [0.01, -0.005, ...])."
- name: risk_free_rate
desc: "tasa de interes libre de riesgo anualizada en forma decimal (ej: 0.02 para 2% anual)."
- name: periods_per_year
desc: "numero de periodos por año (252 para diarios, 12 para mensuales, 52 para semanales)."
output: "Sharpe ratio anualizado en forma decimal (ej: 1.5 indica 1.5x retorno por unidad de riesgo). Mayor es mejor."
tested: false
tests: []
test_file_path: ""
file_path: "python/functions/finance/finance.py"
---
## Ejemplo
```python
daily_returns = [0.01, -0.005, 0.008, 0.003, -0.002, 0.006, 0.004]
sr = sharpe_ratio(daily_returns, 0.02, 252.0)
# Sharpe ratio anualizado
```
## Notas
risk_free_rate es la tasa anual (ej: 0.02 para 2%). Se convierte a tasa por periodo internamente.
periods_per_year indica la frecuencia de los retornos (252 para diarios, 12 para mensuales).
Retorna 0.0 si la desviacion estandar es cero o la lista esta vacia.