上集Dennis介紹過黃金比率、費氏數列等等,但是用黃金比率數浪涉及主觀因素,怎樣可以教曉程式都學會數浪呢?Dennis就告訴我們,的確很難!不過!透過他訂立的指標,做出一些改良,原來都可以將黃金比率應用在程式交易上,配合RSI,程式會更加完善,回測過後,一張大期在四年間可賺 X百萬!
════════════════════
回流加國 唯一留下的 - - 電子版投資天書
!!由淺入深毫無保留全公開!!
施傅【10年財務自由】1小時簡介+工作坊 (免費試看)
現在開始 ▶▷▶ gregorysy.com/
════════════════════
「我要幫你畀首期」遊戲 贏高達52萬首期幫你上車!
即玩▶▶ money-tab.info/youtube-games?fp=e1005
✓ 訂閱【我要做富翁】頻道 ▶ bit.ly/35LOy2J
本月免費活動【★Top 4】現正接受報名:
1. 贏在美股試堂分享會(Online)▶ money-tab.info/ussjac?fp=e1005
2. 阿業期權計算機分享會(Online)▶ money-tab.info/optyip?fp=e1005
3. Dennis 我要做程式交易分享會(Online)▶ money-tab.info/mutden?fp=e1005
4. 陳Sir期指分享會(Online)▶ money-tab.info/optchan?fp=e1005
所有課程/活動一覽: money-tab.info/activity?fp=e1005
✓ APP下載: onelink.to/mtapp
✓ 升級版: money-tab.com/membership
❖訂閱【富翁電視MTTV】頻道:
bit.ly/35dJW4Y
❖訂閱【我要做富翁】頻道:
bit.ly/35LOy2J
❖讚好Facebook專頁:
facebook.com/203349819681082
❖追蹤Instagram專頁:
instagram.com/money_tab/
#黃金分割 #ALGO #程式交易策略 #我要做程式交易 #波浪理論 #RSI #黃金比率 #數浪
「費氏數列計算機」的推薦目錄:
- 關於費氏數列計算機 在 我要做股神 Facebook 的最佳解答
- 關於費氏數列計算機 在 我要做股神 Facebook 的最佳貼文
- 關於費氏數列計算機 在 [閒聊] g++ 8.2.1 把O(n) code 轉成O(1) - 看板C_and_CPP 的評價
- 關於費氏數列計算機 在 費式數列 的評價
- 關於費氏數列計算機 在 以C語言遞回函數實現費式數列及數學式介紹 - YouTube 的評價
- 關於費氏數列計算機 在 Python Taiwan | 大家好,今天和大家分享費氏數列 - Facebook 的評價
- 關於費氏數列計算機 在 2022費氏數列遞迴式-運動賽事熱門討論及分析,精選在PTT ... 的評價
費氏數列計算機 在 我要做股神 Facebook 的最佳貼文
很多有投資經驗的人,相信都有聽聞過黃金比率、黃金分割、費氏數列等等,高深的波浪理論都與這些比率有關,有人認為1.618、0.618等等的黃金分割率是神預測,亦有人否定它的神奇。既然主觀因素這麼重, 如果將黃金分割線,應用在程式交易,其實是否可行?
════════════════════
回流加國 唯一留下的 - - 電子版投資天書
!!由淺入深毫無保留全公開!!
施傅【10年財務自由】1小時簡介+工作坊 (免費試看)
現在開始 ▶▷▶ gregorysy.com/
════════════════════
「我要幫你畀首期」遊戲 贏高達52萬首期幫你上車!
即玩▶▶ money-tab.info/youtube-games?fp=e0928
✓ 訂閱【我要做富翁】頻道 ▶ bit.ly/35LOy2J
「量化交易」手冊 新書發報會+工作坊(Online)▶ money-tab.info/2020-book?fp=e0928
本月免費活動【★Top 5】現正接受報名:
1. 贏在美股試堂分享會(Online)▶ money-tab.info/ussjac?fp=e0928
2. Kyle英國房地產分享會((Online)▶ money-tab.info/engkyle?fp=e0928
3. 阿業期權計算機分享會(Online)▶ money-tab.info/optyip?fp=e0928
4. Dennis 我要做程式交易分享會((Online)▶ money-tab.info/mutden?fp=e0928
5. 陳Sir期指分享會(Online)▶ money-tab.info/optchan?fp=e0928
所有課程/活動一覽: money-tab.info/activity?fp=e0928
✓ APP下載: onelink.to/mtapp
✓ 升級版: money-tab.com/membership
❖訂閱【富翁電視MTTV】頻道:
bit.ly/35dJW4Y
❖訂閱【我要做富翁】頻道:
bit.ly/35LOy2J
❖讚好Facebook專頁:
facebook.com/203349819681082
❖追蹤Instagram專頁:
instagram.com/money_tab/
#黃金分割 #ALGO #程式交易 #我要做程式交易 #波浪理論 #費氏數列 #黃金比率 #數浪
費氏數列計算機 在 費式數列 的推薦與評價
演算法. 費氏陣列的解法很多,基本上可以使用遞迴解,演算法最簡單,如下: Procedure FIB(N) ... ... <看更多>
費氏數列計算機 在 以C語言遞回函數實現費式數列及數學式介紹 - YouTube 的推薦與評價
【C 語言入門】12 - 函式簡介 · 計算機 概論 · 111職員-電路電子(上),相依電路 計算,電容充放電 · C# Tutorial: Functions and Return Types · CASIO 計算 大學園 ... ... <看更多>
費氏數列計算機 在 [閒聊] g++ 8.2.1 把O(n) code 轉成O(1) - 看板C_and_CPP 的推薦與評價
最近有個熱門的討論話題
就是計算費氏數列的複雜度到底是 O(1) 還是 O(n)
剛好我前幾天在看 wiki 嘗試 compiler 的一些東西的時候
https://zh.wikipedia.org/wiki/%E5%B0%BE%E8%B0%83%E7%94%A8
也遇到一些有趣的 O(1) 還是 O(n) 的問題
覺得很有趣所以就分享上來
我也有把問題丟在 stackoverflow 上面問
沒想到上面的反應也蠻熱烈的
https://stackoverflow.com/questions/54686395
讓我不小心賺到了一些 reputation,大概比我回答十個問題還多
---
不管複雜度是 O(1) 或是 O(n),也不管 lookup table 到底要不要存在月球上
費氏數列遞迴的形式都是這條:F(x) = F(x-1) + F(x-2), F(1) = F(2) = 1
不過今天要討論的是一個更簡單的問題 F(x) = F(x-1)+1, F(0) = 0
學過中學以上歸納法的人類都能知道 F(x) = x
而學過 C++ 的人都可以把這個式子轉換變成程式碼
int Identity(int i) {
if (i == 1)
return 1;
else
return Identity(i-1)+1;
}
上面的 wiki 說明了這個並不是有效的 tail recursion 形式
理論上應該不會變成 for loop
會產生 O(n) memory, O(n) runtime 的程式
(PS: 如果是 for loop,應該是 O(1), memory O(n) runtime)
為了驗證,我用了 gcc 8.2.1 編譯看看,結果大出意外
% g++ a.cpp -c -O2 && objdump -d a.o
Disassembly of section .text:
0000000000000000 <_Z8Identityi>:
0: 89 f8 mov %edi,%eax
2: c3 ret
Linux 下 x64 的第一個整數是 %edi,回傳值放在 %eax
等等,所以我以為 O(n) 的問題,真的可以在 O(1) 解出來嗎(誤)
難道 compiler 做了一些數學計算,推出 F(x) = x 了嗎
該不會在這個大 AI 時代,compiler 也要內建高中生等級的 super AI 了吧
該不會我下次升級到 gcc 9 的時候,我的 compiler 就會跑去當 Youtuber 了吧?!
---
Sorry 扯遠了,回歸正題
我一開始的想法是
1. gcc 知道了 negative i 會撞到 UB,因此可以隨便回傳任何值
(PS: negative i 不會變成 infinite loop 的 UB,而是 overflow)
2. positive i 的情形 gcc 經過了某些數學推導算出 F(x) = x
但是怎麼看都覺得太神奇,感覺不會有人實做這種東西
總之經過 stackoverflow 一番討論之後
看起來的結論如下
首先,當代的 gcc 不只可以化簡基本的 tail recursion
就連上面那個形式都可以(可以去看 stackoverflow 的一些討論)
雖然詳細上原理我不太明白,但是應該、大約、好像會變成這樣子
int Identity(int i) {
int ans = 0;
for (; i != 0; i--, ans++);
return ans;
}
接著我猜測這個形式對 compiler 來說應該比較好化簡了
因為這種 for loop 非常常見,應該有機會做某種化簡得到 F(x) = x
順帶一題,直接寫這個程式的話,gcc 是可以化簡 O(n) -> O(1) 的
如果 i != 0 改成 i >= 0 的話,gcc 會變成 return i > 0 ? i : 0;
真的很厲害
---
另外 stackoverflow 裡面有人直接挖出 gcc code 來解釋
但是其實我不是 compiler 專家
所以我這篇主要還是單純分享一些我的觀察啦
如果這個版有人能做出更淺顯易懂,又更完整的解釋的話就太好了
謝謝大家~
--
Time waits for no one.
↑
(。A。)ハァ
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 118.160.89.176
※ 文章網址: https://www.ptt.cc/bbs/C_and_CPP/M.1550249453.A.382.html
... <看更多>