序
記得在上大學時,物理課的教材非常難懂,我非常煩惱。例如分析力學、量子力學、電磁學、熱力學和統計力學等,雖然使用的教材可以說都是名著等級的,卻不像高中教材那樣通俗易懂。
當時我非常希望能在學術研究上有所作為,所以絞盡腦汁地去了解那些知識,但進展並不順利,於是慢慢地就放棄了,開始每天沉浸在社團活動和兼職工作中。這當然也是因為自己還不夠努力,但要說為什麼會變成這樣,現在想來有兩個原因。
第一個原因是我在上大學時沒有掌握正確的學習方法。考上所究所之後,在神經網路和統計學相關的討論課上,在學長和導師的嚴格要求下,我開始不斷地去深究數學式。為了了解那些式子是如何推導出來的,除了自己認真思考之外,我還會向他人請教,或查詢相關的書和文獻。總之,我會在下周上討論課之前一直研究那些式子。我發現透過堅持不懈地努力,一開始不了解的數學式後來也基本上能了解了。不要思考一小時就放棄,而要用一周的時間去研究——我認為,要想真正了解數學式,就必須有這種覺悟。
第二個原因是大學時的教材跟我當時的水準不符合。當時我一直認為了解不了教材是自己能力不夠,但現在回想起來,我意識到那是錯誤的想法。在沒有儲備足夠的基礎知識的情況下就去讀高難度的專業書,當然難以了解其中的內容。也就是說,要想讀懂大學教材,應該先去讀一些過渡性的書。不執著於難懂的書,先找到符合自己當前水準的書才是正道。
現在深度學習備受矚目,機器學習的熱潮已經到來。在這一背景下,市面上出現了很多針對初學者的書,這些書往往只包含機器學習的基本數學式。與此同時,也有很多非常好的專業書。但遺憾的是,印象中很少有適合初學者在學習專業書之前閱讀的書。這時我剛好獲得了一個寫書的機會。於是,我決定為那些想要透過數學式透徹了解機器學習的讀者寫一本適合在學習專業書之前閱讀的書。
本書首先整理了最基礎的數學知識,然後盡可能簡潔地介紹了機器學習的相關問題、數學式及其推導過程,並將透過數學式了解機器學習的想法貫穿全書。因此,透過閱讀本書,讀者應該能掌握足以閱讀專業書的基礎知識。但限於本書的篇幅,有些地方可能解釋得不夠完善,或不容易了解,如果這時大家還能堅持不懈地讀下去,我將倍感榮幸。
這次有幸出版了本書的第2 版。在第2 版中,我以新版的Python 3.7.3進行了修訂,並修改了難以了解的敘述,更新了一部分圖表和數學式,還新增了第10 章,簡短地整理了本書要點。
最後,向那些對第1 版發表評價的讀者,以及對第2 版列出審讀意見的各位表示衷心的感謝。
伊藤真