Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Python examples fixes #713

Merged
merged 6 commits into from
Oct 8, 2019
Merged
Show file tree
Hide file tree
Changes from 5 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion VERSION
Original file line number Diff line number Diff line change
@@ -1 +1 @@
v2.0.16
v2.0.22
29 changes: 17 additions & 12 deletions py/htm/examples/hotgym.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@
from htm.encoders.date import DateEncoder
from htm.bindings.algorithms import SpatialPooler
from htm.bindings.algorithms import TemporalMemory
from htm.algorithms.anomaly_likelihood import AnomalyLikelihood
from htm.algorithms.anomaly_likelihood import AnomalyLikelihood #FIXME use TM.anomaly instead, but it gives worse results than the py.AnomalyLikelihood now
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

OT: this file is a good place to test and replace the python likelihood with TM.anomaly. Currently the Likelihood from TM (c++) really gives bad results. #665

from htm.bindings.algorithms import Predictor

_EXAMPLE_DIR = os.path.dirname(os.path.abspath(__file__))
Expand Down Expand Up @@ -158,17 +158,20 @@ def main(parameters=default_parameters, argv=None, verbose=True):
tm_info.addData( tm.getActiveCells().flatten() )

# Predict what will happen, and then train the predictor based on what just happened.
pdf = predictor.infer( count, tm.getActiveCells() )
for n in (1, 5):
if pdf[n]:
predictions[n].append( np.argmax( pdf[n] ) * predictor_resolution )
else:
predictions[n].append(float('nan'))
predictor.learn( count, tm.getActiveCells(), int(consumption / predictor_resolution))

anomalyLikelihood = anomaly_history.anomalyProbability( consumption, tm.anomaly )
anomaly.append( tm.anomaly )
anomalyProb.append( anomalyLikelihood )
if count > 5: #skip the n(=to the furthest predictions step) step, as predictor must learn something first
pdf = predictor.infer( tm.getActiveCells() )
breznak marked this conversation as resolved.
Show resolved Hide resolved
for n in (1, 5):
if pdf[n]:
predictions[n].append( np.argmax( pdf[n] ) * predictor_resolution )
else:
predictions[n].append(float('nan'))

anomalyLikelihood = anomaly_history.anomalyProbability( consumption, tm.anomaly )
anomaly.append( tm.anomaly )
anomalyProb.append( anomalyLikelihood )

predictor.learn(count, tm.getActiveCells(), int(consumption / predictor_resolution))


# Print information & statistics about the state of the HTM.
print("Encoded Input", enc_info)
Expand All @@ -189,6 +192,8 @@ def main(parameters=default_parameters, argv=None, verbose=True):
# Calculate the predictive accuracy, Root-Mean-Squared
accuracy = {1: 0, 5: 0}
accuracy_samples = {1: 0, 5: 0}
inputs = inputs[6:] #crop the first max prediction-steps inputs (as those don't have inferences)

for idx, inp in enumerate(inputs):
for n in predictions: # For each [N]umber of time steps ahead which was predicted.
val = predictions[n][ idx ]
Expand Down
10 changes: 5 additions & 5 deletions py/htm/examples/sp/sp_tutorial.py
Original file line number Diff line number Diff line change
Expand Up @@ -103,8 +103,7 @@ def corruptSDR(sdr, noiseLevel):
# input. As well, the histogram will show the scores of those columns
# that are chosen to build the sparse representation of the input.

sp.compute(inputSDR, False, outputSDR)
overlaps = sp.getOverlaps()
overlaps = sp.compute(inputSDR, False, outputSDR)
activeColsScores = []
for i in outputSDR.sparse:
activeColsScores.append(overlaps[i])
Expand Down Expand Up @@ -240,10 +239,12 @@ def corruptSDR(sdr, noiseLevel):
# This is the number of times that we will present the input vectors to the SP
epochs = 30

overlapsUntrained = overlaps

for _ in range(epochs):
for i in range(numExamples):
# Feed the examples to the SP
sp.compute(inputVectors[i], True, outputColumns[i])
overlaps = sp.compute(inputVectors[i], True, outputColumns[i])

print("")
print("---------------------------------")
Expand All @@ -254,8 +255,7 @@ def corruptSDR(sdr, noiseLevel):
print("---------------------------------")
print("")

plt.plot(sorted(overlaps)[::-1], label="Before learning")
overlaps = sp.getOverlaps()
plt.plot(sorted(overlapsUntrained)[::-1], label="Before learning")
plt.plot(sorted(overlaps)[::-1], label="After learning")
plt.axvspan(0, len(activeColsScores), facecolor="g", alpha=0.3, label="Active columns")
plt.legend(loc="upper right")
Expand Down