forked from FlorisCalkoen/CoastalCodebook
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* Add files via upload * updating figure * add initialization * formatting * coastal kernel --------- Co-authored-by: floriscalkoen <[email protected]>
- Loading branch information
1 parent
93600d5
commit 62f54ff
Showing
2 changed files
with
843 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,287 @@ | ||
{ | ||
"cells": [ | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"# Coastal Systems Notebook 2c: Theory Equilibrium tide\n", | ||
"\n", | ||
"In Chapter 3 of the book and slides, we learned that the tide is generated through the interplay between gravitational attraction forces in the Earth-Moon and Earth-Sun systems respectively. In this notebook we will explore these concepts in a more interactive way, with some exercises, visualizations, and code. We will not repeat the whole theory, however, so make sure you have followed the lectures for this week and read the relevant pages in Chapter 3 of the book.\n", | ||
"\n", | ||
"We will explore the different aspects of the tide through this Jupyter notebook and use python to create figures, make computations, and analyse data. So, please make sure you activate the coastal environment before running the notebook. Then run the cell below, where we import the packages used in this notebook." | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"metadata": { | ||
"tags": [] | ||
}, | ||
"outputs": [], | ||
"source": [ | ||
"import pathlib\n", | ||
"import sys\n", | ||
"\n", | ||
"from warnings import filterwarnings\n", | ||
"import ipywidgets as widgets\n", | ||
"import matplotlib.patches as mpatches\n", | ||
"import matplotlib.pyplot as plt\n", | ||
"import numpy as np\n", | ||
"import pandas as pd\n", | ||
"\n", | ||
"cwd = pathlib.Path().resolve()\n", | ||
"proj_dir = cwd.parent # this is the root of the CoastalCodeBook" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"<br><br>\n", | ||
"\n", | ||
"First we will have a look at the generation of the tide. To start, we are going to look at the gravitational forces between the Earth, Moon, and Sun. As you have learned, the tide is generated by the so-called <b>differential pull</b>, meaning the difference in gravitational pull on water masses at different locations on the Earth as compared to the gravitational pull for the centre of the earth. To make calculations, we first need a function that can compute the gravitational pull between two celestial bodies (e.g. the Earth and Moon)." | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"metadata": { | ||
"tags": [] | ||
}, | ||
"outputs": [], | ||
"source": [ | ||
"### Functions\n", | ||
"def grav_pull(m1, m2, d):\n", | ||
" \"\"\"\n", | ||
" This function calculates the gravitational pull between two celestial bodies using Newton's law of universal gravitation.\n", | ||
"\n", | ||
" Parameters:\n", | ||
" m1 (float): mass of the first body in kg.\n", | ||
" m2 (float): mass of the second body in kg.\n", | ||
" d (float): distance between the two bodies in meters.\n", | ||
"\n", | ||
" Returns:\n", | ||
" g_pull (float): the gravitational pull between the two bodies in g\n", | ||
"\n", | ||
" \"\"\"\n", | ||
" G = 6.67408e-11 # universal gravitational constant\n", | ||
" g = 9.81 # gravitational acceleration on the Earth\n", | ||
" g_pull = G * (m1 * m2) / d**2 # gravitational pull between two bodies\n", | ||
" \n", | ||
" # we divide the GP by g, so we get the gravitational pull in terms of g\n", | ||
" return g_pull / g \n" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"<br><br>\n", | ||
"The above function computes the gravitational pull between two celestial bodies. We can now use it to compute the forces between the Earth and the Sun or Moon. \n", | ||
"For this notebook, we will compute the forces that are working on 1kg of Earth mass, to keep it simple. Hence, the mass we will fill in for the Earth will be 1kg. Also, we will express the forces in terms of the Earths own gravitational acceleration ($g$), which makes it easier to compare the magnitudes with each other. Run the code cell below to compute the gravitational pull of the moon and sun on the Earth. Compare the values to the ones in the book (section 3.7.2, pp.122-123). Are they equal? " | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"metadata": { | ||
"tags": [] | ||
}, | ||
"outputs": [], | ||
"source": [ | ||
"## Properties of Earth, Moon, and Sun\n", | ||
"m_earth = 1 # mass of the earth in kg (we use 1 to compute the gravitational pull per kg of earth mass)\n", | ||
"m_sun = 1.99e30 # mass of the sun in kg\n", | ||
"m_moon = 7.35e22 # mass of the moon in kg\n", | ||
"d_sun = 1.5e11 # distance between the centers of the sun and earth in meters\n", | ||
"d_moon = 3.84e8 # distance between the centers of the moon and earth in meters\n", | ||
"r = 6.37e6 # radius of the Earth in meters\n", | ||
"\n", | ||
"# Now we compute the gravitational pull and print them\n", | ||
"gp_sun = grav_pull(m_earth, m_sun, d_sun)\n", | ||
"gp_moon = grav_pull(m_earth, m_moon, d_moon)\n", | ||
"\n", | ||
"# Print out results\n", | ||
"print(\"Gravitational pull from the Sun on the center of Earth: %.2E g\" % gp_sun)\n", | ||
"print(\"Gravitational pull from the Moon on the center of Earth: %.2E g\" % gp_moon)" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"<br><br>\n", | ||
"As we can see, the gravitational pull of the sun is about two orders of magnitude larger than that of the moon, and both are much smaller than $g$. Yet, we know that these forces are somehow responsible for tidal ranges of multiple meters, and that the moon is actually responsible for about 70% of these tides. How come? As we can see in the formula, the gravitational pull is strongly dependent on the distance between the two celestial bodies. Moreover, since the Earth is a sphere, different locations on the Earth's surface will experience subtle differences in the gravitational pull, as the distance to the Sun/Moon varies slightly over the Earths surface. \n", | ||
"\n", | ||
"Let's use the above function to compute the gravitational pull from the sun at 8 different locations around the Earth's surface (A-H, see the figure below).\n", | ||
"\n", | ||
"![earth_positions](./figures/02_earth_sun_gp.png)" | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"metadata": { | ||
"tags": [] | ||
}, | ||
"outputs": [], | ||
"source": [ | ||
"# First we compute the distance between the center of the sun and each position on Earth\n", | ||
"distance = d_sun # switch to d_moon to change the computation to moon\n", | ||
"distances = {\n", | ||
" \"X\": distance,\n", | ||
" \"A\": np.sqrt(r**2 + distance**2), # Same as point E\n", | ||
" \"B\": np.sqrt(\n", | ||
" (r * np.sin(45 * np.pi / 180)) ** 2\n", | ||
" + (distance - r * np.cos(45 * np.pi / 180)) ** 2\n", | ||
" ), # Same as point D\n", | ||
" \"C\": distance - r,\n", | ||
" \"D\": np.sqrt(\n", | ||
" (r * np.sin(45 * np.pi / 180)) ** 2\n", | ||
" + (distance - r * np.cos(45 * np.pi / 180)) ** 2\n", | ||
" ), # Same as point B\n", | ||
" \"E\": np.sqrt(r**2 + distance**2), # Same as point A\n", | ||
" \"F\": np.sqrt(\n", | ||
" (r * np.sin(45 * np.pi / 180)) ** 2\n", | ||
" + (r * np.cos(45 * np.pi / 180) + distance) ** 2\n", | ||
" ), # Same as point H\n", | ||
" \"G\": distance + r,\n", | ||
" \"H\": np.sqrt(\n", | ||
" (r * np.sin(45 * np.pi / 180)) ** 2\n", | ||
" + (r * np.cos(45 * np.pi / 180) + distance) ** 2\n", | ||
" ), # Same as point F\n", | ||
"}\n", | ||
"\n", | ||
"# Now compute the gravitational pull for each point.\n", | ||
"gp = {}\n", | ||
"for pos in distances:\n", | ||
" gp[pos] = grav_pull(m_earth, m_sun, distances[pos])\n", | ||
" print(\"Gravitational pull at position %s: %.5E g\" % (pos, gp[pos]) )" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"<br><br>\n", | ||
"As we can see, the differences are very subtle (in the order of 10^-7 $g$). We also know that the gravitational pull is responsible for the Earth's rotation around the Sun. That would imply, however, that the rotation of the Earth varies over its body, along with the gravitational pull. Yet, we know that the Earth rotates around the Sun as a whole. Apparently, the Earth compensates for these subtle differences in gravitational pull so it can rotate around the Sun as one body. The water masses on the surface of the solid Earth, however, can move around and are not as fixed and rigid as the solid land masses. So, while the solid masses of the Earth remain virtually unchanged, its water masses are moved around by these subtle differences in gravitational pull.\n", | ||
"\n", | ||
"So, let's visualize these differences. Earth's rotation is based on the gravitational pull that acts on its center, hence this will be our **reference pull**. For the other locations around the Earth, we will compute the difference from the reference pull, by subtracting the reference pull from the gravitational pull at each location. If we do this with the actual forces we computed above, we won't see the difference since they are very small. Therefore, we will visualize the forces out of proportion, i.e., we exaggerate the difference. Next to the difference in magnitude, there are also slight differences in the direction of the forces at different positions, as each force is directed towards the centre of the Sun/Moon. We will also visualize these out of proportion, so we can actually see the difference. Run the code cell below to get a visualization of the forces we talked about above." | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"metadata": { | ||
"tags": [] | ||
}, | ||
"outputs": [], | ||
"source": [ | ||
"from initialize.Tide_Initialize import plot_grav_pull\n", | ||
"\n", | ||
"plot_grav_pull()" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"<br>\n", | ||
"The red arrows indicate the gravitational pull at each individual location around Earth's surface. The black lined, transparent arrows represent the reference pull and are all equal to the black arrow at the center (X). If we subtract the black arrows from the red arrows at each location, we end up with the green arrows in the second plot, which we call the differential pull. Do the green arrows already give you an indication of the shape of the tides?\n", | ||
"\n", | ||
"Now, let's compute the actual differential pull at location C, for both the Earth-Sun and the Earth-Moon system. You can also check this calculation written out on page 124 of the book (Ch. 3.7.3, eq 3.29/3.30). Note that in the book an approximation is used, hence the values are slightly different." | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"metadata": { | ||
"tags": [] | ||
}, | ||
"outputs": [], | ||
"source": [ | ||
"dp_C_moon = grav_pull(m_earth, m_moon, d_moon - r) - grav_pull(m_earth, m_moon, d_moon)\n", | ||
"dp_C_sun = grav_pull(m_earth, m_sun, distances[\"C\"]) - grav_pull(m_earth, m_sun, d_sun)\n", | ||
"\n", | ||
"print(\"Differential pull at C due to the moon: %E g\" % dp_C_moon)\n", | ||
"print(\"Differential pull at C due to the sun : %E g\" % dp_C_sun)\n", | ||
"print(\"Percentage of the total differential pull associated to the moon: %.1f%%\"\n", | ||
" % (dp_C_moon / (dp_C_sun + dp_C_moon) * 100))\n", | ||
"print(\"Percentage of the total differential pull associated to the sun : %.1f%%\"\n", | ||
" % (dp_C_sun / (dp_C_sun + dp_C_moon) * 100))" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"<br><br>\n", | ||
"Now we can see that the differential pull is actually larger for the Moon than for the Sun. Can you explain why this is the case (hint: look at equations 3.29/3.30 on page 124 of the book and consider the effect of the distance between the earth and the sun and the earth and the moon)?\n", | ||
"\n", | ||
"Still, both are several orders of magnitude smaller than the Earth's own attraction towards its centre, $g$. That means, that the component of the differential pull that is in line with Earth's center (perpendicular to the Earth's surface) can be neglected, since its magnitude is negligible compared to $g$, and will therefore not make a noticable difference. The only thing we are left with then, are the *tangential components* of the differential pull. These are the forces that generate the tide by moving the water around the surface of the Earth. This results in the two bulges of water at either side of the Earth, in line with the Sun/Moon. Hence, if the Sun and Moon are aligned (full moon and new moon), the forces enhance each other and we get a spring tide (larger tidal range). On the other hand, if they are perpendicular to each other (1st and 3rd quarter moon), the lunar and solar differential pull work against each other and we get a neap tide. In the figure below you can play around with different constellations of the Moon and Sun, to see what the effect is on the total tidal shape.\n", | ||
"\n", | ||
"The code below visualizes this concept. In the plot, the sun is fixed to the right side of the Earth (see also Figure 3.21 in the book). You can adjust the position of the Moon by setting its angle relative to the position of the sun. So if you set it at 90, the moon will be in a position 90 degrees counterclock-wise from the sun (i.e., they will be perpendicular). In short, this means:\n", | ||
"\n", | ||
"|Angle | Position |\n", | ||
"|:-:|-|\n", | ||
"| 0 | New moon | \n", | ||
"| 90 | 1st quarter moon | \n", | ||
"| 180 | Full moon |\n", | ||
"| 270 | 3rd quarter moon |\n", | ||
"\n", | ||
"Note: the figure only plots the correct total tide for intervals of 90 degrees (0, 90, 180, or 270 degrees)" | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"metadata": { | ||
"tags": [] | ||
}, | ||
"outputs": [], | ||
"source": [ | ||
"# Note: the figure only plots the correct total tide for intervals of 90 degrees (0, 90, 180, or 270 degrees)\n", | ||
"\n", | ||
"angle_moon = 180 # Adjust here the position of the moon\n", | ||
"angle_sun = 0 # Fixed at 0, dont change\n", | ||
"\n", | ||
"from initialize.Tide_Initialize import plot_tide_diagram\n", | ||
"\n", | ||
"plot_tide_diagram(angle_sun, angle_moon)" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"By adjusting the above figure, we can see how the alignment of the earth, moon, and sun influences the tide experienced by a given point on earth. If the tidal bulges align, we get a higher high tide, \"spring tide\", but if the tidal bulges are out of alignment, we have a reduced high tide, the \"neap tide\". The same holds for low waters: low tides are lower when everything is aligned (spring tide), and the low tides at neap are not quite as low." | ||
] | ||
} | ||
], | ||
"metadata": { | ||
"kernelspec": { | ||
"display_name": "Python 3 (ipykernel)", | ||
"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.11.7" | ||
}, | ||
"vscode": { | ||
"interpreter": { | ||
"hash": "c6737bd8f99d83243aad1fcf161035ff3a42d7dc5e7fc6b52402807c327bcf3f" | ||
} | ||
} | ||
}, | ||
"nbformat": 4, | ||
"nbformat_minor": 4 | ||
} |
Oops, something went wrong.