Scalable architecture for analog matrix operations with resistive devices

US10325006B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-10325006-B2
Application numberUS-201514868496-A
CountryUS
Kind codeB2
Filing dateSep 29, 2015
Priority dateSep 29, 2015
Publication dateJun 18, 2019
Grant dateJun 18, 2019

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

Official abstract text for this publication.

In some aspects, a method for performing analog matrix inversion on a matrix with a network of resistive device arrays B, W, Q, and C is described. The method may include initializing arrays W, Q, B and C, updating the connections of array W in parallel and array Q in parallel until a predetermined condition is satisfied, and responsive to determining that the predetermined condition is satisfied, outputting an inverted matrix based on outputs from the connections of arrays B, W, Q, and C.

First claim

Opening claim text (preview).

The invention claimed is: 1. A system for performing analog matrix inversion on a matrix, the system comprising: a network of resistive device arrays B, W, Q, and C, wherein each of the arrays comprises a plurality of connections, each connection comprising a resistive device configured to store a value, the network configured to: initialize arrays W, Q, B and C; update the plurality of connections of array Win parallel and Q in parallel until a predetermined condition is satisfied; and responsive to determining that the predetermined condition is satisfied, output an inverted matrix based on outputs from the connections of arrays B, W, Q, and C. 2. The system of claim 1 , wherein the predetermined condition is i=n, where n is a value corresponding to a size of the matrix. 3. The system of claim 1 , wherein, array B comprises x connections and z connections; array W comprises y connections and the z connections; array Q comprises the z connections and ζ connections; and array C comprises the x connections and y* connections. 4. The system of claim 3 , wherein the updates to the plurality of connections of arrays B, W, Q, and C causes the network to: read with the outputs of the arrays B, W, Q, and C, that are responsive to the initialization from the x connections, y* connections, and the z connections; pulse a first voltage pulse into the x connections; read a z term from the z connections and a y* term from the y* connections, wherein the z and y terms are responsive to the first voltage pulse; pulse a second voltage pulse into the z connections; read, using a CMOS circuit, a y term from y connections, a y* term from the y* connections, and a ζ term from the ζ connections, wherein the y, y* and ζ terms are responsive to the first and second voltage pulses; compute a value ε based on y and the y* terms; and compute a value η using the ζ terms. 5. The system of claim 3 , wherein the ζ connections are also an output of matrix Q. 6. The system of claim 1 , wherein the resistive device arrays are 2D cross-point devices comprised of resistive devices functioning as weighted connections between neurons. 7. A non-transitory computer-readable storage medium storing instructions executable by a processor to perform a method for performing analog matrix inversion on a matrix with a network of resistive device arrays B, W, Q, and C, the method comprising: initializing arrays W, Q, B and C, wherein each of the arrays comprises a plurality of connections, each connection comprising a resistive device configured to store a value; updating the connections of arrays Win parallel and Q in parallel, until a predetermined condition is satisfied; and responsive to determining that a predetermined condition is satisfied, outputting an inverted matrix based on outputs from the connections of arrays B, W, Q, and C. 8. The computer-readable storage medium of claim 7 , wherein the predetermined condition is i=n, where n is a value corresponding to a size of the matrix. 9. The computer-readable storage medium of claim 7 , wherein, array B comprises x connections and z connections; array W comprises y connections and the z connections; array Q comprises the z connections and connections; and array C comprises the x connections and y* connections. 10. The computer-readable storage medium of claim 9 , wherein updating the connections of arrays B, W, Q, and C comprises: reading, with the outputs of the arrays B, W, Q, and C, that are responsive to the initialization from the x connections, the y* connections, and the z connections; pulsing a first voltage pulse into the x connections; reading a z term from the z connections and a y* term from the y* connections, wherein the z and y terms are responsive to the first voltage pulse; pulsing a second voltage pulse into the z connections; reading, using a CMOS circuit, a y term from the y connections, a y* term from the y* connections, and a ζ term from the ζ connections, wherein the y, y* and ζ terms are responsive to the first and second voltage pulses; computing a value ε based on y and the y* terms; and computing a value η using the ζ terms. 11. The computer-readable storage medium of claim 9 , wherein the ζ connections are also an output of matrix Q. 12. The computer-readable storage medium of claim 7 , wherein the resistive device arrays are 2D cross-point devices comprised of resistive devices functioning as weighted connections between neurons.

Assignees

Inventors

Classifications

  • G06F17/16Primary

    Matrix or vector computation {, e.g. matrix-matrix or matrix-vector multiplication, matrix factorization (matrix transposition G06F7/78)} · CPC title

  • G06N3/065Primary

    Analogue means · CPC title

  • Feedforward networks · CPC title

  • Architecture, e.g. interconnection topology · CPC title

  • Physics · mapped topic

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US10325006B2 cover?
In some aspects, a method for performing analog matrix inversion on a matrix with a network of resistive device arrays B, W, Q, and C is described. The method may include initializing arrays W, Q, B and C, updating the connections of array W in parallel and array Q in parallel until a predetermined condition is satisfied, and responsive to determining that the predetermined condition is satisfi…
Who is the assignee on this patent?
Int Business Machines Int, IBM
What technology area does this patent fall under?
Primary CPC classification G06F17/16. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Jun 18 2019 00:00:00 GMT+0000 (Coordinated Universal Time) (B2). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 8 related publications on this page (citations in our corpus or others sharing the same primary CPC).