Объясни подробно что делает функция double fibonacciMinimization(double a, double b, double epsilon) { int n = 1; while ((b - a) / fibonacci(n) >= epsilon) { n++; } double x1 = a + (double)fibonacci(n - 2) / fibonacci(n) * (b - a); double x2 = a + (double)fibonacci(n - 1) / fibonacci(n) * (b - a); double f1 = func(x1); double f2 = func(x2); for (int i = 1; i < n - 1; i++) { if (f1 < f2) { b = x2; x2 = x1; x1 = a + (double)fibonacci(n - i - 1) / fibonacci(n - i) * (b - a); f2 = f1; f1 = func(x1); } else { a = x1; x1 = x2; x2 = a + (double)fibonacci(n - i) / fibonacci(n - i + 1) * (b - a); f1 = f2; f2 = func(x2); } } return (a + b) / 2;