Static 2D current field

from datetime import datetime, timedelta
import numpy as np

from opendrift.readers.reader_constant_2d import Reader
from opendrift.models.oceandrift import OceanDrift

Constructing a static, rotating ocean current field,

lon, lat = np.meshgrid(np.linspace(2,6,30), np.linspace(59,62,30))
lon0 = 4
lat0 = 60.5
u = -(lat-lat0)/np.sqrt((lon-lon0)**2 + (lat-lat0)**2)
v = (lon-lon0)/np.sqrt((lon-lon0)**2 + (lat-lat0)**2)
lon = np.linspace(0,5,30)
lat = np.linspace(59,62,30)

r = Reader(x=lon, y=lat, proj4='+proj=latlong',
           array_dict = {'x_sea_water_velocity': u, 'y_sea_water_velocity': v})

o = OceanDrift(loglevel=20)
o.set_config('environment:fallback:land_binary_mask', 0)
o.add_reader(r)
o.seed_elements(lon=3, lat=60.5, number=1000, radius=30000, time=datetime.now())
o.run(duration=timedelta(hours=72))
o.animation(fast=True)
15:05:27 INFO    opendrift.models.basemodel:519: OpenDriftSimulation initialised (version 1.11.10 / v1.11.10-15-g65004d9)
15:05:27 INFO    opendrift.models.basemodel.environment:218: Adding a dynamical landmask with max. priority based on assumed maximum speed of 2.0 m/s. Adding a customised landmask may be faster...
15:05:34 INFO    opendrift.models.basemodel.environment:245: Fallback values will be used for the following variables which have no readers:
15:05:34 INFO    opendrift.models.basemodel.environment:248:    sea_surface_height: 0.000000
15:05:34 INFO    opendrift.models.basemodel.environment:248:    x_wind: 0.000000
15:05:34 INFO    opendrift.models.basemodel.environment:248:    y_wind: 0.000000
15:05:34 INFO    opendrift.models.basemodel.environment:248:    upward_sea_water_velocity: 0.000000
15:05:34 INFO    opendrift.models.basemodel.environment:248:    ocean_vertical_diffusivity: 0.000000
15:05:34 INFO    opendrift.models.basemodel.environment:248:    sea_surface_wave_significant_height: 0.000000
15:05:34 INFO    opendrift.models.basemodel.environment:248:    sea_surface_wave_stokes_drift_x_velocity: 0.000000
15:05:34 INFO    opendrift.models.basemodel.environment:248:    sea_surface_wave_stokes_drift_y_velocity: 0.000000
15:05:34 INFO    opendrift.models.basemodel.environment:248:    sea_surface_wave_period_at_variance_spectral_density_maximum: 0.000000
15:05:34 INFO    opendrift.models.basemodel.environment:248:    sea_surface_wave_mean_period_from_variance_spectral_density_second_frequency_moment: 0.000000
15:05:34 INFO    opendrift.models.basemodel.environment:248:    sea_surface_swell_wave_to_direction: 0.000000
15:05:34 INFO    opendrift.models.basemodel.environment:248:    sea_surface_swell_wave_peak_period_from_variance_spectral_density: 0.000000
15:05:34 INFO    opendrift.models.basemodel.environment:248:    sea_surface_swell_wave_significant_height: 0.000000
15:05:34 INFO    opendrift.models.basemodel.environment:248:    sea_surface_wind_wave_to_direction: 0.000000
15:05:34 INFO    opendrift.models.basemodel.environment:248:    sea_surface_wind_wave_mean_period: 0.000000
15:05:34 INFO    opendrift.models.basemodel.environment:248:    sea_surface_wind_wave_significant_height: 0.000000
15:05:34 INFO    opendrift.models.basemodel.environment:248:    surface_downward_x_stress: 0.000000
15:05:34 INFO    opendrift.models.basemodel.environment:248:    surface_downward_y_stress: 0.000000
15:05:34 INFO    opendrift.models.basemodel.environment:248:    turbulent_kinetic_energy: 0.000000
15:05:34 INFO    opendrift.models.basemodel.environment:248:    turbulent_generic_length_scale: 0.000000
15:05:34 INFO    opendrift.models.basemodel.environment:248:    ocean_mixed_layer_thickness: 50.000000
15:05:34 INFO    opendrift.models.basemodel.environment:248:    sea_floor_depth_below_sea_level: 10000.000000
15:05:34 INFO    opendrift.models.basemodel:940: Using existing reader for land_binary_mask
15:05:34 INFO    opendrift.models.basemodel:951: All points are in ocean
15:05:34 INFO    opendrift.models.basemodel:2042: 2024-07-01 15:05:27.054716 - step 1 of 72 - 1000 active elements (0 deactivated)
15:05:34 INFO    opendrift.models.basemodel:2042: 2024-07-01 16:05:27.054716 - step 2 of 72 - 1000 active elements (0 deactivated)
15:05:34 INFO    opendrift.models.basemodel:2042: 2024-07-01 17:05:27.054716 - step 3 of 72 - 1000 active elements (0 deactivated)
15:05:34 INFO    opendrift.models.basemodel:2042: 2024-07-01 18:05:27.054716 - step 4 of 72 - 1000 active elements (0 deactivated)
15:05:34 INFO    opendrift.models.basemodel:2042: 2024-07-01 19:05:27.054716 - step 5 of 72 - 1000 active elements (0 deactivated)
15:05:34 INFO    opendrift.models.basemodel:2042: 2024-07-01 20:05:27.054716 - step 6 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-01 21:05:27.054716 - step 7 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-01 22:05:27.054716 - step 8 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-01 23:05:27.054716 - step 9 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-02 00:05:27.054716 - step 10 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-02 01:05:27.054716 - step 11 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-02 02:05:27.054716 - step 12 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-02 03:05:27.054716 - step 13 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-02 04:05:27.054716 - step 14 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-02 05:05:27.054716 - step 15 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-02 06:05:27.054716 - step 16 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-02 07:05:27.054716 - step 17 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-02 08:05:27.054716 - step 18 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-02 09:05:27.054716 - step 19 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-02 10:05:27.054716 - step 20 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-02 11:05:27.054716 - step 21 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-02 12:05:27.054716 - step 22 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-02 13:05:27.054716 - step 23 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-02 14:05:27.054716 - step 24 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-02 15:05:27.054716 - step 25 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-02 16:05:27.054716 - step 26 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-02 17:05:27.054716 - step 27 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-02 18:05:27.054716 - step 28 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-02 19:05:27.054716 - step 29 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-02 20:05:27.054716 - step 30 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-02 21:05:27.054716 - step 31 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-02 22:05:27.054716 - step 32 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-02 23:05:27.054716 - step 33 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-03 00:05:27.054716 - step 34 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-03 01:05:27.054716 - step 35 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-03 02:05:27.054716 - step 36 of 72 - 1000 active elements (0 deactivated)
15:05:35 INFO    opendrift.models.basemodel:2042: 2024-07-03 03:05:27.054716 - step 37 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-03 04:05:27.054716 - step 38 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-03 05:05:27.054716 - step 39 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-03 06:05:27.054716 - step 40 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-03 07:05:27.054716 - step 41 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-03 08:05:27.054716 - step 42 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-03 09:05:27.054716 - step 43 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-03 10:05:27.054716 - step 44 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-03 11:05:27.054716 - step 45 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-03 12:05:27.054716 - step 46 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-03 13:05:27.054716 - step 47 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-03 14:05:27.054716 - step 48 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-03 15:05:27.054716 - step 49 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-03 16:05:27.054716 - step 50 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-03 17:05:27.054716 - step 51 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-03 18:05:27.054716 - step 52 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-03 19:05:27.054716 - step 53 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-03 20:05:27.054716 - step 54 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-03 21:05:27.054716 - step 55 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-03 22:05:27.054716 - step 56 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-03 23:05:27.054716 - step 57 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-04 00:05:27.054716 - step 58 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-04 01:05:27.054716 - step 59 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-04 02:05:27.054716 - step 60 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-04 03:05:27.054716 - step 61 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-04 04:05:27.054716 - step 62 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-04 05:05:27.054716 - step 63 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-04 06:05:27.054716 - step 64 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-04 07:05:27.054716 - step 65 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-04 08:05:27.054716 - step 66 of 72 - 1000 active elements (0 deactivated)
15:05:36 INFO    opendrift.models.basemodel:2042: 2024-07-04 09:05:27.054716 - step 67 of 72 - 1000 active elements (0 deactivated)
15:05:37 INFO    opendrift.models.basemodel:2042: 2024-07-04 10:05:27.054716 - step 68 of 72 - 1000 active elements (0 deactivated)
15:05:37 INFO    opendrift.models.basemodel:2042: 2024-07-04 11:05:27.054716 - step 69 of 72 - 1000 active elements (0 deactivated)
15:05:37 INFO    opendrift.models.basemodel:2042: 2024-07-04 12:05:27.054716 - step 70 of 72 - 1000 active elements (0 deactivated)
15:05:37 INFO    opendrift.models.basemodel:2042: 2024-07-04 13:05:27.054716 - step 71 of 72 - 1000 active elements (0 deactivated)
15:05:37 INFO    opendrift.models.basemodel:2042: 2024-07-04 14:05:27.054716 - step 72 of 72 - 1000 active elements (0 deactivated)
15:05:37 WARNING opendrift.models.basemodel:2415: Plotting fast. This will make your plots less accurate.
/opt/conda/envs/opendrift/lib/python3.11/site-packages/cartopy/mpl/geoaxes.py:1683: UserWarning: No data for colormapping provided via 'c'. Parameters 'cmap' will be ignored
  result = super().scatter(*args, **kwargs)
15:05:40 INFO    opendrift.models.basemodel:4612: Saving animation to /root/project/docs/source/gallery/animations/example_static_2d_current_0.gif...
15:06:25 INFO    opendrift.models.basemodel:3041: Time to make animation: 0:00:48.077218
../_images/example_static_2d_current_0.gif

Total running time of the script: (1 minutes 5.957 seconds)

Gallery generated by Sphinx-Gallery