Better shit-detection and mitigation when training
This commit is contained in:
parent
f5763fe7da
commit
7fd1f4fa3f
23
caliGraph.py
23
caliGraph.py
@ -823,11 +823,12 @@ def evaluateFitness(books, debugPrint=False):
|
|||||||
fit = sum(errSq)/len(errSq) + 0.005*regressionLoss + 0.2*boundsLoss/len(ratedBooks) - 1.0*sum(linSepLoss)/len(linSepLoss)
|
fit = sum(errSq)/len(errSq) + 0.005*regressionLoss + 0.2*boundsLoss/len(ratedBooks) - 1.0*sum(linSepLoss)/len(linSepLoss)
|
||||||
return fit, gradient
|
return fit, gradient
|
||||||
|
|
||||||
def train(gamma = 1, full=True):
|
def train(initGamma = 1, full=True):
|
||||||
global weights
|
global weights
|
||||||
if full:
|
if full:
|
||||||
for wt in weights:
|
for wt in weights:
|
||||||
weights[wt] = random.random()
|
weights[wt] = random.random()
|
||||||
|
gamma = initGamma
|
||||||
books = loadBooksFromDB()
|
books = loadBooksFromDB()
|
||||||
bestWeights = copy.copy(weights)
|
bestWeights = copy.copy(weights)
|
||||||
mse, gradient = evaluateFitness(books)
|
mse, gradient = evaluateFitness(books)
|
||||||
@ -849,12 +850,22 @@ def train(gamma = 1, full=True):
|
|||||||
if mse < best_mse:
|
if mse < best_mse:
|
||||||
saveWeights(weights)
|
saveWeights(weights)
|
||||||
bestWeights = copy.copy(weights)
|
bestWeights = copy.copy(weights)
|
||||||
else:
|
best_mse = mse
|
||||||
|
if mse > last_mse:
|
||||||
stagLen += 1
|
stagLen += 1
|
||||||
if stagLen == 3 or mse > 100:
|
else:
|
||||||
stagLen = -2
|
stagLen = 0
|
||||||
for wt in weights:
|
if stagLen == 4 or mse > 50:
|
||||||
weights[wt] = random.random()
|
print("#")
|
||||||
|
stagLen = 0
|
||||||
|
gamma = initGamma
|
||||||
|
if random.random() < 0.50:
|
||||||
|
for wt in weights:
|
||||||
|
weights[wt] = random.random()
|
||||||
|
else:
|
||||||
|
weights = copy.copy(bestWeights)
|
||||||
|
for wt in weights:
|
||||||
|
weights[wt] *= 0.975+0.05*random.random()
|
||||||
print('Done.')
|
print('Done.')
|
||||||
|
|
||||||
def saveWeights(weights):
|
def saveWeights(weights):
|
||||||
|
Loading…
Reference in New Issue
Block a user