The present invention provides an event-driven universal neural network circuit. The circuit comprises a plurality of neural modules. Each neural module comprises multiple digital neurons such that each neuron in a neural module has a corresponding neuron in another neural module. An interconnection network comprising a plurality of digital synapses interconnects the neural modules. Each synapse interconnects a first neural module to a second neural module by interconnecting a neuron in the first neural module to a corresponding neuron in the second neural module. Corresponding neurons in the first neural module and the second neural module communicate via the synapses. Each synapse comprises a learning rule associating a neuron in the first neural module with a corresponding neuron in the second neural module. A control module generates signals which define a set of time steps for event-driven operation of the neurons and event communication via the interconnection network.
|
1. A method comprising:
at a neural network circuit comprising a plurality of neurons interconnected via a plurality of synapses:
applying a first set of learning rules to a first set of synapses of the plurality of synapses, wherein the first set of synapses has a first synapse type;
reversing the first set of learning rules to obtain a second set of learning rules that is different from the first set of learning rules;
applying the second set of learning rules to a second set of synapses of the plurality of synapses, wherein the second set of synapses is different from the first set of synapses, and the second set of synapses has a second synapse type that is different from the first synapse type;
receiving at least one input event at a first set of neurons of the plurality of neurons; and
generating at least one output event at a second set of neurons of the plurality of neurons, wherein the second set of neurons is different from the first set of neurons.
8. A neural network circuit, comprising:
a plurality of neurons; and
a plurality of synapses interconnecting the plurality of neurons;
wherein the plurality of neurons comprise a first set of neurons for receiving at least one input event;
wherein the plurality of neurons further comprises a second set of neurons for generating at least one output event, the second set of neurons different from the first set of neurons;
wherein a first set of learning rules is applied to a first set of synapses of the plurality of synapses, the first set of synapses having a first synapse type;
wherein the first set of learning rules is reversed to obtain a second set of learning rules that is different from the first set of learning rules; and
wherein the second set of learning rules is applied to a second set of synapses of the plurality of synapses, the second set of synapses different from the first set of synapses, and the second set of synapses having a second synapse type that is different from the first synapse type.
14. A non-transitory computer program product comprising a computer-readable hardware storage medium having program code embodied therewith, the program code being executable by a computer to implement a method comprising:
at a neural network circuit comprising a plurality of neurons interconnected via a plurality of synapses:
applying a first set of learning rules to a first set of synapses of the plurality of synapses, wherein the first set of synapses has a first synapse type;
reversing the first set of learning rules to obtain a second set of learning rules that is different from the first set of learning rules;
applying the second set of learning rules to a second set of synapses of the plurality of synapses, wherein the second set of synapses is different from the first set of synapses, and the second set of synapses has a second synapse type that is different from the first synapse type;
receiving at least one input event at a first set of neurons of the plurality of neurons; and
generating at least one output event at a second set of neurons of the plurality of neurons, wherein the second set of neurons is different from the first set of neurons.
2. The method of
3. The method of
4. The method of
5. The method of
6. The method of
7. The method of
11. The neural network circuit of
12. The neural network circuit of
13. The neural network circuit of
16. The computer program product of
17. The computer program product of
18. The computer program product of
19. The computer program product of
|
This invention was made with Government support under HR0011-09-C-0002 awarded by Defense Advanced Research Projects Agency (DARPA). The Government has certain rights in this invention.
The present invention relates to neuromorphic and synaptronic computation, and in particular, an event-driven universal neural network circuit.
Neuromorphic and synaptronic computation, also referred to as artificial neural networks, are computational systems that permit electronic systems to essentially function in a manner analogous to that of biological brains. Neuromorphic and synaptronic computation do not generally utilize the traditional digital model of manipulating 0s and 1s. Instead, neuromorphic and synaptronic computation create connections between processing elements that are roughly functionally equivalent to neurons of a biological brain. Neuromorphic and synaptronic computation may comprise various electronic circuits that are modeled on biological neurons.
In biological systems, the point of contact between an axon of a neural module and a dendrite on another neuron is called a synapse, and with respect to the synapse, the two neurons are respectively called pre-synaptic and post-synaptic. The essence of our individual experiences is stored in conductance of the synapses. The synaptic conductance changes with time as a function of the relative spike times of pre-synaptic and post-synaptic neurons, as per spike-timing dependent plasticity (STDP). The STDP rule increases the conductance of a synapse if its post-synaptic neuron fires after its pre-synaptic neuron fires, and decreases the conductance of a synapse if the order of the two firings is reversed.
The present invention relates to an event-driven universal neural network circuit. In one embodiment, the present invention provides a neural network circuit comprising a plurality of neural modules, wherein each neural module comprises multiple digital neurons such that each neuron in a neural module has a corresponding neuron in another neural module. An interconnection network comprising a plurality of digital synapses interconnects the plurality of neural modules. Each synapse interconnects a first neural module to a second neural module by interconnecting a neuron in the first neural module to a corresponding neuron in the second neural module such that corresponding neurons in the first neural module and the second neural module communicate via the synapses. Each synapse comprises a learning rule associating a neuron in the first neural module with a corresponding neuron in the second neural module. A control module generates signals which define a set of time steps for event driven operation of the neurons and event communication via the interconnection network.
In another embodiment, the present invention provides a method comprising performing event-driven spiking computation in a neural network circuit comprising a plurality of neural modules. Each neural module includes multiple digital neurons such that every neuron in a first neural module is connected to a corresponding neuron in a second neural module via an interconnect network of synapses. Each synapse includes a learning rule associating a neuron in the first neural module with a corresponding neuron in the second neural module. Event-driven spiking computation comprises generating signals which define a set of time steps for event-driven operation of the neurons and event communication via the interconnect network. At each time step, each neuron updates its operational state. Based on its operational state, each neuron determines whether to generate a firing event in response to firing events received as input signals from corresponding neurons in other neural modules. Each received input signal is weighted by a synaptic weight of the synapse communicating the input signal to the neuron.
These and other features, aspects and advantages of the present invention will become understood with reference to the following description, appended claims and accompanying figures.
The present invention relates to an event-driven universal neural network circuit. In one embodiment, the present invention provides a neural network circuit comprising a plurality of neural modules, wherein each neural module comprises multiple digital neurons such that each neuron in a neural module has a corresponding neuron in another neural module. An interconnection network comprising a plurality of digital synapses interconnects the plurality of neural modules. Each synapse interconnects a first neural module to a second neural module by interconnecting a neuron in the first neural module to a corresponding neuron in the second neural module such that corresponding neurons in the first neural module and the second neural module communicate via the synapses. Each synapse comprises a learning rule associating a neuron in the first neural module with a corresponding neuron in the second neural module. A control module generates signals which define a set of time steps for event driven operation of the neurons and event communication via the interconnection network.
In another embodiment, the present invention provides a method comprising performing event-driven spiking computation in a neural network circuit comprising a plurality of neural modules. Each neural module includes multiple digital neurons such that every neuron in a first neural module is connected to a corresponding neuron in a second neural module via an interconnect network of synapses. Each synapse includes a learning rule associating a neuron in the first neural module with a corresponding neuron in the second neural module. Event-driven spiking computation comprises generating signals which define a set of time steps for event-driven operation of the neurons and event communication via the interconnect network. At each time step, each neuron updates its operational state. Based on its operational state, each neuron determines whether to generate a firing event in response to firing events received as input signals from corresponding neurons in other neural modules. Each received input signal is weighted by a synaptic weight of the synapse communicating the input signal to the neuron.
Each neuron has an operational state. Based on its operational state, each neuron generates a firing event in response to one or more firing events received as input signals from corresponding neurons in other neural modules via connected synapses. Each said input signal is weighted by said weight of the synapse communicating the input signal to the neuron.
Each neural module generates a firing event vector indicating which neurons in the neural module generated a firing event. The weights of all synapses in the interconnection network are adaptive as a function of the history of the firing event vectors from the first and the second neural modules.
An interface module updates learning rules in one or more synapses in the interconnection network. A learning rule for learning false negatives or unlearning false positives is applied to a synapse in the interconnection network when a neuron interconnected with the synapse generates a firing event.
Each neuron comprises a reconfigurable digital complementary metal-oxide-semiconductor (CMOS) circuit for logic and memory elements for its operational state. Each synapse between two neural modules comprises a reconfigurable digital CMOS circuit for logic and memory elements for its operational state. Each synapse between two neural modules further comprises a communication link implemented via a combination of logical and physical primitives.
Embodiments of the invention provide an event-driven design for a universal neural network circuit. Embodiments of the invention further provide an adaptive neural network circuit that can interface in real-time with spatiotemporal sensorium and motorium to carry out tasks of perception including unsupervised learning, action including supervised learning, and cognition including reinforcement learning, in a noise-robust, self-tuning, and self-configuring fashion. Embodiments of the invention further provide a neural network circuit that provides locality and massive parallelism to enable a low-power, compact hardware implementation.
The term digital neuron as used herein represents an architecture configured to simulate a biological neuron. A digital neuron creates connections between processing elements that are roughly functionally equivalent to neurons of a biological brain. As such, a neuromorphic and synaptronic computation comprising digital neurons according to embodiments of the invention may include various electronic circuits that are modeled on biological neurons. Further, a neuromorphic and synaptronic computation comprising digital neurons according to embodiments of the invention may include various processing elements (including computer simulations) that are modeled on biological neurons. Although certain illustrative embodiments of the invention are described herein using digital neurons comprising electronic circuits, the present invention is not limited to electronic circuits. A neuromorphic and synaptronic computation according to embodiments of the invention can be implemented as a neuromorphic and synaptronic architecture comprising circuitry, and additionally as a computer simulation. Indeed, embodiments of the invention can take the form of an entirely hardware embodiment, an entirely software embodiment or an embodiment containing both hardware and software elements.
An external two-way communication environment may supply sensory inputs and consume motor outputs. Digital neurons implemented using CMOS logic gates receive spike inputs and integrate them. The neurons include comparator circuits that generate spikes when the integrated input exceeds a threshold. In one embodiment, binary synapses are implemented using transposable 1-bit static random access memory (SRAM) cells, wherein each neuron can be an excitatory or inhibitory neuron. Each learning rule on each neuron axon and dendrite are reconfigurable.
A neural network circuit can be represented as a directed graph, with neurons represented by vertices, and synapses between neurons represented by directed edges, each edge associated with a synaptic weight.
The neural network circuit 5 further comprises multiple synapses, synapses 6 and 7. The synapse 6 interconnects every neuron in the neural module 1 to a corresponding neuron in the neural module 2. The synapse 7 interconnects every neuron in the neural module 2 to a corresponding neuron in the neural module 3.
In general, in accordance with an embodiment of this invention, each synapse interconnects only two neural modules. In this specification, any two neural modules a synapse interconnects is generally referred to as “neural module A” and “neural module B”. Each synapse comprises only two ports, a first port connecting the synapse to the “neural module A”, and a second port connecting the synapse to the “neural module B”. In this specification, the first port and the second port of a synapse are generally referred to as “port A” and “port B”, respectively.
Referring back to
Further, each synapse 6, 7 comprises learning rules. The synapse 6 comprises a learning rule associating a neuron in the neural module 1 with a corresponding neuron in the neural module 2. The synapse 6 comprises a learning rule associating a neuron in the neural module 2 with a corresponding neuron in the neural module 3.
Also shown in
Also shown in
With respect to each connection to a synapse, a port of a neural module is classified as one of two types, “port A” or “port B”. If a port of a neural module is a “port A” type, the port connects the neural module to a “port A” of a synapse. If a port of a neural module is a “port B” type, the port connects the neural module to a “port B” of a synapse.
In
In general, in accordance with an embodiment of the invention, the data structure of a neural module comprises the following: x ports, and p neurons. For every port, the data structure of the neural module further comprises a list of all synapses that the port is connected to, the sum of the synaptic weights of all synapses the port is connected to, and a target for the sum of the synaptic weights. If the sum of the synaptic weights is over or under the target, the learning rules of the synapses in the neural network circuit are updated.
For every neuron in the neural module, the data structure of the neural module further comprises a membrane potential of the neuron, a last firing time of the neuron, a list of ports in the neural module that the neuron's output will go to, and a list of ports in the neural module that the neuron's input will come from.
In general, in accordance with an embodiment of the invention, the data structure of a synapse comprises the following: the synaptic weight of the synapse, the delay of the synapse, a pointer to “neural module A”, and a pointer to “neural module B”. The data structure of the synapse further comprises information relating to the most recent communication the synapse had with the “neural module A” and the “neural module B”. Such information includes the last synaptic weight sent to the “neural module A”, the last synaptic weight sent to the “neural module B”, the last spiking times of the p neurons in the “neural module A”, and the last spiking times of the p neurons in the “neural module B”.
The synapse data structure further comprises p2 learning rules. Each learning rule is denoted as R[a][b], wherein a is the index of a neuron in the neural module A, and b is the index of a neuron in the neural module B. Some of the learning rules may be null.
Each neural module has p(p−1)/2 coupling efficiencies between neurons and its associated learning rules.
As shown in
With respect to the synapse 201, the neurons li↑, li+1↓, ui↑, and ui+1↓ are pre-synaptic neurons and the neurons li+1↑, li↓, ui+1↑, and ui↓ are post-synaptic neurons.
In one example, the neural modules 202 and 203 can be treated as the “neural module A” and the “neural module B” that the synapse 201 is connected to, respectively. The data structure for the synapse 201 includes the synaptic weight of the synapse 201, the delay of the synapse 201, a pointer to the neural module 202, a pointer to the neural module 203, the last weight sent to the neural module 202, the last weight sent to the neural module 203, the last spiking times of the four neurons li↑, li↓, ui↑, and ui↓ in the neural module 202, and the last spiking times of the four neurons li+1↑, li+1↓, ui+1↑, and ui+1↓ in the neural module 203. The data structure for the synapse 201 further comprises sixteen (p2=16, where p=4) learning rules. There is a learning rule associating each neuron (li↑, li↓, ui↑, and ui↓) in the neural module 202 with each neuron (li+1↑, li+1↓, ui+1↑, and ui+1↓) in the neural module 203. Some of the learning rules may be null.
In one time step, each neuron in every neuron module updates its operational state and, based on its operational state, each said neuron determines whether to generate a firing event in response to firing events received as input signals by said neuron from neurons in other neural modules. Each said input signal is weighted by the weight of the synapse communicating said input signal to said neuron. The synaptic weight associated with each synapse is adapted as a function of the firing events of the interconnected neurons.
The synapses in the neural network are event-driven. The synaptic weight associated with each synapse is adapted as a function of the firing events of the interconnected neurons.
In general, in accordance with an embodiment of the invention, at a given time-step, a neural module processes all synaptic messages received via its ports. The membrane potential of each neuron in the neural module is then evaluated to determine which neurons fired. A p bit vector is created, the vector indicating which of the p neurons in the neural module fired (a “1” bit at index i indicates that a neuron in the neural module at index i fired).
The firing of at least one neuron in a neural module is an event. The event is communicated to all synapses that the ports of the neural module are connected to. The neural module sends to all synapses connected to its ports of type “port A” the following information: the p bit vector, an extra bit representing the port ID of the port (the type of the port, that is “port A”), and a ratio representing the sum of all synaptic weights on the port over the target. Similarly, the neural module sends to all synapses connected to its ports of type “port B” the following information: the p bit vector, an extra bit representing the port ID of the port (the type of the port, that is “port B”), and a ratio representing the sum of all synaptic weights on the port over the target.
Further, for every neuron in the neural module that fired, the coupling efficiency between the neuron that fired and every other neuron is updated according to the learning rule.
If a synapse connected to a port of type “port A” of the neural module receives a p bit vector and a port ID “A”, the synapse will identify this information as coming from the “neural module A”. The synapse will send to the “neural module B” the following information: the p bit vector received from the “neural module A”, the weight of the synapse, the delay of the synapse, and the last weight sent to the neural module B. Further, for every bit in the p bit vector received that is “1”, learning rules associating a neuron that fired in neural module A with a neuron in neural module B are applied.
Similarly, if a synapse connected to a port of type “port B” of the neural module receives a p bit vector and a port ID “B”, the synapse will identify this information as coming from the “neural module B”. The synapse will send to the “neural module A” the following information: the p bit vector received from the “neural module B”, the weight of the synapse, the delay of the synapse, and the last weight sent to the neural module A. Further, for every bit in the p bit vector received that is “1”, learning rules associating a neuron that fired in neural module B with a neuron in neural module A are applied.
The computational architecture for the present invention provides for different types of synapses, wherein each synapse type includes a different specification for learning rules. Every synapse has a symmetric dual. A symmetric dual for a synapse is defined by reversing the roles of the synapse's p2 learning rules. Each learning rule in a symmetric dual of a synapse is represented as R[b][a]. If the learning rule R[b][a] is not the same as R[a][b], the symmetric dual of the synapse provides a different synapse type. If the learning rule R[b][a] is the same as R[a][b], the symmetric dual of the synapse is the synapse itself.
As discussed above, each synapse comprises two ports. In
The synapse 55 is connected to the neural modules 54 and 53 via ports 55A and 55B, respectively. The synapse 55 interconnects every neuron in the neural module 54 with a corresponding neuron in the neuron module 53. The synapse 56 is connected to the neuron modules 52 and 51 via ports 56A and 56B, respectively. The synapse 56 interconnects every neuron in the neural module 52 with a corresponding neuron in the neuron module 51. The synapse 57 is connected to the neural modules 53 and 52 via ports 57A and 57B, respectively. The synapse 57 interconnects every neuron in the neural module 53 with a corresponding neuron in the neuron module 52.
In
The synapse 56 comprises p2 learning rules, each learning rule associating a neuron in the neural module 52 with a corresponding neuron in the neural module 51. The synapse 56 is a symmetric dual of the synapse 55. The p2 learning rules in the synapse 55 are reversed to obtain a different set of p2 learning rules for the synapse 56. The synapse 56 has a second synapse type SI′.
Finally, the synapse 57 comprises a set of p2 learning rules that differs from the learning rules of synapses 55 and 56. The synapse 57 has a third synapse type SII. Each learning rule in the synapse 57 associates a neuron in the neural module 53 with a corresponding neuron in the neural module 52. Accordingly, only three different types of synapses (SI, SI′, SII) are represented in
The neural network circuit 50 in
The synapse 67 interconnects every neuron in the neural module 61 with a corresponding neuron in the neuron module 62. The synapse 68 interconnects every neuron in the neural module 62 with a corresponding neuron in the neuron module 63. The synapse 69 interconnects every neuron in the neural module 63 with a corresponding neuron in the neuron module 64. The synapse 70 interconnects every neuron in the neural module 63 with a corresponding neuron in the neuron module 65. The synapse 71 interconnects every neuron in the neural module 65 with a corresponding neuron in the neuron module 66.
As discussed above, a neural module can have multiple ports. In
Further,
The neural network circuit 60 in
The synapse 87 interconnects every neuron in the neural module 81 with a corresponding neuron in the neuron module 82. The synapse 88 interconnects every neuron in the neural module 82 with a corresponding neuron in the neuron module 83. The synapse 89 interconnects every neuron in the neural module 83 with a corresponding neuron in the neuron module 84. The synapse 90 interconnects every neuron in the neural module 83 with a corresponding neuron in the neuron module 85. The synapse 91 interconnects every neuron in the neural module 85 with a corresponding neuron in the neuron module 86. The synapse 92 interconnects every neuron in the neural module 82 with a corresponding neuron in the neuron module 85.
As discussed above, a neural module can have multiple ports. In
As shown in
Further shown in
Further,
Similar to the neural network circuit 60 in
In process block 181, the neural modules are established wherein each neural module comprises p neurons. In process block 182, synapses are established, wherein each synapse is interconnected to a first neural module and a second neural module. In process block 183, each neural module processes all synaptic messages received from interconnected synapses. In process block 184, each neural module creates a p bit vector indicating which neurons in the neural module generated an output signal. In process block 185, each neural module sends its p bit vector to all synapses it is connected to. In process block 186, each synapse receiving a p bit vector from a first/second neural module forwards the p bit vector to the second/first neural module and applies learning rules between each neuron that fired in the first/second neural module and its corresponding neuron in the second/first neural module. After process block 186, the invention loops back to process block 183.
The computer system can include a display interface 306 that forwards graphics, text, and other data from the communication infrastructure 304 (or from a frame buffer not shown) for display on a display unit 308. The computer system also includes a main memory 310, preferably random access memory (RAM), and may also include a secondary memory 312. The secondary memory 312 may include, for example, a hard disk drive 314 and/or a removable storage drive 316, representing, for example, a floppy disk drive, a magnetic tape drive, or an optical disk drive. The removable storage drive 316 reads from and/or writes to a removable storage unit 318 in a manner well known to those having ordinary skill in the art. Removable storage unit 318 represents, for example, a floppy disk, a compact disc, a magnetic tape, or an optical disk, etc. which is read by and written to by removable storage drive 316. As will be appreciated, the removable storage unit 318 includes a computer readable medium having stored therein computer software and/or data.
In alternative embodiments, the secondary memory 312 may include other similar means for allowing computer programs or other instructions to be loaded into the computer system. Such means may include, for example, a removable storage unit 320 and an interface 322. Examples of such means may include a program package and package interface (such as that found in video game devices), a removable memory chip (such as an EPROM, or PROM) and associated socket, and other removable storage units 320 and interfaces 322 which allow software and data to be transferred from the removable storage unit 320 to the computer system.
The computer system may also include a communication interface 324. Communication interface 324 allows software and data to be transferred between the computer system and external devices. Examples of communication interface 324 may include a modem, a network interface (such as an Ethernet card), a communication port, or a PCMCIA slot and card, etc. Software and data transferred via communication interface 324 are in the form of signals which may be, for example, electronic, electromagnetic, optical, or other signals capable of being received by communication interface 324. These signals are provided to communication interface 324 via a communication path (i.e., channel) 326. This communication path 326 carries signals and may be implemented using wire or cable, fiber optics, a phone line, a cellular phone link, an RF link, and/or other communication channels.
In this document, the terms “computer program medium,” “computer usable medium,” and “computer readable medium” are used to generally refer to media such as main memory 310 and secondary memory 312, removable storage drive 316, and a hard disk installed in hard disk drive 314.
Computer programs (also called computer control logic) are stored in main memory 310 and/or secondary memory 312. Computer programs may also be received via communication interface 324. Such computer programs, when run, enable the computer system to perform the features of the present invention as discussed herein. In particular, the computer programs, when run, enable the processor 302 to perform the features of the computer system. Accordingly, such computer programs represent controllers of the computer system.
From the above description, it can be seen that the present invention provides a system, computer program product, and method for implementing the embodiments of the invention. The present invention further provides a non-transitory computer-useable storage medium for hierarchical routing and two-way information flow with structural plasticity in neural networks. The non-transitory computer-useable storage medium has a computer-readable program, wherein the program upon being processed on a computer causes the computer to implement the steps of the present invention according to the embodiments described herein. References in the claims to an element in the singular is not intended to mean “one and only” unless explicitly so stated, but rather “one or more.” All structural and functional equivalents to the elements of the above-described exemplary embodiment that are currently known or later come to be known to those of ordinary skill in the art are intended to be encompassed by the present claims. No claim element herein is to be construed under the provisions of 35 U.S.C. section 112, sixth paragraph, unless the element is expressly recited using the phrase “means for” or “step for.”
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the invention. As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
The corresponding structures, materials, acts, and equivalents of all means or step plus function elements in the claims below are intended to include any structure, material, or act for performing the function in combination with other claimed elements as specifically claimed. The description of the present invention has been presented for purposes of illustration and description, but is not intended to be exhaustive or limited to the invention in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the invention. The embodiment was chosen and described in order to best explain the principles of the invention and the practical application, and to enable others of ordinary skill in the art to understand the invention for various embodiments with various modifications as are suited to the particular use contemplated.
Patent | Priority | Assignee | Title |
10204301, | Mar 18 2015 | International Business Machines Corporation | Implementing a neural network algorithm on a neurosynaptic substrate based on criteria related to the neurosynaptic substrate |
10832125, | Mar 18 2015 | International Business Machines Corporation | Implementing a neural network algorithm on a neurosynaptic substrate based on metadata associated with the neural network algorithm |
10984312, | Oct 30 2014 | International Business Machines Corporation | Mapping graphs onto core-based neuromorphic architectures |
11151444, | Mar 08 2013 | International Business Machines Corporation | Structural descriptions for neurosynaptic networks |
11176446, | Mar 26 2015 | International Business Machines Corporation | Compositional prototypes for scalable neurosynaptic networks |
11301753, | Nov 06 2017 | Samsung Electronics Co., Ltd.; Consejo Superior de Investigaciones Cientificas | Neuron circuit, system, and method with synapse weight learning |
9959501, | Mar 08 2013 | International Business Machines Corporation | Structural descriptions for neurosynaptic networks |
9971965, | Mar 18 2015 | International Business Machines Corporation | Implementing a neural network algorithm on a neurosynaptic substrate based on metadata associated with the neural network algorithm |
9984323, | Mar 26 2015 | International Business Machines Corporation | Compositional prototypes for scalable neurosynaptic networks |
Patent | Priority | Assignee | Title |
4893255, | May 31 1988 | Analog Intelligence Corp. | Spike transmission for neural networks |
5331550, | Mar 05 1991 | DIRECT RADIOGRAPHY CORP | Application of neural networks as an aid in medical diagnosis and general anomaly detection |
5646868, | Jun 03 1993 | Daikin Industries, Ltd. | Physical quantity analyzing method and apparatus thereof |
5764860, | Mar 09 1995 | KDDI Corporation | Learning method for multi-level neural network |
5768476, | Aug 13 1993 | KDDI Corporation | Parallel multi-value neural networks |
7181768, | Oct 28 1999 | Synopsys, Inc | Computer intrusion detection system and method based on application monitoring |
7430546, | Jun 07 2003 | Applications of an algorithm that mimics cortical processing | |
7543266, | Nov 20 2006 | Microsoft Technology Licensing, LLC | Lock-free state merging in parallelized constraint satisfaction problem solvers |
7676441, | Jun 11 2004 | Canon Kabushiki Kaisha | Information processing apparatus, information processing method, pattern recognition apparatus, and pattern recognition method |
7953683, | Apr 06 2006 | Sony Corporation | Learning apparatus, learning method, and program for efficiently learning dynamics |
7996342, | Feb 15 2008 | International Business Machines Corporation | Systems, methods and computer program products for supervised dimensionality reduction with mixed-type features and labels |
8059890, | Mar 04 2005 | Method for implementing n-dimensional object recognition using dynamic adaptive recognition layers | |
8103602, | Dec 29 2006 | NEUROSCIENCES RESEARCH FOUNDATION, INC | Solving the distal reward problem through linkage of STDP and dopamine signaling |
8285667, | Feb 10 2006 | Numenta, Inc. | Sequence learning in a hierarchical temporal memory based system |
8626684, | Dec 14 2011 | International Business Machines Corporation | Multi-modal neural network for universal, online learning |
20040162796, | |||
20080071712, | |||
20080091628, | |||
20100179935, | |||
20120259804, | |||
20120311595, | |||
20130073493, | |||
20130159231, | |||
20140019393, | |||
20140250039, | |||
20150227849, | |||
20150262056, | |||
20150363690, | |||
WO2008112921, | |||
WO2009006735, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Feb 03 2016 | MODHA, DHARMENDRA S | International Business Machines Corporation | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 037668 | /0989 | |
Feb 04 2016 | International Business Machines Corporation | (assignment on the face of the patent) | / |
Date | Maintenance Fee Events |
Apr 16 2020 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Jul 01 2024 | REM: Maintenance Fee Reminder Mailed. |
Dec 16 2024 | EXP: Patent Expired for Failure to Pay Maintenance Fees. |
Date | Maintenance Schedule |
Nov 08 2019 | 4 years fee payment window open |
May 08 2020 | 6 months grace period start (w surcharge) |
Nov 08 2020 | patent expiry (for year 4) |
Nov 08 2022 | 2 years to revive unintentionally abandoned end. (for year 4) |
Nov 08 2023 | 8 years fee payment window open |
May 08 2024 | 6 months grace period start (w surcharge) |
Nov 08 2024 | patent expiry (for year 8) |
Nov 08 2026 | 2 years to revive unintentionally abandoned end. (for year 8) |
Nov 08 2027 | 12 years fee payment window open |
May 08 2028 | 6 months grace period start (w surcharge) |
Nov 08 2028 | patent expiry (for year 12) |
Nov 08 2030 | 2 years to revive unintentionally abandoned end. (for year 12) |