Embodiments of the present invention relate generally to memory devices, and, more specifically, to digital filters with memory for reading from, and/or writing to, memory elements in memory devices.
Generally, memory devices include an array of memory elements and associated sensing circuits. The memory elements store data, and the sensing circuits read the data from the memory elements. To read data, for example, a current is passed through the memory element, and the current or a resulting voltage is measured by the sensing circuit. Conventionally, the sensing circuit measures the current or voltage by comparing it to a reference current or voltage. Depending on whether the current or voltage is greater than the reference, the sensing circuit outputs a value of one or zero. That is, the sensing circuit quantizes or digitizes the analog signal from the memory element into one of two logic states.
The sensing circuit also provides feedback when writing to the memory element. In some memory devices, writing is an iterative process in which a value is written to the memory element by incrementally changing some property of the memory element, such as charge stored on a floating gate. After each iteration, the sensing circuit reads from the memory element to determine whether the changed property reflects the target value to be written to the memory element. If the property indicates the proper value, then the process of incrementally changing the property stops. Otherwise, the property is changed by another increment, and the sensing circuit reads from the memory element, repeating the process until the memory element stores the target value. Thus, each time data is written to the memory element, the sensing circuit may both read from the memory element and compare the resulting value to a target value several times.
Certain conventional sensing circuits can slow the writing process. These sensing circuits request and receive the target value over an input/output bus each time that they compare the target value to the value stored by the memory element. Acquiring the target value over the input/output bus can take several clock cycles. As a result, these sensing circuits may increase the time between each iteration of the writing process and, as a result, slow the operation of the memory device.
Additionally, some conventional sensing circuits include comparison circuitry that increases the size of memory devices, which tends to increase their cost. Certain conventional sensing circuits include comparison circuitry that, during a write operation, compares the target value to the value stored by the memory element. For multi-bit memory elements, the comparison circuitry may compare each digit of a multi-bit target value to each digit of a multi-bit value stored by the memory element. Circuitry configured to compare each digit may consume valuable chip surface area, especially in sensing circuits designed to sense multi-bit memory elements.
Various embodiments of the present invention are described below. In an effort to provide a concise description of these embodiments, not all features of an actual implementation are described in the specification. It should be appreciated that in the development of any such actual implementation, as in any engineering or design project, numerous implementation-specific decisions must be made to achieve the developers' specific goals, such as compliance with system-related and business-related constraints, which may vary from one implementation to another. Moreover, it should be appreciated that such a development effort might be complex and time consuming but would nevertheless be a routine undertaking of design, fabrication, and manufacture for those of ordinary skill having the benefit of this disclosure.
Some of the subsequently described embodiments may address one or more of the problems with conventional sensing circuits discussed above. Some embodiments include a quantizing circuit configured to detect small differences in voltages and/or currents. In certain embodiments, the quantizing circuit may include a digital filter, such as a counter, with memory. As explained below, the memory in the digital filter may expedite write operations by locally storing the values to be written to a memory element. Additionally, in some embodiments, the memory may store a preset value used to initialize the counter such that a relatively simple circuit may be used to determine whether the memory element stores the target value being written.
The following description begins with an overview of examples of systems that employ quantizing circuits in accordance with embodiments of the present invention, and the problems within these systems that may be addressed by the quantizing circuits, as described with reference to
Myriad devices may embody one or more of the present techniques. For example, the electronic device 10 may be a storage device, a communications device, an entertainment device, an imaging system, or a computer system, such as a personal computer, a server, a mainframe, a tablet computer, a palm-top computer, or a laptop.
When accessing the memory elements, the control circuitry may receive a command to read from or write to a target memory address. The control circuitry 28 may then convert the target address into a row address and a column address. In the illustrated embodiment, the row address bus 30 transmits the row address to the row address latches 26, and a column address bus 32 transmits column address to the column address latches 20. After an appropriate settling time, a row address strobe (RAS) signal 34 (or other controlling clock signal) may be asserted by the control circuitry 28, and the row address latches 26 may latch the transmitted row address. Similarly, the control circuitry 28 may assert a column address strobe 36, and the column address latches 20 may latch the transmitted column address.
Once row and column addresses are latched, the row decoder 24 may determine which row of the memory array 14 corresponds to the latched row address, and the row drivers 22 may assert a signal on the selected row. Similarly, the column decoder 18 may determine which column of the memory array 14 corresponds with the latched column address, and the quantizing circuit 16 may sense a voltage or current on the selected column. Additional details of reading and writing are described below.
In some embodiments, the illustrated memory elements 64 are flash memory devices. The operation of the flash memory elements is described further below with reference to the
Several of the components of the circuit 66 represent phenomenon affecting the memory elements 64 during operation. The pre-drain resistor 70 generally represents the drain-to-bitline resistance of the memory elements 64 coupled to the bit-line above (i.e., up current from) WL3 when these memory elements 64 are turned on, (e.g., during a read operation). Similarly, the post source resistor 72 generally corresponds to the source-to-ground resistance of the memory elements 64 coupled to the bit-line below WL3 when these memory element 64 is selected. The circuit 66 models electrical phenomena associated with reading the memory elements 64 at the intersection of WL3 and BL0.
The operation of the memory elements 64 will now be briefly described with reference to
To write data to the memory elements 64, a charge corresponding to the data may be stored on the floating gate 78. The charge of the floating gate 78 may be modified by applying voltages to the source 82, drain 80, and/or gate 76 such that the resulting electric fields produce phenomenon like Fowler-Northam tunneling and/or hot-electron injection near the floating gate 78. Initially, the memory elements 64 may be erased by manipulating the word-line voltage to drive electrons off of the floating gate 78. In some embodiments, an entire column or block of memory elements 64 may be erased generally simultaneously. Once the memory elements 64 are erased, the gate 76 voltage may be manipulated to drive a charge onto the floating gate 78 that is indicative of a data value. After the write operation ends, the stored charge may remain on the floating gate 78 (i.e., the memory elements 64 may store data in a nonvolatile fashion).
As illustrated by
The accuracy with which the bit-line current is sensed may affect the amount of data that a designer attempts to store in each memory element 64. For example, in a system with a low sensitivity, a single bit may be stored on each memory element 64. In such a system, a floating gate voltage VFG of 0x may correspond to a value of 0, and a floating gate voltage VFG of −7x may correspond to a value of one. Thus, the difference in floating gate voltages VFG corresponding to different data values may be relatively large, and the resulting differences and bit-line currents for different data values may also be relatively large. As a result, even low-sensitivity sensing circuitry may discern these large differences in bit-line current during a read operation. In contrast, high-sensitivity sensing circuitry may facilitate storing more data in each memory element 64. For instance, if the sensing circuitry can distinguish between the eight different I-V traces depicted by
However, as mentioned above, a variety of effects may interfere with accurate measurement of the bit-line current. For instance, the position of the memory elements 64 along a bit-line may affect RPD and RPS, which may affect the relationship between the word-line voltage VWL and the bit-line current IBIT. To illustrate these effects,
In operation, the quantizing circuit 16 may digitize analog signals from the memory elements 64 in a manner that is relatively robust to noise. As explained below, the quantizing circuit 16 may do this by converting the analog signals into a bit-stream and digitally filtering high-frequency components from the bit-stream.
The analog-to-digital converter 88 may be a one-bit, analog-to-digital converter or a multi-bit, analog-to-digital converter. In the present embodiment, an analog-to-digital converter 88 receives an analog signal from the memory element 64, e.g., a bit-line current IBIT or a bit-line voltage VBL, and outputs a bit-stream that corresponds with the analog signal. The bit-stream may be a one-bit, serial signal with a time-averaged value that generally represents or corresponds to the time-averaged value of the analog signal from the memory element 64. That is, the bit-stream may fluctuate between values of zero and one, but its average value, over a sufficiently large period of time, may be proportional to the average value of the analog signal from the memory element 64. In certain embodiments, the bit-stream from the analog-to-digital converter 88 may be a pulse-density modulated (PDM) version of the analog signal. The analog-to-digital converter 88 may transmit the bit-stream to the digital filter 90 on a bit-stream signal path 94.
The digital filter 90 may remove high-frequency noise from the bit-stream. To this end, the digital filter 90 may be a low-pass filter, such as a counter, configured to average or integrate the bit-stream over a sensing time, i.e., the time period over which the memory element 64 is read. As a result, the digital filter 90 may output a value that is representative of both the average value of the bit-stream and the average value of the analog signal from the memory element 64. In some embodiments, the digital filter 90 is a counter, and the cut-off frequency of the digital filter 90 may be selected by adjusting the duration of the sensing time. In the present embodiment, increasing the sensing time will lower the cutoff frequency. That is, the frequency response of the digital filter 90 may be tuned by adjusting the period of time over which the bit-stream is integrated and/or averaged before outputting a final value. The frequency response of the digital filter 90 is described further below with reference to
Advantageously, in certain embodiments, the quantizing circuit 16 may facilitate the use of multi-bit memory elements 64. As described above, in traditional designs, the number of discrete data values that a memory element 64 stores may be limited by sense amps that react to noise. In contrast, the quantizing circuit 16 may be less susceptible to noise, and, as a result, the memory elements 64 may be configured to store additional data. Without the high frequency noise, the intervals between signals representative of different data values may be made smaller, and the number of data values stored by a given memory element 64 may be increased. Thus, beneficially, the quantizing circuit 16 may sense memory elements 64 that store several bits of data, e.g., 2, 3, 4, 5, 6, 7, 8, or more bits per memory element 64.
Although the quantizing circuit 16 may sample the signal from the memory element 64 over a longer period of time than conventional designs, the overall speed of the memory device 12 may be improved. As compared to a conventional device, each read or write operation of the memory device 12 may transfer more bits of data into or out of the memory element 64. As a result, while each read or write operation may take longer, more data may be read or written during the operation, thereby improving overall performance. Further, in some memory devices 12, certain processes may be performed in parallel with a read or write operation, thereby further reducing the overall impact of the longer sensing time. For example, in some embodiments, the memory array 14 may be divided into banks that operate at least partially independently, so that, while data is being written or read from one bank, another bank can read or write data in parallel.
As illustrated, an input of the counter 90 may connect to the bit-stream signal path 94, which may connect to an output of the comparator 96. The output of the comparator 96 may also connect to a gate of the switch 100 by a feedback signal path 102. The output terminal (e.g., source or drain) of the switch 100 may connect in series to one of the bit-lines 38, 40, 42, 44, or 46, and the input terminal of the switch 100 may connect to a reference current source 104 (IRef). One plate of the capacitor 98 may connect to one of the bit-lines 38, 40, 42, 44, or 46, and the other plate of the capacitor 98 may connect to ground.
The illustrated counter 90 counts the number of clock cycles that the bit-stream 94 is at a logic high value or logic low value during the sampling period. The counter may count up or count down, depending on the embodiment. In some embodiments, the counter 90 may do both, counting up one for each clock cycle that the bit-stream has a logic high value and down one for each clock cycle that the bit-stream has a logic low value. Output terminals (D0-D5) of the counter 90 may connect to the input/output bus 92 for transmitting the count. The counter 90 may be configured to be reset to zero or some other value when a reset signal is asserted. In some embodiments, the counter 90 may be a series connection of D-flip flop, e.g., a D-flip flop having SRAM or other memory for storing an initial value and/or values to be written to the memory element 64.
In the illustrated embodiment, the clocked comparator 96 compares a reference voltage (VRef) to the voltage of one of the bit-lines 38, 40, 42, 44, or 46 (VBL), which may be generally equal to the voltage of one plate of the capacitor 98. The comparator 96 may be clocked (e.g., falling and/or rising edge triggered), and the comparison may be performed at regular intervals based on the clock signal, e.g., once per clock cycle. Additionally, the comparator 96 may latch, i.e., continue to output, values (VFB) between comparisons. Thus, when the clock signals the comparator 96 to perform a comparison, if VBL is less than VRef, then the comparator 96 may latch its output to a logic low value, as described below in reference to
Advantageously, in some embodiments, the quantizing circuit 16 may include a single comparator (e.g., not more than one) for each column of multi-level memory elements 64. In contrast, conventional sensing circuits often include multiple comparators to read from a multi-bit memory cell, thereby potentially increasing device complexity and cost.
The capacitor 98 may be formed by capacitive coupling of the bit-lines 38, 40, 42, 44, and 46. In other designs, this type of capacitance is referred to as parasitic capacitance because it often hinders the operation of the device. However, in this embodiment, the capacitor 98 may be used to integrate differences between currents on the bit-lines 38, 40, 42, 44, or 46 and the reference current to form the bit-stream, as explained further below. In some embodiments, the capacitor 98 may be supplemented or replaced with an integrated capacitor that provides greater capacitance than the “parasitic” bit-line capacitance.
The illustrated switch 100 selectively transmits current IRef from the reference current source 104. In various embodiments, the switch 100 may be a PMOS transistor (as illustrated in
The operation of the quantizing circuit 16 will now be described with reference to
To measure the current through the memory element 64, the illustrated delta-sigma modulator 88 exploits transient effects to generate a bit-stream representative of the bit-line current IBIT. Specifically, the delta-sigma modulator 88 may repeatedly charge and discharge the capacitor 98 with a current divider that subtracts the bit-line current IBIT from the reference current IREF. Consequently, a large current through the memory element 64 may rapidly discharge the capacitor 98, and a small current through the memory element 64 may slowly discharge the capacitor 98.
To charge and discharge the capacitor 98, the delta-sigma modulator 88 switches between two states: the state depicted by
Starting with the charging state (
The comparator 96 and the reference current source 104 may cooperate to charge the capacitor 98 for a discrete number of clock cycles. That is, when the delta-sigma modulator 88 enters the charging state, the delta-sigma modulator 88 may remain in this state for an integer number of clock cycles. In the illustrated embodiment, the comparator 96, the output of which is latched, changes state no more than once per clock cycle, so the switch 100, which is controlled by the output of the comparator 96, VFB, conducts current for a discrete number of clock cycles. As a result, the reference current source 104 conducts current IRef through the bit-line and into the capacitor 98 for an integer number of clock cycles.
After each clock cycle of charging the capacitor 98, the delta-sigma modulator 88 may transition from the charging state to the discharging state, which is illustrated by
In the present embodiment, the delta-sigma modulator 88 discharges the capacitor 98 for a discrete number of clock intervals. After each clock cycle of discharging the capacitor 98, the delta-sigma modulator 88 compares VBL to VRef. If VBL is still greater than VRef, then the comparator 96 may continue to output a logic high signal, i.e., VFB=1, and the switch 100 remains open. On the other hand, if enough current has flowed out of the capacitor 98 that VBL is less than VRef, then the comparator 96 may output a logic low signal, i.e., VFB=0, and the switch 100 may close, thereby transitioning the delta-sigma modulator 88 back to the charging state and initiating a new cycle.
The counter 90 may count the number of clock cycles that the delta-sigma modulator 88 is in either the charging state or the discharging state by monitoring the bit-stream signal path 94. The bit-stream signal path 94 may transition back and forth between logic high and logic low with the output of the comparator 96, VFB, and the counter 90 may increment and/or decrement a count once per clock cycle (or other appropriate interval) based on whether the bit-stream is logic high or logic low. After the sensing time has passed, the counter 90 may output a signal indicative of the count on output terminals D0-D5. As explained below, the count may correspond, e.g., proportionally, to the bit-line current, IBit. In some embodiments, the counter 90 may be preset with a value stored in memory 91 such that a relatively simple circuit can determine whether the memory element 64 stores a target value, as explained below.
As illustrated by
A comparison of
The capacitance of the capacitor 98 may be selected with both the clock frequency and the range of expected bit-line currents in mind. For example, the capacitor 98 may be large enough that the capacitor 98 does not fully discharge or saturate when the bit-line current IBIT is either at its lowest expected value or at its highest expected value. That is, in some embodiments, the capacitor 98 generally remains in a transient state while reading the memory element 64. Similarly, the frequency at which the comparator 96 is clocked may affect the design of the capacitor 98. A relatively high frequency clock signal may leave the capacitor 98 with relatively little time to discharge or saturate between clock cycles, thereby leading a designer to choose a smaller capacitor 98.
Similarly, the size of the reference current may be selected with the range of expected bit-line currents in mind. Specifically, in certain embodiments, the reference current is less than the largest expected bit-line current IBIT, so that, in the case of maximum bit-line current IBIT, the capacitor 98 can draw charge from the reference current while the rest of the reference current flows through the memory element 64.
IBit/IRef=Count/NST
Thus, in the illustrated embodiment, the count is indicative of the bit-line current IBIT, which is indicative of the value stored by the memory element 64.
Advantageously, the quantizing circuit 16 may categorize the bit-line current IBIT as falling into one of a large number of categories, each of which is represented by an increment of the count. That is, the quantizing circuit 16 may resolve small differences in the bit-line current IBIT. The resolution of the quantizing circuit 16 may be characterized by the following equation (Equation 2), in which IMR represents the smallest resolvable difference in bit-line current IBIT, i.e., the resolution of the quantizing circuit 16:
IMR=IRef/NST
Thus, the resolution of the quantizing circuit 16 may be increased by increasing the sensing time or the clock frequency or by decreasing IRef, which may limit the maximum cell current since IMR is less than IRef.
The resolution of the quantizing circuit 16 may facilitate storing multiple bits in the memory element 64 or detecting multiple levels of light intensity in an image sensor element. For example, if the quantizing circuit 16 is configured to categorize the bit-line current IBIT into one of four different levels, then the memory element 64 may store two-bits of data or, if the quantizing circuit 16 is configured to categorize the bit-line current IBIT into one of eight different current levels, then the memory element 64 may store three-bits of data. For the present embodiment, the number of bits stored by the memory element 64 may be characterized by the following equation (Equation 3), in which NB represents the number of bits stored by a memory element 64 and IRange represents the range of programmable bit-line currents through the memory element 64:
NB=log(IRange/IMR)/log 2
In short, in the present embodiment, greater resolution translates into higher density data storage for a given memory element 64.
Truncating less significant digits may introduce a rounding error, or a downward bias, in the output. This effect may be mitigated by presetting the counter 90 in a manner that accounts for this bias. The counter 90 may be preset either before reading from the memory element 64 or before writing to the memory element 64. In some embodiments, the preset value may be one-half of the size of the range of counter values that represent a single output value. In other words, if m digits are truncated from the output, then the counter 90 may be preset to one-half of 2m before reading from a memory element 64 or before writing to the memory element 64. In some embodiments, the memory 91 may store this preset value, as described below with reference to
Each illustrated flip-flop 118-128 also includes a store, transfer, and D-initial input. These inputs may be asserted to locally store a target value to be written to a memory element 64 and to preset the counter 90. Asserting the store signal may cause the flip-flops 118-128 to store the signal on the D-initial input in memory 91. In the illustrated embodiment, the D-initial and Q signals are on different signal paths. However, in other embodiments, the signals may share a signal path. Asserting a transfer signal may cause each flip-flop 118-128 to preset itself, such that its output Q corresponds to the value stored in memory 91.
The D-flip-flop 132 also includes a plurality of transmission gates 148, 150, 152, 154, 156, 158, 160, 162, 164, 166. Each illustrated transmission gate 148-166 includes a PMOS and an NMOS transistor with inverted control signals, e.g., clock and
These transmission gates 148-166 may be controlled by the clock signal and the transfer signal, as indicated by
In operation, the D-flip-flop 132 may transfer data according to the clock signal. For example, on the rising edge of the clock signal, the master flip-flop 136 may transfer the value of the output of the inverter 142 the slave flip-flop 138 and capture the value of the D-input.
The SRAM 134 may include inverters 168 and 170 and transmission gates 172 and 174. In the present embodiment, the output of the inverter 168 is connected to the input of the inverter 170, and the input of the inverter 168 is connected to the output of the inverter 170 via the transmission gate 172. The D-initial input may be connected to the input of the inverter 168 via the transmission gate 174. The transmission gates 172 and 174 may be controlled by the store signal, with a logic high store signal opening transmission gate 174 and closing transmission gate 172 and vice versa.
The illustrated flip-flop 130 may be characterized as storing three bits of data. In this embodiment, the SRAM 134 stores one bit of data, the state of the master flip-flop 136 stores a second bit of data, and the state of the slave flip-flop 138 stores a third bit of data. In other words, the illustrated flip-flop 130 has three-degrees of freedom, meaning that its state can be described with three variables. In other embodiments, flip-flop 130 may store more or less data. However, the master flip-flop 136 and slave flip-flop 138 are distinct from the SRAM in that they are controlled, at least in part, by the clock signal.
In some embodiments, presetting includes storing and transferring the preset value. For example, in some embodiments employing the counter 90 illustrated by
Next, the reference current is conducted both into the capacitor (e.g., the capacitor 98 illustrated in
Next, the capacitor is discharged through the memory element, as depicted by block 186, and a determination is made as to whether a new clock cycle has started, as depicted by block 188. Based on the results of the determination, either the capacitor continues to discharge through the memory cell, as described by block 186, or the count is increased by one, as depicted by block 190. In some embodiments, the counter may count down rather than up, and the count may be decreased by one rather than increased by one.
After changing the count, a determination is made as to whether the voltage of the capacitor is less than the reference voltage, as depicted by block 192. Based on the result of the determination, the read operation 174 either returns to block 186 to continue discharging the capacitor or continues to block 194, where a determination is made as to whether the sensing time has elapsed. Based on the determination at block 194, the read operation 174 either returns to block 178 to initiate a new charge and discharge cycle or outputs a data value from the counter, as depicted by block 196.
The counter may then truncate the count by m-least-significant digits, as illustrated by block 196. Next, the truncated value is output as the data value stored by the memory element, as illustrated by block 198. Outputting the data may include storing the data in tangible, machine-readable memory; transmitting the data to another component; displaying the data, or using the data in subsequent calculations.
Next, in the present embodiment, a preset value is calculated, as illustrated by block 204. Calculating a preset value may include calculating a preset value that accounts for rounding error when truncating bits from the count. In the present embodiment calculating a preset value begins with multiplying a target value to be written to the memory element by 2m, where m is the number of least-significant digits of the count that are disregarded as noise, as illustrated by block 206. For example, if the target value is 010 and m=3, then 2m equals 8, and the multiplication act illustrated by block 206 results in a product of 01 0000.
To finish calculating the preset value, in the present embodiment, one half of 2m is added to the product of the multiplication act illustrated by block 206, as illustrated by block 208. For instance, continuing with the previous example, if the product of the act illustrated by block 206 is 01 0000 and three digits are truncated (m=3), then the preset value is equal to 01 0100. In other embodiments, this act may be omitted, which is not to suggest that other acts described herein may not also be omitted.
Next, in the present embodiment, the preset value to be written to the memory element is locally stored, as illustrated by block 210. Locally storing the preset value may include storing the preset value in memory integrated with the counter, as illustrated by
After locally storing the preset value, a memory-element property that is used to store data may be adjusted by one increment, as illustrated by block 212. Adjusting a memory-element property may include driving a charge on to a floating gate or partially changing the phase of a phase-change memory element. After adjusting the memory-element property, the memory element is read, as illustrated by block 214. This step may include performing the read operation 174 illustrated in
After reading the memory element, it is determined whether the value stored by the memory element is generally equal to the preset value to be written to the memory element, as illustrated by block 218. If the value to be written is not generally equal to the value to be stored, then the memory element property may be adjusted by another increment, and the operation 200 may return to block 212. On the other hand, if the value stored by the memory element is generally equal to the preset value, then the write operation 200 may end, as illustrated by block 220. In the various embodiments, the comparison illustrated by block 218 may include determining whether the value stored by the memory element is greater than or equal to the preset value or within some tolerance of the preset value.
In the write operation 222, after locally storing the preset value, it is used to preset the counter, as illustrated by block 228. In some embodiments, such as the embodiment illustrated by
Presetting the counter with this value may simplify the circuitry that performs the comparison illustrated by block 230. In the present embodiment, rather than comparing each digit of the value read from the memory element to the corresponding digit of the target value to determine whether the memory element stores the target value, it is determined whether the count is all ones (e.g., 1111 1111 for an eight-bit counter). Calculating a preset value in the manner illustrated by block 224 may result in a preset value that sums with the target value and the rounding error correction to a value that is represented by the counter with all ones.
The comparison illustrated by block 230 may include determining whether the count is greater than zero or within some tolerance of zero, e.g., within plus or minus half of 2m of zero. If an affirmative determination is made in the comparison illustrated by block 230, then the write operation 222 may end. Otherwise, the write operation 222 may return to the act illustrated by block 228, and the counter may be reset again with the preset value, e.g., by asserting the transfer signal (
In the illustrated embodiment, the largest digit of the counter indicates whether the memory element stores the target value. Thus, in the comparison illustrated by block 246, it is determined whether the most-significant digit of the counter is substantially equal to one. For example, if the target value is 10, the counter has six digits, and three digits are dropped, then the preset value is 00 1100, and the counter counts up from 00 1100 to 10 0000 when reading from a memory element storing the target value. Thus, in this example, the most-significant digit signals whether the memory element stores the target value. Advantageously, presetting the counter in this manner may simplify or eliminate the circuitry that determines whether the memory element stores the correct value.
In each of the embodiments illustrated by
Next in the write operation 256, the quantizing circuit is preset according to the present value, as illustrated by block 260. Presetting may include changing the state of flip-flops in a counter or otherwise configuring a digital filter. In some embodiments, this act may be preceded by an act of locally storing the preset value, for instance in memory in a counter. After presetting the quantizing circuit, a property of the memory element that is used to store data may be adjusted, as illustrated by block 262, and a value may be read from the memory element with the quantizing circuit, as illustrated by block 264. Next, it is determined whether the quantizing circuit outputs the signal value, as illustrated by block 266. If the quantizing circuit does not output the signal value, then the write operation 256 returns to the act illustrated by block 260. Otherwise, the write operation 256 ends, as illustrated by block 268.
The system 310 typically includes a power supply 314. For instance, if the system 310 is a portable system, the power supply 314 may advantageously include a fuel cell, permanent batteries, replaceable batteries, and/or rechargeable batteries. The power supply 314 may also include an AC adapter, so the system 310 may be plugged into a wall outlet, for instance. The power supply 314 may also include a DC adapter such that the system 310 may be plugged into a vehicle cigarette lighter, for instance.
Various other devices may be coupled to the processor 312 depending on the functions that the system 310 performs. For instance, a user interface 316 may be coupled to the processor 312. The user interface 316 may include buttons, switches, a keyboard, a light pen, a mouse, a digitizer and stylus, and/or a voice recognition system, for instance. A display 318 may also be coupled to the processor 312. The display 318 may include an LCD, an SED display, a CRT display, a DLP display, a plasma display, an OLED display, LEDs, and/or an audio display, for example. Furthermore, an RF sub-system/baseband processor 320 may also be coupled to the processor 312. The RF sub-system/baseband processor 320 may include an antenna that is coupled to an RF receiver and to an RF transmitter (not shown). One or more communication ports 322 may also be coupled to the processor 312. The communication port 322 may be adapted to be coupled to one or more peripheral devices 324 such as a modem, a printer, a computer, or to a network, such as a local area network, remote area network, intranet, or the Internet, for instance.
The processor 312 generally controls the system 310 by implementing software programs stored in the memory. The memory is operably coupled to the processor 312 to store and facilitate execution of various programs. For instance, the processor 312 may be coupled to the volatile memory 326 which may include Dynamic Random Access Memory (DRAM) and/or Static Random Access Memory (SRAM). The volatile memory 326 is typically large so that it can store dynamically loaded applications and data. As described further below, the volatile memory 326 may be configured in accordance with embodiments of the present invention.
The processor 312 may also be coupled to the memory device 12. The memory device 12 may include a read-only memory (ROM), such as an EPROM, and/or flash memory to be used in conjunction with the volatile memory 326. The size of the ROM is typically selected to be just large enough to store any necessary operating system, application programs, and fixed data. Additionally, the non-volatile memory 328 may include a high capacity memory such as a tape or disk drive memory.
The memory device 10 and volatile memory 326 may store various types of software, such as an operating system or office productivity suite including a word processing application, a spreadsheet application, an email application, and/or a database application.
While the invention may be susceptible to various modifications and alternative forms, specific embodiments have been shown by way of example in the drawings and have been described in detail herein. However, it should be understood that the invention is not intended to be limited to the particular forms disclosed. Rather, the invention is to cover all modifications, equivalents, and alternatives falling within the spirit and scope of the invention as defined by the following appended claims.
The present application is a continuation application of U.S. application Ser. No. 14/724,491, entitled “DIGITAL FILTERS WITH MEMORY,” filed May 28, 2015, now U.S. Pat. No. 9,734,894 which issued on Aug. 15, 2017, which is a continuation of U.S. application Ser. No. 12/941,878, entitled “DIGITAL FILTERS WITH MEMORY,” filed Nov. 10, 2010, now U.S. Pat. No. 9,070,469 which issued on Jun. 30, 2015, which is a divisional of U.S. application Ser. No. 11/818,989, entitled “DIGITAL FILTERS WITH MEMORY,” filed Jun. 15, 2007, now U.S. Pat. No. 7,830,729 which issued on Nov. 9, 2010, the entirety of which is incorporated by reference herein for all purposes.
Number | Name | Date | Kind |
---|---|---|---|
4053739 | Miller et al. | Oct 1977 | A |
4231104 | St. Clair | Oct 1980 | A |
4460982 | Gee et al. | Jul 1984 | A |
4562437 | Sasaki et al. | Dec 1985 | A |
4837791 | Nakanishi et al. | Jun 1989 | A |
5218569 | Banks | Jun 1993 | A |
5600319 | Ginetti | Feb 1997 | A |
5614856 | Wilson et al. | Mar 1997 | A |
5627784 | Roohparvar | May 1997 | A |
5748535 | Lin et al. | May 1998 | A |
5777911 | Sherry et al. | Jul 1998 | A |
5953276 | Baker | Sep 1999 | A |
5973956 | Blyth et al. | Oct 1999 | A |
6044019 | Cernea et al. | Mar 2000 | A |
6097637 | Bauer et al. | Aug 2000 | A |
6188340 | Matsumoto et al. | Feb 2001 | B1 |
6282120 | Cernea et al. | Aug 2001 | B1 |
6466476 | Wong et al. | Oct 2002 | B1 |
6490200 | Cernea et al. | Dec 2002 | B2 |
6504750 | Baker | Jan 2003 | B1 |
6567297 | Baker | May 2003 | B2 |
6594186 | Kodaira et al. | Jul 2003 | B2 |
6661708 | Cernea et al. | Dec 2003 | B2 |
6664708 | Shlimak et al. | Dec 2003 | B2 |
6665013 | Fossum et al. | Dec 2003 | B1 |
6741502 | Cernea | May 2004 | B1 |
6781906 | Perner et al. | Aug 2004 | B2 |
6785156 | Baker | Aug 2004 | B2 |
6795359 | Baker | Sep 2004 | B1 |
6798705 | Baker | Sep 2004 | B2 |
6807403 | Tanaka | Oct 2004 | B2 |
6813208 | Baker | Nov 2004 | B2 |
6822892 | Baker | Nov 2004 | B2 |
6826102 | Baker | Nov 2004 | B2 |
6829188 | Baker | Dec 2004 | B2 |
6847234 | Choi | Jan 2005 | B2 |
6850441 | Mokhlesi et al. | Feb 2005 | B2 |
6856564 | Baker | Feb 2005 | B2 |
6870784 | Baker | Mar 2005 | B2 |
6901020 | Baker | May 2005 | B2 |
6914838 | Baker | Jul 2005 | B2 |
6930942 | Baker | Aug 2005 | B2 |
6954390 | Baker | Oct 2005 | B2 |
6954391 | Baker | Oct 2005 | B2 |
6977601 | Fletcher et al. | Dec 2005 | B1 |
6985375 | Baker | Jan 2006 | B2 |
7002833 | Hush et al. | Feb 2006 | B2 |
7009901 | Baker | Mar 2006 | B2 |
7095667 | Baker | Aug 2006 | B2 |
7102932 | Baker | Sep 2006 | B2 |
7133307 | Baker | Nov 2006 | B2 |
7151701 | Combe et al. | Dec 2006 | B2 |
7366021 | Taylor et al. | Apr 2008 | B2 |
7538702 | Baker | May 2009 | B2 |
7667632 | Baker | Feb 2010 | B2 |
7733262 | Baker | Jun 2010 | B2 |
7768868 | Baker | Aug 2010 | B2 |
7817073 | Baker | Oct 2010 | B2 |
7830729 | Baker | Nov 2010 | B2 |
8149646 | Baker | Apr 2012 | B2 |
9070469 | Baker | Jun 2015 | B2 |
20020101758 | Baker | Aug 2002 | A1 |
20020194557 | Park | Dec 2002 | A1 |
20030039162 | Baker | Feb 2003 | A1 |
20030043616 | Baker | Mar 2003 | A1 |
20030067797 | Baker | Apr 2003 | A1 |
20030169841 | van der Valk | Sep 2003 | A1 |
20030198078 | Baker | Oct 2003 | A1 |
20030214868 | Baker | Nov 2003 | A1 |
20040008555 | Baker | Jan 2004 | A1 |
20040027904 | Morikawa | Feb 2004 | A1 |
20040032760 | Baker | Feb 2004 | A1 |
20040062100 | Baker | Apr 2004 | A1 |
20040076052 | Baker | Apr 2004 | A1 |
20040095839 | Baker | May 2004 | A1 |
20040190327 | Baker | Sep 2004 | A1 |
20040190334 | Baker | Sep 2004 | A1 |
20040199710 | Baker | Oct 2004 | A1 |
20040240294 | Baker | Dec 2004 | A1 |
20050002249 | Baker | Jan 2005 | A1 |
20050007803 | Baker | Jan 2005 | A1 |
20050007850 | Baker | Jan 2005 | A1 |
20050013184 | Baker | Jan 2005 | A1 |
20050018477 | Baker | Jan 2005 | A1 |
20050018512 | Baker | Jan 2005 | A1 |
20050041128 | Baker | Feb 2005 | A1 |
20050088892 | Baker | Apr 2005 | A1 |
20050088893 | Baker | Apr 2005 | A1 |
20050201145 | Baker | Sep 2005 | A1 |
20060013040 | Baker | Jan 2006 | A1 |
20060062062 | Baker | Mar 2006 | A1 |
20060221696 | Li | Oct 2006 | A1 |
20060227641 | Baker | Oct 2006 | A1 |
20060250853 | Taylor et al. | Nov 2006 | A1 |
20060291291 | Hosono et al. | Dec 2006 | A1 |
20080309530 | Baker | Dec 2008 | A1 |
20080309540 | Baker | Dec 2008 | A1 |
20080310236 | Baker | Dec 2008 | A1 |
20080310245 | Baker | Dec 2008 | A1 |
20110051511 | Baker | Mar 2011 | A1 |
Entry |
---|
Rane Corporation, RaneNote 137, “Digital Charma of Audio A/D Converters,” 1997, 12 pgs. |
Baker, R.J., (2001-2006) Sensing Circuits for Resistive Memory , presented at various universities and companies, 31 pgs. |
Baker, “CMOS Mixed Signal Circuit Design,” IEEE Press, A. John Wiley & Sons, Inc.; Copyright 2003, Figures 30.63, 31.82, 32.6, 32.7, 32.24, 32.51, 33.34, 33.47, 33.51, 34.18, 34.24; located at http://cmosedu.com/cmos2/book2.htm, 11 pgs. |
Dallas Semiconductor, Maxim Application Note 1870, “Demystifying Sigma-Delta ADCs,” (Jan. 31, 2003), 15 pgs. |
Baker, R.J., (2003) Mixed-Signal Design in the Microelectronics Curriculum, IEEE University/Government/Industry Microelectronics (UGIM) Symposium, Jun.30-Jul. 2, 2003, 4 pgs. |
Baker, R.J. (2004) Delta-Sigma Modulation for Sensing, IEEE/EDS Workshop on Microelectronics and Electron Devices (WMED), Apr. 2004, 36 pgs. |
Baker, “CMOS Circuit Design, Layout, and Simulation,” Second Edition, IEEE Press, A. John Wiley & Sons, Inc.; Copyright 2005; Chapters 13, 16, 17, 20, 22-24, 28-29; pp. 375-396, 433-522, 613-656, 711-828, 931-1022, 369 pgs. |
Hadrick, M. and Baker, R.J., (2005) Sensing in CMOS Imagers using Delta-Sigma Modulation, a general presentation of our work in this area, 21 pgs. |
Baker, R.J. (2005) Design of High-Speed CMOS Op-Amps for Signal Processing, IEEE/EDS Workshop on Microelectronics and Electon Devices (WMED), Apr. 2005, 53 pgs. |
Leslie, M.B., and Baker, R.J., (2006) “Noise-Shaping Sense Amplifier for MRAM Cross-Point Arrays,” IEEE Journal of Solid State Circuits , vol. 41, No. 3, pp. 699-704. |
Duvvada, K., Saxena, V., and Baker, R. J., (2006) High Speed Digital Input Buffer Circuits, proceedings of the IEEE/EDS Workshop on Microelectronics and Electron Devices (WMED), pp. 11-12, Apr. 2006. |
Saxena, V., Plum, T.J., Jessing, J.R., and Baker, R. J., (2006) Design and Fabrication of a MEMS Capacitive Chemical Sensor System, proceedings of the IEEE/EDS Workshop on Mocroelectronics and Electron Devices (WMED), pp. 17-18, Apr. 2006. |
Baker, R.J. and Saxena, V., (2007) Design of Bandpass Delta Sigma Modulators: Avoiding Common Mistakes, presented at various universities and companies, 30 pgs. |
Wikipedia—definition of “Error detection and correction”, pulled from website Jun. 1, 2007, 9 pgs. |
Wikipedia—definition of “Hamming code”, pulled from website Jun. 1, 2007, 8 pgs. |
Wikipedia—definition of “Linear feedback shift register (LFSR),” pulled from website Jun. 1, 2007, 4 pgs. |
Park, “Motorola Digital Signal Processors—Principles of Sigma-Delta Modulation for Analog-to-Digital Converters,”(Undated), 64 pgs. |
NPL—Fairchild Semiconductor, “74AC163-74ACT163 Synchronous Presettable Binary Counter,” datasheet, Feb. 2002. pp. 1-11. |
NPL—Fischer et al., “Sigma-Delta Modulation,” excerpt from Wiley Encylcopedia of Electrical and Electronics Engineering. 1999. pp. 244-254. |
NPL—Shigematus et al., “A 1-V High-Speed MTCMOS Circuit Scheme for Power-Down Application Circuits,” IEEE Journal fo Solid-State Circuits, vol. 32, No. 6 Jun. 1997. pp. 861-869. |
Number | Date | Country | |
---|---|---|---|
20170330612 A1 | Nov 2017 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11818989 | Jun 2007 | US |
Child | 12941878 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14724491 | May 2015 | US |
Child | 15667349 | US | |
Parent | 12941878 | Nov 2010 | US |
Child | 14724491 | US |