import numpy as np
import scipy as sp
from scipy import special
from scipy import optimize

def func(x):
    s = special.softmax(x)
    gs = s[0] * s * (x[0]-x)
    return -(s[0]+gs[1:].sum())

N = 1000
#init = np.array([0,0])
init = np.zeros(N)
init[0] = 6.5
minimum = optimize.fmin(func, init)
print (minimum)
print (func(minimum))



test = np.zeros(N)
test[0] = 2.399 * np.log(N)
print (func(test))
test[2:] = -99999
print (func(test))
