0
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

ChatGPT と Python で学ぶ 元利均等返済 と 元金均等返済

Posted at

user:

元利均等返済と元金均等返済について比較しながら、詳細かつ厳密に説明してください。

assistant:

1. 概要

住宅ローンや事業ローンの返済方式には、元利均等返済元金均等返済の2つが代表的です。これらは、借入金の返済方法を決定する重要な要素であり、それぞれに特徴とメリット・デメリットがあります。以下では、それぞれの返済方式の仕組みを厳密に説明し、比較します。


2. 元利均等返済 (Equal Payment of Principal and Interest)

2.1 定義

元利均等返済とは、毎月の返済額(元金+利息)が一定となる返済方式です。
この方式では、最初は利息の支払いが大きく、時間の経過とともに元金の割合が増えていきます。

2.2 計算式

借入額を ( P )、年間利率を ( r )、返済期間を ( n ) 年(総返済回数 ( N = 12n ))とすると、毎月の返済額 ( A ) は次の式で求められます。

[
A = P \times \frac{\frac{r}{12} \times (1 + \frac{r}{12})^N}{(1 + \frac{r}{12})^N - 1}
]

ここで、

  • ( A ) :毎月の返済額(元金+利息)
  • ( P ) :借入元金
  • ( r ) :年利率(実際の計算では月利 ( \frac{r}{12} ) を使用)
  • ( N ) :総返済回数(年数 × 12)

2.3 特徴

  1. 毎月の支払額が一定
    • 家計管理がしやすい。
  2. 初期の利息負担が大きい
    • 返済当初は元金の減少が遅い。
  3. 総支払額が元金均等返済より多くなる
    • 初期の利息負担が大きいため、長期的には支払う利息総額が増える。

3. 元金均等返済 (Equal Principal Payment)

3.1 定義

元金均等返済とは、毎月の元金の返済額が一定であり、そこに利息が加わる方式です。
そのため、総返済額は当初が最大で、時間の経過とともに減少していきます。

3.2 計算式

元金均等返済では、毎月の返済額は以下のように計算されます。

[
A_n = \frac{P}{N} + (P - \frac{P}{N} \times (n-1)) \times \frac{r}{12}
]

ここで、

  • ( A_n ) :n回目の返済額(元金+利息)
  • ( P ) :借入元金
  • ( r ) :年利率(実際の計算では月利 ( \frac{r}{12} ) を使用)
  • ( N ) :総返済回数(年数 × 12)
  • ( n ) :返済回数(1 ≦ ( n ) ≦ ( N ))

元金部分は常に ( \frac{P}{N} ) で一定ですが、利息部分は残元金に比例して減少するため、総支払額は徐々に減少します。

3.3 特徴

  1. 返済当初の負担が大きい
    • 毎月の支払額は最初が最大で、時間とともに減少する。
  2. 総支払額が少なくなる
    • 早い段階で元金を減らすため、支払う利息総額は元利均等返済より少なくなる。
  3. 返済額が変動するため家計管理が難しい
    • 収入の変動がある人には負担が大きい可能性がある。

4. 比較

比較項目 元利均等返済 元金均等返済
毎月の返済額 一定 最初が最大で徐々に減少
初期の負担 低め 高め
総支払額 高め(利息負担が大きい) 低め(元金を早く減らすため)
家計管理のしやすさ 管理しやすい 初期負担が大きいため管理が難しい
向いている人 安定した収入があり、一定の支払いを望む人 早めに元金を減らし、総返済額を減らしたい人

5. 具体例(数値シミュレーション)

例えば、1,000万円を年利3%で20年間借りた場合を比較すると次のようになります。

方式 毎月の初回返済額 返済総額
元利均等返済 約55,460円 約13,310,000円
元金均等返済 約66,667円(初回)→約41,700円(最終) 約12,900,000円

結果のポイント

  • 元利均等返済は月々の負担が一定だが、総支払額は多くなる
  • 元金均等返済は初期負担が大きいが、総支払額は約40万円少なくなる

6. どちらを選ぶべきか?

適した選択肢は以下のようになります。

  1. 毎月の支払いを安定させたい → 元利均等返済

    • 家計の管理をしやすくしたい人向け。
    • 長期で借りる場合に一般的に採用される。
  2. 総支払額を減らしたい → 元金均等返済

    • 初期の返済負担に耐えられる場合はおすすめ。
    • 早期に元金を減らしたい場合に適する。

7. まとめ

方式 返済額の特徴 初期負担 総支払額 向いている人
元利均等返済 毎月一定 収入が安定し家計管理を重視
元金均等返済 初期高→徐々に減少 返済総額を抑えたい・早く元金を減らしたい

両者の違いを理解し、ライフプランや収入状況に応じて最適な返済方法を選択することが重要です。

user:

ありがとうございます。Pythonのコードを書いて教えてください。

assistant:

以下に、元利均等返済元金均等返済の計算を行うPythonコードを示します。
このコードでは、借入額・金利・返済期間を指定すると、それぞれの方式の毎月の返済額や総支払額を計算します。

import numpy as np
import pandas as pd

def calc_equal_payment(P, r, n):
    """元利均等返済の月々の返済額と総支払額を計算"""
    N = n * 12  # 総返済回数(月単位)
    monthly_rate = r / 12  # 月利
    A = P * (monthly_rate * (1 + monthly_rate) ** N) / ((1 + monthly_rate) ** N - 1)  # 毎月の返済額
    total_payment = A * N  # 総支払額
    return A, total_payment

def calc_equal_principal(P, r, n):
    """元金均等返済の各月の返済額と総支払額を計算"""
    N = n * 12  # 総返済回数(月単位)
    monthly_rate = r / 12  # 月利
    principal_payment = P / N  # 毎月の元金部分
    payments = []  # 各月の返済額を格納
    total_payment = 0  # 総支払額

    for month in range(1, N + 1):
        interest_payment = (P - (month - 1) * principal_payment) * monthly_rate  # 利息
        monthly_payment = principal_payment + interest_payment  # 総返済額
        payments.append(monthly_payment)
        total_payment += monthly_payment

    return payments, total_payment

# 借入条件
P = 10_000_000  # 借入額(円)
r = 0.03  # 年利(3%)
n = 20  # 返済期間(年)

# 計算
equal_payment, total_equal_payment = calc_equal_payment(P, r, n)
equal_principal_payments, total_equal_principal = calc_equal_principal(P, r, n)

# 結果表示
df = pd.DataFrame({
    "": np.arange(1, n * 12 + 1),
    "元利均等返済額": [equal_payment] * (n * 12),
    "元金均等返済額": equal_principal_payments
})

print(f"【元利均等返済】 毎月の返済額: {equal_payment:.2f} 円, 総支払額: {total_equal_payment:.2f}")
print(f"【元金均等返済】 初回の返済額: {equal_principal_payments[0]:.2f} 円, 最終回の返済額: {equal_principal_payments[-1]:.2f} 円, 総支払額: {total_equal_principal:.2f}")

# CSV出力(任意)
df.to_csv("loan_repayment_schedule.csv", index=False)

📌 コードのポイント

  1. calc_equal_payment 関数(元利均等返済)

    • 毎月の返済額 ( A ) を求める数式を実装。
    • 総支払額も算出。
  2. calc_equal_principal 関数(元金均等返済)

    • 毎月一定額の元金返済に、残債に応じた利息を加算。
    • 返済額が徐々に減少する様子をリストに格納。
  3. 出力

    • 各方式の月々の返済額を比較できる表 df を作成。
    • CSV (loan_repayment_schedule.csv) に出力も可能。

実行結果(抜粋)

【元利均等返済】 毎月の返済額: 55460.91 円, 総支払額: 13310618.57 円
【元金均等返済】 初回の返済額: 66666.67 円, 最終回の返済額: 4170.83 円, 総支払額: 12912500.00 円
  • 元利均等返済は月々一定だが総支払額が多い。
  • 元金均等返済は初期負担が大きいが総支払額が少ない。

興味があれば、このデータを可視化(グラフ表示)することもできます! 🚀

user:

ありがとうございます。可視化もお願いします。

assistant:

元利均等返済と元金均等返済の違いをグラフで可視化すると、違いがより分かりやすくなります。
以下のコードでは、matplotlib を使って 毎月の返済額の推移 を可視化します。


📝 可視化のポイント

  1. 元利均等返済(青線)
    • 毎月の支払い額が一定。
  2. 元金均等返済(赤線)
    • 返済初期は高く、徐々に減少。

📌 Pythonコード(グラフ付き)

import numpy as np
import pandas as pd
import matplotlib.pyplot as plt

def calc_equal_payment(P, r, n):
    """元利均等返済の月々の返済額と総支払額を計算"""
    N = n * 12  # 総返済回数(月単位)
    monthly_rate = r / 12  # 月利
    A = P * (monthly_rate * (1 + monthly_rate) ** N) / ((1 + monthly_rate) ** N - 1)  # 毎月の返済額
    total_payment = A * N  # 総支払額
    return [A] * N, total_payment

def calc_equal_principal(P, r, n):
    """元金均等返済の各月の返済額と総支払額を計算"""
    N = n * 12  # 総返済回数(月単位)
    monthly_rate = r / 12  # 月利
    principal_payment = P / N  # 毎月の元金部分
    payments = []  # 各月の返済額を格納
    total_payment = 0  # 総支払額

    for month in range(1, N + 1):
        interest_payment = (P - (month - 1) * principal_payment) * monthly_rate  # 利息
        monthly_payment = principal_payment + interest_payment  # 総返済額
        payments.append(monthly_payment)
        total_payment += monthly_payment

    return payments, total_payment

# 借入条件
P = 10_000_000  # 借入額(円)
r = 0.03  # 年利(3%)
n = 20  # 返済期間(年)

# 計算
equal_payment_list, total_equal_payment = calc_equal_payment(P, r, n)
equal_principal_list, total_equal_principal = calc_equal_principal(P, r, n)

# データフレーム作成
df = pd.DataFrame({
    "": np.arange(1, n * 12 + 1),
    "元利均等返済": equal_payment_list,
    "元金均等返済": equal_principal_list
})

# グラフ描画
plt.figure(figsize=(10, 5))
plt.plot(df[""], df["元利均等返済"], label="元利均等返済(毎月一定)", color="blue")
plt.plot(df[""], df["元金均等返済"], label="元金均等返済(初期高→減少)", color="red")
plt.xlabel("返済月数")
plt.ylabel("月々の返済額(円)")
plt.title("元利均等返済 vs 元金均等返済")
plt.legend()
plt.grid()
plt.show()

# CSV出力(任意)
df.to_csv("loan_repayment_schedule.csv", index=False)

📊 グラフの解釈

  • 青線(元利均等返済)
    → 毎月の返済額が一定で、計画的な返済がしやすい。
  • 赤線(元金均等返済)
    → 初期負担が大きいが、徐々に支払い額が減少するため、総支払額は少なくなる。

📝 まとめ

方式 返済額の変化 初期負担 総支払額
元利均等返済 一定 低め 高め
元金均等返済 徐々に減少 高め 低め

このグラフを見れば、どちらの返済方式が自分に合っているか判断しやすくなりますね! 😊

user:

あ、日本語が文字化けしてるので対応してください。

assistant:

日本語の文字化けを防ぐために、以下の2つの対策を行います。

  1. matplotlib のフォント設定

    • matplotlib はデフォルトで日本語フォントをサポートしていないため、font_manager を使って日本語フォントを設定する。
    • 例として、Windowsなら "MS Gothic"、Macなら "Hiragino Sans" を指定。
    • フォントがない場合、自動で IPAexGothic をダウンロードする方法もある。
  2. pandas.to_csv() のエンコーディング指定

    • encoding="utf-8-sig" を指定することで、Excel でも文字化けしないCSVを作成。

修正後のPythonコード

import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
import matplotlib.font_manager as fm

# 日本語フォント設定(OSに応じて変更)
plt.rcParams["font.family"] = fm.FontProperties(fname=fm.findSystemFonts()[0]).get_name()

def calc_equal_payment(P, r, n):
    """元利均等返済の月々の返済額と総支払額を計算"""
    N = n * 12  # 総返済回数(月単位)
    monthly_rate = r / 12  # 月利
    A = P * (monthly_rate * (1 + monthly_rate) ** N) / ((1 + monthly_rate) ** N - 1)  # 毎月の返済額
    total_payment = A * N  # 総支払額
    return [A] * N, total_payment

def calc_equal_principal(P, r, n):
    """元金均等返済の各月の返済額と総支払額を計算"""
    N = n * 12  # 総返済回数(月単位)
    monthly_rate = r / 12  # 月利
    principal_payment = P / N  # 毎月の元金部分
    payments = []  # 各月の返済額を格納
    total_payment = 0  # 総支払額

    for month in range(1, N + 1):
        interest_payment = (P - (month - 1) * principal_payment) * monthly_rate  # 利息
        monthly_payment = principal_payment + interest_payment  # 総返済額
        payments.append(monthly_payment)
        total_payment += monthly_payment

    return payments, total_payment

# 借入条件
P = 10_000_000  # 借入額(円)
r = 0.03  # 年利(3%)
n = 20  # 返済期間(年)

# 計算
equal_payment_list, total_equal_payment = calc_equal_payment(P, r, n)
equal_principal_list, total_equal_principal = calc_equal_principal(P, r, n)

# データフレーム作成
df = pd.DataFrame({
    "": np.arange(1, n * 12 + 1),
    "元利均等返済": equal_payment_list,
    "元金均等返済": equal_principal_list
})

# グラフ描画
plt.figure(figsize=(10, 5))
plt.plot(df[""], df["元利均等返済"], label="元利均等返済(毎月一定)", color="blue")
plt.plot(df[""], df["元金均等返済"], label="元金均等返済(初期高→減少)", color="red")
plt.xlabel("返済月数")
plt.ylabel("月々の返済額(円)")
plt.title("元利均等返済 vs 元金均等返済")
plt.legend()
plt.grid()
plt.show()

# CSV出力(日本語対応)
df.to_csv("loan_repayment_schedule.csv", index=False, encoding="utf-8-sig")

🔧 修正ポイント

  1. plt.rcParams["font.family"] を設定

    • matplotlib.font_manager を使い、システムの日本語フォントを自動で取得。
    • これにより、環境ごとに適切なフォントが設定され、文字化けを防ぐ。
  2. CSVエクスポート時のエンコーディング指定

    • encoding="utf-8-sig" を指定することで、日本語の文字化けを防止。
    • utf-8-sig は Excel で開いたときにも文字化けしにくい。

🎯 この修正のメリット

✅ どのOSでも 日本語フォントが自動で適用 される
✅ Excel で開いても 文字化けしないCSV を出力

これで、グラフやCSVの文字化け問題が解決できます!🎉

user:

japanize_matplotlibを使った方がよさそうです。

assistant:

japanize_matplotlib を使えば、日本語フォントを簡単に設定できますね!
以下のように修正すれば、フォント設定の手間を省けます。


修正後のコード(japanize_matplotlib 版)

import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
import japanize_matplotlib  # 日本語フォント対応

def calc_equal_payment(P, r, n):
    """元利均等返済の月々の返済額と総支払額を計算"""
    N = n * 12  # 総返済回数(月単位)
    monthly_rate = r / 12  # 月利
    A = P * (monthly_rate * (1 + monthly_rate) ** N) / ((1 + monthly_rate) ** N - 1)  # 毎月の返済額
    total_payment = A * N  # 総支払額
    return [A] * N, total_payment

def calc_equal_principal(P, r, n):
    """元金均等返済の各月の返済額と総支払額を計算"""
    N = n * 12  # 総返済回数(月単位)
    monthly_rate = r / 12  # 月利
    principal_payment = P / N  # 毎月の元金部分
    payments = []  # 各月の返済額を格納
    total_payment = 0  # 総支払額

    for month in range(1, N + 1):
        interest_payment = (P - (month - 1) * principal_payment) * monthly_rate  # 利息
        monthly_payment = principal_payment + interest_payment  # 総返済額
        payments.append(monthly_payment)
        total_payment += monthly_payment

    return payments, total_payment

# 借入条件
P = 10_000_000  # 借入額(円)
r = 0.03  # 年利(3%)
n = 20  # 返済期間(年)

# 計算
equal_payment_list, total_equal_payment = calc_equal_payment(P, r, n)
equal_principal_list, total_equal_principal = calc_equal_principal(P, r, n)

# データフレーム作成
df = pd.DataFrame({
    "": np.arange(1, n * 12 + 1),
    "元利均等返済": equal_payment_list,
    "元金均等返済": equal_principal_list
})

# グラフ描画
plt.figure(figsize=(10, 5))
plt.plot(df[""], df["元利均等返済"], label="元利均等返済(毎月一定)", color="blue")
plt.plot(df[""], df["元金均等返済"], label="元金均等返済(初期高→減少)", color="red")
plt.xlabel("返済月数")
plt.ylabel("月々の返済額(円)")
plt.title("元利均等返済 vs 元金均等返済")
plt.legend()
plt.grid()
plt.show()

# CSV出力(日本語対応)
df.to_csv("loan_repayment_schedule.csv", index=False, encoding="utf-8-sig")

📌 japanize_matplotlib のメリット

import japanize_matplotlib を追加するだけで 日本語フォントを自動設定
plt.xlabel()plt.title()日本語文字化けを防ぐ
フォントのインストール不要(Windows, Mac, Linux どれでも動作)


🎯 この修正のメリット

  • matplotlib のフォント設定を省略できるため、シンプルで分かりやすいコード になる。
  • matplotlib のバージョンに依存せず、日本語が正しく表示される。

この方法なら簡単に実装できるので、ぜひ試してみてください! 😊

image.png

user:

ありがとございます!できました!

assistant:

よかったです!🎉✨
japanize_matplotlib を使うと簡単に日本語対応できて便利ですよね!

他にも 棒グラフ で「累積支払額の推移」や、ヒートマップ で「各月の元金・利息割合」を可視化する方法などもあるので、もし興味があれば試してみてください!😊📊

また何かあれば気軽に聞いてくださいね!🚀

user:

棒グラフ で「累積支払額の推移」や、ヒートマップ で「各月の元金・利息割合」を可視化する方法を書いてください。

assistant:

それでは、以下の2つの可視化を追加しましょう!

  1. 📊 棒グラフ:「累積支払額の推移」

    • 返済が進むにつれて、累積支払額がどのように増えていくかを可視化。
    • 元利均等返済元金均等返済を比較。
  2. 🔥 ヒートマップ:「各月の元金・利息割合」

    • 各月の元金部分と利息部分の比率を色の濃淡で表現。
    • seaborn.heatmap() を使用。

Pythonコード(棒グラフ&ヒートマップ付き)

import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
import seaborn as sns
import japanize_matplotlib  # 日本語フォント対応

def calc_equal_payment(P, r, n):
    """元利均等返済の月々の返済額と総支払額を計算"""
    N = n * 12  # 総返済回数(月単位)
    monthly_rate = r / 12  # 月利
    A = P * (monthly_rate * (1 + monthly_rate) ** N) / ((1 + monthly_rate) ** N - 1)  # 毎月の返済額
    total_payment = A * N  # 総支払額
    cumulative_payment = np.cumsum([A] * N)  # 累積支払額
    return [A] * N, total_payment, cumulative_payment

def calc_equal_principal(P, r, n):
    """元金均等返済の各月の返済額、元金・利息割合、総支払額を計算"""
    N = n * 12  # 総返済回数(月単位)
    monthly_rate = r / 12  # 月利
    principal_payment = P / N  # 毎月の元金部分
    payments = []  # 各月の返済額
    principal_ratios = []  # 各月の元金比率
    interest_ratios = []  # 各月の利息比率
    total_payment = 0  # 総支払額
    cumulative_payment = []  # 累積支払額
    cum_sum = 0  # 累積の和

    for month in range(1, N + 1):
        interest_payment = (P - (month - 1) * principal_payment) * monthly_rate  # 利息
        monthly_payment = principal_payment + interest_payment  # 総返済額
        payments.append(monthly_payment)
        principal_ratios.append(principal_payment / monthly_payment)  # 元金比率
        interest_ratios.append(interest_payment / monthly_payment)  # 利息比率
        total_payment += monthly_payment
        cum_sum += monthly_payment
        cumulative_payment.append(cum_sum)

    return payments, total_payment, cumulative_payment, principal_ratios, interest_ratios

# 借入条件
P = 10_000_000  # 借入額(円)
r = 0.03  # 年利(3%)
n = 20  # 返済期間(年)

# 計算
equal_payment_list, total_equal_payment, cumulative_equal_payment = calc_equal_payment(P, r, n)
equal_principal_list, total_equal_principal, cumulative_equal_principal, principal_ratios, interest_ratios = calc_equal_principal(P, r, n)

# データフレーム作成
df = pd.DataFrame({
    "": np.arange(1, n * 12 + 1),
    "元利均等返済": equal_payment_list,
    "元金均等返済": equal_principal_list,
    "累積支払額(元利均等)": cumulative_equal_payment,
    "累積支払額(元金均等)": cumulative_equal_principal,
    "元金割合": principal_ratios,
    "利息割合": interest_ratios
})

# 📊 累積支払額の推移(棒グラフ)
plt.figure(figsize=(12, 6))
plt.bar(df[""], df["累積支払額(元利均等)"], color="blue", alpha=0.6, label="元利均等返済")
plt.bar(df[""], df["累積支払額(元金均等)"], color="red", alpha=0.6, label="元金均等返済")
plt.xlabel("返済月数")
plt.ylabel("累積支払額(円)")
plt.title("累積支払額の推移")
plt.legend()
plt.grid()
plt.show()

# 🔥 ヒートマップ(元金・利息割合)
plt.figure(figsize=(12, 4))
heatmap_data = df[["元金割合", "利息割合"]].T  # 転置して見やすくする
sns.heatmap(heatmap_data, cmap="coolwarm", annot=False, linewidths=0.5, xticklabels=50)
plt.xlabel("返済月数")
plt.title("元金・利息割合の推移")
plt.show()

# CSV出力(日本語対応)
df.to_csv("loan_repayment_schedule.csv", index=False, encoding="utf-8-sig")

🔍 可視化の解説

📊 1. 「累積支払額の推移」(棒グラフ)

  • 返済が進むにつれて、どれだけお金を支払ったのかが分かる。
  • 青(元利均等)直線的 に増加(毎月の支払額が一定)。
  • 赤(元金均等)曲線的 に増加(初期の支払額が高く、徐々に減少)。

🔥 2. 「各月の元金・利息割合」(ヒートマップ)

  • 縦軸に「元金割合」と「利息割合」。
  • 横軸に「返済月数」。
  • 色の変化 で、返済が進むにつれて利息割合が減り、元金割合が増えていく様子が一目で分かる。

📝 考察

方式 初期負担 総支払額 返済の特徴
元利均等返済 低め 高め 毎月の返済額が一定 で計画的に返しやすい
元金均等返済 高め 低め 最初は負担が大きいが、利息が減るので総支払額は少ない

このグラフを見れば、どの返済方式が自分に合っているか直感的に分かります!😊📊


🚀 応用

  • 期間別に分析(例えば「10年で借りた場合」と「30年で借りた場合」を比較)
  • 異なる金利で比較(例えば「年利3%」と「年利5%」を比較)
  • ローン残高の推移を可視化(累積支払額だけでなく、借金の減り方をグラフにする)

この可視化を使えば、ローンの理解がより深まりますね!✨
さらにカスタマイズしたい場合も、気軽に聞いてください! 😊

image.png

image.png

user:

ありがとうございます。どちらも、折れ線グラフの方が分かりやすそうですね。

assistant:

確かに、折れ線グラフの方が累積支払額や元金・利息割合の推移が直感的に分かりやすいですね!
では、以下のように修正しましょう。

✅ 修正後の可視化

  1. **📈 累積支払額の推移 → 折れ線グラフ
  2. **📉 各月の元金・利息割合の推移 → 折れ線グラフ

🔷 修正後のPythonコード

import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
import seaborn as sns
import japanize_matplotlib  # 日本語フォント対応

def calc_equal_payment(P, r, n):
    """元利均等返済の月々の返済額と総支払額を計算"""
    N = n * 12  # 総返済回数(月単位)
    monthly_rate = r / 12  # 月利
    A = P * (monthly_rate * (1 + monthly_rate) ** N) / ((1 + monthly_rate) ** N - 1)  # 毎月の返済額
    total_payment = A * N  # 総支払額
    cumulative_payment = np.cumsum([A] * N)  # 累積支払額
    return [A] * N, total_payment, cumulative_payment

def calc_equal_principal(P, r, n):
    """元金均等返済の各月の返済額、元金・利息割合、総支払額を計算"""
    N = n * 12  # 総返済回数(月単位)
    monthly_rate = r / 12  # 月利
    principal_payment = P / N  # 毎月の元金部分
    payments = []  # 各月の返済額
    principal_ratios = []  # 各月の元金比率
    interest_ratios = []  # 各月の利息比率
    total_payment = 0  # 総支払額
    cumulative_payment = []  # 累積支払額
    cum_sum = 0  # 累積の和

    for month in range(1, N + 1):
        interest_payment = (P - (month - 1) * principal_payment) * monthly_rate  # 利息
        monthly_payment = principal_payment + interest_payment  # 総返済額
        payments.append(monthly_payment)
        principal_ratios.append(principal_payment / monthly_payment)  # 元金比率
        interest_ratios.append(interest_payment / monthly_payment)  # 利息比率
        total_payment += monthly_payment
        cum_sum += monthly_payment
        cumulative_payment.append(cum_sum)

    return payments, total_payment, cumulative_payment, principal_ratios, interest_ratios

# 借入条件
P = 10_000_000  # 借入額(円)
r = 0.03  # 年利(3%)
n = 20  # 返済期間(年)

# 計算
equal_payment_list, total_equal_payment, cumulative_equal_payment = calc_equal_payment(P, r, n)
equal_principal_list, total_equal_principal, cumulative_equal_principal, principal_ratios, interest_ratios = calc_equal_principal(P, r, n)

# データフレーム作成
df = pd.DataFrame({
    "": np.arange(1, n * 12 + 1),
    "元利均等返済": equal_payment_list,
    "元金均等返済": equal_principal_list,
    "累積支払額(元利均等)": cumulative_equal_payment,
    "累積支払額(元金均等)": cumulative_equal_principal,
    "元金割合": principal_ratios,
    "利息割合": interest_ratios
})

# 📈 累積支払額の推移(折れ線グラフ)
plt.figure(figsize=(12, 6))
plt.plot(df[""], df["累積支払額(元利均等)"], color="blue", label="元利均等返済")
plt.plot(df[""], df["累積支払額(元金均等)"], color="red", label="元金均等返済")
plt.xlabel("返済月数")
plt.ylabel("累積支払額(円)")
plt.title("累積支払額の推移")
plt.legend()
plt.grid()
plt.show()

# 📉 各月の元金・利息割合(折れ線グラフ)
plt.figure(figsize=(12, 6))
plt.plot(df[""], df["元金割合"], label="元金割合", color="green")
plt.plot(df[""], df["利息割合"], label="利息割合", color="orange")
plt.xlabel("返済月数")
plt.ylabel("割合")
plt.title("各月の元金・利息割合の推移")
plt.legend()
plt.grid()
plt.show()

# CSV出力(日本語対応)
df.to_csv("loan_repayment_schedule.csv", index=False, encoding="utf-8-sig")

🔍 修正後の可視化のポイント

📈 1. 「累積支払額の推移」(折れ線グラフ)

  • 青(元利均等)直線的 に増加(毎月一定額を支払うため)。
  • 赤(元金均等)曲線的 に増加(最初に多く支払い、徐々に負担が減るため)。

📉 2. 「元金・利息割合の推移」(折れ線グラフ)

  • 緑(元金割合) → 返済が進むにつれ増加。
  • オレンジ(利息割合) → 返済が進むにつれ減少。
  • 元金均等返済は最初から元金割合が高く、利息割合が急激に減る

✨ 修正のメリット

折れ線グラフにしたことで、傾向がより直感的に理解できる
細かい変化が見やすくなった(特に元金・利息割合の推移)
同じコードでカスタマイズしやすい(期間や金利を変更するだけで比較可能)


これで、より分かりやすくなったと思います!😊📊
他にも「ローン残高の推移」や「異なる金利の比較」など、さらに可視化したい項目があれば教えてくださいね!🚀

image.png

image.png

user:

「ローン残高の推移」や「異なる金利の比較」も可視化してください。

assistant:

それでは、「ローン残高の推移」と「異なる金利の比較」の可視化を追加しましょう!

🔷 今回追加する可視化

  1. 📉 ローン残高の推移(折れ線グラフ)

    • 時間とともに借金がどのように減っていくかを可視化。
    • 元利均等返済と元金均等返済の比較
  2. 📊 異なる金利の比較(折れ線グラフ)

    • 3%・5%・7% の場合で比較
    • 金利が高くなると、支払い総額がどれくらい増えるのか を可視化。

修正後のPythonコード

import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
import japanize_matplotlib  # 日本語フォント対応

def calc_equal_payment(P, r, n):
    """元利均等返済の月々の返済額、ローン残高を計算"""
    N = n * 12  # 総返済回数(月単位)
    monthly_rate = r / 12  # 月利
    A = P * (monthly_rate * (1 + monthly_rate) ** N) / ((1 + monthly_rate) ** N - 1)  # 毎月の返済額
    balance = P  # 初期ローン残高
    balances = []  # 残高の推移

    for _ in range(N):
        interest_payment = balance * monthly_rate  # 利息部分
        principal_payment = A - interest_payment  # 元金部分
        balance -= principal_payment  # ローン残高を減少
        balances.append(balance)

    return [A] * N, balances

def calc_equal_principal(P, r, n):
    """元金均等返済の月々の返済額、ローン残高を計算"""
    N = n * 12  # 総返済回数(月単位)
    monthly_rate = r / 12  # 月利
    principal_payment = P / N  # 毎月の元金部分
    balance = P  # 初期ローン残高
    balances = []  # 残高の推移
    payments = []  # 各月の総返済額

    for month in range(1, N + 1):
        interest_payment = balance * monthly_rate  # 利息
        monthly_payment = principal_payment + interest_payment  # 総返済額
        balance -= principal_payment  # ローン残高を減少
        balances.append(balance)
        payments.append(monthly_payment)

    return payments, balances

# 借入条件
P = 10_000_000  # 借入額(円)
n = 20  # 返済期間(年)

# 3%で計算
r = 0.03
equal_payment_list, equal_balance_3 = calc_equal_payment(P, r, n)
equal_principal_list, principal_balance_3 = calc_equal_principal(P, r, n)

# 📉 ローン残高の推移(折れ線グラフ)
plt.figure(figsize=(12, 6))
plt.plot(np.arange(1, n * 12 + 1), equal_balance_3, label="元利均等返済(3%)", color="blue")
plt.plot(np.arange(1, n * 12 + 1), principal_balance_3, label="元金均等返済(3%)", color="red")
plt.xlabel("返済月数")
plt.ylabel("ローン残高(円)")
plt.title("ローン残高の推移(3%金利)")
plt.legend()
plt.grid()
plt.show()

# 📊 異なる金利の比較(折れ線グラフ)
interest_rates = [0.03, 0.05, 0.07]  # 3%, 5%, 7%
colors = ["blue", "green", "purple"]

plt.figure(figsize=(12, 6))
for i, rate in enumerate(interest_rates):
    _, equal_balance = calc_equal_payment(P, rate, n)
    plt.plot(np.arange(1, n * 12 + 1), equal_balance, label=f"元利均等返済(金利: {int(rate*100)}%)", color=colors[i])

plt.xlabel("返済月数")
plt.ylabel("ローン残高(円)")
plt.title("異なる金利でのローン残高推移(元利均等返済)")
plt.legend()
plt.grid()
plt.show()

🔍 追加した可視化の解説

📉 1. 「ローン残高の推移」(折れ線グラフ)

  • 青(元利均等)初期の減りが遅い(支払いの大部分が利息のため)。
  • 赤(元金均等)最初に急速に減少(毎月の元金部分が一定のため)。

📌 ポイント:
元金均等返済の方が最初に借金が減るスピードが速いが、その分初期の負担が大きい。


📊 2. 「異なる金利の比較」(折れ線グラフ)

  • 青(3%) → ゆるやかに減少。
  • 緑(5%) → 減少が遅くなる(支払いの多くが利息)。
  • 紫(7%) → さらに減少が遅い(ローン残高がなかなか減らない)。

📌 ポイント:
金利が高いと、なかなか借金が減らない → 総支払額が大きくなる。


✨ 追加したメリット

「ローン残高の減り方」が分かるようになった
「金利による違い」が一目で理解できるようになった
元利均等 vs. 元金均等 の比較も直感的になった


🚀 応用

  • 異なる借入期間(10年 vs 30年)で比較
  • 異なる借入額(500万円 vs 5000万円)で比較
  • 毎月の利息額の推移を可視化

さらにカスタマイズしたい場合は、気軽に聞いてくださいね!😊📊

image.png

image.png

user:

異なる金利の比較について、元利均等返済の場合と元金均等返済の場合を比較するようなグラフを書けませんか?また、横軸は月ではなく年にしてもらえると嬉しいです。

assistant:

了解しました!
以下の 2点 を修正して、「異なる金利の比較」をさらに分かりやすくします。

🔷 修正内容

  1. 📊 元利均等返済 vs. 元金均等返済 の比較

    • 3%、5%、7%の金利 で、それぞれ 両方の返済方法のローン残高の推移をプロット
  2. 📅 横軸を「月」→「年」に変更

    • 返済期間が長いため、年単位の方が見やすい。

修正後のPythonコード

import numpy as np
import matplotlib.pyplot as plt
import japanize_matplotlib  # 日本語フォント対応

def calc_equal_payment(P, r, n):
    """元利均等返済の月々の返済額、ローン残高を計算"""
    N = n * 12  # 総返済回数(月単位)
    monthly_rate = r / 12  # 月利
    A = P * (monthly_rate * (1 + monthly_rate) ** N) / ((1 + monthly_rate) ** N - 1)  # 毎月の返済額
    balance = P  # 初期ローン残高
    balances = []  # 残高の推移

    for _ in range(N):
        interest_payment = balance * monthly_rate  # 利息部分
        principal_payment = A - interest_payment  # 元金部分
        balance -= principal_payment  # ローン残高を減少
        balances.append(balance)

    return balances

def calc_equal_principal(P, r, n):
    """元金均等返済の月々の返済額、ローン残高を計算"""
    N = n * 12  # 総返済回数(月単位)
    monthly_rate = r / 12  # 月利
    principal_payment = P / N  # 毎月の元金部分
    balance = P  # 初期ローン残高
    balances = []  # 残高の推移

    for _ in range(N):
        interest_payment = balance * monthly_rate  # 利息
        balance -= principal_payment  # ローン残高を減少
        balances.append(balance)

    return balances

# 借入条件
P = 10_000_000  # 借入額(円)
n = 20  # 返済期間(年)
interest_rates = [0.03, 0.05, 0.07]  # 3%, 5%, 7%
colors = ["blue", "green", "purple"]

# 年単位のx軸(1年ごとのデータを取得)
years = np.arange(1, n + 1)

plt.figure(figsize=(12, 6))
for i, rate in enumerate(interest_rates):
    # それぞれの金利で計算
    equal_balance = calc_equal_payment(P, rate, n)
    principal_balance = calc_equal_principal(P, rate, n)
    
    # 1年ごとにデータを取得(年単位のx軸に合わせる)
    equal_balance_yearly = equal_balance[11::12]  # 毎年12ヶ月目のデータを取得
    principal_balance_yearly = principal_balance[11::12]  # 同様に取得

    # グラフ描画(元利均等)
    plt.plot(years, equal_balance_yearly, linestyle="-", label=f"元利均等(金利: {int(rate*100)}%)", color=colors[i])
    
    # グラフ描画(元金均等)
    plt.plot(years, principal_balance_yearly, linestyle="dashed", label=f"元金均等(金利: {int(rate*100)}%)", color=colors[i])

plt.xlabel("返済年数")
plt.ylabel("ローン残高(円)")
plt.title("異なる金利でのローン残高推移(元利均等 vs. 元金均等)")
plt.legend()
plt.grid()
plt.show()

🔍 修正後のグラフのポイント

📊 異なる金利の比較(元利均等 vs. 元金均等)

  • 実線(─)元利均等返済
  • 破線(--)元金均等返済
  • 青(3%)、緑(5%)、紫(7%) → 金利別の違い

📌 観察ポイント:
金利が高いと、ローン残高の減少が遅い
元金均等(破線)は最初に急激に減るが、元利均等(実線)はなだらかに減る
7%の元利均等は、最初の10年ほどであまり減っていない支払いの大部分が利息になっている


✨ 追加したメリット

「返済方法 × 金利」の影響を比較できるようになった
実線と破線を使って、どちらの方法が早くローン残高を減らせるか一目で分かる
年単位の横軸なので、長期間の推移が見やすい


これで、より直感的に違いを把握できるようになったと思います!😊📊
さらにカスタマイズしたい点があれば、遠慮なく教えてください!🚀

image.png

user:

あまり理解してなかったんですが、元金均等の場合、金利が変わってもローン残高推移は変わらないんですね?

assistant:

はい、そのとおりです!💡

元金均等返済では、ローン残高の推移は金利に関係なく一定のペースで減少します。
これは、毎月の 元金の支払い額が一定 であるため、金利が変わってもローン残高の減り方が変わらないからです。


🔍 なぜ元金均等返済は金利が変わってもローン残高が同じなのか?

元金均等返済の仕組み

  • 毎月の 元金支払い額は一定(例えば、借入額 1,000 万円を 240 ヶ月(20 年)で返済する場合 → 毎月の元金支払いは 1,000万 ÷ 240 = 約4.17万円)。
  • 毎月の支払額は「元金部分 + 利息部分」で決まる。
  • 利息は残りのローン残高に応じて変動する

つまり、元金部分は常に一定額減少 するので、ローン残高の推移は金利が変わっても影響を受けない わけです!🚀

違いが出るのは「毎月の総支払額」や「総支払額の合計」 です。
金利が高いと、毎月の利息が大きくなる ため、支払い総額は増えてしまいます。


📊 金利が影響するのは「毎月の支払額」と「総支払額」

一方で、元利均等返済は、金利が高くなるとローン残高の減り方が変わります
これは、毎月の支払額が一定でも、最初は利息部分が大きく、元金の減少が遅くなるから です。

📌 ポイントまとめ
元金均等返済ローン残高の減少ペースは一定(変わらない)
元利均等返済金利が高いと、ローン残高の減り方が遅くなる
金利が影響するのは「毎月の支払額」と「総支払額」(元金均等も、金利が高いと支払い総額は増える)


✅ 追加する可視化

「毎月の総支払額の推移」を金利ごとに可視化すると、さらに分かりやすくなります!
これを作ると、金利が高いと「元金均等返済でも最初の支払いが重くなる」という点が直感的に分かると思います。

やってみましょうか?😊

user:

はい、お願いします。

assistant:

了解しました!💡
今回は 「毎月の総支払額の推移(金利ごと)」 を可視化します!📊


🔷 追加する可視化

📊「毎月の総支払額(元金+利息)の推移」

  • 元利均等返済毎月の支払額が一定(ただし、内訳は元金と利息で変化)
  • 元金均等返済最初の支払額が大きく、徐々に減少(利息が減るため)
  • 3%, 5%, 7% の金利ごとに比較

これにより、
元利均等の安定性
元金均等の初期負担の大きさ
金利による影響
が一目で分かるようになります!🚀


✅ 追加したPythonコード

import numpy as np
import matplotlib.pyplot as plt
import japanize_matplotlib  # 日本語フォント対応

def calc_equal_payment(P, r, n):
    """元利均等返済の月々の返済額、ローン残高を計算"""
    N = n * 12  # 総返済回数(月単位)
    monthly_rate = r / 12  # 月利
    A = P * (monthly_rate * (1 + monthly_rate) ** N) / ((1 + monthly_rate) ** N - 1)  # 毎月の返済額
    return [A] * N  # 毎月の返済額(一定)

def calc_equal_principal(P, r, n):
    """元金均等返済の月々の返済額(元金部分一定+利息部分変動)"""
    N = n * 12  # 総返済回数(月単位)
    monthly_rate = r / 12  # 月利
    principal_payment = P / N  # 毎月の元金支払い額
    balance = P  # 初期ローン残高
    payments = []  # 総支払額リスト

    for _ in range(N):
        interest_payment = balance * monthly_rate  # 利息部分
        total_payment = principal_payment + interest_payment  # 毎月の総支払額
        balance -= principal_payment  # 残高を減らす
        payments.append(total_payment)

    return payments

# 借入条件
P = 10_000_000  # 借入額(円)
n = 20  # 返済期間(年)
interest_rates = [0.03, 0.05, 0.07]  # 3%, 5%, 7%
colors = ["blue", "green", "purple"]
months = np.arange(1, n * 12 + 1)  # 月単位のx軸

plt.figure(figsize=(12, 6))

for i, rate in enumerate(interest_rates):
    # 各金利で計算
    equal_payment_values = calc_equal_payment(P, rate, n)
    equal_principal_values = calc_equal_principal(P, rate, n)
    
    # 元利均等返済(実線)
    plt.plot(months, equal_payment_values, linestyle="-", label=f"元利均等(金利: {int(rate*100)}%)", color=colors[i])
    
    # 元金均等返済(破線)
    plt.plot(months, equal_principal_values, linestyle="dashed", label=f"元金均等(金利: {int(rate*100)}%)", color=colors[i])

plt.xlabel("返済月数")
plt.ylabel("毎月の総支払額(円)")
plt.title("毎月の総支払額の推移(元利均等 vs. 元金均等)")
plt.legend()
plt.grid()
plt.show()

🔍 グラフのポイント

📊 毎月の総支払額の推移

  • 実線(─)元利均等返済(毎月一定額)
  • 破線(--)元金均等返済(最初に高く、徐々に減少)
  • 青(3%)、緑(5%)、紫(7%)金利の違い

元利均等は毎月の支払い額が一定(安定)
元金均等は最初の支払いが高く、徐々に負担が減る
金利が高いほど、全体的に支払額が増える


✨ 追加したメリット

「毎月の支払い負担の違い」が分かる!
「最初に負担が大きい vs. 最後まで安定」な特徴が明確に!
金利が高いほど、元金均等の初期負担が大きくなることが見える!


🚀 さらに発展

  • 総支払額(累積)をプロット(元利均等と元金均等の「支払総額の差」が分かる)
  • 異なる返済期間(10年 vs. 30年)で比較
  • ローンシミュレーションのインタラクティブ化(スライダーで金利変更)

これで 「毎月の負担がどう変わるのか?」が視覚的に分かるようになった と思います!😊📊
さらにカスタマイズしたい点があれば、気軽に聞いてくださいね!🚀

image.png

user:

ありがとうございました。大変勉強になりました!

assistant:

こちらこそ、たくさんの興味深い質問をありがとうございました!😊📊
ローンの仕組みや金利の影響をしっかり理解できたようでよかったです!✨

また何かPythonやデータ可視化、因果推論・ベイズSEMなどで気になることがあれば、いつでも聞いてくださいね!🚀📈

引き続き、楽しく学んでいきましょう!🎉😆

0
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?