{ "cells": [ { "cell_type": "markdown", "metadata": {}, "source": [ "

\n", " Les nombres en informatique\n", "\n", "


" ] }, { "attachments": { "image.png": { "image/png": "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" } }, "cell_type": "markdown", "metadata": {}, "source": [ "
\n", "
⌛ Avant de commencer votre lecture
\n", "\n", "👉 Ce fichier doit être lu sur un serveur jupyter. **C'est très simple :** \n", "\n", "😊 Le plus simple est de le lire sur basthon en suivant ce lien : https://notebook.basthon.fr/\n", " \n", "👉 Ce fichier est constitué de \"cellules\" de textes explicatifs et de \"cellules\" de codes. Pour le lire, vous pouvez \"éxécuter\" toutes les cellules, ou seulement les cellules de code.\n", "Il y a une icône Exécuter dans la barre de menu : ![image.png](attachment:image.png)\n", "\n", "🖲️ Vous pouvez cliquer maintenant sur \"Exécuter\" ...\n", "
" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "

\n", " Partie 1 : Les ensembles de nombres et la représentation des nombres en informatique\n", "\n", "


" ] }, { "cell_type": "markdown", "metadata": { "id": "DXi11YXnC_9Z" }, "source": [ "En mathématiques et en informatique, les nombres et les ensembles de nombres ne sont pas tout à fait écrits de la même façon...\n", "\n", "Mais pour le dire de façon plus précise : en informatique on ne représente pas tous les nombres.\n", "\n", "Et la raison est évidente : il existe une infinité de nombres. Même dans l'intervalle $[0,1]$ il y en a déjà une infinité, et entre deux nombres aussi proches soient-ils, il y a toujours une infinité de nombres....\n", "\n", "Or, on a certes bien des façons de représenter les nombres dans un ordinateur, mais la réprésentation doit toujours être faite en binaire, avec des 0 et des 1. Chaque chiffre 0 ou 1 est nommé **un bit**. Et\n", "on a forcément un nombre fini de bits, donc un nombre fini de nombres que l'on peut écrire.\n", "\n", "Pas de panique ! on ne va pas coder en binaire, mais juste explorer un peu les nombres en maths et leurs représentations en informatique." ] }, { "cell_type": "markdown", "metadata": { "id": "MpN1srhBC_9e" }, "source": [ "![image.png]()" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "L'ensemble des nombres entiers relatifs est noté $ \\mathbf{Z}$. " ] }, { "cell_type": "markdown", "metadata": { "id": "GXOElh3SC_9f" }, "source": [ "En Python les **entiers relatifs** ont le type int (integer). Enfin... ils peuvent avoir ce type, nous verrons dans ce document qu'ils peuvent être encodés de deux façons..." ] }, { "cell_type": "markdown", "metadata": { "id": "3mQRi6ybC_9f" }, "source": [ "On commence par créer une petite fonction en Python qui affiche si un nombre a le type int ou pas, et s'il est entier ou pas :" ] }, { "cell_type": "code", "execution_count": 2, "metadata": { "id": "V3zqZIMuC_9f" }, "outputs": [], "source": [ "def est_entier(nombre) :\n", " # on regarde comment il est écrit dans l'orinateur\n", " if type(nombre) == int :\n", " print(nombre, \"est de type int\")\n", " else :\n", " print(nombre, \"n'est pas de type int\")\n", "\n", " # on regarde si c'est un entier, pour cela on l'écrit comme un entier (int(x))et on compara avec lui même :\n", " if int(nombre) == nombre :\n", " print(nombre, \"est un entier\")\n", " else :\n", " print(nombre, \"n'est pas un entier\") " ] }, { "cell_type": "code", "execution_count": 3, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "bUdrzlctC_9g", "outputId": "2107d7ed-3db1-4802-b7c5-8ee8f874e15e" }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "1 est de type int\n", "1 est un entier\n", "1.0 n'est pas de type int\n", "1.0 est un entier\n", "1 est égal à 1.0\n" ] } ], "source": [ "a = 1\n", "est_entier(a)\n", "\n", "b = 1.0\n", "est_entier(b)\n", "\n", "\n", "if a == b :\n", " print ( a , \"est égal à\" , b )" ] }, { "cell_type": "markdown", "metadata": { "id": "lm1N8X7mC_9g" }, "source": [ "Il est vrai que 1 est égal à 1.0, mais néanmoins ces deux écritures diffèrent, et ne sont pas représentées de la même façon dans la mémoire de l'ordinateur.\n", "\n", "1 et 1.0 sont bien 2 écritures du même nombre, et dans l'ordinateur, ces deux écritures sont différentes." ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "L'ensemble des nombres réels est noté $ \\mathbf{R}$ " ] }, { "cell_type": "markdown", "metadata": { "id": "zaVGxIvWC_9g" }, "source": [ "Cet ensemble contient tous les nombres entiers, décimaux, rationnels, irrationnels...\n", "\n", "En Python les réels n'existent pas tous, car il est impossible de représenter les valeurs exactes de certain nombres.\n", "\n", "Ces nombres non entiers ont le type float\n", "\n", "float est une abréviation de floating point, qu'on peut traduire en français pas nombres à virgule flottante... ce terme fait référence à la façon dont un nombre est représenté dans la mémoire de l'ordinateur." ] }, { "cell_type": "markdown", "metadata": { "id": "Jj-3Jb8aC_9h" }, "source": [ "Toutefois, ces nombres ne sont pas tout à fait les mêmes qu'en maths, car il y a quelques approximations inévitables dues à la façon dont ces nombres sont encodés dans l'ordinateur. \n", "Par exemple si on écrit 0.1, ce nombre est encodé par une valeur approchée car 0.1 ne peut pas s'écrire de façon exacte en binaire. (Alors que 0.25 oui, on l’écrit 0.01 en binaire).\n", "Cette approximation est visible dès qu’on effectue des calculs simples.\n" ] }, { "cell_type": "code", "execution_count": 4, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "gonMTqTAC_9h", "outputId": "5d8cbe47-8dec-4a8b-eab5-09f522ab6875" }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "0.2\n", "0.30000000000000004\n" ] } ], "source": [ "a = 0.1\n", "print(2 * a)\n", "print(3 * a)" ] }, { "cell_type": "markdown", "metadata": { "id": "aCGYyz4kC_9h" }, "source": [ "🌵 Que pensez vous de la valeur affichée pour 3 * 0.1 ?" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "
\n", " Solution \n", " \n", "
\n", "La valeur affichée pour 3 * 0.1 est fausse.\n", "\n", "
\n", "
" ] }, { "cell_type": "code", "execution_count": 5, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "n7XbT_gAC_9h", "outputId": "4363fd02-1b9b-4090-c07b-cc402f85e35f" }, "outputs": [ { "data": { "text/plain": [ "False" ] }, "execution_count": 5, "metadata": {}, "output_type": "execute_result" } ], "source": [ "a = 0.1\n", "b = 0.3\n", "a + a + a == b" ] }, { "cell_type": "markdown", "metadata": { "id": "m99zZDDFC_9i" }, "source": [ "😢 Pour Python (ou tout autre langage) **0.1 + 0.1 + 0.1 n'est pas égal à 0.3 !!!!**" ] }, { "cell_type": "markdown", "metadata": { "id": "wEdJ_2pkH98P" }, "source": [ "Que signifie ceci ?
\n", "\n", "\n", "Pour une représentation très simple, on peut prendre une règle, un double décimètre par exemple. \n" ] }, { "cell_type": "markdown", "metadata": { "id": "q2ZgltWKI87N" }, "source": [ "![image.png]()" ] }, { "cell_type": "markdown", "metadata": { "id": "LrYnMwO6JA_S" }, "source": [ "\n", "Les flottants c’est comme les nombres marqués par une graduation sur la règle. Il n’y en a pas beaucoup, et par exemple toute longueur mesurée entre 2.3 et 2.4 sera approximée par l’une de ces deux valeurs. \n", "\n", "Et si je vous demande de placer 2.3451 sur le double décimètre..... ?\n", "\n", "La principale différence avec les flottants est que ceux-ci ne sont pas répartis de manière uniforme entre deux bornes comme sur la règle, mais ils deviennent de plus en plus rares à mesure qu’on s’éloigne de 0. \n", "\n", "Il y en a environ $2^{52}$ entre 1 et 2 mais il n’y en a aucun entre\n", "9007199254740992 et 9007199254740994 ($2^{53}$ et $2^{53}$ +2)." ] }, { "cell_type": "markdown", "metadata": { "id": "R5hR4TBgC_9i" }, "source": [ "Quelques nombres irrationnels, vus par nos ordinateurs
" ] }, { "cell_type": "code", "execution_count": 6, "metadata": { "id": "XOs26n7hC_9i" }, "outputs": [], "source": [ "from math import sqrt, pi" ] }, { "cell_type": "code", "execution_count": 7, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "qq_jyA3oC_9i", "outputId": "15de004c-c0bb-4583-f9fb-1e4aa2626496" }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "3.141592653589793\n" ] } ], "source": [ "print(pi)" ] }, { "cell_type": "code", "execution_count": 8, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "XT5mxM93C_9j", "outputId": "3d77cfcc-698e-466d-bd30-8789811ec361" }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "1.4142135623730951\n" ] } ], "source": [ "print(sqrt(2))" ] }, { "cell_type": "markdown", "metadata": { "id": "ejabKV5ORk-f" }, "source": [ "Est-ce que $\\sqrt{2}$ et égal à $1.4142135623730951$ ?" ] }, { "cell_type": "code", "execution_count": 9, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "h2ewYH_0R1b4", "outputId": "2861da35-a2c1-473b-d871-cef38584ee9a" }, "outputs": [ { "data": { "text/plain": [ "True" ] }, "execution_count": 9, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# et pour Python, est-ce égal ?\n", "\n", "sqrt(2) == 1.4142135623730951" ] }, { "cell_type": "markdown", "metadata": { "id": "0ptuyaabC_9j" }, "source": [ "⚠️ Là encore... ATTENTION !
\n", "\n", "Ces petites approximations ont leur importance...\n", "\n", "Regardons ce triangle et écrivons l'égalité de pythagore :\n", "\n" ] }, { "cell_type": "markdown", "metadata": { "id": "yaURhARUSaXB" }, "source": [ "![image.png]()" ] }, { "cell_type": "markdown", "metadata": { "id": "Gb2tmjjuSe7i" }, "source": [ "Le triangle est rectangle si et seulement si :\n", "\n", " $\\sqrt{2}^2 = 1^2+1^2 = 2$\n", "\n", " Ce qui est vrai, nous en conviendrons.\n" ] }, { "cell_type": "code", "execution_count": 10, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "Rde5IkhSC_9j", "outputId": "c7d15b39-2060-4d9a-a25e-41f95cbd20b6" }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "2.0000000000000004\n" ] } ], "source": [ "# Voyons ce qu'en pense Python :\n", "print(sqrt(2) * sqrt(2))" ] }, { "cell_type": "code", "execution_count": 11, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "mYRwd0BDC_9j", "outputId": "5130cdbc-e08f-46eb-d57d-4848fbf6b1a6" }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "False\n" ] } ], "source": [ "# Et faisons le test d'égalité :\n", "racine2 = sqrt(2)\n", "print(racine2 * racine2 == 2 )" ] }, { "cell_type": "markdown", "metadata": { "id": "b_hS-DjmIV2h" }, "source": [ "😢 Encore raté... !\n", "\n", "Si on n'y prend pas garde, le test de l'égalité pourrait nous laisser croire que ce triangle n'est pas rectangle..." ] }, { "cell_type": "markdown", "metadata": { "id": "kxGMtzFJC_9l" }, "source": [ "Mais avec Python on peut CONVERTIR
\n", "\n", "Convertir un float en int :
\n" ] }, { "cell_type": "code", "execution_count": 12, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "910NM-GNC_9l", "outputId": "c156bb5d-a0e1-43e5-e0d1-839acc647e65" }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "a = 1.0\n", "1.0 n'est pas de type int\n", "1.0 est un entier\n", "a = 1\n", "1 est de type int\n", "1 est un entier\n" ] } ], "source": [ "a = 1.0\n", "print(\"a =\", a)\n", "est_entier(a)\n", "\n", "a = int(a)\n", "print(\"a =\",a)\n", "est_entier(a)" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "id": "jlAN5-tiC_9l" }, "outputs": [], "source": [ "# essayer de faire de même avec d'autres nombres décimaux, par exemple 1.2, 1.8 etc...\n" ] }, { "cell_type": "markdown", "metadata": { "id": "bJ-vI53GC_9k" }, "source": [ "🤔 Les nombres saisis sont-ils des nombres ? Des lettres ?
" ] }, { "cell_type": "code", "execution_count": 13, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "ofAM-cQ5C_9k", "outputId": "81c081c8-f645-44fe-c414-807679ae5b2b" }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "Donnez moi un nombre entier : 3\n" ] } ], "source": [ "a = input(\"Donnez moi un nombre entier : \")" ] }, { "cell_type": "code", "execution_count": 14, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "XqjoRy18C_9k", "outputId": "02ffacf9-950a-4318-9928-5bb657781d69" }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "3\n", "3 n'est pas de type int\n", "3 n'est pas un entier\n" ] } ], "source": [ "print(a)\n", "est_entier(a)" ] }, { "cell_type": "markdown", "metadata": { "id": "2K0MFVirC_9k" }, "source": [ "🌵 Etrange non ?\n", "\n", "voyons de plus près :" ] }, { "cell_type": "code", "execution_count": 15, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "0QXIDk9lC_9k", "outputId": "fb4ce7a7-3936-46c3-88ad-e53edd0e05e9" }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "\n" ] } ], "source": [ "print(type(a))" ] }, { "cell_type": "markdown", "metadata": { "id": "Z6zCBxALC_9l" }, "source": [ "str est l'abbréviation de string, en français, chaine de caratères. En fait ici, 2 et 3 sont des caractères, c'est-à-dire des **lettres**. \n", "\n", "L'alphabet que l'on utilise est un alphabet formidable, il contient plus de 1.4 millions de caractères. Les lettre abcd ... ou ABCD.. en font partie, mais les chiffres aussi, et bien d'autres signes." ] }, { "cell_type": "markdown", "metadata": { "id": "31mYWCITC_9m" }, "source": [ "Convertir des caractères en int :
" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "M2B8Eo_hC_9m", "outputId": "634500b7-6d15-480b-b2da-5c8986a87dff" }, "outputs": [], "source": [ "a = int(input(\"Donnez-moi un nombre entier : \"))\n", "print(\"a =\",a)\n", "est_entier(a)" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "1NqTmguETl7j", "outputId": "1bc3cf47-caf3-4c66-a91b-68138b6b3e08" }, "outputs": [], "source": [ "# Entrer le même nombre mais l'écrire avec une virgule, comme 22.0\n", "\n", "a = int(input(\"Donnez-moi un nombre entier : \"))\n", "print(\"a =\", a)\n", "est_entier(a)\n" ] }, { "cell_type": "markdown", "metadata": { "id": "wEayY-6kTxNh" }, "source": [ "Python peut convertir \"22\" en int mais il ne peut pas convertir \"22.0\" car cette écriture ne représente pas un int" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "hd3L8CXrC_9m", "outputId": "2d339520-d5d8-4a08-e3bd-404ee294ee6d" }, "outputs": [], "source": [ "# Essayer ceci :\n", "a = int(\"12\")\n", "print(\"On convertit -> \", a)" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "colab": { "base_uri": "https://localhost:8080/", "height": 201 }, "id": "fOGjfQhaC_9m", "outputId": "60cfb5e8-4303-4e6e-dabf-4aaa27c4d754" }, "outputs": [], "source": [ "# mais en revanche :\n", "a = int(\"1.3\")\n", "print(\"on convertit -> \",a)" ] }, { "cell_type": "markdown", "metadata": { "id": "ZAIybgtxEjCW" }, "source": [ "Python ne peut pas convetir \"1.3\" en int, car 1.3 n'est pas un entier...\n", "\n", "---\n", "\n", "---\n", "\n", "\n", "\n" ] }, { "cell_type": "code", "execution_count": 16, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "ZnykkdZeC_9m", "outputId": "569b1dd3-8943-4166-ba79-08221c7a2e91" }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "On convertit -> 1.3\n" ] } ], "source": [ "# On aurait pu convertir en float :\n", "a = float(\"1.3\")\n", "print(\"On convertit -> \", a)" ] }, { "cell_type": "code", "execution_count": 17, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "Qn93ZiWBExCX", "outputId": "ce1775e1-6ee4-4ab3-9312-4b1a96faf133" }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "1\n" ] } ], "source": [ "# Et pour courronner l'étrangeté :\n", "print(int(1.3))" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "

\n", " Partie 2 : Quels nombres existent et quels nombres n'existent pas en informatique ?\n", "\n", "


" ] }, { "cell_type": "markdown", "metadata": { "id": "YnKt7_ITC_9n" }, "source": [ "Une infinité de nombres ~n'existent pas~ ne sont pas représentés, et beaucoup ~existent~ sont représentés. \n", "En vérité, il existe $2^{32}$ nombres flottants différents, si on utilise la norme d'encodage (qui est nommée IEE-754) en 32 bits, $2^{64}$ nombres si on code en 64 bits, ce qui est aujourd'hui la norme la plus courrante. \n", "Il est possible de coder de façon plus précise mais il restera toujours des petites approximations.\n", "\n", "Combien ça fait $2^{64}$ ?" ] }, { "cell_type": "code", "execution_count": 18, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "ROerLM8BC_9n", "outputId": "2d872b22-37a7-4248-b7cc-a83ab3ff578a" }, "outputs": [ { "data": { "text/plain": [ "18446744073709551616" ] }, "execution_count": 18, "metadata": {}, "output_type": "execute_result" } ], "source": [ "2**64" ] }, { "cell_type": "markdown", "metadata": { "id": "0T8R6QhXC_9n" }, "source": [ "Soit environ 18 milliards de nombres. Ca reste bien peu, comparé à l'infinité de ceux qui existent....\n", "\n" ] }, { "cell_type": "markdown", "metadata": { "id": "Hc_9qnPDqgHj" }, "source": [ "Essayons de calculer avec des entiers $2021^{2021}$ :" ] }, { "cell_type": "code", "execution_count": 19, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "-f-1CCKoquay", "outputId": "b5dda2d9-e7e9-49a3-b6dc-33b13c73aa1d" }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "10707075013391864857359068794430097759345158475055074360185324696840604841566225564579406189100464678304964606573388540129707028992875555668260045164201337947280471840711425484924104433016597154397436250961932360878515291777910608889398281721279871879195749233600233384326746476819700570995209863388777763382798833879737014253699254590204111562500941943425151021624251040629292763292838801691888564040797531949249309696354735538708974766820381439310315732534339417331276457587304837036534719908204123147514432780229056252519032984910235656157449882021310472735301861751956316457709322287437605022076515472551183322482930100667372839996398686543897717443618717039540905171985542318621350471529344584815464951732851120902548344127073797439394839392582580602728838662050971041407273608915912921824151844344335590849666420809080143012636341298608238942678928812140408120987333592099278531780492846147789107892737466934943922516534930947212002631246966615808504689903275904706006963580282212860712140202517808848697707065268230250501331142028493640331871589001099940746366284287665197194537655093205948809819695035468466888426466096033756464095771952599497520933370914203613974071336523829985872133718751247312144901236826259785843758394253337470736980370426403201313149598667143639422770888119193938644687363054985287909281487796451370000519038082184377893835419777658707076055616865899839062720734708480282684889548258467730739746303131848576438908520082808322854123819309751521436908126236792689435161576747184112163246591873001268006014915439822225485754376612332551214367031579411856872435080829830094131483548305775481930308286207305699910441390136913518183396798938205794660413884049394471633752730555098576646089385568005321257418626537385798809844734248430991352254701119526009531959263728857434093636896203614240393917832273699457130988840590620089896982132375242145843583745823278101613905611432101747494144011081231110171628940366745076218787370303339291870112901808248555404496618263303881340984784854560928473187234610554493974879595987471554565851060126337440905056198664237647459088368937940134701566720634649485559445893775312563196008730094993416285340032443509101302796415108040877045824933883541709273446742886944422698652124468678587655821893943893116153237256152690953147320537593980732428008198751993831355505136850699856492064059966574059520413839387831652206142240279540671778308947063062354720732835796098780293279474024593683726414459584032805786101717743425605191196523783747757012137360359094373391239918993144796972148159356230435594535553195368379914728578210251162728715385275844447142997418381552659088353084056981191442831613617234112577075840169795793478807387327686446861331208761206561481931812157531077700928267154754039364153763696762144607066836236221994506532735762039284988415082588009081351142031045605992925956607934960250968121512362360532915292770576131639726821248617651354040635187483548017320659200177636189421456406460740083953448356496437629897661665099521159095549242614252709496511921727122651930640042099619425216041818702925478185946733080613684128786443313810748814019796425310617241850641089797263887653004556938141542264510575184160778573384308067212791717953779902166782288602614742483125114907794148425537311723784447743663683585182021796425409097079747275132598666820687101424959293665378836291766351197946338474977084385295855447747226261423889009808285326345692375503266750040617764675666818486654556239094536169269118781390654441955842313815649752129362320158674727741701662811789455550393379535321788979794778743144554710464549177908727686998430851751723864258312154223154851807869613104877696454031762377947903066832614632614077705018623219217023574095582796747275124208233452391412230491993500387309458792712485091405388232036991104767514301752883929193330150778196972415194094639257698637759108678608698541198872019590100987248700472896397567086938587805590747311467560765678954996018335326193037345554143123900355385725465108203009927448702077302068631067242448837131265115170191905109945296613554592519679777439066564207264914674168511823870024617504788101964129890058720522938941157256948778441311764356749378322310662945037436016306985254834775086614834269041870261284635121674481307864499900896328411303817700829034779218673213974534354040675908993815115406831683786145524681395389155848980846992952201335314104974803909601450147403632156838088597926765670528128274066352681031024486797786600692423170418515445033780310726498798776709497961923544090170390928268193468778508359685218006147916957060198942986446697948371540488525485035602106088448274429325801667652505084584273869592397137349812001857949043680431585180873805319229961075808616995361459656210940782769234024695011304673035080242041880541541788219383491668835503911306911426857462053981264587738349537075632379445464404912589339578898400203254617711722602174220692427185124377813135275385482098101336825992450499068008004111282060952353167518264366416285814605654878751072598861475004390605195660229867912846884437841867754778629268815860063980385225888596849785606713930197329702810043303872679587253701371030778973420297466295084931467804080714008226159848329450021592945843304527769075809628146462240107905897647944716536682466204763883850928339695318826585783818123717442000448281971986995014758008125143080532485572168912031594574026053944845367903731380037082015945564438900444271269394288727273676780785697238672006446105146228979978118713565911979807127240595125192002711512578935331015483520764581225987403297778607178243554026658934040535575303518266644783148917834682949860480382774968219277958929283371247190997251741732625918343078777727366754921415437166646912318992985670528361992963635755296344994946111767990691559413431624494632494704192790866431863006587253643320003943113647706170543794443396685134784234236702950032973730549119073498660523965316972692661785833770032142344666354861979677590355073045029113652560290182772950847041196218804550529478155611419416753159139776764939890853207541313723318160448868868054700376083846257122818880174175938956219125701092317566294104213614636298416918961851650427416335112019813272454543994057050522582438209411016251416760079990839898685375079419769144741819483540291182250853408317604917751804384261366281744019247166363452450676118204131956835301617988560441035904520977298349059597183839425850765435115466752952804624316978136555655093707671592357331029387377373532624717724884848522267343889096826628906559259078331074573422999894603072799210847100222968350772149155527004349716012221595323085654209803801090783071940824076100007700961621265485380856743026451816242152956789327206468799884567\n" ] } ], "source": [ "grand_nombre = 2023**2023\n", "print(grand_nombre)" ] }, { "cell_type": "markdown", "metadata": { "id": "fQ6v6sNMrH1c" }, "source": [ "Combien de chiffres Python a-t-il utilisé pour écrire le résultat de $2023^{2023}$ ?" ] }, { "cell_type": "code", "execution_count": 20, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "E5BDReYSrWTZ", "outputId": "a2faa7da-5a58-43f1-907c-63ca484ea5b7" }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "6689\n" ] } ], "source": [ "nbre_chiffres = len(str(grand_nombre))\n", "print(nbre_chiffres)" ] }, { "cell_type": "markdown", "metadata": { "id": "yZRjMSunqS3Y" }, "source": [ "🙂\n", "```\n", "Les int sont tous représentés (enfin, jusqu'à de très très grands entiers, on pourrait trouver une limite quand même) :\n", "\n", "... -2 -1 0 1 2 3 ...\n", " ---------°---------°---------°---------°---------°---------°---------°\n", "```\n" ] }, { "cell_type": "markdown", "metadata": { "id": "LhDd9Ar6C_9n" }, "source": [ "😟 \n", "```\n", "\n", "Mais pour les réels, on a quelques float, mais pas les nombres qui sont entre deux float :\n", "\n", "... -2.0 -1.0 0.0 1.0 2.0 3.0 ...\n", " °--°-°--|-°--°-°--|-°--°-°--|-°--°-°--|-°--°-°--|-°--°-°--|-°--°-°--|-\n", "```\n", "\n", "La différence entre deux float qui se suivent est de l'ordre de $10^{-45}$ pour les nombres entre 0 et 1, de $10^{-16}$ pour les nombres de l'ordre de quelques unités à quelques milliers, et elle augmente quand on s'éloigne de zéro.\n", "Quelle que soit cette différence, il y a toujours une infinité de nombre réels entre les deux.\n" ] }, { "cell_type": "markdown", "metadata": { "id": "D5CfDGh2WPse" }, "source": [ "🤔 Reprenons l'xemple du début où l'on voit qu' en Python 0.1 + 0.1 + 0.1 = 0.30000000000000004 \n", "En effet 0.1 est représenté par 0.1000000000000000055… et donc quand on fait 0.1 + 0.1 + 0.1 on obtient avec les arrondis la représentation 0.3000000000000000444… qui n’est pas celle de 0.3. \n", "En fait 0.3 est représenté en machine par 0.2999999999999999889…" ] }, { "cell_type": "markdown", "metadata": { "id": "zTwo_QgQWTKM" }, "source": [ "👉 Le plus grand float positif dans l'ordinateur :\n", "- avec cette norme IEEE-754 en 32 bits est $3,402 823 26 × 10^{38}$, c'est à dire en gros 300 mille miliards de miliards de miliards \n", "- avec cette norme IEEE-754 en 64 bits est $1,797 693 134 862 315 7 \\times 10^{308}$" ] }, { "cell_type": "markdown", "metadata": { "id": "xyQygvySrxGH" }, "source": [ "🤔 Recommençons notre calcul de tout à l'heure, mais avec des flottants : $2023.0^{2023.0}$" ] }, { "cell_type": "code", "execution_count": 21, "metadata": { "colab": { "base_uri": "https://localhost:8080/", "height": 184 }, "id": "gskC5-8fsW4K", "outputId": "36c737d8-73c7-4051-9cb8-1f0f5fc2da2d" }, "outputs": [ { "ename": "OverflowError", "evalue": "(34, 'Result too large')", "output_type": "error", "traceback": [ "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m", "\u001b[1;31mOverflowError\u001b[0m Traceback (most recent call last)", "\u001b[1;32m\u001b[0m in \u001b[0;36m\u001b[1;34m\u001b[0m\n\u001b[1;32m----> 1\u001b[1;33m \u001b[0mgrand_flottant\u001b[0m \u001b[1;33m=\u001b[0m \u001b[1;36m2023.0\u001b[0m\u001b[1;33m**\u001b[0m\u001b[1;36m2023.0\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0m\u001b[0;32m 2\u001b[0m \u001b[0mprint\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mgrand_flottant\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n", "\u001b[1;31mOverflowError\u001b[0m: (34, 'Result too large')" ] } ], "source": [ "grand_flottant = 2023.0**2023.0\n", "print(grand_flottant)" ] }, { "cell_type": "markdown", "metadata": { "id": "0PCCTf6-sgBT" }, "source": [ " Overflow signifie dépassement : le nombre est trop grand, Python ne sais pas le calculer.\n", " \n", "Nous voyons ici que Python sait faire certains calculs avec des entiers, qu'il ne sait pas faire avec des flottants ... \n", "👉 **En programmation, il faut toujours être très attentif au type de variable que l'on choisit d'utiliser.**" ] }, { "cell_type": "markdown", "metadata": { "id": "9WbNokuWzofr" }, "source": [ "

\n", " Partie 3 : Comment tester l'égalité entre deux nombres ?\n", "\n", "


" ] }, { "cell_type": "markdown", "metadata": { "id": "HKeSgN2pC_9o" }, "source": [ "Quelques bizarreries dues à ces approximations :
" ] }, { "cell_type": "code", "execution_count": 22, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "iiVQmBE-C_9o", "outputId": "4215fdfe-335a-4857-c177-6c2236b94a04" }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "(1/10) * 554 == 55.4 -> False\n", "(1/10) * 879 == 87.9 -> True\n", "(1/10) * 18 == 1.8 -> True\n", "(1/10) * 119 == 11.9 -> True\n", "(1/10) * 395 == 39.5 -> True\n", "(1/10) * 567 == 56.7 -> True\n", "(1/10) * 609 == 60.9 -> False\n", "(1/10) * 713 == 71.3 -> True\n", "(1/10) * 323 == 32.3 -> False\n", "(1/10) * 251 == 25.1 -> True\n" ] } ], "source": [ "from random import randint\n", "\n", "def fct_etrange(n) :\n", " return (1/10)*n == n/10 # True si 1/10 * n est égal à n/10 et False sinon\n", "\n", "\n", "for i in range(10) :\n", " n = randint(1, 1000) # on prend un nombre n aléatoire entre 1 et 1000\n", " print('(1/10) * ', n ,' == ', n/10 ,' ->', fct_etrange(n)) # et on affiche si l'égalité est vraie ou pas\n", "\n" ] }, { "cell_type": "markdown", "metadata": { "id": "N5RQfUKXC_9o" }, "source": [ "🌵 Des fois oui et des fois non....\n", "\n", "#### Quelle est la probabilité, pour un entier $n$, que : $n \\times \\dfrac{1}{10} = \\dfrac{n}{10}$ ? \n", " \n" ] }, { "cell_type": "code", "execution_count": 23, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "PdkqUsDxC_9o", "outputId": "fed2a055-ea15-46ab-e837-9cd68cbcdf66" }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "la probabilité que n/10 soit exactement égal à n * (1/10) est de : 64.914 % environ\n" ] } ], "source": [ "# On va choisir au hasard 100000 valeurs de n (entre 0 et 1000) et compter combien de fois on à l'egalité vraie :\n", "\n", "nb_True = 0\n", "nTirages = 100000\n", "\n", "for i in range(nTirages) :\n", " n = randint(1, 1000)\n", " if fct_etrange(n) :\n", " nb_True = nb_True + 1\n", "\n", "print('la probabilité que n/10 soit exactement égal à n * (1/10) est de :', nb_True/nTirages*100,'% environ')" ] }, { "cell_type": "markdown", "metadata": { "id": "YM1RyRrfwA94" }, "source": [ "#### Précisons un peu :\n", " Quelle est la distance moyenne que voit Python, lorsqu'il constate une différence, entre : $n \\times \\dfrac{1}{10}$ et $ \\dfrac{n}{10}$ ? \n", "En maths, nous avons vu que la distance entre deux nombres $a$ et $b$ était égale à $|b-a|$. En python, cela s'écrit `abs(b-a)`." ] }, { "cell_type": "code", "execution_count": 24, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "fztQAhYHukEQ", "outputId": "9efcc16c-7229-4e9d-ec56-323d0da76c97" }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "La probabilité que n/10 soit exactement égal à n * (1/10) est de : 64.546 % environ\n", "L'écart moyen dans les cas de non égalité constatée est : 7.950069277297281e-15\n" ] } ], "source": [ "# On va choisir au hasard 100000 valeurs de n et compter combien de fois on a l'egalité vraie. :\n", "# Si l'égalité est fausse, on va calculer l'écart entre (1/10)*n et n/10.\n", "# On affichera la moyenne de ces écarts.\n", "\n", "from statistics import mean\n", "nb_True = 0\n", "nTirages = 100000\n", "\n", "liste_ecarts = [] # constitution de la liste des écarts\n", "\n", "for i in range(nTirages) :\n", " n = randint(1, 1000)\n", " if fct_etrange(n) :\n", " nb_True = nb_True + 1\n", " if not fct_etrange(n):\n", " liste_ecarts.append(abs((1/10)*n - n/10))\n", "moyenne_ecarts = mean(liste_ecarts)\n", "\n", "\n", "print('La probabilité que n/10 soit exactement égal à n * (1/10) est de :',nb_True/nTirages*100,'% environ')\n", "print(\"L'écart moyen dans les cas de non égalité constatée est : \", moyenne_ecarts)" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Comment fait-on pour tester l'égalité alors ?
" ] }, { "cell_type": "markdown", "metadata": { "id": "sAXbc_RG0o7-" }, "source": [ "💡 Il y a plusieurs possibilités :\n", "- Si c'est possible, on travaille avec des entiers.\n", "- On peut convenir, si c'est acceptable, que deux nombres sont égaux si la distance entre les deux est inférieure à une certaine valeur très petite, par exemple à $10^{-14}$. \n", "- Pour les très grands nombres, on peut aussi estimer qu'ils sont égaux, si leur distance relative est inférieure à une certaine valeur très petite." ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Regardons l'égalité de nombres \"pas trop grands\"
" ] }, { "cell_type": "markdown", "metadata": { "id": "Ul-wWD-r2UNn" }, "source": [ "Reprenons l'exemple de la fonction étrange modifiée comme expliqué ci-dessus." ] }, { "cell_type": "code", "execution_count": null, "metadata": { "id": "suxejI6h2edm" }, "outputs": [], "source": [ "def new_fct_etrange(n) :\n", " if abs((1/10)*n - n/10) < 10**(-14):\n", " return True\n", " else:\n", " return False # True si 1/10 * n est égal à n/10 et False sinon" ] }, { "cell_type": "markdown", "metadata": { "id": "Cskci1-53COU" }, "source": [ "Reprenons le test précédant :" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "ODQhx6-h3F5N", "outputId": "bfa68bdd-998e-4fd6-ff91-547dc22d94d0" }, "outputs": [], "source": [ "nb_True = 0\n", "nTirages = 100000\n", "\n", "for i in range(nTirages) :\n", " n = randint(1, 1000)\n", " if new_fct_etrange(n) : # on utilise la nouvelle fonction\n", " nb_True = nb_True + 1\n", "\n", "print('la probabilité que n/10 soit exactement égal à n * (1/10) est de :', nb_True/nTirages*100, '% environ')" ] }, { "cell_type": "markdown", "metadata": { "id": "WSUQwJ9m3hjJ" }, "source": [ "Manifestement le choix de $10^{-14}$ n'est pas bon. Reprenons avec $10^{-13}$." ] }, { "cell_type": "code", "execution_count": 25, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "JTv6Slwh30fD", "outputId": "724a8212-0531-4461-e44c-0e64c4f3e288" }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "la probabilité que n/10 soit exactement égal à n * (1/10) est de : 100.0 % environ\n" ] } ], "source": [ "def new_fct_etrange(n) :\n", " if abs((1/10)*n - n/10) < 10**(-13):\n", " return True\n", " else:\n", " return False # True si 1/10 * n est égal à n/10 et False sinon\n", "\n", "nb_True = 0\n", "nTirages = 100000\n", "\n", "for i in range(nTirages) :\n", " n = randint(1, 1000)\n", " if new_fct_etrange(n) : # on utilise la nouvelle fonction\n", " nb_True = nb_True + 1\n", "\n", "print('la probabilité que n/10 soit exactement égal à n * (1/10) est de :', nb_True/nTirages*100, '% environ')" ] }, { "cell_type": "markdown", "metadata": { "id": "1N2W8swZ375r" }, "source": [ "😀 Cela semble mieux ... \n" ] }, { "cell_type": "markdown", "metadata": { "id": "dNvv_ZxopNBF" }, "source": [ "Regardons l'égalité de nombres \"grands\"
\n", " " ] }, { "cell_type": "markdown", "metadata": { "id": "0iiltNOoplYQ" }, "source": [ "Nous allons tester si Python trouve que $3 \\times 10^{-1} \\times 10^{16}$ est égal à $3 \\times 10^{15}$" ] }, { "cell_type": "code", "execution_count": 26, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "63eAhZEUpR8L", "outputId": "68a6304a-72bd-4243-8ba9-f7896ae33734" }, "outputs": [ { "data": { "text/plain": [ "False" ] }, "execution_count": 26, "metadata": {}, "output_type": "execute_result" } ], "source": [ "3*(10**(-1))*(10**16) == 3.0*10**15" ] }, { "cell_type": "markdown", "metadata": { "id": "s59ZmMQ7qPyK" }, "source": [ "Cherchons la distance absolue que Python trouve entre ces deux nombres :" ] }, { "cell_type": "code", "execution_count": 27, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "65BLQ6IHqJXv", "outputId": "645eb0b1-a1ea-42f3-b588-5f338a887a06" }, "outputs": [ { "data": { "text/plain": [ "0.5" ] }, "execution_count": 27, "metadata": {}, "output_type": "execute_result" } ], "source": [ "abs(3*(10**(-1))*(10**16) - 3.0*10**15)" ] }, { "cell_type": "markdown", "metadata": { "id": "WYx4_aVFqaiG" }, "source": [ "😟 \n", "- Cette distance est très supérieure à la distance $10^{-13}$ que nous avions choisie dans le cas précédant des nombres \"pas trop grands\". Elle est même assez \"énorme\" pour considérer que les deux nombres sont identiques... \n", "- Nous allons maintenant regarder la **distance \"relative\"** entre ces deux nombres : \n", "Posons $a=3 \\times 10^{-1} \\times 10^{16}$ et $b= 3 \\times 10^{15}$. \n", "La distance relative entre $a$ et $b$ est égale à $\\dfrac{|b-a|}{a}$ \n", "Dans notre cas elle est égale à :" ] }, { "cell_type": "code", "execution_count": 28, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "w6mT39TX2HjV", "outputId": "ae0d57bc-5fe6-421b-cf4b-a322e70f4677" }, "outputs": [ { "data": { "text/plain": [ "1.6666666666666663e-16" ] }, "execution_count": 28, "metadata": {}, "output_type": "execute_result" } ], "source": [ "0.5/(3*10**(-1) * 10**(16))\n" ] }, { "cell_type": "markdown", "metadata": { "id": "EZqvvm562X9T" }, "source": [ "🙂 Nous obtenons une distance relative entre $a$ et $b$ de l'ordre de $10^{-16}$. C'est tout à fait raisonnable." ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "En bref ...
" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "
\n", "❓ Bienvenue dans le monde de l'informatique, où voir si deux nombres sont \"égaux\" n'est pas aussi simple qu'en mathématiques.
\n", " 👉 On regardera leur distance \"absolue\" pour des \"petits\" nombres, et leur distance \"relative\" pour les \"grands\" nombres ...\n", "
\n" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "

\n", " Partie 4 : Est-ce important de connaître ces différences entre les nombres \"théoriques\", et ceux qui sont utilisés dans nos ordinateurs ?\n", "\n", "


" ] }, { "cell_type": "markdown", "metadata": { "id": "LXxwmei96_xd" }, "source": [ "😢 Il y a quelques anecdotes tragiques qui prouvent qu'il ne faut pas ignorer ce problème. \n", "Mais restons dans le domaine des mathématiques. \n", "Posons $u=\\frac{1}{3}$ \n", "Calculons $4 \\times \\frac{1}{3} - 1$. Cela donne $\\frac{4}{3} - \\frac{3}{3}$, c'est à dire $\\dfrac{1}{3}$ \n", "Vérifions en Python :\n" ] }, { "cell_type": "code", "execution_count": null, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "CVZaJ8fW8KT2", "outputId": "8a09e6e1-47dd-4f52-f90a-067361509685" }, "outputs": [], "source": [ "u = 1/3\n", "u = 4*u - 1\n", "print(u)" ] }, { "cell_type": "markdown", "metadata": { "id": "ZG5yQGn78fEa" }, "source": [ "Nous aurions imaginé un résultat égal à 0.33333333333333333, ou à 0.33333333333333334. \n", "Regardons si nous faisons ce processus deux fois. Théoriquement, le résultat au bout d'une fois étant égal exectement à $\\dfrac{1}{3}$, le résultat au bout de deux fois sera aussi égal exectement à $\\dfrac{1}{3}$. On peut recommencer indéfiniment, on devrait toujours obtenir $\\dfrac{1}{3}$" ] }, { "cell_type": "code", "execution_count": 29, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "zDgaRDBz8z-z", "outputId": "d68b4629-6315-4a94-e201-795232515acb" }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "0.33333333333333304\n" ] } ], "source": [ "u = 1/3\n", "for i in range(2):\n", " u = 4*u - 1\n", "print(u)" ] }, { "cell_type": "markdown", "metadata": { "id": "M2gsX3X7Hzhe" }, "source": [ "Cela ne semble pas si mal... \n", "Et si nous faisions 27 fois de suite ce processus ?" ] }, { "cell_type": "code", "execution_count": 30, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "A7ARy4c8ICLU", "outputId": "9d4f9df2-1470-4a07-805b-d39c63153218" }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "0.0\n" ] } ], "source": [ "u = 1/3\n", "for i in range(27):\n", " u = 4*u - 1\n", "print(u)" ] }, { "cell_type": "markdown", "metadata": { "id": "GaQ0d9JgIGKf" }, "source": [ "🌵 Aïe ! C'est quand même très différent de $\\dfrac{1}{3}$! \n", "Essayons 28 fois de suite ...\n" ] }, { "cell_type": "code", "execution_count": 31, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "HP7HmUmaIacA", "outputId": "393584f2-ecf6-47fe-faca-6ea68627e634" }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "-1.0\n" ] } ], "source": [ "u = 1/3\n", "for i in range(28):\n", " u = 4*u - 1\n", "print(u)" ] }, { "cell_type": "markdown", "metadata": { "id": "mkXPMXdzIg2_" }, "source": [ "🌵🌵 Aïe ! Aïe ! Aïe ! Aucun rapport avec le résultat $\\dfrac{1}{3}$ attendu... \n", "Regardons pour 50 tours de boucles, puis pour 100 tours de boucles ..." ] }, { "cell_type": "code", "execution_count": 32, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "Gs60NQtMloyL", "outputId": "4d0bbd9d-af56-472d-cc5b-b56b650e5239" }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "après 50 tours de boucles u = -23456248059221.0\n", "après 100 tours de boucles u = -2.9734326931374163e+43\n" ] } ], "source": [ "u = 1/3\n", "for i in range(50):\n", " u = 4*u - 1\n", "print(\"après 50 tours de boucles u = \", u)\n", "\n", "u = 1/3\n", "for i in range(100):\n", " u = 4*u - 1\n", "print(\"après 100 tours de boucles u = \", u)" ] }, { "cell_type": "markdown", "metadata": { "id": "-o3h1HOfmSSs" }, "source": [ "🌵🌵🌵 C'est catastrophique ! \n", "Après 100 tours de boucles, notre nombre qui devrait être égal à $\\dfrac{1}{3}$ est de l'ordre de $-3 \\times 10^{43}$..." ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Si vous avez déjà étudié en mathématiques les suites de nombres
" ] }, { "cell_type": "markdown", "metadata": { "id": "EZoffh3Jn1J8" }, "source": [ "Utilisez le menu des suites de votre calculatrice, pour faire afficher le tableau des 35 premiers termes de la suite constante que nous venons de découvrir : \n", "$\\left\\{\\begin{matrix}\n", "u_{0}=\\frac{1}{3}\\\\ \n", "u_{n+1}=4u_{n}-1\n", "\\end{matrix}\\right.$ \n", "Le résultat risque de ne pas être celui que vous attendiez ..." ] }, { "cell_type": "markdown", "metadata": { "id": "XBV-DUNpEDS1" }, "source": [ "

\n", " Partie 5 : D'autres \"nombres\" de types float\n", "\n", "


" ] }, { "cell_type": "markdown", "metadata": { "id": "J_SZdXNTEUrJ" }, "source": [ "🙋 Regardons ces exemples : A quoi correspondent-ils ?" ] }, { "cell_type": "code", "execution_count": 33, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "a1010FHRJcBK", "outputId": "51d7eaa0-5d77-4316-eef5-1ff26512f9be" }, "outputs": [ { "data": { "text/plain": [ "inf" ] }, "execution_count": 33, "metadata": {}, "output_type": "execute_result" } ], "source": [ "float(\"inf\")" ] }, { "cell_type": "code", "execution_count": 34, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "0DXGNuGkJh5T", "outputId": "dd65994a-181e-4831-b5d1-bb6f319d5bc5" }, "outputs": [ { "data": { "text/plain": [ "nan" ] }, "execution_count": 34, "metadata": {}, "output_type": "execute_result" } ], "source": [ "float(\"Nan\")" ] }, { "cell_type": "markdown", "metadata": { "id": "gL_vuGBlKDDq" }, "source": [ "Remarquons que ces \"nombres\" `inf` et `nan` se trouvent dans la bibliothèque `math`" ] }, { "cell_type": "code", "execution_count": 35, "metadata": { "id": "hVhyjCOOEaIi" }, "outputs": [], "source": [ "from math import inf, nan\n", "\n", "\n", "\n" ] }, { "cell_type": "markdown", "metadata": { "id": "DcOiku7NK_tP" }, "source": [ "`inf` représente \"+ infini\", `-inf` représente \"- infini\" et `nan` représente \"not a number\". \n", "Nous retrouvons en particulier les **formes indéterminées** étudiées en mathématiques :" ] }, { "cell_type": "code", "execution_count": 36, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "H05i4Hh9H5vV", "outputId": "d1ca8a39-f7de-4dce-d340-da53223a5552" }, "outputs": [ { "data": { "text/plain": [ "nan" ] }, "execution_count": 36, "metadata": {}, "output_type": "execute_result" } ], "source": [ "inf + (-inf)" ] }, { "cell_type": "code", "execution_count": 37, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "0aGKexLIFv4k", "outputId": "104fee3d-0bda-44c9-ec8f-35abb0643957" }, "outputs": [ { "data": { "text/plain": [ "nan" ] }, "execution_count": 37, "metadata": {}, "output_type": "execute_result" } ], "source": [ "inf * 0" ] }, { "cell_type": "code", "execution_count": 38, "metadata": { "colab": { "base_uri": "https://localhost:8080/" }, "id": "Y7cd9WdWHkHB", "outputId": "7f006b05-aa10-4bf4-d7ea-564ee6e39859" }, "outputs": [ { "data": { "text/plain": [ "nan" ] }, "execution_count": 38, "metadata": {}, "output_type": "execute_result" } ], "source": [ "inf / inf" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Eplications sur `nan` :
" ] }, { "cell_type": "markdown", "metadata": { "id": "qSv_3VaEG8_s" }, "source": [ "nan sur wikipedia\n", "

" ] }, { "cell_type": "markdown", "metadata": { "id": "UrHwTvOZVX5-" }, "source": [ "\n", "
\n", "\n", "---\n", "\n", "**Auteurs** Jean-Louis Thirot - Lycée Bertrand d'Argentré - Vitré (35) - Mireille Coilhac - Lycée Saint-Aspais de Melun (77)\n", "\n", "Publié sous licence CC BY-NC-SA\n", "\n", "\n", "---\n", "\"Creative
This work is licensed under a Creative Commons Attribution-NonCommercial-ShareAlike 4.0 International License. " ] } ], "metadata": { "colab": { "collapsed_sections": [], "name": "les_nombres_et_python.ipynb", "provenance": [] }, "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.7.6" } }, "nbformat": 4, "nbformat_minor": 1 }