Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Create example_Initialise_JIT_particles_with_initial_values.py #1

Open
wants to merge 3 commits into
base: master
Choose a base branch
from
Open
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
36 changes: 36 additions & 0 deletions Examples/example_Initialise_JIT_particles_with_initial_values.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
### This example shows how to create a particle set in JIT mode while still sampling initial conditions of a variable eg. Temperature
### This works even with mulitple releases during a simulation
### This is an example of a solution to the github issue here: https://github.com/OceanParcels/parcels/issues/861
### This code assumes you have already made the fieldset. (This is not a stand-only piece of code)

# First create a particle class which samples values, in this case it is sampling temperature.
# Within this class create the variable you wish to sample (temp) and initialise it with a value of 0.
# Also create a variable (sampled) to identify if it is the particles day of release.

class SampleParticle(JITParticle): # Define a new particle class
sampled = Variable('sampled', dtype = np.float32, initial = 0, to_write=False) # variable to identify if it is just released
temp = Variable('temp', dtype=np.float32, initial=0) # initialise temperature

# Create the kernel to sample temperature
def SampleTemp(particle, fieldset, time):
particle.temp = fieldset.temp[time, particle.depth, particle.lat, particle.lon]

# Create the kernel to get the initial temperature value for each particle.
def SampleInitial(particle, fieldset, time):
if particle.sampled == 0:
particle.temp = fieldset.temp[time, particle.depth, particle.lat, particle.lon]
particle.sampled = 1
Comment on lines +21 to +24
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Does this actually mean that the temperature at time=0 is also written to the ParticleFile?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It was suppose to... but looking closer it appears it does not to.
I originally checked it looking at distance calulations in another script. The calculations worked with this method (using a prev_lat variable --- Did not work without this kernel) but looking closer it is calculating these initial values but not recording them in the particle file for any variable. This might need some more work. Sorry.


# Create your kernel list to run,
# Put the SampleInitial Kernel before the advection kernel to get the initial value of temp before the 1st advection step occurs.
kernels = SampleInitial + pset.Kernel(AdvectionRK4) + SampleTemp

# Excute the code
pset.execute(kernels,
dt=delta(minutes=30),
output_file=pfile,
verbose_progress=True,
#moviedt=delta(hours=1),
runtime = runtime,
recovery={ErrorCode.ErrorOutOfBounds: DeleteParticle})
pfile.close()
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Not sure this part of the script is needed. Since you've defined the kernels above, users can use them in their own pset.execute()

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ah, that makes sense, thanks. I've now removed this bit.