Differences between revisions 14 and 16 (spanning 2 versions)
Revision 14 as of 2013-11-28 16:06:28
Size: 4265
Editor: anonymous
Comment:
Revision 16 as of 2013-12-19 13:09:36
Size: 4054
Editor: anonymous
Comment:
Deletions are marked like this. Additions are marked like this.
Line 1: Line 1:
= Python Ocean Model (pyOM) = === Python Ocean Model (pyOM) ===
Line 27: Line 27:
 * Ocean Model tar-archive [[attachment:pyOM_1.1.tar.gz|Here]]  * Ocean Model Source Code [[attachment:pyOM_1.1.tar.gz|Here]]
Line 40: Line 40:
2. Extract the tar-archive containing pyOM in dir.

3.1 In Python platform, g
et into the remote server thunder1 (Only for student in UHH)
2. Get into the remote server thunder1 (Only for students in UHH)
Line 47: Line 45:
3.2 Once you log in, find u241155 (Prof. Eden directory) 3. Once you log in, find u241155 (Prof. Eden directory)
Line 52: Line 50:
and change into this directory cd u241155 to get src file for compiling. and copy this directory to your new directory to get src file for compiling.
Line 55: Line 53:
home/zmaw/u241155/pyOM_thunder cp home/zmaw/u241155/pyOM_thunder
Line 57: Line 55:
3.3 Then, by different Fortran subroutines and Python methods in the model configuration 4. Then, by different Fortran subroutines and Python methods in the model configuration
Line 59: Line 57:
{{{
Fortran and Python front end : ./py_config and ./for_config
}}}
environments in specific realizations can be shown. See list of Directories below.
environments in specific realizations can be shown.
Line 64: Line 59:
3.4 In Fortran platform (not recommended), in order to compile the file, specify the path to the location of directory of 'netcdf.inc' in the file dir/for_src/Makefile. List of Directories
Line 66: Line 61:
== List of Directories ==
Line 103: Line 97:
=== Non-Hydrostatic Configurations ===
=
=== Kelvin-Helmholtz Instabilities ====
[[Kelvin|here]]
=== Kelvin-Helmholtz Instabilities More ===
Line 110: Line 101:
=== Hydrostatic Configurations ===
=
=== Eady's Baroclinic Instability ====
=== Eady's Baroclinic Instability ===
Line 115: Line 105:
==== Eddy-driven zonal jets ==== === Eddy-driven zonal jets ===
Line 119: Line 109:
==== Thermohaline Circulation ==== === Thermohaline Circulation ===
Line 123: Line 113:
==== Meridional Overturning Circulation ==== === Meridional Overturning Circulation ===
Line 126: Line 116:
}}}
=== ENSO Response ===
{{{
enso1.py
}}}
=== Equatorial Wave ===
{{{
eq_waves1.py
}}}
=== Significant Wave Height (Rayleigh distribution) ===
{{{
rayleigh.py
}}}
=== Isopycnal Diffusion Problem ===
{{{
isopyc_test1.py

Python Ocean Model (pyOM)

Introduction

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.

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

  • Neglecting of thermodynamic equation
  • 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

1. Make a new directory where the model code should be placed. Name the directory as dir(for instance)

2. Get into the remote server thunder1 (Only for students in UHH)

ssh thunder1

3. Once you log in, find u241155 (Prof. Eden directory)

finger u241155

and copy this directory to your new directory to get src file for compiling.

cp home/zmaw/u241155/pyOM_thunder

4. Then, by different Fortran subroutines and Python methods in the model configuration

environments in specific realizations can be shown.

List of Directories

* ./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:

This routine/method is called only once before allocating the model variables.

* set_parameter :sets all important fixed model parameter

This routine/method is only called once during the model setup.

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

* initial_conditions :sets the initial conditions.

* topography : set the topography.

This routine/method is called 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 Instabilities More

kelvin_helm1.py

Eady's Baroclinic Instability

eady1.py / eady2.py

Eddy-driven zonal jets

jets1.py

Thermohaline Circulation

THC1.py

Meridional Overturning Circulation

acc1.py

ENSO Response

enso1.py

Equatorial Wave

eq_waves1.py

Significant Wave Height (Rayleigh distribution)

rayleigh.py

Isopycnal Diffusion Problem

isopyc_test1.py

//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 pdf file

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

pyOM.png

Source code pyOM_1.1.tar.gz

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