1. Field
Certain aspects of the present disclosure generally relate to neural system engineering and, more particularly, to a method and apparatus for neural learning of natural multi-spike trains in spiking neural networks.
2. Background
The typical spike-timing-dependent plasticity (STDP) learning rule adapts a synaptic weight based on timing between a single pair of pre (input) spike and post (output) spike. However, natural spike trains (e.g., in biology) and spike trains in spiking neural networks do not generally have clearly separated pairs of spikes. Therefore, multiple input and output spikes represent the general case. Yet, learning based on the STDP may fail to converge due to oscillation of weight increases and decreases. Moreover, the basic STDP learning rule may fail to account for biologically observed learning in multi-spike contexts.
Two main models have been proposed in the literature based on theories. One method requires computation based on all combination pairs (pre-synaptic and post-synaptic). However, this approach is often computationally expensive. The other method explains rate-based effects, but not temporal effects that are relevant for temporal coding. Furthermore, this approach can be dependent on the neuron dynamics model and may require complex filtering on multiple time-scales.
Therefore, a computationally practical method is desired that offers stability and fast learning for spiking networks operating in a temporal coding context, which can also be biologically plausible.
Certain aspects of the present disclosure provide a method of neural learning. The method generally includes modulating an input from a pre-synaptic neuron to a post-synaptic neuron by a weight of a synapse connecting the pre-synaptic neuron and the post-synaptic neuron, and adapting the weight of synapse based on at least one of a resource associated with the synapse, a time since a last change of the weight, or spike timing of the pre-synaptic neuron and the post-synaptic neuron.
Certain aspects of the present disclosure provide an apparatus for neural learning. The apparatus generally includes a first circuit configured to modulate an input from a pre-synaptic neuron to a post-synaptic neuron by a weight of a synapse connecting the pre-synaptic neuron and the post-synaptic neuron, and a second circuit configured to adapt the weight of synapse based on at least one of a resource associated with the synapse, a time since a last change of the weight, or spike timing of the pre-synaptic neuron and the post-synaptic neuron.
Certain aspects of the present disclosure provide an apparatus for neural learning. The apparatus generally includes means for modulating an input from a pre-synaptic neuron to a post-synaptic neuron by a weight of a synapse connecting the pre-synaptic neuron and the post-synaptic neuron, and means for adapting the weight of synapse based on at least one of a resource associated with the synapse, a time since a last change of the weight, or spike timing of the pre-synaptic neuron and the post-synaptic neuron.
Certain aspects of the present disclosure provide a computer program product for neural learning. The computer program product generally includes a computer-readable medium comprising code for modulating an input from a pre-synaptic neuron to a post-synaptic neuron by a weight of a synapse connecting the pre-synaptic neuron and the post-synaptic neuron, and adapting the weight of synapse based on at least one of a resource associated with the synapse, a time since a last change of the weight, or spike timing of the pre-synaptic neuron and the post-synaptic neuron.
Certain aspects of the present disclosure provide a method of neural learning. The method generally includes modulating an input from a pre-synaptic neuron to a post-synaptic neuron by a weight of a synapse connecting the pre-synaptic neuron and the post-synaptic neuron, adapting the weight of synapse based on a resource consideration associated with the synapse and spike timing of the pre-synaptic neuron and the post-synaptic neuron, and determining the resource consideration based on one or more timing relations between prior spikes of the pre-synaptic and post-synaptic neurons.
Certain aspects of the present disclosure provide an apparatus for neural learning. The apparatus generally includes a first circuit configured to modulate an input from a pre-synaptic neuron to a post-synaptic neuron by a weight of a synapse connecting the pre-synaptic neuron and the post-synaptic neuron, a second circuit configured to adapt the weight of synapse based on a resource consideration associated with the synapse and spike timing of the pre-synaptic neuron and the post-synaptic neuron, and a third circuit configured to determine the resource consideration based on one or more timing relations between prior spikes of the pre-synaptic and post-synaptic neurons.
Certain aspects of the present disclosure provide an apparatus for neural learning. The apparatus generally includes means for modulating an input from a pre-synaptic neuron to a post-synaptic neuron by a weight of a synapse connecting the pre-synaptic neuron and the post-synaptic neuron, means for adapting the weight of synapse based on a resource consideration associated with the synapse and spike timing of the pre-synaptic neuron and the post-synaptic neuron, and means for determining the resource consideration based on one or more timing relations between prior spikes of the pre-synaptic and post-synaptic neurons.
Certain aspects of the present disclosure provide a computer program product for neural learning. The computer program product generally includes a computer-readable medium comprising code for modulating an input from a pre-synaptic neuron to a post-synaptic neuron by a weight of a synapse connecting the pre-synaptic neuron and the post-synaptic neuron, adapting the weight of synapse based on a resource consideration associated with the synapse and spike timing of the pre-synaptic neuron and the post-synaptic neuron, and determining the resource consideration based on one or more timing relations between prior spikes of the pre-synaptic and post-synaptic neurons.
Certain aspects of the present disclosure provide a method of neural learning. The method generally includes modulating an input from a pre-synaptic neuron to a post-synaptic neuron by a weight of a synapse connecting the pre-synaptic neuron and the post-synaptic neuron, adapting the weight of synapse based on a resource consideration associated with the synapse and spike timing of the pre-synaptic neuron and the post-synaptic neuron, and determining the resource consideration based on an amount of time since a prior commitment to a change of the weight.
Certain aspects of the present disclosure provide an apparatus for neural learning. The apparatus generally includes a first circuit configured to modulate an input from a pre-synaptic neuron to a post-synaptic neuron by a weight of a synapse connecting the pre-synaptic neuron and the post-synaptic neuron, a second circuit configured to adapt the weight of synapse based on a resource consideration associated with the synapse and spike timing of the pre-synaptic neuron and the post-synaptic neuron, and a third circuit configured to determine the resource consideration based on an amount of time since a prior commitment to a change of the weight.
Certain aspects of the present disclosure provide an apparatus for neural learning. The apparatus generally includes means for modulating an input from a pre-synaptic neuron to a post-synaptic neuron by a weight of a synapse connecting the pre-synaptic neuron and the post-synaptic neuron, means for adapting the weight of synapse based on a resource consideration associated with the synapse and spike timing of the pre-synaptic neuron and the post-synaptic neuron, and means for determining the resource consideration based on an amount of time since a prior commitment to a change of the weight.
Certain aspects of the present disclosure provide a computer program product for neural learning. The computer program product generally includes a computer-readable medium comprising code for modulating an input from a pre-synaptic neuron to a post-synaptic neuron by a weight of a synapse connecting the pre-synaptic neuron and the post-synaptic neuron, adapting the weight of synapse based on a resource consideration associated with the synapse and spike timing of the pre-synaptic neuron and the post-synaptic neuron, and determining the resource consideration based on an amount of time since a prior commitment to a change of the weight.
So that the manner in which the above-recited features of the present disclosure can be understood in detail, a more particular description, briefly summarized above, may be had by reference to aspects, some of which are illustrated in the appended drawings. It is to be noted, however, that the appended drawings illustrate only certain typical aspects of this disclosure and are therefore not to be considered limiting of its scope, for the description may admit to other equally effective aspects.
Various aspects of the disclosure are described more fully hereinafter with reference to the accompanying drawings. This disclosure may, however, be embodied in many different forms and should not be construed as limited to any specific structure or function presented throughout this disclosure. Rather, these aspects are provided so that this disclosure will be thorough and complete, and will fully convey the scope of the disclosure to those skilled in the art. Based on the teachings herein one skilled in the art should appreciate that the scope of the disclosure is intended to cover any aspect of the disclosure disclosed herein, whether implemented independently of or combined with any other aspect of the disclosure. For example, an apparatus may be implemented or a method may be practiced using any number of the aspects set forth herein. In addition, the scope of the disclosure is intended to cover such an apparatus or method which is practiced using other structure, functionality, or structure and functionality in addition to or other than the various aspects of the disclosure set forth herein. It should be understood that any aspect of the disclosure disclosed herein may be embodied by one or more elements of a claim.
The word “exemplary” is used herein to mean “serving as an example, instance, or illustration.” Any aspect described herein as “exemplary” is not necessarily to be construed as preferred or advantageous over other aspects.
Although particular aspects are described herein, many variations and permutations of these aspects fall within the scope of the disclosure. Although some benefits and advantages of the preferred aspects are mentioned, the scope of the disclosure is not intended to be limited to particular benefits, uses or objectives. Rather, aspects of the disclosure are intended to be broadly applicable to different technologies, system configurations, networks and protocols, some of which are illustrated by way of example in the figures and in the following description of the preferred aspects. The detailed description and drawings are merely illustrative of the disclosure rather than limiting, the scope of the disclosure being defined by the appended claims and equivalents thereof.
As illustrated in
The transfer of spikes from one level of neurons to another may be achieved through the network of synaptic connections (or simply “synapses”) 104, as illustrated in
The neural system 100 may be emulated by an electrical circuit and utilized in a large range of applications, such as image and pattern recognition, machine learning, motor control, and alike. Each neuron in the neural system 100 may be implemented as a neuron circuit. The neuron membrane charged to the threshold value initiating the output spike may be implemented, for example, as a capacitor that integrates an electrical current flowing through it.
In an aspect, the capacitor may be eliminated as the electrical current integrating device of the neuron circuit, and a smaller memristor element may be used in its place. This approach may be applied in neuron circuits, as well as in various other applications where bulky capacitors are utilized as electrical current integrators. In addition, each of the synapses 104 may be implemented based on a memristor element, wherein synaptic weight changes may relate to changes of the memristor resistance. With nanometer feature-sized memristors, the area of neuron circuit and synapses may be substantially reduced, which may make implementation of a very large-scale neural system hardware implementation practical.
Learning in spiking neural networks, such as the neural network 100 from
Certain aspects of the present disclosure support an engineering solution based on a resource concept to stabilize and accelerate multi-spike learning. Recently, new biological evidence has been found contrary to the typical STDP rule. Certain theories and models have been proposed to explain multi-spike or spike-rate phenomenons. However, these models are complex requiring maintaining histories of prior spike times, computing multiple filters, and having large number of parameters to which performance is sensitive. In addition, these models are not independent computationally from other aspects of an engineered spiking neural network. The resource-based method proposed in the present disclosure is computationally simpler, largely separable, and outperforms the other methods.
The STDP learning rule may effectively adapt a synaptic weight of a synapse connecting a neuron A to a neuron B as a function of time difference between the pre-synaptic neuron A's spike time tpre and post-synaptic neuron B's spike time tpost(i.e., Δt=tpost−tpre). A typical formulation of the STDP is to increase the synaptic weight (i.e., potentiate the synapse) if the time difference is positive (the pre-synaptic neuron fires before the post-synaptic neuron), and decrease the synaptic weight (i.e., depress the synapse) if the time difference is negative (the post-synaptic neuron fires before the pre-synaptic neuron). A change of the synaptic weight may be typically achieved using an exponential decay, as given by:
Δw=Asign(Δt)·e−|Δt|/τ
where τsign(Δt) is a time constant and Asign(Δt) is a scaling magnitude, wherein both τsign(Δt) and Asign(Δt) may typically depend on whether the time difference is positive or negative.
The STDP learning rule is clear if there is one pre-synaptic spike and one post-synaptic spike. On the other hand, the STDP learning rule is not clear if there are multiple spikes, because it is not clear which time should be used. One simple engineering solution can be to use the latest (most recent) times for spikes. In other words, instead of considering all pair combinations, only sequential pairs of spikes are considered. However, there are at least two problems with this approach.
First, using the latest spike time with the typical STDP rule can be insufficient to ensure stable learning. For example, a spike of the pre-synaptic neuron A may be followed by a spike of the post-synaptic neuron B followed by another spike of the pre-synaptic neuron A (a pre-post-pre triplet). Now, the question is should the weight of synapse connecting the neuron A to the neuron B be increased or decreased. According to the STDP rule, the weight would be first increased and then decreased. The overall change would be based on the timing of the independent pairs of the first pre-synaptic spike and the post-synaptic spike, and the second pre-synaptic spike and the post-synaptic spike. However, it is clear that the weight changes conflict each other. The situation may become worse with more spikes, and if the weight update is not performed immediately but rather accumulated.
Second, using the latest spike time with the typical STDP learning rule does not predict the biologically observed learning effects in natural multi-spike trains. Rather, the STDP rule may often predict the completely opposite learning effect (e.g., increase in synaptic weight rather than decrease). Certain theories and methods have been proposed in the literature to explain and model such observed multi-spike trains. However, there are several problems with these prior methods.
One proposed method may require computation based on all combination pairs (pre-synaptic and post-synaptic). This approach can be problematic for several reasons. First, weight adaptation is a function of timing of all spikes. Therefore, an engineering of neural network may require keeping track of a history of pre-synaptic and post-synaptic spikes to be able to compute weight adaptation based on considering all possible pairs of spikes that occurred. This can be computationally very onerous because it may require considering: (i) the time difference between successive spikes of each neuron n at times tn,i and tn,i−1 in order to compute an efficacy for each spike i,
εn,i=1−e−(t
where τe is a time constant depending on whether the neuron is pre-synaptic or post-synaptic, and (ii) each combination of pairs of pre-synaptic and post-synaptic spikes occurring in the past because the weight change is given by,
where n represents the post-synaptic neuron, m represents the pre-synaptic neuron, and i and j are indices of all the prior spikes of that corresponding neuron. Clearly, this may become more and more onerous (in terms of both memory and computation) for multi-spike trains with more spikes.
Second, this method can be sensitive to the time constant parameters for the efficacy filters in terms of accurate and precise predicting of biologically observed data. For example, one setting may predict spike triplets better while resulting in a worse prediction of learning of spike quadruplets. Third, the learning may not be entirely separable from the spiking behavior because of the dependence on the efficacy variables.
The other proposed method predicting neural activity with simple neural models of the threshold type (adaptive exponential integrate-and-fire model with two compartments) may explain rate-based effects. However, this method can be also problematic for several reasons. First, weight adaptation can be based on multiple filters including a synaptic trace filter (of synaptic input xm(t) from a pre-synaptic neuron m) and two separate filters of membrane potential un(t) of a post-synaptic neuron n. These filters take the form of differential equations. For example, one of the post-synaptic membrane potential filters may be described as:
All these filters (one per synapse and two per neuron) are in addition to the model of the neuron itself. The filters can be generally defined in terms of time constants (i.e., one for the pre-synaptic and two for the post-synaptic neuron) and thresholds (one for weight increase and one for weight decrease). Second, this is clearly complicated as the thresholds and time constants may depend on the neuron model being used since they are functions of the neuron membrane potential and not of the spiking (for example, whether a leaky integrate-and-fire neuron model is used or Izhikevich simple neuron model, or otherwise). For example, in this approach, the neuron model can be quite complicated, i.e., the adaptive exponential integrate-and-fire model, given by:
where C is a membrane capacitance, gL is a leak conductance, EL is a resting potential, ΔT is a slope factor, and VT is a threshold potential. In other words, if the neuron dynamics are changed, the thresholds and time constants may have to be changed.
Third, while this method may predict some biologically observed learning as a function of spiking rates, the method does not reliably predict spike timing dependent learning, such as for a cortex. An easy way to observe this is that no learning will occur in the model defined by equation (5) unless there has been a recent post-synaptic activity (prior to a pre-synaptic-post-synaptic pair) because of the rectified term (ū+(t)−θ−)+ in the weight adaptation formulation,
Fourth, the weight adaptation rule may not be separable from the neuron dynamics. Fifth, the memory and computational resources may be required for all the filters and variables.
A method proposed in the present disclosure solves the aforementioned problems by adapting a synaptic weight depending on a learning resource associated with the synapse, which may be depleted by weight change and recovers over time. In the preferred embodiment of the present disclosure, the weight adaptation may be dependent only on the time since the last significant weight change. Hence, this method may be separable and may require no spike trace memory, and can even reduce the frequency of weight changes.
The method proposed in the present disclosure may provide multiple advantages over other methods. First, it may result in stable and fast learning in multi-spike train contexts as well as in single spike contexts, and may accurately and precisely predict biologically observed learning effects in single and multi-spike contexts. Second, the proposed method has very low complexity. Learning or adaptation may depend only on one variable, and thus it may not require history, filtering, or other complex operations. Third, the proposed method may be computationally separable from other neuron operations. The weight adaptation may depend on aspects of the last adaptation, and not of the spike history or neuron dynamics. It may also be independent of the neuron model (whether integrate and fire, leaking integrate and fire, Izhikevich simple model, or any other spiking model). Fourth, the proposed method may reduce the computational complexity even relative to the typical sequential pair-wise STDP. This may be because, in the preferred embodiment, weight adaptation may actually be avoided depending on the prior adaptations. Therefore, an engineering of neural network may operate faster by having fewer weight changes, and yet have better performance. All of these advantages will be explained and demonstrated in the present disclosure.
Certain aspects of the present disclosure provide adapting a synaptic weight depending on available learning resources and spike timing. In an aspect, learning resources may be depleted by synaptic modifications, and may be recovered over time. The amount of synaptic modification may be limited by the amount of learning resources available. According to certain aspects of the present disclosure, the learning resources may be modeled as a single quantity available for a particular neuron or compartment or synapse. In the preferred aspect of the present disclosure, the resources may be per-synapse per-neuron.
In an exemplary case, each neuron n may be a spiking leaky integrate and fire neuron with a membrane voltage vn (t) governed by, for example, the following dynamics,
where α and β are parameters, wm,n is a synaptic weight for the synapse connecting a pre-synaptic neuron m to a post-synaptic neuron n, and ym(t) is the spiking output of the neuron m that may be delayed by dendritic or axonal delay according to Δtm,n until arrival at the neuron n's soma.
In an aspect of the present disclosure, the adaptation of synaptic weight for a synapse connecting the pre-synaptic neuron m to a post-synaptic neuron n may be given by:
Δwm,n=rm,nAsign(Δt)e−|Δt|/τ
or after dropping the indices,
Δw=rAsign(Δt)e−|Δt|/τ
where Δt is the time difference between a post-synaptic spike and a pre-synaptic spike, and r (or rm,n) represents available resources.
In an aspect, if all resources are available, rm,n=1. On the other hand, if no resources are available, rm,n=0. It should be noted that if no resources are available, it may not be required to even compute time difference, sign or exponent. For example, for each of these, the latest values may be used, or Δt=tnlatest−tmlatest. It is proposed in the present disclosure that the weight adaptation has an associated resource time tr (whether or not that is the actual time of the weight change or any other operation) representing the time at which commitment to a synaptic change is made. In an aspect, the resource time may be determined based on the pre-synaptic spike time or the post-synaptic spike time, whichever is later, i.e.,
t
r=max(tn,tm). (10)
In a preferred aspect of the present disclosure, the time defined by equation (10) may be the effective time of weight adaptation (if there is a weight change). In other words, a change in weight may be triggered either upon a post-synaptic firing (after a pre-synaptic firing) or upon a pre-synaptic firing (after a post-synaptic firing).
According to certain aspects, when a weight change occurs, resources may be used up. When the next weight adaptation is being considered, the amount of available resources may be first determined. In one aspect, the amount of available resources may be computed according to:
r=1−rused·e−(t
where the neuron subscripts for the resources r have been omitted to improve clarity. In an aspect, if this is done at the time of potential weight adaptation, tr=t (the current time) and trlast is the time of the prior (last) resource usage (weight adaptation).
Since resources may have been depleted previously, more general model for the resource recovery may be given as:
r(t)=1−(1−r(trlast))·e−(t−t
Alternatively, the resource recovery may be modeled in discrete time. In an aspect of the present disclosure, the resource variable r may be recovered using a step-wise Infinite Impulse Response (IIR) filter, as given by:
r=1−c(1−r), (13)
where the coefficient c may be a value smaller than one depending on the desired time constant. Equivalently, the lack of resource r′ may be modeled instead of the availability of resource r, where r=1−r′. Therefore, equation (12) can be simplified to:
r′=cr′, (14)
where the resource variable r should then be replaced by the variable (1−r′) in equation (9) defining the weight adaptation.
Effectively, the resources used previously (rlast) may be recovered with time constant τr up to the maximum (e.g., to the value of one, without loss of generality). In an aspect, the resources used upon a weight change may be expressed as a function of weight change:
r
used
=f(Δw) (15)
An example of the function of weight change can be to utilize weights in the range [0,1], and use an absolute value of the weight change as the resources used up or, rused=|Δw|. In addition, a scaling factor may be applied, rused=Au|Δw|.
Some advantages of the proposed method can now be observed. First, the method may be computationally non-burdensome. Second, the proposed method may only require knowledge of the resources available, which may only be a function of time since the last resource usage, not of when prior spikes occurred. Third, the proposed method may efficiently work with any spiking neuron model. Although demonstrated with a leaky-integrate and fire neuron model, the proposed method has no dependence on this but rather only on the adaptation timing. Moreover, this method may not even depend on the weight change rule (whether exponential as illustrated in
Further advantages of the proposed method may be obtained in the preferred embodiment. In particular, computations may be reduced. Instead of changing weights upon every potential event (pre-post or post-pre), a threshold may be applied to weight changes. Namely, a weight change may not be made unless there is a sufficient threshold of resources available, i.e.,
Δw=(r>θr)Asign(Δt)e−|Δt|/τ
where rm,n>θr is a logical expression yielding 0 or 1, and θr is a first resource threshold. If resources are below the threshold, computation of weight change may not be required. This may save computation and memory lookup for time differences.
Further, resource usage may be conditioned depending on a minimum weight change, i.e.,
r
used
=f(Δwm,n) if Δwm,n>θw, else rused=0, (17)
where θw is a threshold of minimum change. For example, f(Δwm,n)=1 may be used to render this operation independent of the amount of weight change. In this formulation, either resources are fully used or not used at all (i.e., rused=1 or 0).
It can be observed that it may not be required keeping track of resources r, but of the time of the last non-zero resource usage trlast because the weight change consideration may be given by:
r=1−e−(t
Δw=(r>θr)Asign(Δt)e−|Δt|/τ
Given the value for τr, equation (18) can be solved for Δtr=t−trlast in,
1−e−(Δt
Obtaining parameter Δtr may be given by,
Δtr=−τr log(1−θr). (21)
Therefore, the weight change defined by equation (19) may be given by:
Δw=(t−trlast>Δtr)Asign(Δt)e−|Δt|/τ
According to equation (22), if the time since last resource usage is larger than Δtr, then a weight adaptation may be considered by computing the remainder of equation (22). Further, if the absolute value of the weight change is above θw, set trlast=t. Otherwise, either leave trlast unchanged or set trlast=−∞.
The method of synapse weight adaptation proposed in the present disclosure, may provide stable and fast learning, and may also predict biological learning since resources may be required to change synaptic weights. It has been theorized in the literature that long-term potentiation (LTP, weight increase) and long-term depression (LTD, weight decrease) are independent processes. However, the triggering mechanisms, if both based on Ca2+ dynamics, may not be independent and thus the LTP and LTD may be related. In other words, the trigger mechanism for weight change may be common and make use of a single resource model biologically realistic. Nevertheless, it may not be necessary to use only one resource in the method.
The method proposed in the present disclosure may be extended to utilize two or more resources and assign each of these to a particular weight adaptation operation. For example, one resource may be used for LTP (long-term weight increases) and another resource may be used for LTD (long term weight decreases). Alternatively, one resource may be used for longer term changes and one resource may be used for short term changes, or combinations thereof. For example,
r(j)=1−rused(j)e−(t−t
where j is the particular resource type index.
Alternatively, the same resource may be used for one or more types of weight change but with different parameter τr(i) depending on the type of modification that occurred at trlast, i.e.,
r(j)=1−rusede−(t−t
According to certain aspects, the resource model may also work well if the resources are computed after the weight change rather than before. This may be particularly effective if the resource time constant is set much shorter than with the preferred embodiment defined by equation (22). Various other variations are possible, such as combinations of the aforementioned modifications, quantization, and reordering of operations.
According to certain aspects of the present disclosure, the resource may be modified in relation to adapting the weight of synapse. Further, the resource may be recovered over time towards a value of the resource before the modification. In one aspect, modifying the resource may comprise decreasing the resource. For example, the resource may be decreased by an amount proportional to an absolute value of a change in the weight of synapse during the adaptation. In addition, the resource may be decreased to zero, if an absolute value of a change in the weight of synapse during the adaptation is above a threshold.
In an aspect, a change in the weight of synapse during the adaptation may not be applied, if the resource is below a threshold. In another aspect, a change in the weight of synapse during the adaptation may not be applied, if the time since the last change is below a threshold. Further, recovering the resource over time may comprise recovering, after a time delay, the resource to the value before the modification of resource.
In an aspect, modifying the resource may occur when committing to adapting the weight. In another aspect, modifying the resource may occur when determining an aspect of adapting the weight, and adapting the weight may occur at a later time. For example, the aspect of adapting the weight may comprise at least one of an amount of a change in the weight, or a direction of a change in the weight.
According to certain aspects of the present disclosure, adapting the weight of synapse may further comprise: updating the weight of synapse effective at a time of spiking of the post-synaptic neuron or the pre-synaptic neuron, storing, at a time of the weight update, a time of updating the weight as a last time the resource was used, computing the resource at another time of updating the weight as a function of the other time and the last time the resource was used, and obtaining a change in the weight of synapse as a function of the computed resource. In one aspect, a value of the last time the resource was used may not be overwritten, if a magnitude of the change in the weight of synapse is below a threshold. Further, the change in the weight may be zero, if a value of the other time minus the last time the resource was used is smaller than a threshold.
In an aspect of the present disclosure, weight changes may be made later than when weight changes are triggered. For example, the weight changes may be triggered at pre-synaptic or post-synaptic events, and associated resources may be committed (accounted for) at that time or later depending on the amount of weight change that will occur in the future. The actual weight of the synapse may then be modified at a later time (separately). The weight changes may even be accumulated and applied together or applied slowly over longer time. It should thus be understood that actual weight change and resource modeling may be separated in time.
In an aspect of the present disclosure, the resource may be modeled by an equivalent function of a plurality of relative timings between prior pairings of pre-synaptic and post-synaptic spikes and the relative timing between those pairs. In other words, adapting the weight of synapse may be based on a resource consideration associated with the synapse and spike timing of the pre-synaptic neuron and the post-synaptic neuron, wherein that resource consideration may be determined based on a plurality of timing relations between pre-synaptic and post-synaptic neuron spikes and the timing relations among the plurality.
In an aspect of the present disclosure, the one or more timing relations may comprise information about a time difference between a pair of the prior spikes of the pre-synaptic and post-synaptic neurons. In another aspect, the one or more timing relations may comprise information about a time difference between a pair of the prior spikes and another pair of the prior spikes. In yet another aspect, the one or more timing relations comprise information about a time since a pair of the prior spikes occurred.
The various operations of methods described above may be performed by any suitable means capable of performing the corresponding functions. The means may include various hardware and/or software component(s) and/or module(s), including, but not limited to a circuit, an application specific integrate circuit (ASIC), or processor. Generally, where there are operations illustrated in Figures, those operations may have corresponding counterpart means-plus-function components with similar numbering. For example, operations 600, 700 and 800 illustrated in
As used herein, the term “determining” encompasses a wide variety of actions. For example, “determining” may include calculating, computing, processing, deriving, investigating, looking up (e.g., looking up in a table, a database or another data structure), ascertaining and the like. Also, “determining” may include receiving (e.g., receiving information), accessing (e.g., accessing data in a memory) and the like. Also, “determining” may include resolving, selecting, choosing, establishing and the like.
As used herein, a phrase referring to “at least one of” a list of items refers to any combination of those items, including single members. As an example, “at least one of: a, b, or c” is intended to cover: a, b, c, a-b, a-c, b-c, and a-b-c.
The various illustrative logical blocks, modules and circuits described in connection with the present disclosure may be implemented or performed with a general purpose processor, a digital signal processor (DSP), an application specific integrated circuit (ASIC), a field programmable gate array signal (FPGA) or other programmable logic device (PLD), discrete gate or transistor logic, discrete hardware components or any combination thereof designed to perform the functions described herein. A general purpose processor may be a microprocessor, but in the alternative, the processor may be any commercially available processor, controller, microcontroller or state machine. A processor may also be implemented as a combination of computing devices, e.g., a combination of a DSP and a microprocessor, a plurality of microprocessors, one or more microprocessors in conjunction with a DSP core, or any other such configuration.
The steps of a method or algorithm described in connection with the present disclosure may be embodied directly in hardware, in a software module executed by a processor, or in a combination of the two. A software module may reside in any form of storage medium that is known in the art. Some examples of storage media that may be used include random access memory (RAM), read only memory (ROM), flash memory, EPROM memory, EEPROM memory, registers, a hard disk, a removable disk, a CD-ROM and so forth. A software module may comprise a single instruction, or many instructions, and may be distributed over several different code segments, among different programs, and across multiple storage media. A storage medium may be coupled to a processor such that the processor can read information from, and write information to, the storage medium. In the alternative, the storage medium may be integral to the processor.
The methods disclosed herein comprise one or more steps or actions for achieving the described method. The method steps and/or actions may be interchanged with one another without departing from the scope of the claims. In other words, unless a specific order of steps or actions is specified, the order and/or use of specific steps and/or actions may be modified without departing from the scope of the claims.
The functions described may be implemented in hardware, software, firmware, or any combination thereof. If implemented in software, the functions may be stored or transmitted over as one or more instructions or code on a computer-readable medium. Computer-readable media include both computer storage media and communication media including any medium that facilitates transfer of a computer program from one place to another. A storage medium may be any available medium that can be accessed by a computer. By way of example, and not limitation, such computer-readable media can comprise RAM, ROM, EEPROM, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other medium that can be used to carry or store desired program code in the form of instructions or data structures and that can be accessed by a computer. Also, any connection is properly termed a computer-readable medium. For example, if the software is transmitted from a website, server, or other remote source using a coaxial cable, fiber optic cable, twisted pair, digital subscriber line (DSL), or wireless technologies such as infrared (IR), radio, and microwave, then the coaxial cable, fiber optic cable, twisted pair, DSL, or wireless technologies such as infrared, radio, and microwave are included in the definition of medium. Disk and disc, as used herein, include compact disc (CD), laser disc, optical disc, digital versatile disc (DVD), floppy disk, and Blu-ray® disc where disks usually reproduce data magnetically, while discs reproduce data optically with lasers. Thus, in some aspects computer-readable media may comprise non-transitory computer-readable media (e.g., tangible media). In addition, for other aspects computer-readable media may comprise transitory computer-readable media (e.g., a signal). Combinations of the above should also be included within the scope of computer-readable media.
Thus, certain aspects may comprise a computer program product for performing the operations presented herein. For example, such a computer program product may comprise a computer readable medium having instructions stored (and/or encoded) thereon, the instructions being executable by one or more processors to perform the operations described herein. For certain aspects, the computer program product may include packaging material.
Software or instructions may also be transmitted over a transmission medium. For example, if the software is transmitted from a website, server, or other remote source using a coaxial cable, fiber optic cable, twisted pair, digital subscriber line (DSL), or wireless technologies such as infrared, radio, and microwave, then the coaxial cable, fiber optic cable, twisted pair, DSL, or wireless technologies such as infrared, radio, and microwave are included in the definition of transmission medium.
Further, it should be appreciated that modules and/or other appropriate means for performing the methods and techniques described herein can be downloaded and/or otherwise obtained by a user terminal and/or base station as applicable. For example, such a device can be coupled to a server to facilitate the transfer of means for performing the methods described herein. Alternatively, various methods described herein can be provided via storage means (e.g., RAM, ROM, a physical storage medium such as a compact disc (CD) or floppy disk, etc.), such that a user terminal and/or base station can obtain the various methods upon coupling or providing the storage means to the device. Moreover, any other suitable technique for providing the methods and techniques described herein to a device can be utilized.
It is to be understood that the claims are not limited to the precise configuration and components illustrated above. Various modifications, changes and variations may be made in the arrangement, operation and details of the methods and apparatus described above without departing from the scope of the claims.
While the foregoing is directed to aspects of the present disclosure, other and further aspects of the disclosure may be devised without departing from the basic scope thereof, and the scope thereof is determined by the claims that follow.