Differences between revisions 16 and 36 (spanning 20 versions)
Revision 16 as of 2013-12-19 13:09:36
Size: 4054
Editor: anonymous
Comment:
Revision 36 as of 2014-09-13 14:56:24
Size: 4118
Editor: CarstenEden
Comment:
Deletions are marked like this. Additions are marked like this.
Line 1: Line 1:
=== Python Ocean Model (pyOM) === ## page was renamed from TO/pyOM
'''
Python Ocean Model (pyOM)'''
Line 5: Line 7:
A numerical Ocean Circulation Model  to configure and to integrate idealized numerical simulations with an easy to use python (GUI) and a standard Fortran90 frontend. A numerical Ocean Circulation Model to configure and to integrate idealized numerical simulations with python (GUI) and a standard Fortran90 frontend.
Line 17: Line 19:
 * Neglecting of thermodynamic equation  * Fully incompressible thermodynamics
Line 37: Line 39:
=== Installation ===
1. Make a new directory where the model code should be placed. Name the directory as dir(for instance)
=== Installation (only for students of UHH) ===
Line 40: Line 41:
2. Get into the remote server thunder1 (Only for students in UHH) 1. Login at the remote server thunder1
Line 45: Line 46:
3. Once you log in, find u241155 (Prof. Eden directory)
2. Once you logged in, make a new directory where the model code should be placed. Name the directory as dir (for instance)


3. Find home directory of u241155
Line 50: Line 55:
and copy this directory to your new directory to get src file for compiling. and copy the following directory to your new directory to get src files for compiling
Line 53: Line 58:
cp home/zmaw/u241155/pyOM_thunder cp home/zmaw/u241155/pyOM_thunder <dir>
Line 55: Line 60:
4. Then, by different Fortran subroutines and Python methods in the model configuration
Line 57: Line 61:
environments in specific realizations can be shown. 4. Now all model code and Fortran subroutines and Python methods for the model configuration can be found in <dir>
Line 59: Line 63:
List of Directories List of Directories in <dir>
Line 73: Line 77:
== Model configurations: ==
'''This routine/method is called only once before allocating the model variables. '''
== Model Configurations ==
'''Allocating the model variables'''
Line 76: Line 80:
* ''set_parameter'' :sets all important fixed model parameter * set_parameter :sets all important fixed model parameter
Line 78: Line 82:
'''This routine/method is only called once during the model setup. ''' '''In the model setup'''
Line 86: Line 90:
'''This routine/method is called for each time step. ''' '''For each time step'''
Line 97: Line 101:
=== Kelvin-Helmholtz Instabilities More === === Kelvin-Helmholtz Instability ===
[[https://wiki.zmaw.de/ifm/TO/pyOM/Kelvin-Helmholtz%20Instability|Content Here]]
Line 101: Line 107:
=== Rayleigh–Bénard Convection ===
[[https://wiki.zmaw.de/ifm/TO/pyOM/Rayleigh–Bénard%20Convection|Content Here]]

{{{
rayleigh.py
}}}
Line 102: Line 114:
[[https://wiki.zmaw.de/ifm/TO/pyOM/Rayleigh–Bénard%20Convection|Content Here]]
Line 106: Line 120:
[[https://wiki.zmaw.de/ifm/TO/pyOM/Eddy-driven%20Zonal%20Jets|Content Here]]
Line 110: Line 126:
[[https://wiki.zmaw.de/ifm/TO/pyOM/Thermohaline%20Circulation|Content Here]]
Line 113: Line 131:
=== Meridional Overturning Circulation === === Southern Ocean Circulation ===
[[https://wiki.zmaw.de/ifm/TO/pyOM/Southern%20Ocean%20Circulation|Content Here]]
Line 118: Line 138:
[[https://wiki.zmaw.de/ifm/TO/pyOM/ENSO%20Response|Content Here]]
Line 121: Line 143:
=== Equatorial Wave === === Equatorial Waves ===
[[https://wiki.zmaw.de/ifm/TO/pyOM/Equatorial%20Waves|Content Here]]
Line 125: Line 149:
=== Significant Wave Height (Rayleigh distribution) ===
{{{
rayleigh.py
}}}
=== Isopycnal Diffusion Problem ===
=== Isopycnal Diffusion ===
[[https://wiki.zmaw.de/ifm/TO/pyOM/Isopycnal%20Diffusion|Content Here]]
Line 133: Line 155:
== //pyOM (Python Ocean Model) ==
is a numerical ocean circulation model with an easy to use python (GUI) and a standard

Fortran90 frontend. In both cases, the dynamical core of the model is written in Fortran90.

Some features are

 * surface pressure or implicit linear free surface formulation
 * nonhydrostatic version
 * 1D domain decomposition for parallel computation
 * Documentation available as [[attachment:pyOM.pdf|pdf file]]
Line 148: Line 158:

Source code [[attachment:pyOM_1.1.tar.gz]]

Python Ocean Model (pyOM)

Introduction

A numerical Ocean Circulation Model to configure and to integrate idealized numerical simulations with python (GUI) and a standard Fortran90 frontend.

In both cases, the dynamical core of the model is written in Fortran90.

Features

  • Surface pressure or implicit linear free surface formulation
  • Non-hydrostatic version
  • 1D domain decomposition for parallel computation

Assumptions and Approximations

  • Fully incompressible thermodynamics
  • Boussinesq approximation
    • ( Volume conservation and Buoyancy perturbations in gravity term)
  • Cartesian and beta-plane approximation

Resources

  • Model Manual Here

  • Ocean Model Source Code Here

Prerequisites and Installation

Prerequisites

1. Unix system

2. Fortran 90 compiler

3. Fortran and Python front ends NetCDF-library

Installation (only for students of UHH)

1. Login at the remote server thunder1

ssh thunder1

2. Once you logged in, make a new directory where the model code should be placed. Name the directory as dir (for instance)

3. Find home directory of u241155

finger u241155

and copy the following directory to your new directory to get src files for compiling

cp home/zmaw/u241155/pyOM_thunder <dir>

4. Now all model code and Fortran subroutines and Python methods for the model configuration can be found in <dir>

List of Directories in <dir>

* ./for_src: Fortran subroutines used by both Fortran and Python front end

* ./py_src: Python modules and extension modules

* ./py_config: Configuration examples of Python front end

* ./for_config: Configuration examples for Fortran front end

* ./doc: contains documentation

* ./bin: contains executable of Fortran front end after successful compilation

Model Configurations

Allocating the model variables

* set_parameter :sets all important fixed model parameter

In the model setup

* set_coriolis : sets the (vertical and horizontal) Coriolis parameter.

* initial_conditions :sets the initial conditions.

* topography : set the topography.

For each time step

* boundary_conditions : set the surface boundary conditions.

* restoring_zones : set the interior sources and sinks for density.

* momentum_restoring_zones : set the interior sources and sinks for momentum.

* tracer_sources : set interior sources and sinks for the passive tracer. Also sets the surface boundary conditions.

Sample Configurations

Kelvin-Helmholtz Instability

Content Here

kelvin_helm1.py

Rayleigh–Bénard Convection

Content Here

rayleigh.py

Eady's Baroclinic Instability

Content Here

eady1.py / eady2.py

Eddy-driven zonal jets

Content Here

jets1.py

Thermohaline Circulation

Content Here

THC1.py

Southern Ocean Circulation

Content Here

acc1.py

ENSO Response

Content Here

enso1.py

Equatorial Waves

Content Here

eq_waves1.py

Isopycnal Diffusion

Content Here

isopyc_test1.py

An example of the python GUI for Eady's baroclinic instability case is shown below.

pyOM.png

IfmWiki: TO/outdated/pyOM (last edited 2014-09-13 14:56:24 by CarstenEden)