Skip to content

Commit

Permalink
MOM6 Angle Calculation (#34)
Browse files Browse the repository at this point in the history
* Start of Angle Calc

* Blacl

* Rand

* Rand

* Keith Method Step 1, add t-point boundaries to coords()

* Start implementing alternative angles approaches...

* Set up rotational method framework

* Add h, t, and change default mom6_angle_calc to regional

* black

* Fred Angle Calc

* Black

* Black 2

* Keith Method

* Tidal Rotational Methods Completed

* Finish rotational methods for velocity_tracers

* Combine the grid_rotation_calc for fred_pseudo and mom6 general (keiths)

* Move rotation/angle functions to a different file

* Doesn't make sense to use rot method in expt because the regrid methods are in segment right now. Something to discuss and then add

* Clean up the keith method to use the regridding func add_secondary_dimension

* Add angle_calc to docs

* Main Page Link for now...

* Start testing setup

* Change func name for consistency

* Minor Commenting

* Minor Commenting

* Black

* Redo Auto Docs

* Start of testing

* Test until curved grid generation comes in

* Bug

* Test_Rotation Changes

* Adjust Docker Path

* Testing Framework Trial 1

* Docker Docs

* Test Cleaning

* Change name of docker docs

* Adjust docker image to crocodile one

* Step 1: Setup Framework Tidal Regridding Nans/LandMask BugFix

* Finish setting up masking framework

* Revert "Finish setting up masking framework"

This reverts commit 9287030.

* Revert "Step 1: Setup Framework Tidal Regridding Nans/LandMask BugFix"

This reverts commit a2b961a.

* respond to alper comments
  • Loading branch information
manishvenu authored Dec 19, 2024
1 parent cc957cf commit f7df20c
Show file tree
Hide file tree
Showing 16 changed files with 1,247 additions and 520 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/testing.yml
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ jobs:
testing:
needs: formatting
runs-on: ubuntu-latest
container: ghcr.io/cosima/regional-test-env:updated
container: ghcr.io/crocodile-cesm/crocodile_rm6_test_env:latest
defaults:
run:
shell: bash -el {0}
Expand Down
45 changes: 45 additions & 0 deletions docs/angle_calc.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
# Rotation and angle calculation in RM6 using MOM6 Angle Calculation
This document explains the implementation of MOM6 angle calculation in RM6, which is the process by which RM6 calculates the angle of curved hgrids.

**Issue:** MOM6 doesn't actually use the user-provided "angle_dx" field in input hgrids, but internally calculates the angle.

**Solution:** To accomodate this fact, when we rotate our boundary conditions, we implemented MOM6 angle calculation in a file called "rotation.py", and adjusted functions where we regrid the boundary conditions.


## MOM6 process of angle calculation (T-point only)
1. Calculate pi/4rads / 180 degrees = Gives a 1/4 conversion of degrees to radians. I.E. multiplying an angle in degrees by this gives the conversion to radians at 1/4 the value.
2. Figure out the longitudunal extent of our domain, or periodic range of longitudes. For global cases it is len_lon = 360, for our regional cases it is given by the hgrid.
3. At each point on our hgrid, we find the q-point to the top left, bottom left, bottom right, top right. We adjust each of these longitudes to be in the range of len_lon around the point itself. (module_around_point)
4. We then find the lon_scale, which is the "trigonometric scaling factor converting changes in longitude to equivalent distances in latitudes". Whatever that actually means is we add the latitude of all four of these points from part 3 and basically average it and convert to radians. We then take the cosine of it. As I understand it, it's a conversion of longitude to equivalent latitude distance.
5. Then we calculate the angle. This is a simple arctan2 so y/x.
1. The "y" component is the addition of the difference between the diagonals in longitude (adjusted by modulo_around_point in step 3) multiplied by the lon_scale, which is our conversion to latitude.
2. The "x" component is the same addition of differences in latitude.
3. Thus, given the same units, we can call arctan to get the angle in degrees


## Problem
MOM6 only calculates the angle at t-points. For boundary rotation, we need the angle at the boundary, which is q/u/v points. Because we need the points to the left, right, top, and bottom of the point, this method won't work for the boundary.


# Convert this method to boundary angles - 3 Options
1. **GIVEN_ANGLE**: Don't calculate the angle and use the user-provided field in the hgrid called "angle_dx"
2. **EXPAND_GRID**: Calculate another boundary row/column points around the hgrid using simple difference techniques. Use the new points to calculate the angle at the boundaries. This works because we can now access the four points needed to calculate the angle, where previously at boundaries we would be missing at least two.


## Code Description

Most calculation code is implemented in the rotation.py script, and the functional uses are in regrid_velocity_tracers and regrid_tides functions in the segment class of RM6.


### Calculation Code (rotation.py)
1. **Rotational Method Definition**: Rotational Methods are defined in the enum class "Rotational Method" in rotation.py.
2. **MOM6 Angle Calculation**: The method is implemented in "mom6_angle_calculation_method" in rotation.py and the direct t-point angle calculation is "initialize_grid_rotation_angle".
3. **Fred's Pseudo Grid Expansion**: The method to add the additional boundary row/columns is referenced in "pseudo_hgrid" functions in rotation.py

### Implementation Code (regional_mom6.py)
Both regridding functions (regrid_velocity_tracers, regrid_tides) accept a parameter called "rotational_method" which takes the Enum class defining the rotational method.

We then define each method with a bunch of if statements. Here are the processes:

1. Given angle is the default method of accepting the hgrid's angle_dx
2. Fred's method is the least code, and we simply swap out the hgrid angle with the generated one we calculate right where we do the rotation.
43 changes: 33 additions & 10 deletions docs/api.rst
Original file line number Diff line number Diff line change
@@ -1,22 +1,45 @@
===============
API reference
===============
regional\_mom6 package
======================

Submodules
----------

+++++++++++++++++++
``regional_mom6``
+++++++++++++++++++
regional\_mom6.regional\_mom6 module
------------------------------------

.. automodule:: regional_mom6.regional_mom6
:members:
:undoc-members:
:private-members:
:show-inheritance:

regional\_mom6.regridding module
--------------------------------

+++++++++++
``utils``
+++++++++++
.. automodule:: regional_mom6.regridding
:members:
:undoc-members:
:show-inheritance:

regional\_mom6.rotation module
------------------------------

.. automodule:: regional_mom6.rotation
:members:
:undoc-members:
:show-inheritance:

regional\_mom6.utils module
---------------------------

.. automodule:: regional_mom6.utils
:members:
:undoc-members:
:show-inheritance:

Module contents
---------------

.. automodule:: regional_mom6
:members:
:undoc-members:
:show-inheritance:
35 changes: 35 additions & 0 deletions docs/docker_image_dev.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
# Docker Image & Github Testing (For contributors)

RM6 uses a docker image in github actions for holding large data. It wasn't directly being used, but for downloading the curvilinear grid for testing, we are using it. This document is a list of helpful commands to work on it.

The link to the image is here:
https://github.com/COSIMA/regional-mom6/pkgs/container/regional-test-env

For local development of the image to add data to it for testing, first pull it.
```docker pull ghcr.io/cosima/regional-test-env:updated```

Then to do testing of the image, we cd into our cloned version of RM6, and run this command. It mounts our code in the /workspace directory.:
```docker run -it --rm \ -v $(pwd):/workspace \ -w /workspace \ ghcr.io/cosima/regional-test-env:updated \ /bin/bash```

The -it flag is for shell access, and the workspace stuff is to get our local code in the container.
You have to download conda, python, pip, and all that business to properly run the tests.

Getting to adding the data, you should create a folder and add both the data you want to add and a file simple called "Dockerfile". In Dockerfile, we'll get the original image, then copy the data we need to the data folder.

```
# Use the base image
FROM ghcr.io/cosima/regional-test-env:<tag>
# Copy your local file into the /data directory in the container
COPY <file> /data/<file>
```

Then, we need to build the image, tag it, and push it

```
docker build -t my-custom-image . # IN THE DIRECTORY WITH THE DOCKERFILE
docker tag my-custom-image ghcr.io/cosima/regional-test-env:<new_tag>
docker push ghcr.io/cosima/regional-test-env:<new_tag>
```


2 changes: 2 additions & 0 deletions docs/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -91,8 +91,10 @@ The bibtex entry for the paper is:
installation
demos
mom6-file-structure-primer
angle_calc
api
contributing
docker_image_dev


Indices and tables
Expand Down
Loading

0 comments on commit f7df20c

Please sign in to comment.