hma / common /plot /plot_dynamics_ablation_deltapsnr.py
LeroyWaa's picture
draft
246c106
raw
history blame
1.62 kB
import seaborn as sns
import matplotlib
import matplotlib.pyplot as plt
import numpy as np
import pandas as pd
import numpy as np
# Sample data based on the provided image structure
tasks = ["Passive Dynamics", "Full Dynamics", "Forward Dynamics"]
bar_labels = ["Passive Dynamics", "Full Dynamics", "Forward Dynamics"]
values = np.array([
[0.33],
[1.23],
[1.87],
# [0.87, 0.55, 0.25, 0.03, 0.01, 0.0]
])
# Bar colors matching the provided image
bar_colors = ['#a6cee3', '#1f78b4', '#ffffff', '#cab2d6', '#b3b3cc', '#33a02c']
# Plotting the data
fig, ax = plt.subplots(figsize=(5, 3))
# Set bar width and x positions for each group
bar_width = 0.4
x = np.arange(len(tasks))
# Plot each group's bars with the specified colors
for i in range(values.shape[1]):
bars = ax.bar(x + i * bar_width, values[:, i], width=bar_width, color=bar_colors[i], edgecolor='black')
bars[-1].set_color('#cab2d6')
bars[-1].set_edgecolor('black')
for container in ax.containers:
ax.bar_label(container, label_type="edge", fontsize="x-large", fmt="%.2f")
# Set titles, labels, and ticks
# ax.set_title("Zero-Shot Performance Comparison Across Tasks")
ax.set_xlabel("Model", fontsize=14)
ax.set_ylabel("Delta PSNR", fontsize=14)
ax.set_xticks(x )
ax.set_xticklabels(tasks, fontsize=12)
ax.set_ylim(values.min() - 0.1, values.max() + 0.2)
ax.tick_params(axis='x', rotation=15)
# Adding the legend outside the plot area
# ax.legend(loc='upper center', bbox_to_anchor=(0.5, 1.15), ncol=3)
# Display the plot
plt.tight_layout()
# plt.show()
plt.savefig("output/dynamics_ablation_controllability.png", dpi=300)