3D Bar Chart

Risk Assessment Matrix 3D

3D bar chart with legend showing risk levels across departments

Output
Risk Assessment Matrix 3D
Python
import matplotlib.pyplot as plt
import numpy as np
from mpl_toolkits.mplot3d import Axes3D
from matplotlib.colors import LinearSegmentedColormap
import matplotlib.cm as cm

fig = plt.figure(figsize=(12, 8), facecolor='white')
ax = fig.add_subplot(111, projection='3d')
ax.set_facecolor('white')

depts = 5
categories = 4
xpos = np.arange(depts)
ypos = np.arange(categories)
xpos, ypos = np.meshgrid(xpos, ypos)
xpos = xpos.flatten()
ypos = ypos.flatten()
zpos = np.zeros_like(xpos)

dx = dy = 0.6
np.random.seed(1313)
dz = np.random.randint(1, 10, size=20)

cmap = LinearSegmentedColormap.from_list('', ['#6CF527', '#F5B027', '#F5276C'])
norm = plt.Normalize(1, 10)
bar_colors = [cmap(norm(v)) for v in dz]

ax.bar3d(xpos, ypos, zpos, dx, dy, dz, color=bar_colors, alpha=0.9, edgecolor='#000000', linewidth=0.3)

sm = cm.ScalarMappable(cmap=cmap, norm=norm)
sm.set_array([])
cbar = fig.colorbar(sm, ax=ax, shrink=0.5, aspect=15, pad=0.1)
cbar.set_label('Risk Level', fontsize=10, color='#1f2937')
cbar.ax.tick_params(colors='#000000')

ax.set_xlabel('Department', fontsize=11, color='#1f2937', labelpad=10)
ax.set_ylabel('Risk Type', fontsize=11, color='#1f2937', labelpad=10)
ax.set_zlabel('Level', fontsize=11, color='#1f2937', labelpad=10)
ax.set_title('Risk Assessment Matrix', fontsize=14, color='#1f2937', fontweight='bold', pad=20)

ax.set_xticks(range(5))
ax.set_xticklabels(['IT', 'Finance', 'HR', 'Ops', 'Legal'], fontsize=8)
ax.set_yticks(range(4))
ax.set_yticklabels(['Cyber', 'Compliance', 'Market', 'Operation'], fontsize=8)
ax.tick_params(colors='#000000', labelsize=9)

ax.xaxis.pane.fill = False
ax.yaxis.pane.fill = False
ax.zaxis.pane.fill = False
ax.xaxis.pane.set_edgecolor('#000000')
ax.yaxis.pane.set_edgecolor('#000000')
ax.zaxis.pane.set_edgecolor('#000000')
ax.grid(True, alpha=0.5, linewidth=0.5)
ax.xaxis._axinfo['grid']['color'] = '#000000'
ax.yaxis._axinfo['grid']['color'] = '#000000'
ax.zaxis._axinfo['grid']['color'] = '#000000'
ax.xaxis._axinfo['tick']['color'] = '#000000'
ax.yaxis._axinfo['tick']['color'] = '#000000'
ax.zaxis._axinfo['tick']['color'] = '#000000'
ax.xaxis.line.set_color('#000000')
ax.yaxis.line.set_color('#000000')
ax.zaxis.line.set_color('#000000')

plt.tight_layout()
plt.show()
Library

Matplotlib

Category

3D Charts

Did this help you?

Support PyLucid to keep it free & growing

Support