{ "cells": [ { "cell_type": "markdown", "metadata": { "heading_collapsed": true, "slideshow": { "slide_type": "slide" } }, "source": [ "# なんで型なんてあるのか\n", "\n", "20180907 勉強会" ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "slide" } }, "source": [ "# 型に興味をもったきっかけ" ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "subslide" } }, "source": [ "## プログラミングに初めて触れたとき\n", "\n", "- 最初に触ったのはC言語\n", "- int, float, char, ...\n", " - コレ全部覚えなあかんの?\n", " - ややこしくね???\n", " - なんでわざわざ範囲の狭い型使うの?\n", " - 全部long long intでええやん!!!" ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "subslide" } }, "source": [ "## そして動的型付けの言語を始める\n", "\n", "\n", "- Python\n", "- JavaScript\n", "- PHP\n", "\n", "→型書かんで良いの超ラクじゃん!!!最高!!!" ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "slide" } }, "source": [ "## 再び静的型付けの言語を始める\n", "\n", "- 仕事でTypeScript\n", "- ノリでHaskell, Go\n", "\n", "→型に興味を持ち始める\n", "\n" ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "slide" } }, "source": [ "# この本を読んだ\n", "\n", "- 8章が型の話\n", "\n", "![]()" ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "slide" } }, "source": [ "# 静的型付けと動的型付けの違い" ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "subslide" } }, "source": [ "## 静的型付けの言語\n", "\n", "- プログラムを実行前に型検査を行う\n", "- 効率がいい\n", " - 型宣言をすることで、その変数に対して適切なデータ領域を確保できる\n", " - それによって高度な最適化ができる\n", "- コンパイルを通すのが大変だったりする\n", "\n", "- 例\n", " - C, C++, Rust, Go, Haskell, etc.\n", " \n" ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "subslide" } }, "source": [ "## 動的型付けの言語\n", "\n", "- プログラムを実行しながら型検査を行う\n", "- 楽に書ける\n", "- 遅い\n", "\n", "- 例\n", " - Python, JavaScript, PHP, Ruby, etc." ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "slide" } }, "source": [ "# 強い型付けと弱い型付け" ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "subslide" } }, "source": [ "## 強い型付け\n", "- 型安全性がある\n", "- 型検査を通れば、安全さが保証される\n", "- ML, Haskell, etc.\n" ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "fragment" } }, "source": [ "## 弱い型付け\n", "- 型安全性がない\n", "- 検査を通っても安全さは保証されない\n", "- C, C++, etc.\n" ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "slide" } }, "source": [ "# 本題: なんで型が必要なのか。" ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "slide" } }, "source": [ "# そのまえに..\n", "## 0と1でデータを表す方法" ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "subslide" } }, "source": [ "## 例えば浮動小数点数\n", "\n", "- IEEE754で定められたものがよく使われる\n", "- 以下の3つの部分で表される\n", " - 符号\n", " - 0なら正、1なら負\n", " - 指数\n", " - -127~128 (2^8とれる)\n", " - -127なら小数点を右に127個動かす\n", " - 128なら小数点を左に128個動かす\n", " - 127のバイアスが加わる\n", " - 0個ずらすとき127\n", " - 仮数\n", " - 1.XXXXX の XXXXX の部分\n", "- [浮動小数点数シミュレーター](https://tools.m-bsys.com/calculators/ieee754.php)" ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "subslide" } }, "source": [ "#### 単精度浮動小数点数の場合はこんなん\n", "\n", "- 全体で32bit\n", " - 符号部に1bit\n", " - 指数部に8bit\n", " - 仮数部に23bit\n", "\n", "\n", "![](http://www.cc.kyoto-su.ac.jp/~yamada/programming/float.png) \n", "【画像引用元】[浮動小数点数型と誤差](http://www.cc.kyoto-su.ac.jp/~yamada/programming/float.html)" ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "subslide" } }, "source": [ "### 例\n", "\n", "さっきの32bitで表現してみる!\n", "- 10進数で7.0" ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "fragment" } }, "source": [ "#### → 2進数で表す\n", "- 111.0" ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "fragment" } }, "source": [ "#### →小数点を左に2つずらす \n", "- 1.11 * 10^2" ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "subslide" } }, "source": [ "### 1.11 * 10^2 とは\n", "\n", "- 符号\n", " - 正数なので0\n", "- 仮数\n", " - 1.XXX の XXX の部分なので\n", " - 11\n", "- 指数\n", " - 10の2乗なので2\n", " - 127のバイアスを考慮すると129(2^7 + 1)\n", " - 10000001\n", "\n", " " ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "fragment" } }, "source": [ "### 結果\n", "\n", "0 10000001 11000000 00000000 0000000" ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "slide" } }, "source": [ "## じゃあこれはなんぼ?\n", "\n", "- 0 10000001 11000000 00000000 0000000" ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "slide" } }, "source": [ "## 答え\n", "\n", "さっきと同じだから7!!!!!!" ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "fragment" } }, "source": [ "と思ったが、 \n", "これが示す型が「浮動小数点数型」ではなく「整数型」の場合、1,088,421,888になる \n", "\n", "どういうことかというと.." ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "slide" } }, "source": [ "### 整数型の場合 \n", "00000000 00000000 00000000 00000001 なら1 \n", "00000000 00000000 00000000 00000010 なら2 \n", "... \n", "... \n", "... \n", "00000000 00000000 00000000 11111111 なら255 \n", "... \n", "\n", "\n", "となる" ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "subslide" } }, "source": [ "## さっきのは\n", "\n", "- 0 10000001 11000000 00000000 0000000\n", "\n", "### 整数型の場合\n", "\n", "- 2^(6+8+7) + 2^(6+8+8) + 2^(6+8+8+1) + 2^(6+8+8+8)\n", "- = 2097152 + 4194304 + 8388608 + 1073741824\n", "- = 1,088,421,888\n", "\n", "\n", "### 浮動小数点数型の場合\n", "\n", "- さっきみたように7.0\n", "\n" ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "slide" } }, "source": [ "## つまり\n", "\n", "- 0 10000001 11000000 00000000 0000000\n", "- これだけみてもコンピュータはどの数値を表しているのかわからない\n" ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "fragment" } }, "source": [ "→ 型いるやん!!!!!!" ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "slide" } }, "source": [ "## 動的型付けの言語はどうしているのか\n", "\n", "### 例えばPython\n", "\n", "![](https://github.com/mrsekut/slides/blob/master/img/py.png?raw=true)" ] }, { "cell_type": "markdown", "metadata": { "slideshow": { "slide_type": "slide" } }, "source": [ "# 他におもろかったもの\n", "\n", "- 型推論についての話\n", "- クラスやinterfaceも型や!!みたいな話" ] } ], "metadata": { "celltoolbar": "Slideshow", "kernelspec": { "display_name": "Python 3", "language": "python", "name": "python3" }, "language_info": { "codemirror_mode": { "name": "ipython", "version": 3 }, "file_extension": ".py", "mimetype": "text/x-python", "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", "version": "3.6.1" }, "toc": { "nav_menu": {}, "number_sections": false, "sideBar": true, "skip_h1_title": false, "toc_cell": false, "toc_position": {}, "toc_section_display": "block", "toc_window_display": false } }, "nbformat": 4, "nbformat_minor": 2 }