从F#中的列表中删除nans

时间:2017-02-10 11:34:27

标签: list f# nan

我想从列表中删除nan,因此我已实现了下面显示的功能。

val it : float list =
  [50.0; -20833.33333; 4.50701062e-14; -4.267032701e-15; 3.942195769e-16;
   -3.555114863e-17; 3.130384319e-18; 0.0; 0.0; 0.0; 0.0; 0.0; 0.0; 
   nan; nan; nan; nan; nan; nan; nan; nan; nan]

let rec remove_nan l =
    match l with
    | [] -> []
    | x::rest -> if x=nan then remove_nan rest
                 else x::(remove_nan rest)

remove_nan points

但是,它不会从列表中删除nan。为什么他们不被删除?

1 个答案:

答案 0 :(得分:21)

NaN具有奇怪的方程属性。具体来说,nan = nan是假的!在代码中使用它:

if System.Double.IsNaN x then remove_nan rest

或者如下定义remove_nan,它更短,并且不会增加堆栈:

let remove_nan = List.filter (System.Double.IsNaN >> not)