{ "cells": [ { "cell_type": "markdown", "metadata": {}, "source": [ "### eigenvectsに関するコメント\n", "\n", "最後の固有値を求めるeigenvectsで失敗するかもしれません.\n", "これはsympyのversionによるようです.1.6.1ではダメです.\n", "それまでのは行けそうです.\n", "\n", "上の方で,対角ベクトルを与えるところで,\n", "Rationalを使うとちゃんと求めてくれます.\n", "```python\n", "#V = [1/5,1,1/2,1/3,1/4,1/2,1]\n", "V = [Rational(1,5),1,Rational(1,2),Rational(1,3),Rational(1,4),Rational(1,2),1]\n", "```\n", "\n", "これに関する問い合わせと開発者の反応は[Githubのissue](https://github.com/sympy/sympy/issues/20351) の通りです.\n", "この辺りがOSS開発ソフトで時々おこる問題です.\n", "そういうものだということを覚悟して,\n", "いくつかのライブラリや他のソフトで結果をクロス検証することを心がけてください.\n", "\n", "<2020-11-02 月>\n" ] }, { "cell_type": "code", "execution_count": 1, "metadata": {}, "outputs": [ { "data": { "image/png": "iVBORw0KGgoAAAANSUhEUgAAANUAAACvCAYAAABq+ZskAAAACXBIWXMAAA7EAAAOxAGVKw4bAAAOOElEQVR4Ae2d3Y3cRhaFexbzLAi7wAYwzmDGjsBSBitlIDsD61HzZsgZyBuBYWXgzUCQMtAGsMAKA0fgc1q8g252kV3N+rks1imAIllk1e37VR2yyCleXb158+Z2t9t9xBJK7+/v71+EDihPBHolAE18hu83If9x7Or64MAv2ObJh+m/hzvaFgER2BN4G+DwHHn/Yv6hqN5BZRJRgJayROCQAHTy6+E+t5HH1YmomDmbUNAU+n+c+A2Wt8irJkTY4lD1dyx32H7AulqSbRfmTfa3wzvVbAdFp+Jz189Yv+eJWD/F6iPWz7EUE9Zg59+w9QXLt1iCY1nkZ0+yXZ+5NSLYN9vfokQFB3+As0+x3guKjmP7Ydh/h12OJ4sk2kHF+5cl2P4J27xbVUmyvW/nqszZsODedH/7W2TvZKf+FDj3A/KeAQLvWkoikItA0/0tVlTPQIvDr3GyYR+PK4lALgJN97ezooq8C/09F03V0zeBLfS3s6JCE5tg5t62afjXtxZyet98f4sRVQywf8ScpHNEIBOBVfe3GFGFnqWMjV1V+HcrJRHIQaD5/nZWVBjj2rAvNMSzPHthkQOq6uiYwBb621lRDe37H6xvAm1tdyoeVxKBXASa7m+xouLUIM5mGKc7ZHw6uLqMj2tfBJYQaLq/RYkKouEEwi9Y7ycMkhK2OfR7ieUV9ysle0C1O2Qls3szsl2Jduv97erge6pv4Mzks9EgIk5w5DMWX0x8h4VzAUMzLXAoX4INXrmY+EdBipk2+Vv/wLGTGcPIz5Zkuz5zNh64s52b6W/4vZxaxS89rqJFRUeVREAEwgQORRU1/AtXo1wREIEQAYkqREV5IpBAQKJKgKeiIhAiIFGFqChPBBIISFQJ8FRUBEIEJKoQFeWJQAIBiSoBnoqKQIiARBWiojwRSCAgUSXAU1ERCBGQqEJUlCcCCQSuLy2L6Ri3KMO5eFUDWsKuW2BF2d7P9fQIntpkm0fdqdCpGPPvdyyM8cfAljdYqiXYZWDFD1i/xsKY76+xcDJt8d8h2/WZs2O1zD1WVAyc+QLLj/D3NzpdK8FmMLAi7DOwJ0VeLMn2cfBUgC7OnI3ZOvcoURXrtXEVewZWlO3jNvqA3Wfo9Pwso2RqmnsLovIMrCjbx9Kx7+3IpWRqmvuqRRV5RSzyFbBsz2qmCHNa3AL3VYsKjK3x+LXxVCo1FJHtKeJfv76ePpp2pHnuaxdVTPNY7IiYc3OfI9u5icbVt2ruFNWTwQ9bx7lV56wvM2bsilYqkKdsn8IvzZwWW+X+T8O16jsVxtc27AsN8SzPHp7Npyxr2d4H2BmzLMqcxrbAnaL6cyBn62F3NSvPwIqyfdwN7E5VOnhqi9z/Z6hWfacafqRnYEXZtp7ydX2HVY3gqU1zXyIqe0i0q9Yx9sx7GA64BfKUbZ/gqa1zv47VABzl1YPJ/vDHuYBVAlrCJq+Qb2GPATwtkOf32P+E/dJJtuszZ5s2y13BNEtLUvV3QQAX+McItUuGf11AkpMisJSARLWUnMqJwAQBiWoCjLJFYCkBiWopOZUTgQkCEtUEGGWLwFICEtVScionAhMEKCr+rYmfyc9NZJwormwREIGBAKdWUUc7iuoGC2M9VJkhATtKIrBFApwUsY+ZouHfFptXPrkSkKhc8cv4FglEz/0z5zEd4xbbnAdYNZgm7XvZht0mgzqSWUry9Ju/29N+iu0oUcEAP05jEE2+zPgWC5/DqiRP23QQ9hnI82esGfOO+2TxEevnWIp8IEk7TKi/S9ut+x41/EPjegbT9LStQJ57ee8F/oBNBdMceMytokQ1V8HGjzUd1DGhbTz95s/2tJ9sW6Ka73l8TRr6+50N+3i8VOrVNnk27btENSEJDHktyMnEGfvsIn/b69U2iW7Bd4lqWjImGD5LTKUY4U2Vncvv1TaZNO+7RDXXtc8fs3gd58/Mf0avtkly1b5TVE+G9rb1sNv9KvQsZVDsaqpAnkYk37pV7kfBNP8ceNg6H56Ga8LY3oZ9oSGe5dkLi6ye9mqbEBv2vam4f1k77IWVtRjU8UIXg6d7+s0f5Gk/2baeqYJ96jGz6aCOj15cvuHpN3+tp/1k20tEZQ+J9lxxeZMtL1HVNoYiCuQ5tBVYcMj7Esur5c0XV7J17tdxbu7HulQwk/3Bs1owTUB2sw1/77AokOdu9x041ApgClPtclcwTTafkggkEsCFX8E0ExmquAhMEljyTDVZmQ6IgAh8jVEhDiIgAhkJ6E6VEaaqEgESkKjUD0QgMwGJKjNQVScCFJWCaaofiEA6AU5vUjDNdI6qQQQeCXBShIJpPuLQhghkJKBnqowwVZUIkED03D+ejKkYbkElB/u3WHMeoAJ5EkiFhDb3ZO7W31L6erSoYMQlsCPscna0AnkCwsCieCBPT+Z2ncBvcOlvtJ9qO2r4ByOeQSU9g2l62u6S+dCpPX1Pth0lKjiaHGCQsJQuItAzc0/fk23HioqvC0MBOSxGA48r5SXQM3NP35NtnxUVhn4W5GSuy3h8BTz3e5o+1jNzT99z2T4rKvROE8zDTE+NEd5McR0aEeiZuafvWWzHiGrU3sFdix0RPKjMIgR6Zu7p+1nbFJUF0bT1uAeEnqXsHFN2qaCSZqe3dc/MPX1PsR0fTBPjTBv2hYZ4lmcvLHrr/EX87Zm5p++Jti8OppkcYLBI79t2pT0z9/Q92XbsM1VygMFt9/8i3vXM3NP3ZNtRosJt0S2o5Ki72kOiPcuNDhfdrWq7Z+aevuewfX1BN7zDuS5BJeEorx5M/MMckwJ5fuVQ7F9P5oNTbv0N9pNsK5hmsW6pinsigIsQ5wy+w/oqavjXExz5KgKpBCSqVIIqLwIjAhLVCIh2RSCVgESVSlDlRWBEQKIaAdGuCKQSkKhSCaq8CIwIUFQKpjmCol0RWECA05sUTHMBOBURgSkCnJigYJpTdJQvAikE9EyVQk9lRSBA4JK5f/vimIZxiw3Oxasa0BJ23QIr0nEvvz1tezNv1fcoUQEuP0Z0CWg5gHUJrOjpt6dtT+aD7ab7W6yoHuAs46Ht0Ng/YcW7VZUEe8Hghsh/jx/AB8PnpX4IbHj67WnbjTnb0pl7su8tPFMlBzcsJboN19sz82TfWxAVX1WGAnJYXAweV8pLoGfmyb6vWlQYBnBsfS55fAV87jc1e7xn5rl8X7Wo0DNNMHy+mEoxwpsqq/xTAj0zz+L72kV12uSnORY74vSIckoR6Jn5Wd8pqicDeVuXaogl9Yaepaweu6ookKcRybPumXmK7/HBNPO007JahlerLBwa4lmevbBYZkSljgj0zDzR94uDaR6Br7yTHNyw8u/dgrmemSf73sIzVXJwwy308so+9Mw82fclorIHNXumKdreuCUrkOdu1ytz9q3mfL+OVQQ6NxXMZH9srRbQEjbvsCiQZ8Ugop7MYXvXcn9TME22oJIIJBLARUDBNBMZqrgITBJY8kw1WZkOiIAI7HYSlXqBCGQmIFFlBqrqRECiUh8QgcwEJKrMQFWdCFBUCqapfiAC6QQUTDOdoWoQgSMCnBShYJpHSLQjApkI6JkqE0hVIwJGIHrunxXAdIxbbHMeYDfBNOGzWyBPT9tsc6/2Hmw3yT1KVADLDwK7C6Y5NKxLIE9P297t7el7DttRwz9AfsDyAgv/q5DfaLhWgs1gcEPYt2CaxX5Kx7bd2puN2Tr3KFEV67VxFScHN4wzEzyrV9tBGBUzm+begqj4qjIUkMNiU/B4qdSr7VI8Y+ttmvuqRYVhgAV3mWuMIl8g92p7DnSNY1vgvmpRoRFNMA8zDRojvJnik4d6tT0JpNKB5rmvXVQx7WgxDGLOzX1Or7Zzc7y0vlVzX7uoQs9S1gB2RSsVTLNX28bXa90891WLCuNrG/aFhniWZy8ssnaCXm1nhbigsi1wX7WohjZJDm64oG2tSK+2zX+vddPcWxBVcnDDhJ7Rq+0EZFmKNs19iajsIdGeabJQnKoEwwG3YJq92h61RdX2pu3WuV+PAE7uwlFePZjsj61dBNOEv3dYXAJ5etp2bm+43i53BdNk8ymJQCIBXIQUTDORoYqLwCSBJc9Uk5XpgAiIgIJpqg+IQHYCulNlR6oKeycgUfXeA+R/dgISVXakqrB3AhJV7z1A/mcnIFFlR6oKeycgUfXeA+R/dgISVXakqrB3AtFz/wgKUzGaDG6Y2si9+j20+S3WnPdZNXjqYLvJ/hZ9p0LHYlDJD1i/xvILtl9j+QPbNwRQMsl2Xebg/RQLJ0wz4D6DqBZv43H/abnNo0QFBxXQcmh1sODXyFsP5Klgmvf3bON9urTNo0SFmpsObjiwWbLq1e8lrHKWaZp7rKiaDm6Y0Nq9+p2ALEvRprmfFRVufRZgZY5Wka+AZXsO+WNMxNmTWju4hTY/Kyo0igmGzxJTKUZ4U2Xn8mV7mk4p5tMW6xxpvs1jRBWD0uIYxJyb+xzZzk10/fWtus1jRNV8cMOFfaRXvxfiylasee5nRTW8TiSx0HDD8hTQMluf2v+R/WGozvge1m55RZgfGvLY3kJ/OyuqAWzTwQ0TOkevficgy1K0ae6xomo6uGFCM/fqdwKyLEWb5h4lKtySFdBy6CvDK9+X2H2VpftMVOLJfPST7KWAvZUbHc6/6+l7DtuXTKi9A77ugkrC5y79Rufi3YKJf4hlqhk8lfaa5a5gmmw+JRFIJICLkIJpJjJUcRGYJBD1TDVZWgdEQAROCEhUJ0iUIQJpBCSqNH4qLQInBCSqEyTKEIE0Aoev1D/jDca4tvfI4wdjSiIgAgMBaOIzNm+mgFBUnEP248QJm5xfNuGrskUgloAFpAme/xfY4ThFRxHY1AAAAABJRU5ErkJggg==", "text/latex": [ "$\\displaystyle \\left[\\begin{matrix}0 & 1 & 1 & 1 & 1 & 0 & 1\\\\1 & 0 & 0 & 0 & 0 & 0 & 0\\\\1 & 1 & 0 & 0 & 0 & 0 & 0\\\\0 & 1 & 1 & 0 & 1 & 0 & 0\\\\1 & 0 & 1 & 1 & 0 & 1 & 0\\\\1 & 0 & 0 & 0 & 1 & 0 & 0\\\\0 & 0 & 0 & 0 & 1 & 0 & 0\\end{matrix}\\right]$" ], "text/plain": [ "⎡0 1 1 1 1 0 1⎤\n", "⎢ ⎥\n", "⎢1 0 0 0 0 0 0⎥\n", "⎢ ⎥\n", "⎢1 1 0 0 0 0 0⎥\n", "⎢ ⎥\n", "⎢0 1 1 0 1 0 0⎥\n", "⎢ ⎥\n", "⎢1 0 1 1 0 1 0⎥\n", "⎢ ⎥\n", "⎢1 0 0 0 1 0 0⎥\n", "⎢ ⎥\n", "⎣0 0 0 0 1 0 0⎦" ] }, "execution_count": 1, "metadata": {}, "output_type": "execute_result" } ], "source": [ "from sympy import *\n", "init_printing()\n", "M = Matrix([[0, 1, 1, 1, 1, 0, 1],\n", "[1, 0, 0, 0, 0, 0, 0],\n", "[1, 1, 0, 0, 0, 0, 0],\n", "[0, 1, 1, 0, 1, 0, 0],\n", "[1, 0, 1, 1, 0, 1, 0],\n", "[1, 0, 0, 0, 1, 0, 0],\n", "[0, 0, 0, 0, 1, 0, 0]])\n", "M" ] }, { "cell_type": "code", "execution_count": 2, "metadata": {}, "outputs": [ { "data": { "image/png": "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", "text/latex": [ "$\\displaystyle \\left[\\begin{matrix}0 & 1 & 1 & 0 & 1 & 1 & 0\\\\1 & 0 & 1 & 1 & 0 & 0 & 0\\\\1 & 0 & 0 & 1 & 1 & 0 & 0\\\\1 & 0 & 0 & 0 & 1 & 0 & 0\\\\1 & 0 & 0 & 1 & 0 & 1 & 1\\\\0 & 0 & 0 & 0 & 1 & 0 & 0\\\\1 & 0 & 0 & 0 & 0 & 0 & 0\\end{matrix}\\right]$" ], "text/plain": [ "⎡0 1 1 0 1 1 0⎤\n", "⎢ ⎥\n", "⎢1 0 1 1 0 0 0⎥\n", "⎢ ⎥\n", "⎢1 0 0 1 1 0 0⎥\n", "⎢ ⎥\n", "⎢1 0 0 0 1 0 0⎥\n", "⎢ ⎥\n", "⎢1 0 0 1 0 1 1⎥\n", "⎢ ⎥\n", "⎢0 0 0 0 1 0 0⎥\n", "⎢ ⎥\n", "⎣1 0 0 0 0 0 0⎦" ] }, "execution_count": 2, "metadata": {}, "output_type": "execute_result" } ], "source": [ "Mt = M.T\n", "Mt" ] }, { "cell_type": "code", "execution_count": 43, "metadata": {}, "outputs": [ { "data": { "image/png": "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", "text/latex": [ "$\\displaystyle \\left[\\begin{matrix}\\frac{1}{5} & 0 & 0 & 0 & 0 & 0 & 0\\\\0 & 1 & 0 & 0 & 0 & 0 & 0\\\\0 & 0 & \\frac{1}{2} & 0 & 0 & 0 & 0\\\\0 & 0 & 0 & \\frac{1}{3} & 0 & 0 & 0\\\\0 & 0 & 0 & 0 & \\frac{1}{4} & 0 & 0\\\\0 & 0 & 0 & 0 & 0 & \\frac{1}{2} & 0\\\\0 & 0 & 0 & 0 & 0 & 0 & 1\\end{matrix}\\right]$" ], "text/plain": [ "⎡1/5 0 0 0 0 0 0⎤\n", "⎢ ⎥\n", "⎢ 0 1 0 0 0 0 0⎥\n", "⎢ ⎥\n", "⎢ 0 0 1/2 0 0 0 0⎥\n", "⎢ ⎥\n", "⎢ 0 0 0 1/3 0 0 0⎥\n", "⎢ ⎥\n", "⎢ 0 0 0 0 1/4 0 0⎥\n", "⎢ ⎥\n", "⎢ 0 0 0 0 0 1/2 0⎥\n", "⎢ ⎥\n", "⎣ 0 0 0 0 0 0 1⎦" ] }, "execution_count": 43, "metadata": {}, "output_type": "execute_result" } ], "source": [ "#V = [1/5,1,1/2,1/3,1/4,1/2,1]\n", "V = [Rational(1,5),1,Rational(1,2),Rational(1,3),Rational(1,4),Rational(1,2),1]\n", "VA = diag(*V)\n", "VA" ] }, { "cell_type": "code", "execution_count": 44, "metadata": {}, "outputs": [ { "data": { "image/png": "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", "text/latex": [ "$\\displaystyle \\left[\\begin{matrix}0 & 1 & \\frac{1}{2} & 0 & \\frac{1}{4} & \\frac{1}{2} & 0\\\\\\frac{1}{5} & 0 & \\frac{1}{2} & \\frac{1}{3} & 0 & 0 & 0\\\\\\frac{1}{5} & 0 & 0 & \\frac{1}{3} & \\frac{1}{4} & 0 & 0\\\\\\frac{1}{5} & 0 & 0 & 0 & \\frac{1}{4} & 0 & 0\\\\\\frac{1}{5} & 0 & 0 & \\frac{1}{3} & 0 & \\frac{1}{2} & 1\\\\0 & 0 & 0 & 0 & \\frac{1}{4} & 0 & 0\\\\\\frac{1}{5} & 0 & 0 & 0 & 0 & 0 & 0\\end{matrix}\\right]$" ], "text/plain": [ "⎡ 0 1 1/2 0 1/4 1/2 0⎤\n", "⎢ ⎥\n", "⎢1/5 0 1/2 1/3 0 0 0⎥\n", "⎢ ⎥\n", "⎢1/5 0 0 1/3 1/4 0 0⎥\n", "⎢ ⎥\n", "⎢1/5 0 0 0 1/4 0 0⎥\n", "⎢ ⎥\n", "⎢1/5 0 0 1/3 0 1/2 1⎥\n", "⎢ ⎥\n", "⎢ 0 0 0 0 1/4 0 0⎥\n", "⎢ ⎥\n", "⎣1/5 0 0 0 0 0 0⎦" ] }, "execution_count": 44, "metadata": {}, "output_type": "execute_result" } ], "source": [ "trans_mat = Mt*VA\n", "trans_mat" ] }, { "cell_type": "code", "execution_count": 50, "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "[(0, 1, [Matrix([\n", "[ 0],\n", "[ 1],\n", "[ 0],\n", "[ 0],\n", "[ 0],\n", "[-2],\n", "[ 1]])]), (1, 1, [Matrix([\n", "[ 5],\n", "[52/19],\n", "[44/19],\n", "[33/19],\n", "[56/19],\n", "[14/19],\n", "[ 1]])])]\n" ] } ], "source": [ "trans_mat.eigenvects(error_when_incomplete=False)\n", "v_all = trans_mat.eigenvects(error_when_incomplete=False)\n", "print(v_all)" ] }, { "cell_type": "code", "execution_count": 52, "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "Matrix([[5], [52/19], [44/19], [33/19], [56/19], [14/19], [1]])\n" ] } ], "source": [ "v = Matrix(trans_mat.eigenvects(error_when_incomplete=False)[1][2])\n", "print(v)" ] }, { "cell_type": "code", "execution_count": 53, "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "0.699456533837389\n", "0.382860418521518\n", "0.323958815672054\n", "0.242969111754040\n", "0.412311219946250\n", "0.103077804986563\n" ] } ], "source": [ "v_n = v.norm().evalf()\n", "for i in range(0,6):\n", " print(v[i]/v_n)" ] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] } ], "metadata": { "kernelspec": { "display_name": "Python 3.8.5 ('base')", "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.8.5" }, "toc": { "base_numbering": 1, "nav_menu": {}, "number_sections": true, "sideBar": true, "skip_h1_title": false, "title_cell": "Table of Contents", "title_sidebar": "Contents", "toc_cell": false, "toc_position": {}, "toc_section_display": true, "toc_window_display": false }, "vscode": { "interpreter": { "hash": "f3f87633aac09da3bda522f97956bee375b5501d1579e6458804e567301cb62a" } } }, "nbformat": 4, "nbformat_minor": 4 }