You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I’m trying to set globalDecay and maxAge to a value greater than zero in a TMRegion. But I keep getting an AssertionError.
I looked at these docs, and they say that maxSynapsesPerSegment and maxSegmentsPerCell must be set to -1 to disable fixed-sized CLA mode, but setting those two parameters don’t seem to correct the problem.
Does anyone know how to set globalDecay and maxAge to values greater than zero?
Traceback (most recent call last):
File "./nunetwork.py", line 655, in<module>
fq_results_filename=FQ_RESULTS_FILENAME)
File "./nunetwork.py", line 487, in run_the_predictor
network = createNetwork(dataSource=dataSource, fq_model_filename=fq_model_filename)
File "./nunetwork.py", line 391, in createNetwork
network.initialize()
File "/opt/python_envs/nupic/local/lib/python2.7/site-packages/nupic/engine/__init__.py", line 697, in initialize
engine_internal.Network.initialize(self, *args, **kwargs)
File "/opt/python_envs/nupic/local/lib/python2.7/site-packages/nupic/bindings/engine_internal.py", line 1210, in initialize
return _engine_internal.Network_initialize(self)
File "/opt/python_envs/nupic/local/lib/python2.7/site-packages/nupic/regions/tm_region.py", line 425, in initialize
**autoArgs)
File "/opt/python_envs/nupic/local/lib/python2.7/site-packages/nupic/algorithms/backtracking_tm_cpp.py", line 162, in __init__
outputType = outputType,
File "/opt/python_envs/nupic/local/lib/python2.7/site-packages/nupic/algorithms/backtracking_tm.py", line 214, in __init__
assert (globalDecay == 0.0)
AssertionError
Work Around
I just did some debugging into the nupic library, and discovered in backtracking_tm_cpp.py on line 109, default values for maxSegmentsPerCell and maxSynapsesPerSegment are set to -1.
Additionally, when debugging I see the value of both maxSegmentsPerCell and maxSynapsesPerSegment are 4294967295 which is the maximum value for an unsigned int in C. It seems like there might be a problem with the C bindings converting the values input into the model params file, model.yaml, into an unsigned int, but should be converting it to a signed int.
At any rate, commenting out the following two lines from models.yaml works around the issue:
maxSynapsesPerSegment: -1maxSegmentsPerCell: -1
The text was updated successfully, but these errors were encountered:
@rhyolight yeah looks like that functionality is broken which isn't surprising as no one has used it in a while. Would be nice to fix but make sure you don't change behavior of models not using it.
Out of curiosity, is it something amiss in the C-bindings? I ask so that in the future I know better where to look and hopefully lend more of a hand to fixing things rather than just reporting them.
I posted this issue on the HTM Forum. Matt suggested posting it here, so here it is:
Issue
I’m trying to set globalDecay and maxAge to a value greater than zero in a TMRegion. But I keep getting an AssertionError.
I looked at these docs, and they say that maxSynapsesPerSegment and maxSegmentsPerCell must be set to -1 to disable fixed-sized CLA mode, but setting those two parameters don’t seem to correct the problem.
Does anyone know how to set globalDecay and maxAge to values greater than zero?
Here are the parameters and the call-stack:
Work Around
I just did some debugging into the nupic library, and discovered in backtracking_tm_cpp.py on line 109, default values for maxSegmentsPerCell and maxSynapsesPerSegment are set to -1.
Additionally, when debugging I see the value of both maxSegmentsPerCell and maxSynapsesPerSegment are 4294967295 which is the maximum value for an unsigned int in C. It seems like there might be a problem with the C bindings converting the values input into the model params file, model.yaml, into an unsigned int, but should be converting it to a signed int.
At any rate, commenting out the following two lines from models.yaml works around the issue:
The text was updated successfully, but these errors were encountered: