ST_FilterByM — Removes vertices based on their M value
geometry ST_FilterByM(geometry geom, double precision min, double precision max = null, boolean returnM = false);
Filters out vertex points based on their M-value. Returns a geometry with only vertex points that have a M-value larger or equal to the min value and smaller or equal to the max value. If max-value argument is left out only min value is considered. If fourth argument is left out the m-value will not be in the resulting geometry. If resulting geometry have too few vertex points left for its geometry type an empty geometry will be returned. In a geometry collection geometries without enough points will just be left out silently.
This function is mainly intended to be used in conjunction with ST_SetEffectiveArea. ST_EffectiveArea sets the effective area of a vertex in its m-value. With ST_FilterByM it then is possible to get a simplified version of the geometry without any calculations, just by filtering
| ![[Note]](../images/note.png) | |
| There is a difference in what ST_SimplifyVW returns when not enough points meet the criteria compared to ST_FilterByM. ST_SimplifyVW returns the geometry with enough points while ST_FilterByM returns an empty geometry | 
| ![[Note]](../images/note.png) | |
| Note that the returned geometry might be invalid | 
| ![[Note]](../images/note.png) | |
| This function returns all dimensions, including the Z and M values | 
Availability: 2.5.0