File: template.py

package info (click to toggle)
pyferret 7.6.5-10
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 138,136 kB
  • sloc: fortran: 240,609; ansic: 25,235; python: 24,026; sh: 1,618; makefile: 1,123; pascal: 569; csh: 307; awk: 18
file content (86 lines) | stat: -rw-r--r-- 3,282 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
'''
Template for creating a PyFerret Python External Function (PyEF).
The names of the functions provided should not be changed.  By 
default, PyFerret uses the name of the module as the function name.

Copy this file using a name that you would like to be the function
name, then modify the contents of these functions and comments as
desired. 
'''

import numpy


def ferret_init(efid):
    '''
    Initialization function for this PyFerret PyEF.  Returns
    a dictionary describing the features of this PyFerret PyEF.
    At a minimum, assigns the number of arguments expected and 
    a descriptions of the functions.  May also provide 
    descriptions of the arguments and specifications for a 
    non-standard result grid.
    '''
    init_dict = { }

    init_dict["numargs"] = 1
    init_dict["descript"] = "Pass through"

    return init_dict


def ferret_result_limits(efid):
    '''
    Defines the index limits for all abstract axes in the result grid.
    Returns an (X,Y,Z,T,E,F)-axis six-tuple of either (low,high) pairs, 
    for an abstract axis, or None, for a non-abstract axis.  The low 
    and high values are integer values.  If the result grid has no 
    abstract axes, this function will not be called and can be deleted.
    '''
    axis_limits = (None, None, None, None, None, None)

    return axis_limits


def ferret_custom_axes(efid):
    '''
    Defines all custom axes in ther result grid.  Returns a (X,Y,Z,T,E,F)-
    axis six-tuple of either a (low, high, delta, unit_name, is_modulo) 
    tuple, for a custom axis, or None, for a non-custom axis.  The low,
    high, and delta values are floating-point values in units of the axis 
    coordinate ("world coordinates").  If the result grid has no custom
    axes, this function will not be called and can be deleted.
    '''
    axis_info = (None, None, None, None, None, None)
    
    return axis_info


def ferret_compute(efid, result, result_bdf, inputs, input_bdfs):
    '''
    Computation function for this PyFerret PyEF.  Assign values to the
    elements of result; do not reassign result itself.  In other words,
    assign values using notation similar to 'result[...] = ...'; do not
    use notation similar to 'result = ...' as this will simply define
    a new local variable called result, hiding the variable passed into
    this function.

    If an error is detected, raise an appropriate exception.  ValueError
    is commonly used for unexpected values.  IndexError is commonly used 
    for unexpected array sizes.

    Arguments:
        result     - numpy float array to be assigned
        result_bdf - numpy read-only float array of one element giving the 
                     missing-data value to be used when assigning result
        inputs     - tuple of numpy read-only float arrays giving the input
                     values provided by the caller
        input_bdfs - numpy read-only float arrays of one element giving the
                     missing-data value for the corresponding inputs array
    '''
    # Create masks of values that are undefined and that are defined
    bad_mask = ( inputs[0] == input_bdfs[0] )
    good_mask = numpy.logical_not(bad_mask)
    result[good_mask] = inputs[0][good_mask]
    result[bad_mask] = result_bdf
    return