最近在用fenics框架跑有限元代码,其中有一个部分是把在矩阵里定义的初始值,赋值到有限元空间里,这就涉及到了初始矩阵和有限元空间坐标的转化,部分代码如下
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。先除再乘的话,数学逻辑上一样,但是如果一个很小的数,除以一个很大的数,会有舍入误差。所以先乘再除。
![设计模式学习[5]---装饰模式](https://i-blog.csdnimg.cn/direct/e38cafa7c8b94476a2d6f4381553bb46.png)















![[数据集][图像分类]熊分类数据集309张5类别黑熊泰迪北极熊等](https://i-blog.csdnimg.cn/direct/df7c050025e8439488539dae82cd1fd7.png)
