RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1499554
Accepted
Alex Kazantsev
Alex Kazantsev
Asked:2023-02-24 21:03:05 +0000 UTC2023-02-24 21:03:05 +0000 UTC 2023-02-24 21:03:05 +0000 UTC

在Python算法中获取函数零而不是值

  • 772

实现了使用二分法求根的算法。一共有三个函数:f()它包含了我们要找根的方程,print_dichotomy一个将计算结果输出到控制台的装饰器,以及dichotomy()一个使用二分法的脚本。

但是,字符串print('Значения функции составляют:\n', func)输出零。为什么?

代码:

import numpy as np

def print_dichotomy(dichotomy):
    def wrapper(a,b,eps):
        res = list(dichotomy(a,b, eps))
        func = ', '.join(map(lambda x: f'{f(x):.4f}', res))
        print('Корни по методу дихотомии находятся в точках:')
        print(', '.join(map(lambda x: f'{x:.4f}', res)))
        print('Значения функции составляют:\n', func)
    return wrapper

def f(x):
    return 1.2-np.log(x)-4*np.cos(2*x) 

@print_dichotomy
def dichotomy(a, b, eps):  
    """
    Функция отделения и уточнения корня.
    Передаются параметры: отрезок от a до b делим на n частей (отдельный запрос), погрешность по функции eps
    """
      
    # 2. определим ограничения на границы отрезка 
    assert a != 0, 'a равно 0'
    assert b != 0, 'b равно 0'

    # 3. запросим количество частей n, на которые будет дробиться отрезок 
    n = int( input('Введите параметр n (целое число): ') )
    
    # 4. отделим корни
    # 4.1. разделим заданный отрезок на n частей 
    grid = np.linspace(a, b, n)
    # 4.2. уточним наличие корней на каждом отрезке 
    for x, y in zip(grid, grid[1:]):
        # если на отрезке нет корня, смотрим следующий отрезок
        if f(x) * f(y) > 0:  
            continue
        root = None
        # 5. уточним корни
        # пока отрезок больше заданной погрешности по функции, выполняем нижестоящие операции:
        while abs(f(y) - f(x)) > eps or ((y - x)/2) > eps:
            if y != x:
            # получаем середину отрезка
                mid = (y + x) / 2
            # если функция в середине отрезка равну нулю или меньше погрешности:
                if f(mid) == 0 or abs(f(mid)) < eps:
                # корень равень серединному значению:
                    root = mid  
                    break
            # иначе если произведение функции в середине отрезка на функцию в т. а <0:
                elif (f(mid) * f(x)) <= 0:
                    # серединой становится точка b:
                    y = mid  
                else:
                    # в другом случае — точка а:
                    x = mid  
        if root:
            yield root

dichotomy(0.0001, 50, 0.000001)
python
  • 1 1 个回答
  • 31 Views

1 个回答

  • Voted
  1. Best Answer
    Stanislav Volodarskiy
    2023-02-25T02:11:30Z2023-02-25T02:11:30Z

    是的,该行显示零或接近零的数字,因为这些是根中函数的近似值。它应该是这样的:

    $ python temp.py
    Введите параметр n (целое число): 10
    Корни по методу дихотомии находятся в точках:
    2.3970, 7.1653, 14.7317, 32.5048, 39.7206
    Значения функции составляют:
     0.0000, 0.0000, -0.0000, -0.0000, -0.0000
    

    将精度从四改为十:

    <        func = ', '.join(map(lambda x: f'{f(x):.4f}', res))
    -----------
    >        func = ', '.join(map(lambda x: f'{f(x):.10f}', res))
    
    $ python temp.py
    Введите параметр n (целое число): 10
    Корни по методу дихотомии находятся в точках:
    2.3970, 7.1653, 14.7317, 32.5048, 39.7206
    Значения функции составляют:
     0.0000005723, 0.0000001953, -0.0000007381, -0.0000009070, -0.0000007247
    
    • 1

相关问题

  • 是否可以以某种方式自定义 QTabWidget?

  • telebot.anihelper.ApiException 错误

  • Python。检查一个数字是否是 3 的幂。输出 无

  • 解析多个响应

  • 交换两个数组的元素,以便它们的新内容也反转

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5