All code needed to reprdocue our results is given in the Observed Hessian folder.
The structure is as follows:

1) different_ansatz: Compares different ansatz architecutres Lmax/Lupper ratio
2) expressibility: Compares Lmax/Lupper with expressibility metric
3) gu_bound_comp: Compares Lmax/Lupper with our bound and Gu's bound
4) liu_bound_comp: Compares Lmax/Lupper with our bound and Liu's bound
5) Observable_scaling: Compares Lmax/Lupper as ||M||_2 grows
6) Parameter_scaling: Compares Lmax/Lupper as P grows
7) Samples: Compares Lmax/Lupper by using different number of samples
8) Train_Vqe: Trains a n>1 vqe with different learning rates
9) Train_vqe_1q: Trains a n=1 vqe with different learning rates
10) Vqe_lr_1q: Finds the optimal learning rate for a VQE with 1 qubit
11) Vqe_optlr: Finds the optimal learning rate for a VQE with n>1 qubits