import numpy as np

class DiscreteDensity:
    def __init__(self, N=20):
        self.N = N
        self.cat = np.array([1, 2, 4, 7, 10, 12, 10, 7, 4, 2,
                     1, 2, 3, 5, 7, 8, 7, 5, 3, 2])
        self.probs = self.cat / np.sum(self.cat)
    def sample(self, num, shuffle=True):
        return np.random.choice(np.arange(self.N), num, p=self.probs)

cls = DiscreteDensity()
y = cls.sample(100000)

import seaborn as sns
import matplotlib.pyplot as plt
plt.rcParams.update({'font.size': 25})
plt.figure(figsize=(6, 4),)
sns.histplot(y,bins=20)
plt.xticks([])
plt.yticks([])
plt.xlim([0,19])
plt.xlabel('')
plt.ylabel('')
plt.title('Parameter distribution')
plt.show()