🛠️ToolsShed

Calculadora de Juros Compostos

Calcule o crescimento de juros compostos para investimentos ao longo do tempo.

A Calculadora de Juros Compostos mostra como um investimento ou conta de poupança cresce ao longo do tempo quando os juros são ganhos não apenas sobre o principal, mas também sobre os juros acumulados de períodos anteriores.

Insira o valor principal, a taxa de juros anual, a frequência de composição (diária, mensal, trimestral ou anual) e o número de anos. A calculadora mostra o saldo final, o total de juros ganhos e um detalhamento ano a ano.

Entender os juros compostos é essencial para o planejamento da aposentadoria, avaliação de contas de poupança, comparação de custos de empréstimos e tomada de decisões de investimento informadas. O principal insight é que começar cedo e reinvestir os retornos pode produzir significativamente mais riqueza.

Perguntas Frequentes

Implementação de Código

def compound_interest(principal, annual_rate, years, n=12, contribution=0):
    """
    Calculate compound interest with optional regular contributions.

    Parameters:
        principal    - initial investment
        annual_rate  - annual interest rate (e.g. 0.07 for 7%)
        years        - investment duration in years
        n            - compounding frequency per year (12 = monthly)
        contribution - periodic contribution (same frequency as n)

    Returns dict with final balance, total invested, and total interest.
    """
    r = annual_rate / n
    periods = int(years * n)
    balance = principal
    for _ in range(periods):
        balance = balance * (1 + r) + contribution
    total_invested = principal + contribution * periods
    return {
        "final_balance":  balance,
        "total_invested": total_invested,
        "total_interest": balance - total_invested,
    }

def rule_of_72(annual_rate):
    """Estimate years to double at a given annual rate."""
    return 72 / (annual_rate * 100)

# Simple formula (no contributions)
def compound_formula(P, r, n, t):
    """A = P(1 + r/n)^(nt)"""
    return P * (1 + r / n) ** (n * t)

# Examples
result = compound_interest(10000, 0.07, 20, n=12, contribution=500)
print(f"Final balance:   ${result['final_balance']:,.2f}")
print(f"Total invested:  ${result['total_invested']:,.2f}")
print(f"Total interest:  ${result['total_interest']:,.2f}")
print(f"Years to double: {rule_of_72(0.07):.1f} years at 7%")

# Compounding frequency comparison
for label, n in [("Annual", 1), ("Monthly", 12), ("Daily", 365)]:
    A = compound_formula(10000, 0.12, n, 10)
    print(f"{label:8}: ${A:,.2f}  (EAR = {((1 + 0.12/n)**n - 1)*100:.4f}%)")

Comments & Feedback

Comments are powered by Giscus. Sign in with GitHub to leave a comment.