Note
Go to the end to download the full example code.
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)
09:17:59 INFO opendrift:569: OpenDriftSimulation initialised (version 1.14.9 / v1.14.9-61-g2d35ef6)
09:17:59 INFO opendrift.models.basemodel.environment:203: Adding a global landmask from GSHHG
09:18:03 INFO opendrift.models.basemodel.environment:227: Fallback values will be used for the following variables which have no readers:
09:18:03 INFO opendrift.models.basemodel.environment:230: sea_surface_height: 0.000000
09:18:03 INFO opendrift.models.basemodel.environment:230: x_wind: 0.000000
09:18:03 INFO opendrift.models.basemodel.environment:230: y_wind: 0.000000
09:18:03 INFO opendrift.models.basemodel.environment:230: upward_sea_water_velocity: 0.000000
09:18:03 INFO opendrift.models.basemodel.environment:230: ocean_vertical_diffusivity: 0.000000
09:18:03 INFO opendrift.models.basemodel.environment:230: horizontal_diffusivity: 0.000000
09:18:03 INFO opendrift.models.basemodel.environment:230: sea_surface_wave_significant_height: 0.000000
09:18:03 INFO opendrift.models.basemodel.environment:230: sea_surface_wave_stokes_drift_x_velocity: 0.000000
09:18:03 INFO opendrift.models.basemodel.environment:230: sea_surface_wave_stokes_drift_y_velocity: 0.000000
09:18:03 INFO opendrift.models.basemodel.environment:230: ocean_mixed_layer_thickness: 50.000000
09:18:03 INFO opendrift.models.basemodel.environment:230: sea_floor_depth_below_sea_level: 10000.000000
09:18:03 INFO opendrift:1903: Skipping environment variable ocean_vertical_diffusivity because of condition ['drift:vertical_mixing', 'is', False]
09:18:03 INFO opendrift:1903: Skipping environment variable ocean_mixed_layer_thickness because of condition ['drift:vertical_mixing', 'is', False]
09:18:03 INFO opendrift:1914: Storing previous values of element property lon because of condition (('general:coastline_action', 'in', ['stranding', 'previous']), 'or', ('general:seafloor_action', 'in', ['previous']))
09:18:03 INFO opendrift:1914: Storing previous values of element property lat because of condition (('general:coastline_action', 'in', ['stranding', 'previous']), 'or', ('general:seafloor_action', 'in', ['previous']))
09:18:03 INFO opendrift:1922: Storing previous values of environment variable sea_surface_height because of condition ['drift:vertical_advection', 'is', True]
09:18:03 INFO opendrift:955: Using existing reader for land_binary_mask to move elements to ocean
09:18:03 INFO opendrift:986: All points are in ocean
09:18:03 INFO opendrift:2211: 2026-06-05 09:17:59.955772 - step 1 of 72 - 1000 active elements (0 deactivated)
09:18:03 INFO opendrift:2211: 2026-06-05 10:17:59.955772 - step 2 of 72 - 1000 active elements (0 deactivated)
09:18:03 INFO opendrift:2211: 2026-06-05 11:17:59.955772 - step 3 of 72 - 1000 active elements (0 deactivated)
09:18:03 INFO opendrift:2211: 2026-06-05 12:17:59.955772 - step 4 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-05 13:17:59.955772 - step 5 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-05 14:17:59.955772 - step 6 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-05 15:17:59.955772 - step 7 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-05 16:17:59.955772 - step 8 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-05 17:17:59.955772 - step 9 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-05 18:17:59.955772 - step 10 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-05 19:17:59.955772 - step 11 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-05 20:17:59.955772 - step 12 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-05 21:17:59.955772 - step 13 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-05 22:17:59.955772 - step 14 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-05 23:17:59.955772 - step 15 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-06 00:17:59.955772 - step 16 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-06 01:17:59.955772 - step 17 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-06 02:17:59.955772 - step 18 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-06 03:17:59.955772 - step 19 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-06 04:17:59.955772 - step 20 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-06 05:17:59.955772 - step 21 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-06 06:17:59.955772 - step 22 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-06 07:17:59.955772 - step 23 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-06 08:17:59.955772 - step 24 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-06 09:17:59.955772 - step 25 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-06 10:17:59.955772 - step 26 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-06 11:17:59.955772 - step 27 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-06 12:17:59.955772 - step 28 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-06 13:17:59.955772 - step 29 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-06 14:17:59.955772 - step 30 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-06 15:17:59.955772 - step 31 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-06 16:17:59.955772 - step 32 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-06 17:17:59.955772 - step 33 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-06 18:17:59.955772 - step 34 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-06 19:17:59.955772 - step 35 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-06 20:17:59.955772 - step 36 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-06 21:17:59.955772 - step 37 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-06 22:17:59.955772 - step 38 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-06 23:17:59.955772 - step 39 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-07 00:17:59.955772 - step 40 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-07 01:17:59.955772 - step 41 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-07 02:17:59.955772 - step 42 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-07 03:17:59.955772 - step 43 of 72 - 1000 active elements (0 deactivated)
09:18:04 INFO opendrift:2211: 2026-06-07 04:17:59.955772 - step 44 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-07 05:17:59.955772 - step 45 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-07 06:17:59.955772 - step 46 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-07 07:17:59.955772 - step 47 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-07 08:17:59.955772 - step 48 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-07 09:17:59.955772 - step 49 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-07 10:17:59.955772 - step 50 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-07 11:17:59.955772 - step 51 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-07 12:17:59.955772 - step 52 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-07 13:17:59.955772 - step 53 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-07 14:17:59.955772 - step 54 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-07 15:17:59.955772 - step 55 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-07 16:17:59.955772 - step 56 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-07 17:17:59.955772 - step 57 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-07 18:17:59.955772 - step 58 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-07 19:17:59.955772 - step 59 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-07 20:17:59.955772 - step 60 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-07 21:17:59.955772 - step 61 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-07 22:17:59.955772 - step 62 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-07 23:17:59.955772 - step 63 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-08 00:17:59.955772 - step 64 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-08 01:17:59.955772 - step 65 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-08 02:17:59.955772 - step 66 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-08 03:17:59.955772 - step 67 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-08 04:17:59.955772 - step 68 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-08 05:17:59.955772 - step 69 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-08 06:17:59.955772 - step 70 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-08 07:17:59.955772 - step 71 of 72 - 1000 active elements (0 deactivated)
09:18:05 INFO opendrift:2211: 2026-06-08 08:17:59.955772 - step 72 of 72 - 1000 active elements (0 deactivated)
09:18:05 WARNING opendrift:2574: Plotting fast. This will make your plots less accurate.
09:18:06 INFO opendrift:4777: Saving animation to /root/project/docs/source/gallery/animations/example_static_2d_current_0.gif...
09:18:58 INFO opendrift:3200: Time to make animation: 0:00:53.055539
Total running time of the script: (1 minutes 4.746 seconds)