{ "cells": [ { "cell_type": "markdown", "id": "a205c519", "metadata": {}, "source": [ "# Laboratorio 1: Python Básico, Librerias y Modelamiento Básico.\n", "\n", "---\n", "### Profesor: Daniel Ruiz Mejía\n", "### Nombre: ______\n", "*Métodos computacionales 2025-I*\n", "\n", "---" ] }, { "cell_type": "markdown", "id": "0634e826", "metadata": {}, "source": [ "# 1.\n", "Diseñar un programa en el que entrado un numero `a` retorne una variable booleana True or false si cumple que es:\n", "\n", "- [Números defectivo](https://es.wikipedia.org/wiki/Número_defectivo) : la suma de los divisores propios es menor que el número. \n", "\n", " La rutina se deberá llamar números_defectivos\n", "\n", "\n", "\n", "- [Números abundantes](https://es.wikipedia.org/wiki/Número_abundante): la suma de los divisores es mayor que el número.\n", "\n", " La rutina se deberá llamar números_abundantes\n", "\n", "\n", "\n", "- [Números semiperfectos](https://es.wikipedia.org/wiki/N%C3%BAmero_semiperfecto) la suma de todos o algunos de los divisores propios es igual al número.\n", "\n", " La rutina se debera llamar numeros_semiperfectos\n", "\n", "- [Números perfectos](https://es.wikipedia.org/wiki/N%C3%BAmero_perfecto) la suma de todos sus divisores propios, excepto el mismo numero, es igual al número.\n", "\n", " La rutina se deberá llamar numeros_perfectos\n", "\n", "\n", "- [Números primos](https://es.wikipedia.org/wiki/N%C3%BAmero_primo) el número es divisible unicamente por sí mismo y por 1.\n", "\n", " La rutina se deberá llamar numeros_primos\n", "\n", "\n", "**Problema no obligatorio** \n", "\n", "Retornar los 30 primeros números de cada clase" ] }, { "cell_type": "code", "execution_count": null, "id": "ef8dd628", "metadata": {}, "outputs": [], "source": [ "#Aquí va su código" ] }, { "cell_type": "markdown", "id": "7abaa420", "metadata": {}, "source": [ "# 2.\n", "Determine si un número `n` entero ingresado por el usuario es un [palíndromo](https://en.wikipedia.org/wiki/Palindromic_number), (Retorne `True` en caso afirmativo y `False` en caso contrario) " ] }, { "cell_type": "code", "execution_count": null, "id": "f4074c2f", "metadata": {}, "outputs": [], "source": [ "#Aquí va su código" ] }, { "cell_type": "markdown", "id": "f5ef6ce7", "metadata": {}, "source": [ "# 3.\n", "Una característica útil de las funciones definidas por el usuario es la **recursion**, la capacidad de una función de llamarse a sí misma. Por ejemplo, considere la siguiente definición del factorial $n!$ de un entero positivo $n$:\n", "\n", "$$n! = \n", "\\begin{cases} \n", "1 & \\text{si } n = 1, \\\\ \n", "n \\times (n - 1)! & \\text{si } n > 1.\n", "\\end{cases}$$\n", "\n", "Esta constituye una definición completa del factorial que nos permite calcular el valor de $n!$ para cualquier entero positivo. Podemos emplear esta definición directamente para crear una función en Python para factoriales, así:\n", "\n", "\n", "\n", "```python\n", "def factorial(n):\n", " if n == 1:\n", " return 1\n", " else:\n", " return n * factorial(n-1)\n", "```\n", "- Los números de Catalan $C_n$ aparecieron previamente en clase. La definición dada allí puede reescribirse como:\n", "\n", "$$C_n = \n", "\\begin{cases} \n", "1 & \\text{si } n = 0, \\\\\n", "\\frac{4n - 2}{n + 1} \\, C_{n-1} & \\text{si } n > 0.\n", "\\end{cases}$$\n", "\n", "Escriba una función en Python, usando recursión, que calcule $C_n$. Utilice su función para calcular e imprimir $C_{50}$.\n", "\n", "- Euclides demostró que el máximo común divisor $g(m, n)$ de dos enteros no negativos $m$ y $n$ satisface:\n", "\n", "$$g(m, n) =\n", "\\begin{cases} \n", "m & \\text{si } n = 0, \\\\\n", "g(n, m \\bmod n) & \\text{si } n > 0.\n", "\\end{cases}$$\n", "\n", "Escriba una función en Python $g(m, n)$ que emplee recursión para calcular el máximo común divisor de $m$ y $n$ usando esta fórmula. Use su función para calcular e imprimir el máximo común divisor de 108 y 192.\n" ] }, { "cell_type": "code", "execution_count": null, "id": "7f8fb186", "metadata": {}, "outputs": [], "source": [ "#Aquí va su código" ] }, { "cell_type": "markdown", "id": "7f0f66c8", "metadata": {}, "source": [ "# 4.\n", "Un problema conocido de mecánica cuántica involucra una partícula de masa $m$ que encuentra un escalón de potencial unidimensional, como se muestra en la figura:\n", "\n", "![image.png]()\n", "\n", "\n", "La partícula con energía cinética inicial $E$ y vector de onda $k_1 = \\sqrt{2mE}/\\hbar$ entra desde la izquierda y encuentra un salto abrupto en la energía potencial de altura $V$ en la posición $x = 0$. Resolviendo la ecuación de Schrödinger, se puede demostrar que cuando $E > V$ la partícula puede:\n", "- Pasar el escalón, en cuyo caso tendrá una energía cinética menor $E - V$ al otro lado y un vector de onda correspondientemente más pequeño $k_2 = \\sqrt{2m(E - V)}/\\hbar$\n", "- Ser reflejada, manteniendo toda su energía cinética y vector de onda sin cambios, pero moviéndose en dirección opuesta.\n", "\n", "\n", "Las probabilidades $T$ y $R$ para transmisión y reflexión están dadas por:\n", "\n", "$$T = \\frac{4k_1k_2}{(k_1 + k_2)^2}, \\quad R = \\left(\\frac{k_1 - k_2}{k_1 + k_2}\\right)^2.$$\n", "\n", "Consideremos una partícula con masa igual a la del electrón $m = 9.11 \\times 10^{-31} \\, \\text{kg}$ y energía $10 \\, \\text{eV}$ que encuentra un escalón de potencial de altura $9 \\, \\text{eV}$. Escriba un programa en Python para calcular e imprimir las probabilidades de transmisión y reflexión usando las fórmulas anteriores.\n" ] }, { "cell_type": "code", "execution_count": null, "id": "f231cf33", "metadata": {}, "outputs": [], "source": [ "#Aquí va su código" ] }, { "cell_type": "markdown", "id": "34155057", "metadata": {}, "source": [ "# 5.\n", "La órbita en el espacio de un cuerpo alrededor de otro, como un planeta alrededor del Sol, no necesita ser circular. En general toma la forma de una elipse, con el cuerpo a veces más cerca y a veces más lejos. Si se conocen la distancia $\\ell_{1}$ del acercamiento más próximo que hace un planeta al Sol, llamado perihelio, y su velocidad lineal $v_{1}$ en el perihelio, entonces cualquier otra propiedad de la órbita puede calcularse a partir de estos dos datos de la siguiente manera.\n", "La segunda ley de Kepler nos dice que la distancia $\\ell_{2}$ y velocidad $v_{2}$ del planeta en su punto más distante, o afelio, satisfacen $\\ell_{2}v_{2}=\\ell_{1}v_{1}$. Al mismo tiempo, la energía total, cinética más gravitacional, de un planeta con velocidad $v$ y distancia $r$ del Sol está dada por\n", " $$\n", " E = \\tfrac{1}{2}mv^{2} - G\\frac{mM}{r},\n", " $$\n", " donde $m$ es la masa del planeta, $M=1.9891\\times 10^{30}\\,\\mathrm{kg}$ es la masa del Sol, y $G=6.6738\\times 10^{-11}\\,\\mathrm{m}^{3}\\,\\mathrm{kg}^{-1}\\,\\mathrm{s}^{-2}$ es la constante gravitacional de Newton. Dado que la energía debe conservarse, se llega a que $v_{2}$ es la raíz más pequeña de la ecuación cuadrática\n", " $$\n", " v_{2}^{2} - \\frac{2GM}{v_{1}\\ell_{1}}v_{2} - \\left[v_{1}^{2} - \\frac{2GM}{\\ell_{1}}\\right] = 0.\n", " $$\n", " Una vez que se tiene $v_{2}$, podemos calcular $\\ell_{2}$ usando la relación $\\ell_{2}=\\ell_{1}v_{1}/v_{2}$.\n", "\n", "- Dados los valores de $v_{1}$, $\\ell_{1}$, y $\\ell_{2}$, otros parámetros de la órbita vienen dados por fórmulas simples que pueden derivarse de las leyes de Kepler y del hecho de que la órbita es una elipse:\n", "$$\n", " \\text{Semieje mayor:} \\quad a = \\tfrac{1}{2}(\\ell_{1}+\\ell_{2}), \n", "$$\n", "$$\n", " \\text{Semieje menor:} \\quad b = \\sqrt{\\ell_{1}\\ell_{2}}, \n", "$$\n", "$$\n", " \\text{Periodo orbital:} \\quad T = \\frac{2\\pi ab}{\\ell_{1}v_{1}}, \n", "$$\n", "$$\n", " \\text{Excentricidad orbital:} \\quad e = \\frac{\\ell_{2}-\\ell_{1}}{\\ell_{2}+\\ell_{1}}.\n", "$$\n", "\n", "Escriba un programa que solicite al usuario ingresar la distancia al Sol y la velocidad en el perihelio, luego calcule e imprima las cantidades $\\ell_{2}$, $v_{2}$, $T$, y $e$.\n", "\n", "- Pruebe su programa calculando las propiedades de las órbitas de la Tierra (para la cual $\\ell_{1}=1.4710\\times 10^{11}\\,\\mathrm{m}$ y $v_{1}=3.0287\\times 10^{4}\\,\\mathrm{m}\\,\\mathrm{s}^{-1}$) y del cometa Halley ($\\ell_{1}=8.7830\\times 10^{10}\\,\\mathrm{m}$ y $v_{1}=5.4529\\times 10^{4}\\,\\mathrm{m}\\,\\mathrm{s}^{-1}$). Entre otras cosas, debería encontrar que el período orbital de la Tierra es un año y el del cometa Halley es alrededor de 76 años.\n" ] }, { "cell_type": "code", "execution_count": null, "id": "2b8f351c", "metadata": {}, "outputs": [], "source": [ "#Aquí va su código" ] }, { "cell_type": "markdown", "id": "cd4ec81e", "metadata": {}, "source": [ "# 6. \n", "Un proyectil es lanzado desde una altura inicial $y_0 = 0$ con una velocidad inicial de $4.0\\, \\text{m/s}$ a $45^\\circ$ respecto a la horizontal. Graficar la trayectoria del proyectil en su plano de movimiento (considerando el eje $x$ paralelo a la horizontal y el origen en la posición inicial del proyectil) desde el punto de lanzamiento hasta el punto donde impacta el suelo (asumiendo un terreno plano). La gráfica debe incluir etiquetas en los ejes y un título. Recuerde que las ecuaciones del movimiento parabólico están dadas por\n", "\n", "$$\n", "\\text{Posición horizontal:} \\quad x(t) = v_{0x} t = v_0 \\cos\\theta \\cdot t \n", "$$\n", "$$\n", "\\text{Posición vertical:} \\quad y(t) = y_0 + v_{0y} t - \\frac{1}{2}gt^2 = y_0 + v_0 \\sin\\theta \\cdot t - \\frac{1}{2}gt^2 \n", "$$\n", "$$\n", "\\text{Velocidad horizontal:} \\quad v_x(t) = v_{0x} =v_0 \\cos \\theta= \\text{constante} \n", "$$\n", "$$\n", "\\text{Velocidad vertical:} \\quad v_y(t) = v_{0y} - gt = v_0 \\sin\\theta - gt\n", "$$" ] }, { "cell_type": "code", "execution_count": null, "id": "74e3d972", "metadata": {}, "outputs": [], "source": [ "#Aquí va su código" ] }, { "cell_type": "markdown", "id": "316251cc", "metadata": {}, "source": [ "# 7.\n", "\n", "Los polinomios de Legendre son de gran importancia en física, especialmente en la solución de la ecuación de Laplace en coordenadas esféricas. Son fundamentales en la expansión en armónicos esféricos, lo que los hace esenciales en problemas de mecánica cuántica y electromagnetismo. Cada polinomio de Legendre $P_n(x)$ es un polinomio de grado $n$. Este puede ser expresado usando la Fórmula de Rodrigues:\n", " \n", "$$\n", "P_n (x)=\\frac{1}{n!\\ 2^n} \\frac{d^n}{dx^n} (x^2-1)^n, \\ \\ n \\in \\mathbb{Z^{+}}+\\{0\\}\n", "$$\n", " \n", "- Utilizando la fórmula de Rodrigues halle $P_0(x)$ y $P_1(x)$.\n", "- Con la fórmula de recurrencia\n", "$$\n", " P_{j+1}(x)=\\frac{(2j+1)x P_j (x)-jP_{j-1}(x)}{j+1},\n", "$$\n", "elabore un código que permita calcular $P_n(x)$ para $n\\geq2$.\n", "- En una misma gráfica muestre $P_n(x)$ para $1\\leq n\\leq5$.\n" ] }, { "cell_type": "code", "execution_count": null, "id": "4a015586", "metadata": {}, "outputs": [], "source": [ "#Aquí va su código" ] } ], "metadata": { "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.12.6" } }, "nbformat": 4, "nbformat_minor": 5 }