An empty value is not comparable to a number by design. This helps detect unexpected empty values. However, because of that, a filtering condition must do type-checking first. Here are examples of correct expressions for your case:
IF not isempty([EC1]) THEN [EC1] <= 5 ELSE false()
Alternatively
if( isempty([EC1]), false(), [EC1] <= 5)
If you only need to select a few integers, I would suggest using the simple “Filter” action.
I understand the reason and the solution, but it makes in complex conditions the formular more complex.
Maybe you can add it on the feature request list @dgudkov to have an option checkbox for the filters like "interpret empty values as 0" and/or "interpret non numeric values as 0".
hint for others - my workaround to keep the formular as simple as possible is a previous modify step, that sets non numeric values to 0. (but I would also be happy, if I can leave out this).