→ celestialgod: 少複製一次記憶體,應該有差 09/11 00:06
→ celestialgod: 但是差異應該很小 09/11 00:06
→ celestialgod: 你可以rbenchmark 1000次看看 09/11 00:07
→ andrew43: 考慮程式碼開發與維護的成本常常比執行速度還重要很多。 09/11 13:57
→ andrew43: 如果與都寫在一起,要除蟲或改寫會比較難。請考慮這點。 09/11 13:59
→ celestialgod: 所以這時候要推薦magrittr 09/11 14:00
→ celestialgod: P %>% '['((t-(N+1)):(t-1)) %>% diff %>% abs %>% 09/11 14:01
→ celestialgod: sum %>% divide_by(N) 09/11 14:01
→ celestialgod: magrittr可以在板上搜尋到介紹文章 09/11 14:01
→ PhysicsBoy: 長知識了,有空來研究一下,至於維護就靠詳細筆記^^ 09/11 14:59
推 andrew43: 注意程式碼過度相依的問題。只是原則沒有絕對。 09/11 21:41
推 Edster: 什麼是程式碼過度相依? 09/11 23:13
→ andrew43: 例如函數A裡使用函數B,如果函數B要改,就改函數B就好。 09/12 00:33
→ andrew43: 若都寫在一起成函數C,想改變原本函數B的部份都要改寫。 09/12 00:36
→ andrew43: 簡單來說,避免「牽一髮而動全身」就是了。 09/12 00:38
→ andrew43: 至於相依,在這個例子不太明顯。在開發package可能會明 09/12 00:39
→ andrew43: 白一點。 09/12 00:40
→ celestialgod: 把a大的話翻譯一下,應該是重複使用的程式應該獨立 09/12 00:40
→ celestialgod: 避免更改時只有更動到部分的block 09/12 00:40
→ andrew43: 相依就像A函數的使用方法被B函數決定。一改B函數,A就錯 09/12 00:41
→ andrew43: 了。 09/12 00:42
→ celestialgod: 針對性的函數,不能一體適用... 09/12 00:42
→ celestialgod: 這時候要考慮用class去做函數方法運用 09/12 00:43
→ celestialgod: 或是加入case control避免更動其中一部分的函數 09/12 00:43
→ celestialgod: 造成其他函數的結果出問題 或是 不正確運行 09/12 00:44
→ andrew43: 這些都只是原則,沒有一定要怎麼做。好用好改就好。 09/12 00:45
→ andrew43: 多謝c兄幫忙解釋。 09/12 00:45
→ celestialgod: 我上次看dr的原始碼看得很痛苦= = 09/12 00:46
→ celestialgod: 他東拆拆西拆拆都看不懂了...嘆氣... 09/12 00:47
→ celestialgod: 我有時候也不懂到底拆分出常用的CODE是否真的會 09/12 00:48
→ celestialgod: 比較好 09/12 00:48
→ celestialgod: 我知道至少在修改跟維護上面會方便很多 09/12 00:49
→ celestialgod: 在讀者眼中可能不見得是好事... 09/12 00:49
→ celestialgod: 可能兩個稍微不同的CASE用同一個函數處理 09/12 00:50
→ celestialgod: 可能要花很多時間去找相異之處 09/12 00:50
→ celestialgod: 一切真的是看每個人 09/12 00:50
→ andrew43: 如果看到作者的UML,說不定就秒看懂了~ 09/12 00:59
→ celestialgod: 所以應該建議r package在打包時做network 09/12 01:14