The present disclosure relates to memory devices and methods for storing and reading data. In particular, but without limitation, this disclosure relates to memory devices and methods for storing and reading data in which a first portion of data is mapped to a pattern of programmed memory cells.
Two dimensional (2D) NAND flash memory uses floating gate transistors organised into a cell which can be programmed to store a varying level of electrical charge. The number of different voltage levels, q, to which a cell can be programmed allows representation of log2 q binary bits per cell. Many such cells can be grouped into a logical page and pages grouped into logical blocks. A page is the smallest addressable unit for reading and writing data, whilst a block is the smallest erasable unit.
Cells can be connected in series to form a string, with a selection transistor placed at each end. Groups of strings tend to share common control lines for the selection transistors; one called a bit line and the other called a source line. Word lines are formed by connecting together the control gate of the floating gate transistors.
Each cell can be set into one of q logical states in Q={s0, . . . , sq-1}, where s0 corresponds to the erased state (no charge) while the remaining states represent the programmed states with a different charge for each. The cases with q=2, 4, 8 are also known as single, multi and triple-level cell (SLC, MLC and TLC) technologies respectively. The logical state of a cell is mapped into a voltage level reflecting the charge stored in its floating gate, i.e. s0 reflects the lowest voltage while sq-1 reflects the highest voltage. Without loss of generality, it can be assumed that the states themselves are the voltages.
Each cell can be treated as an individual storage medium. Since each cell can be in one of q states, each log2 q bits can be stored into a cell by setting its voltage to the corresponding value. For example, in the case of q=4, have 11→s0, 10→s1, 00→s2 and 01→s3.
Once programmed, the voltage of a cell can be perturbed from a number of processes. The major sources of noise are random telegraph noise (RTN) and charge leakage, which are the result of physical deterioration of the floating gate transistor.
In addition to noise, cells with close proximity to a cell being programmed with a high voltage will suffer from parasitic capacitance coupling. This will make the voltage shift of a programmed cell induce a voltage shift in neighbouring cells. This effect is referred to as cell to cell interference (CCI). Cell to cell interference becomes stronger as the density of the device increases.
Furthermore, repeated programming and erasing of memory cells can lead to the cells wearing over time. This means that flash memory tends to have a finite number of program-erase cycles before data can no longer be reliably retrieved.
There is therefore a need for providing an improved method of storing data which can improve device reliability and reduce stress on individual cells.
Arrangements of the present invention will be understood and appreciated more fully from the following detailed description, made by way of example only and taken in conjunction with drawings in which:
According to a first arrangement there is provided a memory device comprising a plurality of memory cells and a controller configured to receive data to be stored in a set of memory cells and map a first portion of the data to a selection of memory cells to be programmed from the set of memory cells, wherein the number of cells to be programmed k is less than number of cells in the set n. The controller is further configured to map a second portion of the data to a plurality of voltage levels to be programmed into the memory cells to be programmed and store the first and second portions of the data in the set of memory cells by programming each memory cell of the selection of memory cells to be programmed to a respective voltage level of the plurality of voltage levels.
By dividing the data into first and second portions and storing the first portion in the form of a selection of programmed memory cells (a particular pattern of programmed memory cells), cell to cell interference can be reduced by increasing the number of cells in the erased state. In the present arrangement “programmed memory cells” refers to any memory cell that is programmed to a voltage level above that indicative of the erased state.
The memory may be non-volatile memory, for instance, flash memory. In the present arrangement, the first and second portions of the data are different, i.e. input data is divided into the first and second portions.
The selection may be a unique pattern or combination of memory cells taken from the set of memory cells. By mapping the first portion of data to a selection of memory cells to be programmed, the first portion of data may be encoded in the form of indices representing the location of the memory cells to be programmed. The selection may therefore be a combination of indices of memory cells, with each index indicating a location of the memory cell within the set. The set of memory cells may be a word line of NAND memory. The number of cells to be programmed k may be a predefined number.
According to an arrangement storing the first and second portions of the data comprises ensuring that each memory cell of the set of memory cells that has not been selected for programming has a voltage level indicating that the cell is erased. This may mean erasing memory cells that have previously been programmed or keeping erased cells erased. A voltage level indicating that a cell is erased can be considered to be the lowest programmed state (s0).
According to an arrangement the number of cells to be programmed k divided by the total number of memory cells in the set n is equal to:
wherein q is the total number of voltage levels that each memory cell may occupy. This provides maximum storage efficiency.
According to a further arrangement the mapping of the first portion of the data to the selection of memory cells to be programmed comprises mapping the first portion of the data to a decimal number m, and determining a predetermined number k of indices ik, each index ik indicating the location of a respective memory cell to be programmed into the set of memory cells, the indices satisfying:
m=C(ik,k)+C(ik-1,k−1)+ . . . +C(i1,1)
wherein C(ix,x) is the binomial coefficient for a selection of ix distinct values from a total of x values, and n>ik>ik-1> . . . >i1 wherein n is the total number of memory cells in the set. Accordingly, the mapping of the first portion of the data to the selection of memory cells to be programmed may utilise a combinatorial number system. This provides a more efficient method of determining the selection of memory cells to be programmed. The indices may range from 0 to n−1. The mapping to a decimal number m may comprise a binary to decimal conversion.
According to an arrangement determining the predetermined number k of indices ik comprises: a) setting a counter x to equal k and a further decimal number m′ to equal the decimal number m; b) determining the largest index ix that satisfies:
C(ix,x)≦m′
c) updating the further decimal number m′ such that:
m′=m′−C(ix,k)
and, d) if the counter x is equal to one then output the set of k indices {i1, i2, . . . , ik}, otherwise, repeating steps b-d.
According to a further arrangement there is provided a method of storing data in a memory device comprising a plurality of memory cells and a controller, the method comprising the controller: receiving data to be stored in a set of memory cells; mapping a first portion of the data to a selection of memory cells to be programmed from the set of memory cells, wherein the number of cells to be programmed k is less than number of cells in the set n; mapping a second portion of the data to a plurality of voltage levels to be programmed into the memory cells to be programmed; and, storing the first and second portions of the data in the set of memory cells by programming each memory cell of the combination of memory cells to be programmed to a respective voltage level of the plurality of voltage levels.
According to an arrangement storing the first and second portions of the data comprises ensuring that each memory cell of the set of memory cells that has not been selected for programming has a voltage level indicating that the cell is erased.
According to a further arrangement the number of cells to be programmed k divided by the total number of memory cells in the set n is equal to:
wherein q is the total number of voltage levels that each memory cell may occupy.
According to an arrangement the mapping of the first portion of the data to the selection of memory cells to be programmed comprises: mapping the first portion of the data to a decimal number m; and, determining a predetermined number k of indices ix, each index ix indicating the location of a respective memory cell to be programmed into the set of memory cells, the indices satisfying:
m=C(ik,k)+C(ik-1,k−1)+ . . . +C(i1,1)
wherein C(ix,x) is the binomial coefficient for a selection of ix distinct values from a total of x values, and n>ik>ik-1> . . . >i1 wherein n is the total number of memory cells in the set.
According to a further arrangement determining the predetermined number k of indices ik comprises: a) setting a counter x to equal k and a further decimal number m′ to equal the decimal number m; b) determining the largest index ix that satisfies:
C(ix,x)≦m′
c) updating the further decimal number m′ such that:
m′=m′−C(ix,k)
and, d) if the counter x is equal to one then output the set of k indices {i1, i2, . . . , ik}, otherwise, repeating steps b-d.
According to a further arrangement there is provided a memory device comprising a plurality of memory cells and a controller configured to: determine a pattern of the programmed memory cells within a set of memory cells; determine the voltage levels of the programmed memory cells; map the pattern of the programmed memory cells to a first portion of data; and, map the voltage levels of the programmed memory cells to a second portion of data. The memory device is therefore able to decode data that is stored in the form of a pattern of programmed memory cells. By storing data in the form of a pattern of programmed memory cells, cell to cell interference can be reduced.
According to an arrangement determining the pattern of programmed memory cells comprises determining which of the plurality of memory cells has a voltage level above a threshold voltage level. The threshold voltage level may be a level separating an erased state from a programmed state.
According to a further arrangement the threshold voltage level is predefined or the threshold voltage level is determined such that exactly a predetermined number k of memory cells have a voltage level above the threshold voltage level.
According to a further arrangement determining the pattern of the programmed memory cells comprises determining a respective index ix for each programmed memory cell, each index ix indicating the position of the respective programmed memory cell within the set of memory cells. Mapping the pattern of the programmed memory cells to a first portion of data comprises: determining a decimal number m from the index ix of the programmed memory cells, wherein:
m=C(ik,k)+C(ik-1,k−1)+ . . . +C(i1,1)
wherein C(ix,x) is the binomial coefficient for a selection of ix distinct values from a total of x values, k is the number of programmed memory cells, and n>ik>ik-1> . . . >i1 wherein n is the total number of memory cells in the set; and mapping the decimal number m to the first portion of data.
The decimal number may be a combinatorial number. The mapping of a decimal number to the first portion of data may comprise mapping the decimal number to a set of bits (e.g. via a decimal to binary conversion).
According to a further arrangement there is provided a method of reading data from a memory device comprising a plurality of memory cells and a controller. The method comprises the controller: determining pattern of the programmed memory cells within a set of memory cells; determining the voltage levels of the programmed memory cells; mapping the pattern of the programmed memory cells to a first portion of data; and mapping the voltage levels of the programmed memory cells to a second portion of data.
According to a further arrangement determining the pattern of programmed memory cells comprises determining which of the plurality of memory cells has a voltage level above a threshold voltage level.
According to an arrangement the threshold voltage level is predefined or the threshold voltage level is determined such that exactly a predetermined number k of memory cells have a voltage level above the threshold voltage revel.
According to an arrangement determining the pattern of the programmed memory cells comprises determining a respective index ix for each programmed memory cell, each index ix indicating the position of the respective programmed memory cell within the set of memory cells. Mapping the pattern of the programmed memory cells to a first portion of data comprises: determining a decimal number in from the index ix of the programmed memory cells, wherein:
m=C(ik,k)+C(ik-1,k−1)+ . . . +C(i1,1)
wherein C(ix,x) is the binomial coefficient for a selection of ix distinct values from a total of x values, k is the number of programmed memory cells, and n>ik>ik-1> . . . >i1 wherein n is the total number of memory cells in the set; and mapping the decimal number m to the first portion of data.
Arrangements provide a means of storing data in memory in which cell to cell interference is reduced by encoding data in the form of a pattern of programmed and unprogrammed cells. This also improves the lifetime of flash memory as the number of erase cycles is reduced by reducing the number of cells that are programmed in each word line.
Amplitude Programming
Cell Location Programming
Cell location programming (CLP) differs from the amplitude programming (AP) method of storing information in its fundamental working principles. According to an arrangement, a fixed number of cells are left unprogrammed (i.e. erased) and the pattern of programmed and unprogrammed cells is used to represent further stored data. Accordingly, the charge density is reduced within the memory device as a number of cells are left unprogrammed. This reduces the chance of cell to cell interference and charge leakage. Moreover, by reducing the number of cells that are programmed, the number of program and erase cycles is reduced thereby reducing the stress on individual cells and improving the lifespan of the memory device overall.
As discussed, the pattern of programmed and unprogrammed cells can be used to encode data. Consider a word line with n cells and each cell having q programmable states. Ali cells are initially in the erased state, s0. Assume that exactly k cells are chosen out of the n cells to be programmed while the other (n−k) cells are left in the erased state s0. There are C distinct possible ways to choose such k cells where C is the binomial coefficient:
Each of the cells chosen for programming can be programmed to one of (q−1) possible states (as there are a total of q possible states including s0 for an unprogrammed cell). Let Fm=f(fm,1, . . . , fm,k) be a vector representing the states for each of the m combinations of programmed cells, where mεC(n,k) and a fm,kεQ\{s0}. This states that, for every combination, in, of k cells from the set of C(n,k) possible combinations, the cells can be programmed to one of {s1, . . . , sq-1} levels. Each of the k cells is programmed to one of a total of q−1 possible voltage levels. Thus, for each combination, m, of k cells there are a total of (q−1)k possible voltage levels. Consequently, for all C(n,k) possible combinations there are a total of (q−1)k×C(n,k) possible voltage levels, with each combination representing a unique pattern which can be used to program k of n available cells. This is termed cell location programming (CLP).
The first b1 bits are mapped by the index selector block 220 into an element I of (n,k) representing the set of indices of the k cells to be programmed. For small n and/or k the index selector can be a simple lookup table; however, this table becomes very large when k and n are large. Another technique is provided for large k and n, as described below.
The other b2 bits are mapped 230 into a (q−1)-ary stream F of size k representing the states to which each of the cells indexed by I is to be programmed.
The two mapping schemes I,F are combined to form a combined mapping that is used to program a subset of the n cells 240. The cells not present in element I are left unprogrammed (erased) at level s0, whilst each of the cells indicated by element I is programmed to the one of (q−1) possible states (s1 to sq-1) according to F.
Combinatorial Mapping
The index selector step 220 of the cell selection step 320 can be implemented using a lookup table to map bits b1 onto sets of indices identifying the cells to be programmed. This can, however, take a long time for large values of n and/or k and would require a very large lookup table. Accordingly, a method is provided to make the mapping of bits to a unique sequence of k programmed cells more efficient. This method utilises combinatorial numbers.
A combinatorial number system provides a one-to-one mapping between natural numbers and k-combinations (sets of k distinct indices). An index value is assigned to each possible combination of indices. The combinatorial index, m, corresponds to:
m=C(ik,k)+C(ik-1,k−1)+ . . . +C(i1,1)
where values i1 to ik are the indices of the cells to be programmed according to the combinatorial index m and n>ik>ik-1> . . . >i1. By calculating the appropriate index values, the vector Im=(im,1, . . . , im,k) can be determined for a given combinatorial index m.
The largest cell index ix is found 430 that satisfies:
C(ix,x)≦m′
This can be found by any suitable method, for instance, an iterative method may be used that successively moves from higher values of ix to lower values of ix (or vice versa) until the above relationship is satisfied. Equally, a binary search algorithm may be implemented. In the event that m′=0 then is set to 0.
Once the appropriate value of ix has been found, it is determined 440 if the counter, x, is equal to 1. If not, then the binomial coefficient for that cell index is subtracted 450 from the current value of m′:
m′=m′−C(ix,x)
The counter x is decreased by one 460 and the method loops back to step 430 to calculate the next cell index ix.
If x is found to equal one in step 440 then all of the required cell indices have been calculated and the method outputs 470 the vector I=(i1, i2, . . . , ik) representing the cells to be programmed.
The above method provides a fast and efficient means of determining the indices of the cells to be programmed based on a set of input bits b1.
As an example, let n=7 and k=3, for which there are 35 possible combinations, enumerated from 0 to 34. The combinatorial index value 31 can then be written as follows:
31=C(i1,3)+C(i2,2)+C(i3,1)
The first cell index, i1, is determined first. In this case, the largest value of i1 that satisfies C(i1,3)≦31 is i1=6 as C(6,3)=20, which is smaller than 31, whereas C(7,3)=35, which is too large.
The next cell index, i2, is determined, this time by finding the largest value that satisfies C(i2,2)≦m′ where m′=31−20=11. In this case, this is i2=5 as C(5,2)=10.
Finally, i3 is determined to be 1 as C(1,1)=1, which is less than or equal to 11−10=1.
The combinatorial index value therefore represents:
31=C(6,3)+C(5,2)+C(1,1)
Thus, the index value 31 can be used to represent the k=3 cell locations that have cell indices {6,5,1}.
Data Detection
When reading data from the memory cells, it can be efficient to read only the k cells that are programmed, as the remaining cells are known to have been set to s0. Prior to determining the data held in the k programmed storage cells, precisely k cells need to be selected for reading.
m=C(ik,k)+C(ik-1,k−1)+ . . . +C(i1,1)
and this combinatorial index m can then be mapped back to the sequence of bits, b1, for instance, via a decimal-to-binary converter.
The location of the programmed cells is also used to determine the bits stored in these cells. The voltage level programmed into each programmed cell is determined 530 and these values are mapped back to their symbol values 540 to determine the bits that are stored in the cells themselves, b2.
The two sets of bits, b1 and b2, are then combined 550 to obtain the full set of stored bits, b.
One method for selecting k cells is to use fixed voltage threshold values, by careful selection of these threshold values precisely k programmed cell locations can be identified by comparing the voltage levels from a number of cells, b (where b>k) to the threshold values.
At this stage, the location of the programmed and unprogrammed cells has been determined (the cells that have a voltage level that exceeds t1 are the programmed cells). This can therefore be used to determine to b1. The method then proceeds, however, to determine the programmed states for the programmed cells.
The voltage level of each programmed cell is then compared 630 to a second threshold, t2. If the voltage level of the cell is less than or equal to the second threshold then the cell is determined to be in the first programmed state, s1. If not, then the method moves on to compare the voltage to the next threshold. This method continues for each of q−1 thresholds. If the voltage of a cell is not less than or equal to the highest threshold, tq-1, then the cell is determined to be in the highest programmed state, sq-1; otherwise, it is deemed to be in the second highest state, sq-2.
The method begins by setting an initial value for t1. This may be predefined. The voltage levels of all of the cells are then compared to t1 and the number of cells that have voltage levels that exceed t1 is determined. It is determined 720 if exactly k cells have voltage levels that exceed t1. If exactly k cells exceed t1 then these cells are determined to be the k programmed cells. The locations of these cells are output to allow the b1 bits to be determined based on the programming pattern and fixed references are applied 730 to the programmed cells to determine their exact programming state to allow the b2 bits to be determined (as shown in steps 630-640 of
If the number of cells that have voltage levels that exceed t1 does not exactly equal k then it is determined 730 if less than k cells exceed t1 to determine how to adjust the threshold t1. If the number of cells that exceed t1 is less than k then the threshold is lowered 750 by a predetermined amount ε; otherwise, the threshold is increased 760 by ε. This method then returns to step 720 to check whether exactly k cells have voltage levels that exceed the new value of t1. Accordingly, the threshold is iteratively adapted until exactly k programmed cells have been located.
The arrangements described herein provide a number of advantages when compared to existing methods of data storage, namely:
Accordingly, the maximum storage efficiency for q from 1 to 8 is obtained at:
This can be seen via the locations of the maxima in
The interface 810 is configured to interface with other interfaces such as monitors, printers and keyboards, other computers, etc. The interface 810 may consist of a single port or may comprise a plurality of ports for interfacing with external electronic equipment. Whilst a joint input and output interface 810 is shown in
The interface 810 is configured to provide data to the controller 830 for storage in the memory 820. Alternatively, the controller 820 may generate the data to be stored itself through processes performed in the controller 820.
The controller 830 is configured to implement the functions of the memory device 800 as described herein. The controller 830 is therefore configured to control the memory 820 to store data in the memory 820 according to the cell location programming scheme. The controller 830 is also configured to read data from the memory 820 according to the cell location programming scheme. Data read from the memory 820 may be provided to the interface 810 so that it may be output. Alternatively, the controller 830 may perform processes on the data read from the memory 820 before storing or outputting the processed data. The controller 830 executes its functions based on executable software code stored in memory 820.
The memory 820 is non-volatile NAND flash memory. The memory 820 is divided into a number of blocks. The blocks are the smallest erasable unit in the memory 820. Each block is divided into a number of pages, each comprising a number of memory cells. A page is the smallest programmable unit in the memory 820. Each page comprises n memory cells. The controller 830 is configured to store a pattern of k programmed cells in each page of memory cells.
According to the cell location programming scheme described herein, a portion of the data stored in the memory 820 is stored in the form of a particular pattern of programmed memory cells and non-programmed memory cells. By forcing only a subset k out of a total of n memory cells to be programmed, leaving the remainder unprogrammed, additional information is conveyed by the location of the k programmed cells since each combination represents a unique state. In the example of multi-level flash memory, since a cell can be programmed to different states other than the unprogrammed (erased) state, information can be stored in the threshold voltage levels of the k programmed cells.
This scheme can achieve a storage efficiency ratio as high as 0.9 when compared with the conventional method of programming. This small reduction of storage efficiency brings significant gains in device reliability. By only subjecting a subset of cells in the block to high program voltages, stress on individual cells is reduced and, significantly, the probability of severe cell to cell interference is also reduced.
Specifically, the methods described herein provide a reduction in the interference between cells as fewer cells store a charge. There is also an increase in the lifetime of the memory device 800 as, on average, each cell undergoes a reduced number of program and erase cycles (as many cells remain erased between the storage of two sets of data). Furthermore, this scheme provides a more reliable means of storing data as the data stored in the form of the pattern of programmed cells is unaffected by any of the programmed cells shifting from one programmed state to another.
Cell location programming is technology agnostic. Accordingly, whilst the above arrangements are described with reference to NAND flash memory, alternative arrangements utilise alternative storage technologies.
While certain arrangements have been described, the arrangements have been presented by way of example only, and are not intended to limit the scope of the inventions. Indeed, the novel methods and devices described herein may be embodied in a variety of other forms; furthermore, various omissions, substitutions and changes in the form of the methods and systems described herein may be made.
Number | Name | Date | Kind |
---|---|---|---|
6397364 | Barkan | May 2002 | B1 |
7800945 | Cernea | Sep 2010 | B2 |
9245630 | Kwak | Jan 2016 | B2 |
20120246395 | Cho | Sep 2012 | A1 |
20160125947 | Yano | May 2016 | A1 |
Entry |
---|
Ertugrul Basar et al., “Orthogonal frequency division multiplexing with index modulation”, IEEE Transactions on Signal Processing (vol. 61, No. 22, Nov. 15, 2013), 16 pages. |
James McCaffrey, “Generating the mth Lexicographical Element of a Mathematical Combination,” MSDN Library (Jul. 2004), 9 pages, available at https://msdn.microsoft.com/en-us/library/aa289166(vs.71).aspx. |