import numpy as np
import cvxpy as cp
from matplotlib import pyplot as plt

# set hyperparameters
a = 1e-4
b = 1e-2
k = 2
f = 10

# non cap-and-trade system utility
x = cp.Variable(1)
objective = cp.Maximize(-cp.power(x, -k) - a*x)
constraints = [x >= 0]
prob = cp.Problem(objective, constraints)

# The optimal objective value is returned by `prob.solve()`.
result = prob.solve()
solved_x = x.value.item()
theoretical_x = np.power(k/a, 1/(k+1))
print(f"The solved equilibrium is {solved_x} and the theoretical equilibrium is {theoretical_x}\n")

# cap-and-trade system
x_ct = cp.Variable(1)
y_ct = cp.Variable(1)
objective_ct = cp.Maximize(-cp.power(x_ct, -k) - a*x_ct + b*y_ct)
constraints_ct = [x_ct >= 0, x_ct + y_ct <= f]
prob_ct = cp.Problem(objective_ct, constraints_ct)

# Optimal objective for cap-and-trade system
result_ct = prob_ct.solve()
solved_x_ct = x_ct.value.item()
solved_y_ct = y_ct.value.item()
theoretical_x_ct = np.power(k/(a+b), 1/(k+1))
print(f"Solved Equilibrium: ({solved_x_ct}, {solved_y_ct})\n")
print(f"Theoretical Equilibrium: ({theoretical_x_ct}, {f - theoretical_x_ct})")

# compare utilities between cap and trade and no cap and trade (fixed a & b)
prices = 1e-2
costs = 1e-2
caps = np.geomspace(1, 100, num=1000)
flops = np.power(k/costs, 1/(k+1))
flops_ct = np.power(k/(costs+prices), 1/(k+1))
u = np.ones(1000) * -flops ** (-k) - costs * flops
u_ct = -flops_ct ** (-k) - costs * flops_ct + prices*(caps - flops_ct)

plt.figure()
plt.plot(caps, u, label='No Cap-and-Trade System', linewidth=2)
plt.plot(caps, u_ct, label='Cap-and-Trade System', linewidth=2)

# Increase size and set weight to bold for axis labels
plt.xlabel('Maximum Allowable FLOPs', fontsize=14, fontweight='bold')
plt.ylabel('Utility', fontsize=14, fontweight='bold')

# Increase tick label size for better readability on log scales
plt.xticks(fontsize=12)
plt.yticks(fontsize=12)

plt.xscale('log')
plt.grid()

# Increase legend font size
plt.legend(fontsize=14, loc='best')
plt.savefig('cap-vs-no-cap-utility-vary-f.pdf', dpi=300)

# compare utilities between cap and trade and no cap and trade (fixed a & b)
prices = 1e-2
costs = np.geomspace(1e-6, 1e-1, num=100)
caps = 10
flops = np.power(k/costs, 1/(k+1))
flops_ct = np.power(k/(costs+prices), 1/(k+1))
u =-flops ** (-k) - costs * flops
u_ct = -flops_ct ** (-k) - costs * flops_ct + prices*(caps - flops_ct)

plt.figure()
plt.plot(costs, u, label='No Cap-and-Trade System', linewidth=2)
plt.plot(costs, u_ct, label='Cap-and-Trade System', linewidth=2)

# Increase size and set weight to bold for axis labels
plt.xlabel('Cost-per-FLOP (a)', fontsize=14, fontweight='bold')
plt.ylabel('Utility', fontsize=14, fontweight='bold')

# Increase tick label size for better readability on log scales
plt.xticks(fontsize=12)
plt.yticks(fontsize=12)

plt.xscale('log')
plt.grid()

# Increase legend font size
plt.legend(fontsize=14, loc='best')
plt.savefig('cap-vs-no-cap-utility-vary-a.pdf', dpi=300)

# cap and trade versus no cap and trade as costs increase (fixed b)
costs = np.geomspace(1e-6, 1e-1, num=1000)
prices = 1e-2
flops = np.power(k/costs, 1/(k+1))
flops_ct = np.power(k/(costs+prices), 1/(k+1))

plt.figure()
plt.plot(costs, flops, label='No Cap-and-Trade System', linewidth=2)
plt.plot(costs, flops_ct, label='Cap-and-Trade System', linewidth=2)

# Increase size and set weight to bold for axis labels
plt.xlabel('Cost-per-FLOP (a)', fontsize=14, fontweight='bold')
plt.ylabel('Optimal FLOPs (ronnaFLOPs)', fontsize=14, fontweight='bold')

# Increase tick label size for better readability on log scales
plt.xticks(fontsize=12)
plt.yticks(fontsize=12)

plt.yscale('log')
plt.xscale('log')
plt.grid()

# Increase legend font size
plt.legend(fontsize=14, loc='best')

plt.savefig('cap-vs-no-cap-fixed-b.pdf', dpi=300)

# cap and trade versus no cap and trade as selling costs increase (b = sqrt(a))
costs = np.geomspace(1e-6, 1e-1, num=1000)
prices = np.power(costs, 0.5)
flops = np.power(k/costs, 1/(k+1))
flops_ct = np.power(k/(costs+prices), 1/(k+1))

plt.figure()
plt.plot(costs, flops, label='No Cap-and-Trade System', linewidth=2)
plt.plot(costs, flops_ct, label='Cap-and-Trade System', linewidth=2)

# Increase size and set weight to bold for axis labels
plt.xlabel('Market Price-per-FLOP (b)', fontsize=14, fontweight='bold')
plt.ylabel('Optimal FLOPs (ronnaFLOPs)', fontsize=14, fontweight='bold')

# Increase tick label size for better readability on log scales
plt.xticks(fontsize=12)
plt.yticks(fontsize=12)

plt.yscale('log')
plt.xscale('log')
plt.grid()

# Increase legend font size
plt.legend(fontsize=14, loc='best')

plt.savefig('cap-vs-no-cap-adjust-b.pdf', dpi=300)





