数値微分を行う関数をC#で記述しました。次のようになります。
public double Diff(double x)
{
double h = 0.0000001;
return (Function(x + h) - Function(x)) / h;
}
次のように、任意の関数を渡すことができます。
public double Diff(double x, function f)
{
double h = 0.0000001;
return (f(x + h) - f(x)) / h;
}
私はこれはデリゲートで可能だと思いますが(おそらく?).
どんな助けも大歓迎です。
上記のようにFuncを使用しても機能しますが、同じタスクを実行し、ネーミング内でインテントを定義するデリゲートもあります。
public delegate double MyFunction(double x);
public double Diff(double x, MyFunction f)
{
double h = 0.0000001;
return (f(x + h) - f(x)) / h;
}
public double MyFunctionMethod(double x)
{
// Can add more complicated logic here
return x + 10;
}
public void Client()
{
double result = Diff(1.234, x => x * 456.1234);
double secondResult = Diff(2.345, MyFunctionMethod);
}
.Net(v2以降)には、デリゲートとしての関数の受け渡しを非常に簡単にするいくつかのジェネリック型があります。
戻り値の型を持つ関数にはFunc <>があり、戻り値の型がない関数にはAction <>があります。
FuncとActionの両方は、0〜4個のパラメーターを取るように宣言できます。たとえば、Func <double、int>は1つのdoubleをパラメーターとして取り、intを返します。アクション<double、double、double>は、パラメーターとして3つのdoubleを取り、何も返しません(void)。
したがって、Funcを取るためにDiff関数を宣言できます。
public double Diff(double x, Func<double, double> f) {
double h = 0.0000001;
return (f(x + h) - f(x)) / h;
}
そして、それをそのように呼び出し、FuncまたはActionのシグネチャに適合する関数の名前を単に与えます:
double result = Diff(myValue, Function);
ラムダ構文を使用して関数をインラインで記述することもできます。
double result = Diff(myValue, d => Math.Sqrt(d * 3.14));
public static T Runner<T>(Func<T> funcToRun)
{
//Do stuff before running function as normal
return funcToRun();
}
使用法:
var ReturnValue = Runner(() => GetUser(99));