python数值误差

最近在用fenics框架跑有限元代码,其中有一个部分是把在矩阵里定义的初始值,赋值到有限元空间里,这就涉及到了初始矩阵和有限元空间坐标的转化,部分代码如下

python 复制代码
for i in range(len(dof_coordinates)):
    #     x, y = dof_coordinates[i]
        #原本的区间是0到physical_length的,根据num_grids_per_axis长度进行缩放.
        # ix, iy = min(int(x / physical_length * (num_grids_per_axis - 1)), num_grids_per_axis - 1), min(int(y / physical_length * (num_grids_per_axis - 1)), num_grids_per_axis - 1)
        ix, iy = min(int(x * (num_grids_per_axis - 1) / physical_length), num_grids_per_axis - 1), min(
            int(y * (num_grids_per_axis - 1) / physical_length), num_grids_per_axis - 1)

这里有一点需要注意:

x要先和num_grids_per_axis相乘,然后再除以physical_length。先除再乘的话,数学逻辑上一样,但是如果一个很小的数,除以一个很大的数,会有舍入误差。所以先乘再除。

相关推荐
搞科研的小刘选手2 分钟前
【人工智能专题】2026年人工智能与生成式设计国际学术会议(ICAIGD 2026)
人工智能·算法·aigc·生成式ai·学术会议·计算机工程·生成式设计
梦想画家5 分钟前
ISA-95实战:从数据标准到经营分析落地案例
人工智能·isa-95·数据整理
码路星河7 分钟前
从EasyExcel到FastExcel再到Fesod:高性能Excel处理工具的完整演进与实战指南
人工智能
天一生水water13 分钟前
基于时域统计特征的时间序列故障诊断
人工智能·智慧油田
凯子坚持 c15 分钟前
在 openJiuwen 里把在线小工具搬回本地
人工智能·windows·stable diffusion·openteledb·openclaw
宇擎智脑科技21 分钟前
智能体架构选型之争:OpenClaw与VibeSurf的技术路线对比分析
人工智能·智能体架构·智能体载体形式
_ziva_25 分钟前
大模型核心问题全解析:从激活函数到训练实战
人工智能·深度学习·机器学习
像风一样的男人@26 分钟前
python --打包pyd或so文件
开发语言·python
ViiTor_AI1 小时前
AI 自动去除视频字幕和水印:ViiTor 字幕移除工具完整使用教程
人工智能
何伯特1 小时前
Dropout:深度学习中防止过拟合的“随机失活”艺术
人工智能·深度学习