Spatial Filter - Rectangular
Categories:
Script: Filtering/ex_spatial_filter_rectangular.py
Description
This Python External Attribute script applies lowpass, highpass, bandpass or band reject spatial filters with rectangular symmetry. The filters are applied by direct spatial convolution of a kernel formed by cascading two 1D Hamming Window FIR filters computed using scipy.signal.firwin (https://docs.scipy.org/doc/scipy/reference/generated/scipy.signal.firwin.html).
By setting the stepout in one direction to 0 the filter will be applied as a 1D spatial filter in the other direction.
Note that the filter cutoff or band pass/reject frequency is specified in Normalised Spatial Frequency. Normalised Frequency ranges from 0 to 1 at the spatial nyquist. Converting a spatial frequency in cycles/metre to the equivalent Normalised Spatial Frequency is as simple as dividing it by the spatial nyquist frequency.
Examples
This example shows inline and crossline FK spectra after applying a 2D lowpass rectangular filter with inline and crossline normalised frequency cutoffs of 0.6 and 0.3 respectively.
data:image/s3,"s3://crabby-images/b31b5/b31b500766098b35aed6039aadc8bbab74dce8a4" alt="Input Inline FK Spectrum"
data:image/s3,"s3://crabby-images/efde8/efde837adb01e84ee883900b035c478da9b64069" alt="After lowpass filter"
data:image/s3,"s3://crabby-images/a343f/a343f0bf9b6310a5cdf39b37e639556855711da9" alt="Input crossline FK Spectrum"
data:image/s3,"s3://crabby-images/fe1e0/fe1e0ea39139445cad73addac51179d103ad85d5" alt="After lowpass filter"
This example shows a timeslice at 300ms TWT from the F3 Demo dataset after applying a 1D spatial filter along the inlines (stepout of 0,9) with a crossline normalised frequency cutoff of 0.5.
data:image/s3,"s3://crabby-images/b996a/b996acf4069494598a98c9be519ed27c16135c4c" alt="Input"
data:image/s3,"s3://crabby-images/174e1/174e130b962abdcd32e2a3b8e50fbcca86e60587" alt="Xline Lowpass Filtered"
This example shows the timeslice at 300ms TWT from the F3 Demo dataset with the crossline lowpass filter above followed by a 1D bandreject spatial filter along the crosslines (stepout 9,0) with an inline normalised rejection frequency of 0.17.
data:image/s3,"s3://crabby-images/174e1/174e130b962abdcd32e2a3b8e50fbcca86e60587" alt="Xline Lowpass Input"
data:image/s3,"s3://crabby-images/de25d/de25df45d6f67bff9011cb3125270293314b4602" alt="Inline Bandreject Filtered"
Input Parameters
data:image/s3,"s3://crabby-images/5fdc3/5fdc326fc141b93fe19d94ddc8442b8fedc4b507" alt="ex_spatial_filte_rectangular.py input parameters"
ex_spatial_filte_rectangular.py input parameters
NAME | DESCRIPTION |
---|---|
Stepout | Determines the size of the convolution operator. Minimum of 9 (filter kernel size of 19) recommended. Setting the stepout to zero will apply a 1D filter, e.g. a stepout of 0,9 will apply a 1D crossline frequency filter. |
Type | Filter type - Low Pass, High Pass, Band Pass or Band Reject. |
Normalised Inline Spatial Frequency | For Low Pass and High Pass filters this specifies the inline filter cutoff. For Band Pass/Reject filters this is the centre of the pass/reject band. The width of the band is hardwired to +/- 0.1 in the script. The filter cutoff corresponds to the half amplitude point. |
Normalised Xline Spatial Frequency | For Low Pass and High Pass filters this specifies the crosslineline filter cutoff. For Band Pass/Reject filters this is the centre of the pass/reject band. The width of the band is hardwired to +/- 0.1 in the script. The filter cutoff corresponds to the half amplitude point. |
Feedback
Was this page helpful?
Glad to hear it! Please tell us how we can improve.
Sorry to hear that. Please tell us how we can improve.