Wystarczy ingerować w F # i starałem się tworzyć podstawową funkcję Lagrange'a interpolacji opartej na tej wersji C# (skopiowane z C++ wpisu wiki):Przepisanie kodu C# F #
double Lagrange(double[] pos, double[] val, double desiredPos)
{
double retVal = 0;
for (int i = 0; i < val.Length; ++i)
{
double weight = 1;
for (int j = 0; j < val.Length; ++j)
{
// The i-th term has to be skipped
if (j != i)
{
weight *= (desiredPos - pos[j])/(pos[i] - pos[j]);
}
}
retVal += weight * val[i];
}
return retVal;
}
Najlepszym mogę przyjść z pomocą mojego ograniczoną wiedzę na temat F # i programowania funkcjonalnego było:
let rec GetWeight desiredPos i j (pos : float[]) weight =
match i with
| i when j = pos.Length -> weight
| i when i = j -> GetWeight desiredPos i (j+1) pos weight
| i -> GetWeight desiredPos i (j+1) pos (weight * (desiredPos - pos.[j])/(pos.[i] - pos.[j]))
let rec Lagrange (pos : float[]) (vals : float[]) desiredPos result counter =
match counter with
| counter when counter = pos.Length -> result
| counter -> Lagrange pos vals desiredPos (result + (GetWeight desiredPos counter 0 pos 1.0)* vals.[counter]) (counter+1)
ktoś może zapewnić lepszą/porządniej F # w wersji opartej na samym kod C#?
Myślę, że jest to dobry przykład tego, kiedy imperatywny kod jest łatwiejszy do odczytania i utrzymania niż funkcjonalny. – gradbot