Recent developments in the field of artificial intelligence have resulted in various products and/or applications, including, but not limited to, speech recognition, image processing, machine learning, natural language processing, or the like. Such products and/or applications often use neural networks to process large amounts of data for learning, training, cognitive computing, or the like.
Aspects of the present disclosure are best understood from the following detailed description when read with the accompanying figures. It is noted that, in accordance with the standard practice in the industry, various features are not drawn to scale. In fact, the dimensions of the various features may be arbitrarily increased or reduced for clarity of discussion.
The following disclosure provides many different embodiments, or examples, for implementing different features of the provided subject matter. Specific examples of components, values, operations, materials, arrangements, or the like, are described below to simplify the present disclosure. These are, of course, merely examples and are not intended to be limiting. Other components, values, operations, materials, arrangements, or the like, are contemplated. For example, the formation of a first feature over or on a second feature in the description that follows may include embodiments in which the first and second features are formed in direct contact, and may also include embodiments in which additional features may be formed between the first and second features, such that the first and second features may not be in direct contact. In addition, the present disclosure may repeat reference numerals and/or letters in the various examples. This repetition is for the purpose of simplicity and clarity and does not in itself dictate a relationship between the various embodiments and/or configurations discussed. Source/drain(s) may refer to a source or a drain, individually or collectively dependent upon the context.
A neural network is implemented by several matrices or arrays of resistors arranged in successive layers through which data propagate. In some embodiments, data are transferred from one resistor array to a next resistor array by analog voltages. As a result, it is possible to omit analog-to-digital conversion or analog-to-digital converters (ADCs) between successive layers in a neural network. As ADCs often occupy a large chip area, sometimes even larger than the chip area of resistor arrays, by omitting ADCs between successive layers in a neural network, at least one embodiment makes it possible to significantly reduce the chip area as well as power consumption of an integrated circuit (IC) implementing the neural network. Reduced area and power consumption in accordance with some embodiments are improvements over other approaches where ADCs are used for data conversion and/or data transfer between successive layers of a neural network.
The neural network 100 comprises a plurality of layers A-E each comprising a plurality of nodes (or neurons). The nodes in successive layers of the neural network 100 are connected with each other by a matrix or array of connections. For example, the nodes in layers A and B are connected with each other by connections in a matrix 102, the nodes in layers B and C are connected with each other by connections in a matrix 104, the nodes in layers C and D are connected with each other by connections in a matrix 106, and the nodes in layers D and E are connected with each other by connections in a matrix 108. Layer A is an input layer configured to receive input data 111. The input data 111 propagate through the neural network 100, from one layer to the next layer via the corresponding matrix of connections between the layers. As the data propagate through the neural network 100, the data undergo one or more computations as described with respect to
As illustrated in
In at least one embodiment, value B2 at node B2 is calculated by the following activation function (1):
A generalized form of activation function (1) is given as the following activation function (2):
where i=1, 2, . . . n, j=1, 2, . . . m, and Wij is the weight of the connection connecting node Ai and node Bj.
In some embodiments, in addition to weights assigned to the connections in the matrix 102, a bias is further assigned to one or more of the nodes. For example, when a bias b is assigned to node Bj, the activation function at node Bj becomes:
The input data 111 comprise values A1, A2, A3, . . . An applied to corresponding nodes A1, A2, A3 to An. Values B1, B2, B3 to Bm are calculated from input values A1, A2, A3, . . . An and the corresponding weights Wij based on activation function (2). Calculated values B1, B2, B3 to Bm are then used, together with corresponding weights of connections in the matrix 104, to calculate values at the nodes of layer C by using one or more corresponding activation functions. Values at the nodes in subsequent layers D and E are calculated in a similar manner, resulting in the output data 112 being output from output layer E of the neural network 100. The described activation functions (1) and (2) are examples. Other activation functions for calculating values at nodes in the neural network 100 are within the scopes of various embodiments.
In an example application of the neural network 100, learning or training is performed in the neural network 100 by applying a training set of input data to input layer A, propagating the input data through the neural network 100 by calculating values at various nodes in the neural network 100 as described herein, and collecting a set of output data from the output layer E. The collected set of output data are compared with an expected set of output data to determine an amount of error in the collected output data as compared to the expected output data. Based on the determined amount of error, one or more weights of one or more connections in the neural network 100 are adjusted with an aim to reduce the amount of error, and the process is repeated with the application of the same or a different training set of input data to the neural network 100 after weight adjustments. When the amount of error falls below a predetermined acceptable level, the neural network 100 is considered trained and can now be used to process actual input data. For example, when the neural network 100 has been trained to perform image processing, the trained neural network 100 processes one or more input images, and outputs, e.g., one or more faces recognized from the input images. The described training process and application of the neural network 100 are examples. Other applications and/or training processes are within the scopes of various embodiments.
In some embodiments, at least one matrix 102, 104, 106, 108 of connections in the neural network 100 is implemented by an array of resistors each corresponding to a weight of a connection, as described herein.
The IC 200 comprises a first array of resistors (or resistor array) 202, a second resistor array 204, and a controller 210.
The resistor array 202 is an r×t array, where r and t are positive integers, with r input conductive lines 221, 222, . . . 22r, and t output conductive lines 231, 232, . . . 23t. The resistor array 202 comprises a plurality of resistors. Each resistor of the resistor array 202 is electrically coupled between a corresponding input conductive line 22k (where k is 1, 2, . . . r) and a corresponding output conductive line 23l (where l is 1, 2, . . . t), and is indicated in
The resistor array 204 is a t×u array, where u is a positive integer, with t input conductive lines 241, 242, . . . 24t, and u output conductive lines 251, 252, . . . 25u. The resistor array 204 comprises a plurality of resistors. Each resistor of the resistor array 204 is electrically coupled between a corresponding input conductive line 24k′ (where k′ is 1, 2, . . . t) and a corresponding output conductive line 25l′ (where l′is 1, 2, . . . u), and is indicated in
In some embodiments, at least one resistor in at least one of the resistor arrays 202, 204 is a controllably variable resistor having a conductance adjustable or programmable, e.g., under control of the controller 210. Example configurations of controllably variable resistors include, but are not limited to, static random-access memory (SRAM), resistive RAM (RRAM), magnetoresistive RAM (MRAM), phase change RAM (PCRAM), spin transfer torque RAM (STTRAM), floating-gate metal-oxide-semiconductor field-effect transistors (FGMOS), spintronics, or the like.
The controller 210 is electrically coupled to the resistor arrays 202, 204, and is configured to adjust the conductance of at least one resistor in the resistor arrays 202, 204, as described herein. In at least one embodiment, the controller 210 is further configured to apply input data 211 to the resistor array 202 and/or to process output data 212 output from the resistor array 204. Example hardware configurations of the controller 210 include, but are not limited to, a processor, a central processing unit (CPU), a multi-processor, a distributed processing system, an application specific integrated circuit (ASIC), or a computer system as described with respect to
The IC 200 further comprises a plurality of interface circuits 261, 262, . . . 26t, each electrically coupled between a corresponding output conductive line 231, 232, . . . 23t of the resistor array 202 and a corresponding input conductive line 241, 242, . . . 24t of the resistor array 204. For example, the interface circuit 261 is electrically coupled between the output conductive line 231 of the resistor array 202 and the input conductive line 241 of the resistor array 204. For another example, the interface circuit 26t is electrically coupled between the output conductive line 23t of the resistor array 202 and the input conductive line 24t of the resistor array 204.
The IC 200 further comprises a plurality of circuits 271, 272, . . . 27u electrically coupled correspondingly to the output conductive lines 251, 252, . . . 25u of the resistor array 204. The circuits 271, 272, . . . 27u comprise ADCs or interface circuits similar to interface circuits 261, 262, . . . 26t. In the example configuration in
In some embodiments, resistors in at least one of the resistor arrays 202, 204 correspond to connections in a matrix described with respect to
The input data 211 input to the resistor array 202 corresponds to the input data 111 input to layer A. Input signals IN1, IN2, . . . INr, in the input data 211 correspond to values A1, A2, . . . An input to the corresponding nodes in layer A. In at least one embodiment, input signals IN1, IN2, . . . INr comprise analog voltages. In some embodiments, input signals IN1, IN2, . . . INr comprise voltage pulses of corresponding digital signals. In the description herein, a voltage of a signal is denoted by the name of the signal. For example, input signal IN1 has a voltage IN1, input signal INr, has a voltage INr, or the like.
The voltage of each of input signals IN1, IN2, . . . INr causes a corresponding current to flow from a corresponding input conductive line 22k through a corresponding resistor Gk,l of the resistor array 202 to a corresponding output conductive line 231. For example, the voltage of input signal IN1 causes a corresponding current IN1×G1,2 to flow from the input conductive line 221 through resistor G1,2 to the output conductive line 232, the voltage of input signal IN2 causes a corresponding current IN2×G2,2 to flow from the input conductive line 222 through resistor G2,2 to the output conductive line 232, and the voltage of input signal INr, causes a corresponding current INr×Gr,2 to flow from the input conductive line 22r through resistor Gr,2 to the output conductive line 232. The sum of the currents IN1×G1,2+IN2×G2,2+. . .INr×Gr,2 that flow from the input conductive lines 221, 222, . . . 22r to the output conductive line 232 is denoted as signal Y2 on the output conductive line 232. In at least one embodiment, signal Y2 corresponds to value B2 of the corresponding node as described with respect to
Each of the interface circuits 261, 262, . . . 26t is configured to receive the corresponding signal Y1, Y2, . . . Yt on the corresponding output conductive line 231, 232, . . . 23t of the resistor array 202, and apply an analog voltage IN′1, IN′2, . . . IN′t corresponding to the signal Y1, Y2, . . . Yt to the corresponding input conductive line 241, 242, . . . 24t of the resistor array 204. As a result, data transfer is performed between outputs of the resistor array 202 and inputs of the resistor array 204. This data transfer is equivalent, in one or more embodiments, to the data transfer between matrices 102, 104 through nodes B1, B2, . . . Bm in layer B of the neural network 100.
The analog voltages IN′1, IN′2, . . . IN′t , on the input conductive line 241, 242, . . . 24t of the resistor array 204 cause currents to flow from the input conductive line 241, 242, . . . 24t to the output conductive lines 251, 252, . . . 25u through corresponding resistors of the resistor array 204. Signal Y′1 on the output conductive line 251 is the sum of the currents that are caused by the analog voltages IN′1, IN′2, . . . IN′t, to flow from the input conductive lines 241, 242, . . . 24t to the output conductive line 251. Signal Y′2 on the output conductive line 252 is the sum of the currents that are caused by the analog voltages IN′1, IN′2, . . . IN′t, to flow from the input conductive lines 241, 242, . . . 24t to the output conductive line 252. Signal Y′u on the output conductive line 25u is the sum of the currents that are caused by the analog voltages IN′1, IN′2, . . . IN′t, to flow from the input conductive lines 241, 242, . . . 24t to the output conductive line 25u.
In one or more embodiments where the circuits 271, 272, . . . 27u are interface circuits, the circuits 271, 272, . . . 27u are configured to convert signals Y′1, Y′2, . . . Y′u to further analog voltages to be input to a subsequent resistor array. In some embodiments where the circuits 271, 272, . . . 27u are ADCs, the circuits 271, 272, . . . 27u are configured to convert signals Y′1, Y′2, . . . Y′u to digital signals OUT1, OUT2, . . . OUTu to be processed by the controller 210.
In some embodiments, the controller 210 is configured to determine an amount of error between obtained and expected output data as described herein, and, based on the determined amount of error, adjust the conductance of at least one resistor in the resistor arrays 202, 204. Conductance adjustments in the IC 200 correspond to the described weight adjustments in the neural network 100. An example configuration for conductance adjustment is described with respect to
The described configuration and/or operation of the IC 200 are examples. Other configurations and/or operations are within the scopes of various embodiments. In at least one embodiment, the IC 200 comprises more than two resistor arrays. In one or more embodiments, the resistor array 202 corresponds to a matrix of connections between two hidden layers of a neural network. In such embodiments, signals IN1, IN2, . . . INrare analog voltages output by a further resistor array preceding the resistor array 202.
As described herein, the IC 200 in accordance with some embodiments comprises interface circuits 261, 262, . . . 26t configured to provide signals Y1, Y2, . . . Yt at output conductive lines 231, 232, . . . 23t of the resistor array 202 as analog voltages IN′1, IN′2, . . . IN′t to input conductive lines 241, 242, . . . 24t of the resistor array 204. As a result, it is possible in at least one embodiment to quickly and efficiently perform data transfer between successive layers in a corresponding neural network, without performing analog-to-digital conversion or requiring ADCs. In one or more embodiments, the IC 200 achieves one or more of increased processing speed, reduced chip area cost, or reduced power consumption, compared to other approaches that include ADCs or perform analog-to-digital conversion between successive resistor arrays.
The memory device 300 comprises a plurality of memory cells MC, and a memory controller 302 electrically coupled to the memory cells MC and configured to control operations of the memory cells MC including, but not limited to, a read operation, a write operation, or the like. Write operations include, but are not limited to, programming operation, set operation, reset operations, or the like. In at least one embodiment, the memory controller 302 corresponds to the controller 210 described with respect to
The memory cells MC are arranged in a plurality of columns and rows in a memory array 304. In at least one embodiment, each of the memory cells MC represents a resistor in a resistor array as described with respect to
The memory device 300 further comprises a plurality of word lines (also referred to as “address lines”) WL1 to WLr extending along the rows, and a plurality of bit lines (also referred to as “data lines”) BL1 to BLt extending along the columns of the memory cells MC. Each of the memory cells MC is electrically coupled to the memory controller 302 by at least one of the word lines, and at least one of the bit lines. In some example operations, word lines are configured for transmitting addresses of the memory cells MC to be read from, or for transmitting addresses of the memory cells MC to be written to, or the like. In at least one embodiment, a set of word lines is configured to perform as both read word lines and write word lines. Examples of bit lines include read bit lines for transmitting data read from the memory cells MC indicated by corresponding word lines, write bit lines for transmitting data to be written to the memory cells MC indicated by corresponding word lines, or the like. In at least one embodiment, a set of bit lines is configured to perform as both read bit lines and write bit lines. The word lines are commonly referred to herein as WL, and the bit lines are commonly referred to herein as BL. Various numbers of word lines and/or bit lines in the memory array 304 are within the scope of various embodiments. In some embodiments, each memory cell MC is coupled to additional conductive lines, such as source lines and/or drain lines. Example memory types of the memory cells MC include, but are not limited to, SRAM, RRAM, MRAM, PCRAM, STTRAM), or the like. In one or more example embodiments described herein, the memory cells MC include RRAM memory cells.
In the example configuration in
The word line driver 312 is coupled to the memory array 304 via the word lines WL. The word line driver 312 is configured to decode a row address of the memory cell MC selected to be accessed in a read operation or a write operation. The word line driver 312 is configured to supply a voltage to the selected word line WL corresponding to the decoded row address, and a different voltage to the other, unselected word lines WL. The bit line driver 316 is coupled to the memory array 304 via the bit lines BL. The bit line driver 316 is configured to decode a column address of the memory cell MC selected to be accessed in a read operation or a write operation. The bit line driver 316 is configured to supply a voltage to the selected bit line BL corresponding to the decoded column address, and a different voltage to the other, unselected bit lines BL. The peripheral circuitry 318 is coupled to the memory array 304 via the bit lines BL, and comprises interface circuits or ADCs corresponding to those described with respect to
In at least one embodiment, each memory cell MC corresponds to a resistor in the resistor array 202, 204, the word lines WL correspond to the input conductive lines 221, 222, . . . 22r or the input conductive lines 241, 242, . . . 24t, and the bit lines BL correspond to the output conductive lines 231, 232, . . . 23t or the output conductive lines 251, 252, . . . 25u. In some embodiments, each memory cell MC has two possible states corresponding to two conductance values of a corresponding resistor, or corresponding to two weight values of a connection in a neural network. In at least one embodiment, each memory cell MC has more than two possible states corresponding to more than two conductance values of a corresponding resistor, or corresponding to more than two weight values of a connection in a neural network. In some embodiments, each memory cell MC comprises multiple memory elements coupled together in parallel and/or in series to increase the number of possible states of the memory cell MC, to therefore increase the number of possible weight values of a connection in a neural network. Other configurations are within the scopes of various embodiments.
To switch a memory cell MC between different states, corresponding to conductance adjustment of a corresponding resistor as described herein, one or more write operations are performed by applying predetermined voltages to the bit lines BL and word lines WL. For example, when a memory cell 311 coupled to bit line BL1 and word line WL1 is selected to be accessed or programed in a write operation, a write voltage is applied by the controller 302 across the corresponding selected bit line BL1 and word line WL1, whereas the other, non-selected bit lines BL2-BLt and word lines WL2-WLr are biased at a voltage of about half the write voltage. The write voltage across the selected memory cell 311 is sufficient to switch the memory cell 311 from one logic state (e.g., logic “1”) to another logic state (e.g., logic “0”) which corresponds to conductance adjustment of a resistor represented by the memory cell 311. The biasing voltages across the other, non-elected memory cells are not sufficient to affect the logic states of the non-elected memory cells, and therefore, conductance values of resistors represented by the other, non-elected memory cells are not adjusted. In some embodiments, more than one memory cells are written to or programed in a common write operation.
To propagate data through the memory array 304 to perform computations corresponding to, for example, activation function (1) or (2) as described, a read operation is performed for the memory cells MC in the memory array 304. For example, the word lines WL1-WLr are selected or enabled by the controller 302 at the same time. Input signals, e.g., IN1-INr, as described with respect to
The described configuration and/or operation of the memory device 300 are examples. Other configurations and/or operations are within the scopes of various embodiments. For example, in the described example configuration, the bit lines BL and word lines WL are used for both write and read operations. In one or more further embodiments, the bit lines BL and/or the word lines WL are used in write operations, and additional input and/or output conductive lines are coupled to the memory cells MC to be used in read operations. In some other embodiments, the bit lines BL and/or the word lines WL are used as input and/or output conductive lines in read operations, and additional conductive lines are coupled to the memory cells MC to be used in write operations. In at least one embodiment, one or more advantages described herein with respect to the IC 200 are achievable by the memory device 300.
The interface circuit 400 comprises an integrator circuit 410, and a buffer circuit 420.
The integrator circuit 410 has an input 411 and an output 412. The input 411 is electrically coupled to an output conductive line 413 from a resistor array as described herein. In some embodiments, the output conductive line 413 corresponds to one of the output conductive lines 231, 232, . . . 23t of the resistor array 202, and a signal Yk corresponding to one of the signals Y1, Y2, . . . Yt is supplied by the conductive line 413 to the integrator circuit 410. The signal Yk corresponds to the sum of currents flowing on the conductive line 413 when a set of input data is applied to the input conductive lines of the resistor array, as described herein. The integrator circuit 410 is configured to integrate the signal Yk over time, e.g., over the duration of a read operation, to generate an intermediate voltage Vk at the output 412.
The buffer circuit 420 is electrically coupled to the output 412 of the integrator circuit 410 to receive the intermediate voltage Vk, and is configured to generate an analog voltage Vout corresponding to the intermediate voltage Vk. In some embodiments, the analog voltage Vout is applied to a corresponding input conductive line of a subsequent resistor array. For example, the analog voltage Vout is applied, as one of the analog voltages IN′1, IN′2, . . . IN′t, to the corresponding input conductive lines 241, 242, . . . 24t of the resistor array 204, as described herein.
In the example configuration in
When the switch 460 is closed, the analog voltage Vout is output from the buffer circuit 420 to be applied to a corresponding input conductive line in the subsequent resistor array. When the switch 460 is open, the analog voltage Vout is not output from the buffer circuit 420. A reason for controlling the switch 460 to be open is to ensure stable or correct operation of the interface circuit 400, buffer circuit 420, or other circuitry that is electrically coupled to the output of the buffer circuit 420. In some embodiments, the switch 460 is controlled to be closed or open by a controller as described. In at least one embodiment, the switch 460 is omitted.
The comparator circuit 430 is configured to control the driving circuit 440 to generate the analog voltage Vout in accordance with a result of the comparison between the intermediate voltage Vk and the feedback voltage VFB. For example, when the feedback voltage VFB is smaller than the intermediate voltage Vk, the control signal output by the comparator circuit 430 to the input 441 of the driving circuit 440 causes the driving circuit 440 to increase the analog voltage Vout. When the feedback voltage VFB is greater than the intermediate voltage Vk, the control signal output by the comparator circuit 430 to the input 441 of the driving circuit 440 causes the driving circuit 440 to decrease the analog voltage Vout. In either case, the difference between the intermediate voltage Vk and the feedback voltage VFB is decreased, and the corresponding control signal causes the driving circuit 440 to move a voltage value of the analog voltage Vout toward a stable voltage value. The stable voltage value of the analog voltage Vout, or a stable state of the driving circuit 440, is reached when the feedback voltage VFB becomes equal to the intermediate voltage Vk. In other words, the buffer circuit 420 is configured to force the feedback voltage VFB (which corresponds to the analog voltage Vout) to be aligned with the intermediate voltage Vk, in one or more embodiments. At the stable state, the analog voltage Vout corresponds to the intermediate voltage Vk and the signal Yk on the conductive line 413. As a result, when the analog voltage Vout is applied to a corresponding input conductive line of a subsequent resistor array, data transfer from the resistor array which outputs the signal Yk and the subsequent resistor array is quickly and efficiently achieved, in at least one embodiment.
A reason the buffer circuit 420 is included in the interface circuit 400 in accordance with some embodiments is that the intermediate voltage Vk, while corresponding to the signal Yk output from the resistor array, does not have sufficient current loading capability in some situations. As described with respect to
The interface circuit 500 comprises an integrator circuit 510, and a buffer circuit 520A. The buffer circuit 520A comprises a comparator circuit 530, a driving circuit 540, a feedback circuit 550A, and a switch 560.
The integrator circuit 510 comprises an operational amplifier 515 and a capacitor 516. An input 511 of the operational amplifier 515 is electrically coupled to an output conductive line 513 from a resistor array to receive a signal Yk, as described herein. A further input 514 of the operational amplifier 515 is grounded. The capacitor 516 is electrically coupled between the input 511 and an output 512 of the operational amplifier 515. The operational amplifier 515 and the capacitor 516 are configured to integrate the signal Yk over time to generate an intermediate voltage Vk. The described configuration of the integrator circuit 510 is an example. Other integrator circuit configurations are within the scopes of various embodiments.
The comparator circuit 530 comprises an operational amplifier 535. A first input 531 of the operational amplifier 535 is electrically coupled to the output 512 of the operational amplifier 515 to receive the intermediate voltage Vk. A second input 532 of the operational amplifier 535 is electrically coupled to the feedback circuit 550A to receive a feedback voltage VFB. The operational amplifier 535 is configured to compare the intermediate voltage Vk at the first input 531 with the feedback voltage VFB at the second input 532, and output a result of the comparison as a control signal at an output 533 of the operational amplifier 535. The described configuration of the comparator circuit 530 is an example. Other comparator circuit configurations are within the scopes of various embodiments.
The driving circuit 540 comprises a transistor 545. The transistor 545 has a gate terminal 541 electrically coupled to the output 533 of the operational amplifier 535 to receive the control signal. The transistor 545 further has a first source/drain terminal 542 configuring the output of the driving circuit 540, and a second source/drain terminal 543 electrically coupled to a node of a power supply voltage VDD. The transistor 545 is configured to generate the analog voltage Vout at the output 542, based on the control signal at the gate terminal 541. Examples of transistor 545 include, but are not limited to, metal oxide semiconductor field effect transistors (MOSFET), complementary metal oxide semiconductor (CMOS) transistors, bipolar junction transistors (BJT), high voltage transistors, high frequency transistors, p-channel and/or n-channel field effect transistors (PFETs/NFETs), FinFETs, planar MOS transistors with raised source/drains, or the like. In some embodiments, the transistor 545 is a p-channel metal-oxide semiconductor (PMOS) transistor, the first source/drain terminal 542 is a drain of the PMOS transistor, the second source/drain terminal 543 is a source of the PMOS transistor, the first input 531 of the operational amplifier 535 is an inverting input, and the second input 532 of the operational amplifier 535 is a non-inverting input. In some embodiments, the transistor 545 is an n-channel metal-oxide semiconductor (NMOS) transistor, the first source/drain terminal 542 is a source of the NMOS transistor, the second source/drain terminal 543 is a drain of the NMOS transistor, the first input 531 of the operational amplifier 535 is a non-inverting input, and the second input 532 of the operational amplifier 535 is an inverting input. The power provided by VDD ensures sufficient current loading capability of the driving circuit 540, as described herein. The described configuration of the driving circuit 540 is an example. Other driving circuit configurations are within the scopes of various embodiments.
The feedback circuit 550A comprises a connector 553 and a transistor 555. The connector 553 has a first end electrically coupled to the output 542 of the driving circuit 540, and a second end electrically coupled to the second input 532 of the operational amplifier 535. The transistor 555 has a controllable gate terminal 556 configured to receive a bias voltage VBias, a first source/drain terminal 557 electrically coupled to the output 542 of the driving circuit 540 and the first end of the connector 553, and a second source/drain terminal 558 which is grounded. The connector 553 applies the analog voltage Vout as the feedback voltage VFB to the second input 532 of the operational amplifier 535. In other words, VFB=Vout in the example configuration in
The switch 560 is electrically coupled between the output 542 of the driving circuit 540 and an output 522 of the interface circuit 500. The switch 560 is configured to selectively or controllably isolate the interface circuit 500 from other circuitry for one or more reasons discussed herein. In some embodiments, the switch 560 is controlled to be closed or open by a controller. For example, the switch 560 comprises a transistor having a gate terminal controlled by a controller. In at least one embodiment, the transistor of the switch 560 is a PMOS transistor. In some embodiments, the transistor of the switch 560 is an NMOS transistor. The described configuration of the switch 560 is an example. Other switch configurations are within the scopes of various embodiments. In at least one embodiment, the switch 560 is omitted.
In some embodiments, the interface circuit 500 is configured to operate in a manner described with respect to the interface circuit 400. Compared to ADCs used in other approaches for data conversion and/or data transfer between successive layers or resistor arrays, the buffer circuit 520A has a smaller footprint, lower power consumption, and shorter latency (i.e., faster speed). In some embodiments, the buffer circuit 520A has a footprint of about 10 times smaller than an ADC, and power consumption of about 100 times lower than an ADC. In at least one embodiment, one or more advantages described herein with respect to one or more of the IC 200, the memory device 300, or the interface circuit 400, are achievable by the interface circuit 500.
The buffer circuit 520B in
In operation, a voltage VA at the node 572 is applied as the feedback voltage VFB to the second input 532 of the operational amplifier 535. The feedback voltage VFB is determined as follows: VFB=VA=Vout×R2/(R1+R2). When the stable state is reached, Vk=VFB and, therefore, Vout=Vk×(R1+R2)/R2=Vk×(1+R1/R2), i.e., Vout>Vk. As a result, it is possible to increase the analog voltage Vout applied to the subsequent resistor array without increasing, or even while decreasing, the intermediate voltage Vk output from the integrator circuit 510. In at least one embodiment, even when the sum of the currents in signal Yk (and, hence, the intermediate voltage Vk) is small, it is possible to apply a corresponding analog voltage Vout of a sufficient voltage level to the subsequent resistor array, to ensure proper and/or reliable operation of the interface circuit and/or the IC including the interface circuit. In at least one embodiment, one or more advantages described herein with respect to one or more of the IC 200, the memory device 300, the interface circuit 400, or the interface circuit 500 are achievable by the buffer circuit 520B.
The buffer circuit 520C in
For example, the analog voltage Vout is applied from the output 542 to the offset voltage circuit 573, and is offset at the offset voltage circuit 573 by an offset voltage Voffset before being applied to the second input 532 of the operational amplifier 535. The offset voltage circuit 573 is configured to cause the offset voltage Voffset to be either added to Vout or subtracted from Vout. In some embodiments, the offset voltage Voffset is a positive voltage value and is subtracted from Vout, resulting in VFB =Vout−Voffset. At the stable state, Vk=VFB and Vout=Vk+Voffset. As described herein, Vk corresponds to Yk, which in turn, corresponds to the sum of currents expressed by Σi=1nAi×Wij in activation functions (2), (3). The additional component Voffset corresponds to bias b in activation function (3). In other words, the feedback circuit 550C makes it possible, in one or more embodiments, to add an assigned bias b to a node to realize activation function (3). When the bias b to be added is positive, the offset voltage circuit 573 is configured to add a positive offset voltage Voffset to analog voltage Vout, or to subtract a negative offset voltage Voffset from the analog voltage Vout. An example circuit configuration of the offset voltage circuit 573 comprises a positive and/or negative power supply voltage supplied via an adjustable resistor to the connector 553. Controlling the adjustable resistor, e.g., by a controller as described herein, adjusts the voltage value and/or polarity of the offset voltage Voffset, resulting in an intended bias b. The described configuration of the offset voltage circuit 573 is an example. Other circuit configurations for applying offset voltages are within the scopes of various embodiments.
In at least one embodiment, an offset voltage circuit corresponding to the offset voltage circuit 573 is included in the connector 571 of the feedback circuit 550B in
At operation 605, one or more first voltages are applied to corresponding one or more first input conductive lines. For example, as described with respect to
At operation 615, a second voltage is generated, wherein the second voltage corresponds to a sum of one or more currents caused by the one or more first voltages to flow through corresponding one or more programmable resistors to the first output conductive line. For example, as described with respect to
At operation 625, an analog voltage corresponding to the second voltage is applied to a second input conductive line of a second resistor array. For example, as described with respect to
In at least one embodiment, the analog voltage (e.g., Vout) is generated from the second voltage (e.g., Vk) without performing an analog-to-digital conversion, as described herein.
In some embodiments, operations 605, 615, 625 correspond to a computation of an activate function at a node (e.g., B2 in
The described methods and algorithms include example operations, but they are not necessarily required to be performed in the order shown. Operations may be added, replaced, changed order, and/or eliminated as appropriate, in accordance with the spirit and scope of embodiments of the disclosure. Embodiments that combine different features and/or different embodiments are within the scope of the disclosure and will be apparent to those of ordinary skill in the art after reviewing this disclosure.
In some embodiments, system 700 is a general purpose computing device including a hardware processor 702 and a non-transitory, computer-readable storage medium 704. Storage medium 704, amongst other things, is encoded with, i.e., stores, computer program code 706, i.e., a set of executable instructions. Execution of instructions 706 by hardware processor 702 implements a portion or all of the methods or processes or operations described herein in accordance with one or more embodiments (hereinafter, the noted processes and/or methods).
Processor 702 is electrically coupled to computer-readable storage medium 704 via a bus 708. Processor 702 is also electrically coupled to an I/O interface 710 by bus 708. A network interface 712 is also electrically connected to processor 702 via bus 708. Network interface 712 is connected to a network 714, so that processor 702 and computer-readable storage medium 704 are capable of connecting to external elements via network 714. Processor 702 is configured to execute computer program code 706 encoded in computer-readable storage medium 704 in order to cause system 700 to be usable for performing a portion or all of the noted processes and/or methods. In one or more embodiments, processor 702 is a central processing unit (CPU), a multi-processor, a distributed processing system, an application specific integrated circuit (ASIC), and/or a suitable processing unit.
In one or more embodiments, computer-readable storage medium 704 is an electronic, magnetic, optical, electromagnetic, infrared, and/or a semiconductor system (or apparatus or device). For example, computer-readable storage medium 704 includes a semiconductor or solid-state memory, a magnetic tape, a removable computer diskette, a random access memory (RAM), a read-only memory (ROM), a rigid magnetic disk, and/or an optical disk. In one or more embodiments using optical disks, computer-readable storage medium 704 includes a compact disk-read only memory (CD-ROM), a compact disk-read/write (CD-R/W), and/or a digital video disc (DVD).
In one or more embodiments, storage medium 704 stores computer program code 706 configured to cause system 700 to be usable for performing a portion or all of the noted processes and/or methods. In one or more embodiments, storage medium 704 also stores information which facilitates performing a portion or all of the noted processes and/or methods.
System 700 includes I/O interface 710. I/O interface 710 is coupled to external circuitry. In one or more embodiments, I/O interface 710 includes a keyboard, keypad, mouse, trackball, trackpad, touchscreen, and/or cursor direction keys for communicating information and commands to processor 702.
System 700 also includes network interface 712 coupled to processor 702. Network interface 712 allows system 700 to communicate with network 714, to which one or more other computer systems are connected. Network interface 712 includes wireless network interfaces such as BLUETOOTH, WIFI, WIMAX, GPRS, or WCDMA; or wired network interfaces such as ETHERNET, USB, or IEEE-1364. In one or more embodiments, a portion or all of noted processes and/or methods, is implemented in two or more systems 700.
System 700 is configured to receive information through I/O interface 710. The information received through I/O interface 710 includes one or more of instructions, data, design rules, libraries of standard cells, and/or other parameters for processing by processor 702. The information is transferred to processor 702 via bus 708. System 700 is configured to receive information related to a UI through I/O interface 710. The information is stored in computer-readable medium 704 as user interface (UI) 742.
In some embodiments, a portion or all of the noted processes and/or methods is implemented as a standalone software application for execution by a processor. In some embodiments, a portion or all of the noted processes and/or methods is implemented as a software application that is a part of an additional software application. In some embodiments, a portion or all of the noted processes and/or methods is implemented as a plug-in to a software application. In some embodiments, at least one of the noted processes and/or methods is implemented as a software application. In some embodiments, a portion or all of the noted processes and/or methods is implemented as a software application that is used by system 700.
In some embodiments, the processes are realized as functions of a program stored in a non-transitory computer readable recording medium. Examples of a non-transitory computer readable recording medium include, but are not limited to, external/removable and/or internal/built-in storage or memory unit, e.g., one or more of an optical disk, such as a DVD, a magnetic disk, such as a hard disk, a semiconductor memory, such as a ROM, a RAM, a memory card, and the like.
In some embodiments, an integrated circuit comprises a first array of resistors, a second array of resistors, and a plurality of interface circuits electrically coupled between the first array of resistors and the second array of resistors. Each interface circuit among the plurality of interface circuits is configured to receive a signal from the first array of resistors, and apply an analog voltage corresponding to the signal to the second array of resistors.
In some embodiments, an integrated circuit comprises a first array of resistors, a second array of resistors, and at least one interface circuit electrically coupled between the first array of resistors and the second array of resistors. The at least one interface circuit comprises a comparator circuit having a first input configured to receive an intermediate voltage corresponding to a current output from the first array of resistors, a driving circuit electrically coupled to an output of the comparator circuit, and a feedback circuit electrically coupling an output of the driving circuit to a second input of the comparator circuit. The driving circuit is configured to generate an analog voltage, and output the analog voltage to the second array of resistors. The feedback circuit is configured to apply a feedback voltage corresponding to the analog voltage to the second input of the comparator circuit. The comparator circuit is configured to perform a comparison between the intermediate voltage and the feedback voltage, and control the driving circuit to generate the analog voltage in accordance with a result of the comparison.
In some embodiments, an integrated circuit comprises a first array of resistors, a second array of resistors, and at least one interface circuit electrically coupled between the first array of resistors and the second array of resistors. The at least one interface circuit comprises an operational amplifier, a transistor and a feedback circuit. The operational amplifier has a first input electrically coupled to the first array of resistors, a second input, and an output. The transistor has a gate terminal electrically coupled to the output of the operational amplifier, a first source/drain terminal electrically coupled to the second array of resistors, and a second source/drain terminal electrically coupled to a node of a power supply voltage. The feedback circuit is electrically coupled between the first source/drain terminal of the transistor and the second input of the operational amplifier.
The foregoing outlines features of several embodiments so that those skilled in the art may better understand the aspects of the present disclosure. Those skilled in the art should appreciate that they may readily use the present disclosure as a basis for designing or modifying other processes and structures for carrying out the same purposes and/or achieving the same advantages of the embodiments introduced herein. Those skilled in the art should also realize that such equivalent constructions do not depart from the spirit and scope of the present disclosure, and that they may make various changes, substitutions, and alterations herein without departing from the spirit and scope of the present disclosure.
This application is a continuation application of U.S. patent application Ser. No. 18/362,393, filed Jul. 31, 2023, which is a divisional application of U.S. patent application Ser. No. 17/463,082, filed Aug. 31, 2021, now U.S. Pat. No. 11,837,281, issued Dec. 5, 2023. The entire contents of the above-referenced patent(s) and applications are incorporated by reference herein.
Number | Date | Country | |
---|---|---|---|
Parent | 17463082 | Aug 2021 | US |
Child | 18362393 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 18362393 | Jul 2023 | US |
Child | 18785998 | US |