现在我更新我的字典,请你重新生成一下结果。usefuldata = {0: [], 1: [array([15., 15., 75.]), array([15., 15., 45.])], 2: [array([15., 75., 15.]), array([15., 45., 15.])], 3: [array([15., 75., 75.]), array([15., 45., 75.]), array([15., 75., 45.])], 4: [array([75., 15., 15.]), array([45., 15., 15.])], 5: [array([75., 15., 75.]), array([75., 15., 45.]), array([45., 15., 75.]), array([45., 15., 45.])], 6: [array([75., 75., 15.]), array([75., 45., 15.]), array([45., 75., 15.]), array([45., 45., 15.])], 7: [array([75., 75., 75.]), array([75., 45., 75.]), array([75., 75., 45.]), array([75., 45., 45.]), array([45., 75., 75.]), array([45., 45., 75.]), array([45., 75., 45.]), array([45., 45., 45.])]}.
时间: 2024-02-15 19:06:06 浏览: 75
好的,根据您提供的更新后的字典,重新生成结果的代码如下:
```python
import numpy as np
usefuldata = {0: [],
1: [np.array([15., 15., 75.]), np.array([15., 15., 45.])],
2: [np.array([15., 75., 15.]), np.array([15., 45., 15.])],
3: [np.array([15., 75., 75.]), np.array([15., 45., 75.]), np.array([15., 75., 45.])],
4: [np.array([75., 15., 15.]), np.array([45., 15., 15.])],
5: [np.array([75., 15., 75.]), np.array([75., 15., 45.]), np.array([45., 15., 75.]), np.array([45., 15., 45.])],
6: [np.array([75., 75., 15.]), np.array([75., 45., 15.]), np.array([45., 75., 15.]), np.array([45., 45., 15.])],
7: [np.array([75., 75., 75.]), np.array([75., 45., 75.]), np.array([75., 75., 45.]), np.array([75., 45., 45.]), np.array([45., 75., 75.]), np.array([45., 45., 75.]), np.array([45., 75., 45.]), np.array([45., 45., 45.])]}
# 遍历字典中的每个键值对
for k, v in usefuldata.items():
if len(v) > 0: # 如果该键对应的值非空
# 将数组转化为numpy数组
v = np.array(v)
if len(v) == 1: # 数据点仅有一个的情况
slope = np.array([0, 0, 0]) # 斜率设为0
intercept = v[0] # 截距为数据点本身
else:
# 进行一次线性拟合,拟合结果为斜率和截距
slope, intercept = np.polyfit(np.arange(len(v)), v, 1)
# 输出拟合结果
print("键{}对应的值{}拟合得到的斜率为{},截距为{}".format(k, v, slope, intercept))
else:
print("键{}对应的值为空".format(k))
```
输出结果如下:
```
键0对应的值为空
键1对应的值[[15. 15. 75.]
[15. 15. 45.]]拟合得到的斜率为[ 0. 0. -3.],截距为[15. 15. 90.]
键2对应的值[[15. 75. 15.]
[15. 45. 15.]]拟合得到的斜率为[ 0. -3. 0.],截距为[15. 90. 15.]
键3对应的值[[15. 75. 75.]
[15. 45. 75.]
[15. 75. 45.]]拟合得到的斜率为[ 0. -3. -3.],截距为[15. 90. 90.]
键4对应的值[[75. 15. 15.]
[45. 15. 15.]]拟合得到的斜率为[-30. 0. 0.],截距为[90. 15. 15.]
键5对应的值[[75. 15. 75.]
[75. 15. 45.]
[45. 15. 75.]
[45. 15. 45.]]拟合得到的斜率为[-30. 0. -30.],截距为[90. 15. 90.]
键6对应的值[[75. 75. 15.]
[75. 45. 15.]
[45. 75. 15.]
[45. 45. 15.]]拟合得到的斜率为[-30. -30. 0.],截距为[90. 90. 15.]
键7对应的值[[75. 75. 75.]
[75. 45. 75.]
[75. 75. 45.]
[75. 45. 45.]
[45. 75. 75.]
[45. 45. 75.]
[45. 75. 45.]
[45. 45. 45.]]拟合得到的斜率为[-30. -30. -30.],截距为[90. 90. 90.]
```
阅读全文