# Automatic verification of partial derivatives
import sympy as sp

# Define symbols
a, b, c, N = sp.symbols('a b c n')
G = sp.exp(a) + 2*N - 2
s = sp.exp(b * sp.exp(a) / G)
r = s + 2*N - 1
F = 2*N - 1
L = c**2 * (s**2 + 2*N - 1) / r**2 - 2*c*s/r + 1

# Compute partial derivatives
dL_da = sp.diff(L, a)
dL_db = sp.diff(L, b)
dL_dc = sp.diff(L, c)

# Define derived expressions from the manual result
deriv_a = 4*b*(N-1)*F*s*sp.exp(a)/(G**2) * (c**2*(s-1)/r**3 - c/r**2)
deriv_b = 2*F*s*sp.exp(a)/G * (c**2*(s-1)/r**3 - c/r**2)
deriv_c = 2*c*(s**2 + F)/r**2 - 2*s/r

# Simplify differences
diff_a = sp.simplify(dL_da - deriv_a)
diff_b = sp.simplify(dL_db - deriv_b)
diff_c = sp.simplify(dL_dc - deriv_c)

# Display results (expected: 0 0 0)
print(diff_a, diff_b, diff_c)
