import matplotlib.pyplot as plt
from matplotlib.patches import Circle

x = [0, 1, 2, 3, 4, 5, 6, 7]
y = [6731, 302750, 8541, 13389, 145510, 5833, 11950, 5296]

total = 0
for i in y:
    total += i
for i in y:
    print(i/total)
others_sum = sum(y[i] for i in range(len(y)) if i not in [1, 4])
processed_data = {
    'Pattern 1': y[1],
    'Pattern 4': y[4],
    'Others': others_sum
}

total = sum(processed_data.values())
percentages = {k: (v/total)*100 for k, v in processed_data.items()}
sorted_data = dict(sorted(percentages.items(), 
                         key=lambda x: x[1], 
                         reverse=True))

plt.rcParams['font.family'] = 'Arial'
plt.rcParams['font.sans-serif'] = ['Arial']


fig, ax = plt.subplots(figsize=(15, 4.5))
cum_pos = 0

for (name, value), color in zip(sorted_data.items(), colors):
    bar = ax.barh(0, value, left=cum_pos, 
                  color=color,
                  alpha=0.9,
                  height=1.5)
    cum_pos += value

ax.set_xlabel('Percentage (%)', fontsize=38, labelpad=20)
ax.set_yticks([])
ax.tick_params(axis='x', labelsize=28, length=0)
ax.spines['top'].set_visible(False)
ax.spines['right'].set_visible(False)
ax.spines['left'].set_visible(False)
ax.spines['bottom'].set_visible(False)

circle_radius = 0.015
for i, ((name, value), color) in enumerate(zip(sorted_data.items(), colors)):
                   circle_radius, 
                   color=color,
                   transform=ax.transAxes)
    ax.add_patch(circle)
    
    ax.text(0.1 + i*legend_spacing, 1.1, 
            f'{name}',
            transform=ax.transAxes,
            color='black',
            fontsize=28,
            ha='center')

plt.tight_layout()
plt.savefig('mask_distribution_percentage.svg', 
            bbox_inches='tight', 
            dpi=300,
            transparent=True)
plt.close()
