跳到主要內容

AI程式小實驗 - 定期定額績效試算


最近我在嘗試用AI學習寫程式,想不到我這個coding能力很弱的資訊系逃兵,在有生之年還能和AI家教學習寫程式,真的是非常感動啊😍

我在研究所念的是資訊管理,不過其實我是在大三的時候才決定轉換跑道。

在那之前,我就讀公共行政系,可能很多人都不知道這個科系是做什麼的?坦白說其實我也不太清楚。在大學聯考結束選填志願的時候,我是用刪去法,根據我粗淺的認知,把沒有興趣的科系刪除,剩下的再依據分數排序填寫。

原本我填寫的領域是法律、政治、社會,結果錄取了這個科系,但真正進了大學才發現,我對這個領域其實完全不了解,對這個科系也不感興趣,一直到了大三時,覺得成年了應該為自己的人生負責, 才開始思考未來的方向(汗顏😓)。

後來決定轉換跑道,準備報考當時最熱門的資訊網路相關研究所,當然,順利轉換跑道很幸運,不過由於基礎並不扎實,所以念得有些辛苦。例如程式設計,當時我只能自己看書學習,沒有YT、也沒有老師可以請教,遇到看不懂的地方,除了多看幾本書對照,好像也沒有其它的方法。(順帶一提,那大概是我學生時期最用功唸書的一段日子,也真的去報名補習)

不過現在有了AI真的非常方便,不僅可以直接幫我們寫程式,甚至還可以教我們怎麼寫程式,逐段鉅細靡遺地的解說程式的內容,就像一個免費的家教一樣,而且不會累也不會有脾氣,真的是非常方便。

這大大地降低了學習的門檻,我相信現在的學生(或非學生),只要有心,都可以透過AI獲得很好的學習體驗,就算不是資訊背景,也可以很快學會運用程式軟體的基礎能力,幫自己提升工作效率。

我最近就嘗試請AI寫了幾個簡單的投資策略,測試我的投資想法,雖然還很陽春,但過程相當有趣,而且在整理教案時,也能夠有更實際的數據佐證,這是我體驗到AI帶來的便利。

以下是我用AI寫的一個小工具,計算每月定期定額投資1萬元在指定的標的上,所能夠得到的年化報酬率結果。對於想要參與「金雞計劃」的朋友,就可以用這個工具來實測投資標的以往的績效,作為未來的參考。

我運用的是TradingView pine script (v6)這個平台,有興趣的朋友可以複製以下的程式碼測試看看,當然,也歡迎發揮創意利用AI練習撰寫新的程式。說不定你會有新的發現!

🤔看完本文之後請想一想:
  1. 你聽過「量化交易」嗎?什麼是「量化交易」?你有興趣嘗試嗎?


以下是程式碼(若有疏漏謬誤之處也歡迎指教)

//@version=6
strategy("定期定額 DCA", overlay=true, initial_capital=0, currency=currency.USD, calc_on_order_fills=true, calc_on_every_tick=true)

//------------------------------------------------------------------
// 使用者輸入:設定投資的開始與結束日期
// 請依 ISO-8601 格式輸入 (例如 "2020-01-01T00:00:00")
//
// 注意:本策略僅於 startDate ~ endDate 區間內進行定期定額投資
//------------------------------------------------------------------
startDate = input.time(timestamp("2010-01-01T00:00:00"), "Start Date")
endDate   = input.time(timestamp("2024-12-31T23:59:59"), "End Date")

//------------------------------------------------------------------
// 定義 XIRR 函數:根據現金流及其發生時間,利用二分法求解 IRR
// XIRR 公式: Σ[ CF[i] / (1 + r)^((t[i]-t0)/365) ] = 0
//------------------------------------------------------------------
f_xirr(_flows, _times) =>
    n = array.size(_flows)
    if n < 2
        na
    else
        rLow = -0.99
        rHigh = 10.0
        // 以 50 次迭代達到足夠精度
        for i = 0 to 50
            rMid = (rLow + rHigh) / 2.0
            npv = 0.0
            t0 = array.get(_times, 0)
            for j = 0 to n - 1
                cf = array.get(_flows, j)
                t  = array.get(_times, j)
                // 將毫秒轉換為天數 (1 天 = 86,400,000 毫秒)
                days = (t - t0) / 86400000.0
                npv += cf / math.pow(1 + rMid, days / 365.0)
            if npv > 0
                rLow := rMid
            else
                rHigh := rMid
        (rLow + rHigh) / 2.0

//------------------------------------------------------------------
// 宣告全域變數:用來記錄每次投資的現金流與時間、累計買進的股數以及總投入金額
//------------------------------------------------------------------
var float[] cashFlows    = array.new_float()
var int[]   cashFlowTimes = array.new_int()
var float   totalShares   = 0.0
var float   totalInvested = 0.0

// 用來確保僅在設定期間結束後首次計算 XIRR 與累積報酬率
var bool computedResults = false

//------------------------------------------------------------------
// 判斷是否為新月份的第一根 K 線(month open)
// ta.change(time("M")) 回傳數值,需與 0 比較取得布林值
//------------------------------------------------------------------
is_new_month = ta.change(time("M")) != 0

//------------------------------------------------------------------
// 每月定期定額投資 10000 元:僅在使用者設定的期間內進行
//------------------------------------------------------------------
if is_new_month and time >= startDate and time <= endDate
    shares_to_buy = 10000 / open
    totalShares += shares_to_buy
    totalInvested += 10000
    // 記錄投入的現金流(支出以負值表示)
    array.push(cashFlows, -10000)
    array.push(cashFlowTimes, time)
    // 下單買入(strategy.entry 便於在策略測試器中觀察交易)
    strategy.entry("Buy", strategy.long, qty = shares_to_buy)

//------------------------------------------------------------------
// 當 bar 的時間大於或等於使用者設定的結束日期,且尚未計算結果時:
// 1. 計算最終組合價值 (持有股數 * 當前收盤價)
// 2. 加入正向現金流並計算 XIRR
// 3. 計算總累積報酬率 = (最終組合價值 - 總投入金額) / 總投入金額 * 100%
// 4. 利用 label 顯示結果
//------------------------------------------------------------------
if not computedResults and time >= endDate
    finalValue = totalShares * close
    array.push(cashFlows, finalValue)
    array.push(cashFlowTimes, time)
    irr = f_xirr(cashFlows, cashFlowTimes)
    computedResults := true
   
    // 總累積報酬率 (%)
    cumulativeReturn = (finalValue - totalInvested) / totalInvested * 100.0

    // 顯示 XIRR,轉換為百分比格式
    label.new(bar_index, high, text="XIRR: " + str.format("{0,number,#.##}%", irr * 100), style=label.style_label_up, color=color.green, textcolor=color.white)
   
    // 顯示總累積報酬率
    label.new(bar_index, high * 0.95, text="累積報酬率: " + str.format("{0,number,#.##}%", cumulativeReturn), style=label.style_label_up, color=color.blue, textcolor=color.white)

留言

這個網誌中的熱門文章

金雞計算機

讀取規劃 登出 金雞計算機 本計算機是根據「 學校沒教但孩子一定要學的9堂理財課 」書中「 金雞計畫 」內容設計,僅供教育用途,協助讀者模擬退休規劃。 資產成長設定以台股、美股歷史年化報酬率(約10%)每年複利,退休金提領率以3%估算;尚未計入稅賦、手續費與通膨,實際結果仍以市場表現為準,敬請留意風險。有任何建議都歡迎 指教 !謝謝! 請使用Google帳號登入開始試算 使用 Google 登入 1.預計幾年後退休 2.預計退休後每年生活費(元/年) 3.目前可用於投資金額(元,含定存、基金、股票等流動資產) 4.未來每月可投資金額(元/月,定期定額) 開始試算 重設 💾 儲存我的規劃 您需要的退休金額 — 預估可能的退休金 — 是否達成退休目標 —

金雞計畫:和孩子一起養成億萬金雞 - 建立孩子的理財素養

最無痛的投資法:只要每天66元,和孩子一起養成億萬金雞 您好:我是Julian,豬力安老師 您知道嗎,只要每天66元,從小開始引導孩子儲蓄投資,等孩子65歲退休時,就有機會養成一隻「億萬金雞母」,備妥財務安全網! 我是專職投資人,當了爸爸之後,一直天真地以為孩子也會「子承父業」對金融交易感興趣。直到2014年經歷了一場中年危機,我才發覺自己的天真,所以開始關注理財教育,思考「小朋友也能學會」的投資理財法。 我從2019年暑假開始,帶著孩子啟動一個為期10年的長期投資實驗,我稱之為「金雞計畫」。 作為公益推廣,我想邀請更多家庭加入這個計畫,帶領您的孩子用壓歲錢(零用錢)養成「金雞母」,和孩子一起追蹤記錄,就算是一個趣味實驗吧😊 歡迎有興趣的大小朋友一起加入,就從現在開始💪 需要費用嗎 這個計畫是公益推廣,不收取任何費用 進一步學習歡迎【訂閱YouTube|看卡通學理財】 👉  https://www.youtube.com/@RichEDU168 歡迎支持我的書【 學校沒教但孩子一定要學的9堂理財課 】,書中有更詳細的說明 為什麼要推廣「金雞計畫」 身為家長,您是否和我一樣,有著「望子成龍、望女成鳳」的期許和焦慮? 在我的成長過程中,受的是傳統的填鴨式教育,一切分數至上,考好成績才有機會上好學校、上好學校才有機會找好工作、找好工作才有機會獲得好收入、才有好生活...似乎只有取得好成績,人生才有希望。 這是一段痛苦的回憶,除了分數,我不知道自己為何而學?大學聯考放榜選填志願時,我不知道各個科系要學什麼?也不知道自己的人生方向和目標在哪?所以我不希望孩子重蹈覆轍。 我期望孩子有更多的時間可以好好探索、認識自己,找出自己的興趣、熱忱與人生方向。行行出狀元,我相信他們有一天也會在屬於自己的舞台上發光發熱!同時,金雞計畫就是一份提供孩子財務安全保障的計畫! 我看到許多家長投資大量時間、金錢幫孩子安排補習、送進名校,無非是希望孩子更有「競爭力」,這真的能夠保障每個孩子的未來嗎? 金雞計畫參考歷史經驗,只要平均每天66元(每月2000元),及早開始,持之以恆,每個孩子都有機會在退休時養成一隻價值千萬、甚至億萬的「金雞母」,備妥財務安全網! 很可惜,我沒有看到學校課綱或補習班教案有這樣的長期規劃!相較於私校學費、補習費,金雞計畫的C/P值簡直高到爆炸! 媒...

給爸媽的「幸福家庭投資長」線上課 - 只送不賣 - 讀者限定

學員分享(高雄 歐先生, 50歲, 2個孩子的爸) 過去我只知道錢越多越好,卻因為沒有明確目標,常陷入焦慮。豬力安老師幫我釐清退休目標,以終為始,就像先畫好靶再射箭,不再盲目追高殺低。現在投資變得輕鬆無負擔,心境也更安定!感謝老師,讓我懂得善用複利的力量,退休終於有了清晰的路徑! 🤔 您對退休規劃最大的擔心是什麼?  是擔心存不夠錢?  還是投資太難、怕賠錢?  或是沒有時間準備,還是不知道怎麼開始? 📘 即日起凡購買(含已購買)《 學校沒教但孩子一定要學的9堂理財課 》的讀者,只要完成以下步驟,就能解鎖豬力安老師特別為您準備的超值回饋大禮!  還沒買書嗎?手刀下單,獲得這門專屬免費線上課 👉 《 學校沒教但孩子一定要學的9堂理財課 》 📌 行動步驟: 1、花30秒填寫 線上問卷 2、加入 官方Line (@128hfcek) 3、私訊關鍵字「索取免費線上課」,提供購買證明  💡立即解鎖,幫自己打造不怕老、不怕窮的退休計畫!  🥳 課程亮點 ✅ 快速上手:只要6個小問題,就能帶你逐步完成退休藍圖  ✅ 簡單易懂:零基礎也能聽懂,立刻學會「金雞計畫」的退休法則  ✅ 實際有效:只要一個步驟,就能預備未來退休的金雞母  ✅ 安心退休:不再焦慮,知道自己該怎麼準備,心裡才真正踏實  📌 適合這樣的你   ✔️ 想擁有清晰的財務目標,不再焦慮迷茫 😌   ✔️ 希望掌握適合自己的投資工具,讓錢真正幫你工作 💼   ✔️ 想建立正確的風險管理觀念,市場震盪時能穩穩應對 😎   投資自己,是報酬率最高的選擇!別再錯過成長的機會,現在行動,為未來打造更穩固的財富基石! 📢 延伸課程 👨‍👩‍👧 親子理財工作坊 (線上課籌備中)   🎓 兒童&青少年理財營(寒暑假限定) 2026 AI創富理財冬令營(4~6年級預定10月開放報名) 載入中…