我想生成一个图形,该图形显示同一图形上各种收敛方法/值的数值函数的误差。
我使用while循环来增加收敛条件的不同值,并在图形上绘制误差,每种收敛方法一次(用后缀A和B标记)。
问题是,每次我在matplotlib中调用plot时,该行都会显示为不同的颜色。我希望为每个会聚值使用相同的颜色(即,如果它们共享一个会聚值,则将它们绘制为相同的颜色),以使读者更容易看到连接的线。
我的代码当前产生的示例。
我希望每对中的彩色和黑色虚线是相同的颜色。我没有包括函数的定义,但是我用来生成图形的代码是
conv = 1e-0
h=0.1
while conv>1e-4:
errorlist_A, errorlist_B = [],[]
gridsize = []
grid_x = 40
while grid_x <= 100:
analytical = (np.ones((grid_x,grid_x)))*edge_val
P = np.zeros((grid_x,grid_x))
gridsize.append(grid_x)
solA = solvelap_avg_rand(grid_x,grid_x,edge_val,P,h,conv)
solB = solvelap_max_rand(grid_x,grid_x,edge_val,P,h,conv)
errorlist_A.append(errorfunc(grid_x,grid_y,analytical,solA,edge_val))
errorlist_B.append(errorfunc(grid_x,grid_y,analytical,solB,edge_val))
grid_x +=5
print(grid_x)
plt.plot(gridsize,errorlist_A, label = "{0:.1g}".format(conv))
plt.plot(gridsize,errorlist_B, label = "{0:.1g}".format(conv) , linestyle = "--", color = "k")
conv *=0.1
plt.title("Fig:6 Error per Node Vs. Grid Width")
plt.xlabel("Grid Width")
plt.ylabel("Average Error Per Node (Log10)")
plt.yscale("log")
plt.legend()
plt.show()
注意:我知道您可以手动设置线条的颜色作为参数,但是我不确定如何循环执行。
此外,如果有任何方法可以防止图例阻止剧情,那也将非常有帮助。
参考方案
我会使用颜色图自动定义颜色。但是,由于您事先不知道会有多少条曲线,因此我们可以绘制所有曲线并在之后为它们上色。
修改代码中的以下几行:
# Remove the `color=` parameter here, it will be overwritten anyway.
plt.plot(gridsize, errorlist_A, label="{0:.1g}".format(conv))
plt.plot(gridsize, errorlist_B, label="{0:.1g}".format(conv), linestyle = "--")
然后在plt.show()之前添加这些内容:
# After you plotted them, apply a random color to each curve.
import matplotlib.cm as cm
colormap = cm.get_cmap("plasma") # The various colormaps can be found here: https://matplotlib.org/3.1.0/tutorials/colors/colormaps.html
ax = plt.gca()
lines = ax.lines
N = len(lines)
for n in range(0, N, 2): # For each two-lines made via `plt.plot(...)`:
random_color = colormap(n/N) # This function takes a number between 0 and 1 and returns a color.
lines[n].set_color(random_color)
lines[n+1].set_color(random_color)
Python-crontab模块 - python
我正在尝试在Linux OS(CentOS 7)上使用Python-crontab模块我的配置文件如下:{ "ossConfigurationData": { "work1": [ { "cronInterval": "0 0 0 1 1 ?", "attribute&…Python GPU资源利用 - python
我有一个Python脚本在某些深度学习模型上运行推理。有什么办法可以找出GPU资源的利用率水平?例如,使用着色器,float16乘法器等。我似乎在网上找不到太多有关这些GPU资源的文档。谢谢! 参考方案 您可以尝试在像Renderdoc这样的GPU分析器中运行pyxthon应用程序。它将分析您的跑步情况。您将能够获得有关已使用资源,已用缓冲区,不同渲染状态上…Python Pandas导出数据 - python
我正在使用python pandas处理一些数据。我已使用以下代码将数据导出到excel文件。writer = pd.ExcelWriter('Data.xlsx'); wrong_data.to_excel(writer,"Names which are wrong", index = False); writer.…Python sqlite3数据库已锁定 - python
我在Windows上使用Python 3和sqlite3。我正在开发一个使用数据库存储联系人的小型应用程序。我注意到,如果应用程序被强制关闭(通过错误或通过任务管理器结束),则会收到sqlite3错误(sqlite3.OperationalError:数据库已锁定)。我想这是因为在应用程序关闭之前,我没有正确关闭数据库连接。我已经试过了: connectio…Python:在不更改段落顺序的情况下在文件的每个段落中反向单词? - python
我想通过反转text_in.txt文件中的单词来生成text_out.txt文件,如下所示:text_in.txt具有两段,如下所示:Hello world, I am Here. I am eighteen years old. text_out.txt应该是这样的:Here. am I world, Hello old. years eighteen a…