Тип данных dob , который вы передаете, равен String
, но в python требуется tuple
. Поэтому вам нужно сначала преобразовать вашу строку в tuple
, просто измените, следуя ниже
Если Вы записали функцию, она была уже получена.
И, учитывая, что это - международная функция, я предположу, что Вы не подразумеваете, что определение исчисления "происходит".
Вы думаете о Лямбда-выражениях?
В основном можно передать функцию в функцию.
Поэтому думайте в некотором роде на объекте. В зависимости от природы объекта помог бы определить, как объекты отсортированы.
Но можно все еще создать универсальную функцию вида, затем передают в том, как сравнить объекты.
При размышлении о символьном управлении формулами затем, Вы - более обеспеченное выполнение Ваших дериваций на языках как Maple или Mathematica. Они разработаны для символьного вычисления.
Править: Если Maple и Mathematica являются слишком дорогими для Вас затем существуют другие опции. Википедия имеет довольно полный список компьютерных пакетов алгебры. http://en.wikipedia.org/wiki/Comparison_of_computer_algebra_systems
Вы не можете вычислить точную производную функции с помощью компьютерной программы (если Вы не делаете символьную математику..., но это - другой, более сложный путь, тема).
Существует несколько подходов к вычислениям числовой производной функции. Самым простым является метод с тремя точками в центре:
[f(x+h) - f(x-h)] / 2h
Другой подход является методом с пятью точками в центре:
[f(x-2h) - 8f(x-h) + 8f(x+h) - f(x+2h)] / 12h
Другая тема - то, как реализовать это использование C#. Во-первых, Вам нужен делегат, который представляет функцию, которая отображает подмножество вещественных чисел на другое подмножество вещественных чисел:
delegate double RealFunction(double arg);
Затем Вам нужна маршрутизация, которая оценивает производную:
public double h = 10e-6; // I'm not sure if this is valid C#, I'm used to C++
static double Derivative(RealFunction f, double arg)
{
double h2 = h*2;
return (f(x-h2) - 8*f(x-h) + 8*f(x+h) - f(x+h2)) / (h2*6);
}
Если Вы хотите объектно-ориентированную реализацию, необходимо создать следующие классы:
interface IFunction
{
// Since operator () can't be overloaded, we'll use this trick.
double this[double arg] { get; }
}
class Function : IFunction
{
RealFunction func;
public Function(RealFunction func)
{ this.func = func; }
public double this[double arg]
{ get { return func(arg); } }
}
class Derivative : IFunction
{
IFunction func;
public static double h = 10e-6;
public Derivative(IFunction func)
{ this.func = func; }
public double this[double arg]
{
get
{
double h2 = h*2;
return (
func[arg - h2] - func[arg + h2] +
( func[arg + h] - func[arg - h] ) * 8
) / (h2 * 6);
}
}
}