Login| Sign Up| Help| Contact|

Patent Searching and Data


Title:
APPARATUSES AND METHODS FOR SENSING MEMORY CELLS
Document Type and Number:
WIPO Patent Application WO/2019/203988
Kind Code:
A1
Abstract:
Sensing memory cells can include: applying a voltage ramp to a group of memory cells to sense their respective states; sensing when a first switching event occurs to one of the memory cells responsive to the applied voltage ramp; stopping application of the voltage ramp after a particular amount of time subsequent to when the first switching event occurs; and determining which additional memory cells of the group experience the switching event during the particular amount of time. Cells determined to have experienced the switching event responsive to the applied voltage ramp are sensed as storing a first data value and cells determined to not have experienced the switching event responsive to the applied voltage ramp are sensed as storing a second data value. The group stores data according to an encoding function constrained such that each code pattern includes at least one data unit having the first data value.

Inventors:
SFORZIN MARCO (IT)
AMATO PAOLO (IT)
Application Number:
PCT/US2019/023502
Publication Date:
October 24, 2019
Filing Date:
March 22, 2019
Export Citation:
Click for automatic bibliography generation   Help
Assignee:
MICRON TECHNOLOGY INC (US)
International Classes:
G11C16/26; G06F3/06; G11C7/06; G11C16/30
Foreign References:
US20170206956A12017-07-20
US20140098607A12014-04-10
US20110242900A12011-10-06
US20120008399A12012-01-12
US20160372200A12016-12-22
EP1883113A12008-01-30
Other References:
See also references of EP 3782155A4
Attorney, Agent or Firm:
MYRUM, Tod A. (US)
Download PDF:
Claims:
What is claimed is;

1. A method for sensing memory cells, the method comprising; applying a voltage ramp to a group of memory cells to sense their

respective states;

sensing when a first switching event occurs to one of the memory cells of the group responsive to the applied voltage ramp;

stopping application of the voltage ramp after a particular amount of time subsequent to when the first switching event occurs; an determining which additional memory cells of the group experience the switching event during the particular amount of time; wherein the cells of the group determined to have experienced the

switching event responsive to the applied voltage ramp are sensed as storing a fust data value and the cells of the group determined to not have experienced the switching event responsive to the applied voltage ramp are sensed as storing a second data value; and wherein the group stores date according to an encoding function

constrained such that each code pattern includes at least one data unit having the first data value.

2. The method of claim 1 , wherein the method includes sensing the

respective states of the memory cells by comparing respective threshold voltages of the memory cells without utilizing a separate reference voltage to which the respective threshold voltages are compared.

3. The method of any one of claims ! and 2, wherein the particular amount of time is selected such that a magnitude of the vol age ramp after die particular amount of time is insufficient to swi tch the cells of the group storing the second data value. 4, The method of any one of claims 1 and 2, wherein a threshold voltage state to which the first data value corresponds is a lower threshold voltage state than a threshold voltage state to which the second data value corresponds.

5. The method of any one of claims 1 and 2 , wherein

the group of memory cells comprises a plurality of sets of memory cells each comprising N memory cells;

“N” is at least 2, and wherein the encoding function is applied on per set basis such that the code patterns per set include only those code patterns ha ving at least one of the first data value; and the encoding function maps n~bii data patterns to respective {n+lVbrt code paterns, wherein“n” is a number greater than 2, and wherein each of the (n+ l }~hit code patterns is a combined code pattern comprising the code patterns per set.

6. The method of any one of claims 1 and 2, wherein

the group of memory cells comprises a plurality of sets of memory cells each comprising N memory cells;

“N” is at least 2, and wherein the encoding function is applied on per set basis such that the code patterns per set include only those code patterns having at least one of the first data value; encoding function maps n-bit data patterns to respective (n+l )-bit code patterns, wherein V’ is a number greater than 2;

encoding function maps each one of then-bit data patterns to a matching one of the (n-f ! )4M code patterns with a additional bit having the first data value added; and

the additional bit ha ving the first da ta value is a last bit of the (n-M )-hit code patterns. An apparatus, comprising;

an array of memory cells each programmable to a first state corresponding to a first data value an to a second state corresponding to a second data value;

wherein the memory cells are configured to store data according to an encoding function; and

wherein each encoded data pattern corresponding to the encoding function comprises at least one data unit having the first data value; and a controller coupled to the array and configured to sense an encoded data pattern store in a group of memory cells by:

applying a voltage ramp to the group.

determining whe a first switching event occurs to memory cell of the group responsi ve to the applied voltage ramp;

stopping application of the voltage ram after a particular amount of time subsequent to when the first switching event occurs ; and

determining which additional memory cells of the group

experience the switching event during the particular amount of time; and

wherein the cells of the group determined to have experienced the switching event responsive to the applied voltage ramp are sensed as storing the first data val ue and the cells of the group determined to not have experienced the switching event responsive to the applied voltage ramp are sensed as storing the second data value.

8. The apparatus of claim 7, wherein a starting voltage of the voltage rarap lias a magnitude selected to be lower than a lowermost threshold voltage corresponding to the first state, and wherein the particular amount of time is selected such that a m gnitude of the voltage ramp upon the stopping is lower than a lowermost threshold voltage corresponding to the second state.

9. The apparatus of claim 7, wherein the controller is configured to sense the encoded data pattern by comparing the respective threshold voltages of the memory cells without utilizing a separate reference voltage to which the respective threshold voltages are compared.

10. The apparatus of any one of claims ? to 9, wherein the group of memory cells includes memory cells comprising a chalcogemde material servin as at least one of a switch element and a storage element.

1 1.. Tire apparatus of any one of claims 7 to 9, w erein the array is a three dimensional (3D) cross point array.

12. An apparatus, comprising: a memory comprising a group of memory' cells; and a controller configured to: apply a ramp voltage to the group of memory cells; determine a switching event for the group;

remove the ra p voltage from the group at a particular time after the switching event; and determine states of the memory cells of the group based on whether the memory·' cells switch while the ramp voltage is being applied.

! 3. The apparatus of claim 12, wherein at least one memory cell of the group is programmed to switch while the ramp voltage is being applied; and the controller is configured to encode respecti v e slates of the memory cells of the group other than the at least one memory ceil of the group in accordance with an assigned encoding of respective data bits.

14. The apparatus of claim 12* wherein the states of the memory cells of the group correspond to an encoded data pattern stored in the group of memory cells,

i 5. The apparatus of any one of claims 12 to 14, wherein the contro ller is configured to: determine memory ceils that switched while the ramp voltage is being applied to have a first state; and determine memory cells that did not switch while the ramp voltage is being applied to have a second state.

16. The apparatus of claim 15. wherein a width of a threshold distribution corresponding to the first state is less than a margin between the first and second states.

17. The apparatus of claim 15, wherein the particular time is equal to a width of a threshold distribution corresponding to the first state divided by a slope of the ramp voltage.

18. An apparatus, comprising; a memory compri sing a group of memory c eils; an

a controller configured to;

apply a ramp voltage to the group, wherein at leas one memory cell of the group is to be programmed to a first state such that the at least one memory cell switches m response to the ramp voltage;

remove the ramp voltage at a particular time after the at least one memory cell switches;

determine that each additional memory cell of the group that

switches in response to the ramp voltage is in the first state; and determine that each memory cell of the group that does not switch while the ramp voltage is applied is in a second state.

19. The apparatus of claim IS, wherein the controller is configured to encode the first state as a first bit code and to encode the second state as a second bit code,

20. The apparatus of claim 18, wherein the controller is configured to encode respective states of respective memory cells i the group of' memory ceils according to respective data values.

Description:
APPARATUSES AND METHODS FOR SENSING MEMORY CELLS

TECHNICAL FIELD

£0001] The present disclosure relates generally to apparatus such as storage systems, and their operation, and, more particularly, to apparatuses and methods for sensing memory cells.

BACKGROUND

£0002] Storage systems may be implemented in electronic systems, such as computers, cell phones, hand-held electronic devices, etc. Some storage systems, such as solid state drives (SSDs), embedded Multi-Media Controller (eMMC) devices. Universal Flash Storage (IJFS) devices, and the like may include non-volatile storage memories for storing user data fro a host Nonvolatile storage memories provide persistent data by retaining stored data when not powered and may include NAND flash memory, phase change memory (PCM), resistive random access memory (RRAM), magnetic random access memory (MRAM), and programmable conductive memory among other types of memory that can be wri tten to a particular number of times throughout their lifetime.

£0003] Non-volatile memory cells can be programmed to a desired state.

As an example, some memory cells can be programmed to one of multiple states that can correspond to (e.g , be encoded with) different bit patterns. The particular programmed state of a cell can be determined by, for example, comparing the threshold voltage of the cell to a reference voltage I some examples, a threshold voltage (Vt) of a cell can drift, which can make accurate sensing (e.g., reading) difficult since the drift may need to be tracked in order to ensure use of proper demarcation/read voltages.

BRIEF DESCRIPTION OF THE DRAWINGS

£0004] Fi gure 1 i s a block diagram of an apparatus, in. accordance with a number of embodiments of the present disclosure.

£0005] Figur e 2 ill ustrates an example of threshold voltage distributions corresponding to states to which memory ceils can be programmed, in accordance with a number of embodi ments of the present disclosure. ]000ø] Figure 3 illustrates an example of a portion of a memory that can be sensed using die methods disclosed herein, in accordance with a number of embodiments of the present disclosure.

fO0O?| Figure 4A is a graphical illustration in which two memory ceils are determined to have the same state, in accordance with a number of embodiments of fire present disclosure,

10008] Figure 48 is a graphical illustration in which two memory’ cells are determined to have different states, in accordance with a number of embodiments of the present disclosure.

]0009j Figure 5 illustrates the collective states that the group of memory cells can have and the corresponding bit codes, in accordance with a number of embodiments of the present disclosure

10010] Figure 6 illustrates assi gning groups of data bits to the code bits resulting from combining two groups of memory cells, in accordance with a number of embodiments of the present disclosure.

J0011 ] Figure 7 illustrates the possible collective states that a group of memory’ cells can have and the corresponding bit codes, in accordance with a number of embodiments of the present disclosure.

]O0i2] Figure 8 i llustrates assigning groups of data bits to code bits corresponding to collective states of a group of memory’ ceils in which the same memory’ cell of the group is programmed to a particular state, in accordance with a number of embodiments of the present disclosure

]0013] Figure 9 illustrates a flowchart of a method, in accordance with a number of embodiments of the present disclosure

DETAILED DESCRIPTION

10014] Sensing memory cells can include: applying a voltage ramp to a gronp of memory cells to sense their respective states; sensing when a first switching event occurs to one of the memory cells responsive to the applied voltage ramp; stopping application of the v ltage ramp after a particular amount of time subsequent to when the first switching event occurs ; and determining which additional memory cells of the group experience the switching event during the particular amount of time. Those cells determined to have

experienced the switching event responsive to the applied voltage ramp are sensed as storing a first data value and those cells determined to not have experienced the switching event responsive to the applied voltage ramp are sensed as storing a second date valise. T he group stores data according to an encoding function constrained such that each code pattern includes at least one data unit having the first date value.

j OOiS j Embodiments of the present disclosure provide a technical advantage over prior approaches by overcoming the problems associated with threshold voltage drift that may occur as some memory cells, such as resistance variable memory cells, age and/or change temperature. For example, during a sensing operation, such as a read operation, the sensing voltage may be applied across a memory cell to determine the state of the memory cell, corresponding to the threshold voltage of the memory' cell. However, as the number of times the memory cell is overwritten with new data increases (e.g„ as the memory cell ages) and/or the temperature of the memory cell changes, the threshold voltage corresponding to the state of the cell may change, making it difficult to accurately determine the state of the memory ' cell using the sensing voltage. {0016] However, embodiments of the present disclosure avoid the need to use a sensing voltage, and thus overcome the problems associated with drift. For example, one memory cell of a group of memory cells may be programmed to a particular state such that the memory cell experiences a switching event (e.g., in response to a ramp voltage) before additional memory cells in the group. The states of the additional memory cells in the group may then be determined based on whether they experience a switching event in response to the ramp voltage within a particular ti me of when the one memory cell programmed to the particular state experiences a switching event. This allows the states of the remaining memory' cells to be determined relative the particular state of the one memory cell, thus allowing the sensing to effectively follow the drift of the particular state, thereby overcoming the problems associated with the drift.

10017 j Figure I is a block diagram of an apparatus in the form of a computing system 100, in accordance with a n umber of embodiments of the present disclosure. Computing system 100 includes a memory system 102 that can be, for example, a storage system such as an SSD, a UFS device, an embedded eMMC device, etc. However, embodiments are not limited to a particular type of memory system. For example memory system 102 could serve as main memory for system 100

m As shown in Figure I, the system 102 can include a controller

108 coupled to a memory 106 and host 104 Host 104 can be, for example, a host system such as a personal laptop computer, a desktop computer a digital camera, a mobile device (e.g., cellular phone), network server, internet of Things (loT) enabled device, or a memory card reader, among various other types of hosts. For instance, host 104 can include one or more processors capable of accessing memory 106 (e.g.. via controller 108) over an interface, which can i nclude a bus . The interface may be "a standardized interface , such as a serial advanced technology attachment (SATA), peripheral component interconnect express (PCle), or a universal serial bus (USB), among various others.

19j Memory 106 cart comprise a number of memory devices (e.g., memory dies, chips, etc.), which each can comprise a number of arrays 1 10 The arrays 150 can include two-dimensional (2D) and/or three-dimensional (3D) array structures, such as cross point array structures. The memory cells can include, for example, various types of resistance variable (e.g., PCRAM cells, RRAM cells, 3D cross point cells), which may comprise a resistance variable storage element and/or switch element. In a number of embodiments, the memory cells can be self-selecting memory (SSM) cells in which a single material can serve as both the storage element and the memory element.

{0020] As an example, the memory·' cells can be phase change memory

(PCM) ceils, which can be chalcogenide base memory cells comprising a single chalcogenide material serving as both a storage element an a switch element for the cells and/or a stack of materials with a first chalcogenide material serving as a switch element and a second chalcogenide serving as a storage element for the cells. However, embodiments are not limited to a particular array architecture and/or memory cell type. For instance, the array 150 might comprise NAN D flash memory cells and/or NOR flash memory cells, among others.

{{Mill ] The memory device 106 includes a read component 1 12 that can comprise various circuitry associate with operating memory cells in accordance with embodiments of the present disclosure. For example, as described further below, the rea component can include sense amplifiers. jl022j The controller 108 can comprise, for example, a state machine, a sequencer, and or some other type of control circuitry, and can communicate with the memory devices 106 to control data read, write, and erase operations, among other operations. The controller 108 can include for example, a number of components in the form of hardware (e.g., one or more integrated eircnu,ri and/or software (e.g., .instructions, which may be in the form of firmware) for controlling access to the number of memory devices 106 and/or for facilitating data transfer between the host 104 and memory' devices 106. In general, the controller 108 can receive and execute commands from the host 104 to achieve the desired access to the memory 106 The controller 108 can be responsible for, among other things, performing various methods for improved memory' operations in accordance with embodiments described herein.

10023j Controller 108 can include an encoder/decoder 1 1 1 that can be used to map between stored data patterns and code patterns, as described further herein. In some examples , a group of memory cel ls can store data according to an encoding function implemented by encoder/decoder i l l . For example, the encoding function can be constrained such that each code pattern corresponding to a data pattern stored by a group of cells includes at least one data unit having particular data value,

10024] Controller 108 is configured to perform the methods disclosed herein, such as reading, in accordance with a number of embodiments. For example, a memory·' cel l of a group of memory' cel ls may programmed to have a particular state, such as the lowest state to which the memory' cells can be programmed. For a group of two memory' cells, for example, controller 108 may determine a state of the remaining memory cell based on whether the remaining memory cell experiences a switching event within a particular time after the memory cell at the particular state experiences a switching event. For example, if the remaining memory' cell experiences a switching event within the particular time after the memory ceil programmed to the particular state experiences a switching event, controller 108 may determine that the two memory cells have the same state. Otherwise, controller 108 may determine that the two memory cells have different states. For example, the switching event can involve

swi tching from a non-conductive state of the memory cell to a conducti ve state of the memory cell. |0025j Figure 2 illustrates an example ofVt distributions corresponding to states to which memory cells can be programmed, in accordance with a number of embodiments of the present disclosure. Vt distributions 220-1 and 2:20-2 respectively correspond to a low state (e.g., Vt level) L and a higher state H. A memory cell having a state L can be encoded with code bit of 1 (e.g., logical level 1 ), and a memory cell ha ving a state H can he encoded with a code bit of 0 (e.g., logical level 0). For example, the H state may be referred to as state 0, and the L state may be referred to as state 1.

(0026] The states 0 and 1 may respectively correspond to different resistance levels to which the respective corresponding memory cells are programmed. In some examples, the width W of Vt distribution 220-1 in volts (e.g., the range of Vts corresponding Vt distribution 220-1 ) is less than the margin M in volts (e.g., the range of Vts) between Vt distribution 220-1 and Vt distribution 220-2.

|0027] Figure 3 shows an example of a portion of memory array 310 that may be read using the methods disclosed herein, in accordance with a number of embodiments of the present disclosure. Memory array 310 can be a portion of memory array 1 10, in some examples. Memory array 310 includes memory cells 314-1 to 314-N, such as cross-point memory cells, located at intersections of a signal line 315, such as a word line, and signal lines 316-1 to 316-N, such as bit lines. For instance, memory cells 314-1 to 314-N are respectively coupled to signal lines 316-1 to 316-N and are commonly coupled to signal line 315. Signal lines 316-1 to 316-N, and thus memory ceils 314- 1 to 314-N, can be coupled to a read component 312 that can be included in read component 1 12, for example. Read component 312 can include sense amplifiers 317-1 to 3G7-N that are respectively coupled to signal lines 356-1 to 316-N, and thus to memory cells 314-1 to 314-N.

|0028| Sense amplifiers 317-1 to 317-N may respectively output voltages respectively indicative of memory cells 314-1 to 314-N undergoing switching events, such as thresholding events (e.g,, snapback events), in response to voltages being applied across memory cells 314- S to 314-N being greater than or equal to threshold voltages ( Vts) of memory cells 314-1 to 314-N. For example, the memory cells may switch from one conductivity state, such as a low conductivity state (e.g., high resistive state), to another conductivity state, such as a high conductivity state (e.g. a low resistive state), A sense amplifier may sense the switching event by sensing a change in current through the memory ceil that may be reflected in the output voltage of the sense amplifier.

10929] In some examples, a timewise increasing ramp voltage can be applied to signal line 315 while concurrently applyin a voltage (e.g., the same voltage) to signal lines 316-1 to 316-N so that a timewise increasing ramp voltage is applied across (e.g., to) memory cells 314-1 to 314-N concurrently. Sense amplifiers 317-1 to 317-N can sense respective switching events of memory cells 314-1 to 314-N in response to applying the ramp voltage across memory cells 314-1 to 314-N.

[0030] Memory cells 314 can be, for example, resistance variable memory cells whose respective states (e.g., stored data values) depend on the respective programmed resistances of memory cells. Memory ceils 314 can be overwritten individually without first being erased, in some examples.

[0031] In some examples, a first group of two memory cells, such as memory cells 314-1 (A) and 3.14-2 (B), may be programmed to a collective state by respectively programming memory cells 314-1 (A) and 314-2 (B) to one of the states 1 and 0. Similarly, a second group of two memory cells, such as memory cells 314-3 (C) and 314-4 (D), may be programmed to a collective state by respectively programming memory cells 314-3 (C) and 314-4 (D) to one of the states 1 and 0. In other examples, other groups having other «timbers of cells such as three cells, four cells, up to N cells, are envisioned. Hereinafter, memory' cells 314-1 (A), 314-2 (B), 314-3 (C ), and 314-4 (D) will be respectively referred to as memory' cells A, B, C, and D.

[0032] Figure 4A is a graphical illustration in which two memory cells of a group of memory cells are determined to ha ve the same sta te in accordance with a number of embodiments of the present disclosure. Figure 4B is a graphical illustration in which two memory cells of a group of memory cells are determined to have different states, in accordance with a number of

embodiments of the present disclosure. For example, Figures 4 A and 4B correspond to (e.g , illustrate what occurs during) a read operation performed by controller 108. Figures 4A and 4B illustrate determining a state of a memory cell, such as memory cell B, based on whether that memory' cell experiences a switching event (e.g., switches) within a particular time (e.g., that may be referred to a a threshold delay time) of when (e.g. after) another memory cell » such as memory cell A, experiences a switching event

]0033] As shown in the examples of Figures 4A and 4B, a timewise increasing ramp voltage 425 is applied across memory cells A and B

concurrently, For example, a timewise increasing ramp voltage may he applied to access line 15 i Figure 3 while the same fixed voltage is applied to access lines 316-1 and 316-2 in Figure 3 concurrently, resulting in ramp voltage 425 |O034] The Vt distributions corresponding to states 1 and 0 are superimposed on the voltage V axis in Figures 4A an 4B. A starting voltage of ramp voltage 425 is less than the Vis of the Vt distributions corresponding to state 1, corresponding to the lowest state to which the memory cells can be programmed

|0035] Note that the examples of Figures 4A and 4B in vol ve determining a collective state of a group of two memory cells (e.g., memory cells A and B) by determining the indi vidual state of each of the two memory cells, but may be applied to groups having any number of memory cells. In some examples, at least one memory cel l of a group, such as memory cell A in this example, is to be programmed to a particular state, such as the state I, and the states of the other memory cells In the group, such as the state memory cell B in this example, are to be determined relative to the particular state. In some examples, the memory cell programmed to the state 1 may be referred to as set memory cell and may be the first memory cell in tire group to experience a switching event in response to ramp voltage 425. For example, the set memory cell acts as a reference memory cell and requires that each collective state a group of memory cells can have a memory cell with the state 1. For example, the respective states of the memory cells can be determined wi thout utilizing a separate reference voltage to which the respective threshold voltages are compared. The group including memory cells A and B stores data according to an encoding function constrained such that a corresponding code pattern includes at least one data unit having a data value 1 , corresponding to state 1. f0936jj In Figures 4A and 4B, memory· cell A is the first memory cell to switch as indicated by step 427 and may be the set memory cell For example, memory cell A may be in state 1. Memory cell A switches when the voltage of voltage ramp 425 reaches the Vt of memory cell A. Ramp voltage 425 is applied to memory cells A and B fox the threshold delay time after memory cell A switches. Memory ceil B switches when the voltage of voltage ramp 425 reaches the Vi of memory cell B as indicated by step 429.

f0037J When memory eel! B switches within the threshold delay time after memory cell A switches, as shown in Figure 4 A, It is determine that memory cell B is also in state L For example, memory cell A and B are sensed as storing a data value of L Therefore, the collective st ate of memory cells A and B is determined to be 11 in Figure 4A.

10038! In some examples, ramp voltage 425 is removed from the memor cells A and B at the threshold delay time after memory cell A switches. In an example, the threshold delay time may be equal to the width W of the Vt distribution, such as Vt distribution 220-1 , corresponding to the lowest state di vided by the slope S (e.g., the rate of change) of ramp voltage 425. For example, threshold delay time may be W/S.

[9039] When memory cell B fails to switch within the threshold delay time after memory cell A switches, as shown in Figure 4B, it is determined that memory '' cell B is in state 0. For example, memory cel! B may be determined to be in state 0 without waiting for memory cell B to switch. For example, when memory cell B fails to switch before ramp voltage 425 is removed, it is determined to be in state 0. The collective state of memory cells A and B in Figure 4B is determined to be 10, the respective individual states of memory cells A and B determined in Figure 4B. Note that the group of memory ceils A and B stores data according to a encoding function constrained such that respective code patterns 11 and 10 include at least one data unit having the data value 1, for example.

(0U40{ Note that memory cell B in Figure 4B does not switch until a time

†B when the voltage across memory cell B is the voltage VB and indicated by step 431 in Figure 4 B. However, the state of memory cell B can be determined at the threshold delay time after memory cell A switches without waiting until time tB.

10941] The examples of Figures 4 A and 4B are not limited to memory cell A being the set memory cell. For example, memory cells A an B may be interchanged in Figures 4A and 4B, in which case memory cell B is the set memory' ceil. Therefore, the collective state i Figure 4A will remain the same (e.g., 1 1 ) since both memory cell A and memory cell B will be in state 1.

However, the collective state in Figure 4A will be inverted (e.g., 01} since memory cell A will be in state 0 and memory cell B will be in state 1.

10942] Figure 5 illustrates the collective states that the group of two-state memory cells A and B can have and the corresponding bit codes, in accordance with a number of embodiments of the present disclosure. For example, the bit codes incl ude the indivi dual bits corresponding the individual states of memory cells A and B, In method described in conjunction with Figures 4A and 4B > at least one of memory cells A and B may be programmed to state 1, thus precluding the collective state 535-1 in which both memory cells A and B are in state 0 This means that in the remaining collective states 535-2 to 535-4 at least one of the memory cells A and B is in state 1 , as shown in Figure 5. Figure 5 illustrates an example storing data according to an encoding function constrained such that respective code patterns include at least the data value 1 , for example.

[0043] In the examples of Figures 4A and 4B, applying the ramp voltage to memory cells A and B, having a set memory cell that is in the state 1 , such as memory cell A, and determining the state of memory cell B based on whether memory cell B switches within the threshold delay time of when memory cell A switches, overcomes the problems associated with drift. This is because the ramp voltage allows the state of memory cell A to be determined regardless of whether state .1 drifted and because the state of memory ce ll B is determined relative to state 1 regardless of whether state 1 drifted

[0044] In some examples, the method described in conjunction with

Figures 4A and 4B may be used to determine tire collective states of the group of memory cells€ and D in Figure 3. For example, memory cells C and D may be respectively substituted for memory cells A and B in the method described in conjunction with Figures 4A and 4B and in the example depicted in Figure 5

For instance, the group of memory cells C and D may have the collective states 535-2 to 535-4 depicted in the example of Figure 5.

[0045] Figure 6 illustrates assi gning groups of three data bits (e.g., data states) of a data pattern to the code bits of a code pattern resulting from combining two groups of two memory cells. in accordance with a number of embodiments of the present disclosure. In Figure 6, each of the data bits dl, d2, and d3 correspond to one of the two states 0 and 1. Therefore, there are eight possible data slates 639-1 to 639-8 each corresponding to a different dat pattern. In f igure 6, the group (e.g,, a first group) of memory cells A and B and the group (e.g., a second group) memory cells C and D and their respective collective states are combined. Figure 6 shows the nine combined collective slates 637-1 to 637-9 of the combined first and second groups, where each collecti ve state corresponds to a different code pattern. In the example of Figure 6, data states 639-1 to 639-8 are respectively assigned to combined collective states 637-1 to 637-8, thereby leaving combined collective state 637-9 unused. The collective states 637-1 to 637-8 are respectively encoded in accordance with the assigne encodings 639-1 to 639-8, for example

|0046] in the example of Figure 6, the three-bit data patterns are mapped to four-bit code patterns. In general an encoding function can map n-bit data patterns (e.g., n ~ 3 in Figure 6) to respective (n-rl)-bit code patterns, where“n” is a number greater than two, and where each of the (n+l)~bit code patterns is a combined code patter n comprising the code patterns per set of memory cells , such as memory cells A, B, C, and. D in Figure 6

|0047] In some examples, the method described in conjunction with

Figures 4 A aud 4B may be used to determine the states of the memory cells in groups of memory cells having more than two memory cells. For example, memory cells A, B, C, and D (e.g., each operating as a two-state cell) may be treated as a group of memory cells, and the individual states of memory cells A, B, C, and D, and thus the collective s tate of the group, m ay be determi ned

[6048] For ex ample, one of memory cells A, B, C , and D may be a set memory cell and may be in state 1. Ramp voltage 425 may he applied across memory cells A, B, C, and D concurrently, and the first memory ceil that switches is in state 1 and is the set memory' cell. Voltage ramp 425 is then applied until the threshold delay time after the set memory' cell switches, at which time ramp voltage 425 is removed. Any of the remaining memory cells in the group that switches while is ramp voltage 425 is being applied is determined to be in state 1 , whereas any of the remaining memory cells that do not s witch while ramp voltage 425 is being applied is in state 0.

10049] Figure 7 illustrates the possible collective states that the group of two-state memory cells A, B, C, and D can have and the corresponding hit codes, in accordance with a number of embodiments of the disclosure. For example, the bit codes include the individual bits corresponding the indi vidual states of memory cells A, B, C, and D. However, at least one of memory cells A, B, C, and D (e.g., the set memory cell) is programmed to state 1, thus precluding the collective state 741-1 in which all of memory cells A, B, C, and D are in state 0. This means that in the remaining collective states 741-2 to 74.1-16 at least one of the memory cells A, B, C, and D is in state I, as shown in Figure 7. Figure 7 illustrates another example storing data according to an encoding function constrained such that respective code patterns include at least the data value 1, for example. The encoding function can be applied on per set basis (e.g., ie set including memory cells A, B, C, and D) such that the code patterns per set include only those code patterns having at least one of die first data value, such as the data value 1 in Figure 7.

10050] Note that in the example of Figure 5, there are 2 2 - 1 3 available collective states for two memory cells, and in die example of Figure 5, there are 2 4 - 1 15 available collective states for four memory cells. In general, there are 2 N - 1 available collective states for N memory cells. The loss of one state is due the having one memory cell in a group be a set memory cell in state 1. However, the problems associated with drift are overcome by determining die states of the remaining cells according to when the set cell switches.

{0051 j In the example of Figure 7 any one of memory cells A, B, C, and

D can be the set cell, as long as it is die first memory ceil of the grou to switch. For example, memory cells D, C, B, and A are respectively the set. memor cells for collective states 741-2, 741-3, 741-5, and 741-9.

|0O52 j in other examples, the same memory cell in a group may be the set cell, meaning that the same cell in the group will always switch first. The states of the remaining memory cells may then be determined according to whether they swi tch within the threshold delay time of when the set memory cell switches. For such examples, only the remaining memory cells may be used for data storage and the states of the remaining memory cells may correspond to code bits.

fiiOSS] Figure 8 illustrates assigning groups of three data bits (e.g., dat states ) of data patterns to the code bits code patterns corresponding to collective states of a group of memory cells in which the same memory cell of the group is assigned to the same state, in accordance with a number of embodiments. In Figure 8, memory cel ! D o f the group of memory cells A, B, C, and D may always be programmed to state 1 , and the remaining memory·' cells A, B, C can be programed to either state 1 or state 0. This means that the number of possible collective states is based on three memory·' cells and is thus 2 - - 8.

{0054] In Figure 8, the three data bits d 1 s d2, d3 of a three- bi t data pattern are respectively stored in memory cells A, B, and C. For example, the states of data bits dl, d2, d3 may be as previously described in conjunction with Figure 6 correspond one-to-one with the dat states of memory cells A, B, and C. The data states 839-1 to 839-8 are respectively assigned to collective states 847-1 to 847-8, each corresponding to a four-bit code pattern. For example, the collective states 847-1 to 847-8 are respectively encoded in accordance with the assigned encodings 839-1 to 839-8.

{ 551 hi the example of Figure 8, n-bit (e.g., three-hit) data patterns are mapped to (n + l)~bi code patterns in general, an encoding function can map n~ bit data patterns to respective (n+T)-hit code patterns. The encoding function can map each one of the n-bit data patterns to a matching one of the (n-H )-bit code patterns with an additional bit having a particular data value, such as a data value of 1, added, where the addi ti onal bit is a last bit of the (n+ l )-bit code patterns, as shown in Figure 8.

{0956] Figure 9 illustrates a flowchart of a method 955, such as a read method, that may be implemented by controller 108 and that may correspond to Figures 4A an 4B, in accordance with a number of embodiments of the present disclos ure. A ramp voltage is applied to a group of memory cells in block 957.

At block 959 a first switching event is determined for the group. The ramp voltage is removed at the threshold delay time after the first switching event at block 961. At block 963, the states of the memory cells are determined based on whether they switched while the ramp voltage was being applied. For example, memory cells that switch while the ramp voltage was applied, including the memory cell that switched first, are in state 1. Otherwise, the memory cells are in state 0. Although states 1 and 0 were used to respectively denote the low and high states of a memory cell, the disclosure Is not so limited. For example, states 0 and 1 can be used to respectively denote the low and high states.

{9057] in the preceding detailed description, reference is made to die accompanying drawings that form a part hereof and in which is shown, by way of illustration, specific examples. In the drawings, like numerals describe substantially similar components throughout the several views. Other examples may be utilized, and structural, logical and/or electrical changes may be made without departing fro the scope of the present disclosure.

|¾058j The figures herein follow a numbering convention in whic the first digit or digits cm respond to the drawing figure number and the remaining digits identify an element or component in the drawing. Similar elements or components between different figures may be identified by the use of similar digits. As will be appreciated, elements shown in the various embodiments herein can he added, exchanged, and/or eliminated so as to provide a number of additional embodiments of the present disclosure. In addition, as will be appreciated, the proportion and the relative scale of the elements provided in the figures are intended to illustrate the embodiments of the present disclosure and should not be taken in a limiting sense.

|0059j As used herein,“a number of’ something can refer to one or more of such things. For example a number of memory cells can refer to one or more memory cells. A“plurality” of something intends two or more. As used herein multiple acts being performed concurrently refers to acts overlapping, at least in part, over a particular time period. As used herein, the teen“coupled” may include electrically coupled, directly coupled, and/or directly connected with no intervening elements (e.g., by direct physical contact) or indirectly coupled and/or connected with intervening elements. The term couple may further include two or more elements that co-operate or interact with each other (e.g., as in a cause and effect relationship).

(0060] Although specific examples have been illustrated and described herein, those of ordinary ski ll in the art will appreciate that an arrangement calculated to achieve the same results can he substituted for the specific embodiments shown. This disclosure is intended to cover adaptations or variations of one or more embodiments of the present disclosure. It is to be understood that the above description has been made in an illustrative fashion and not a restrictive one. The scope of one or more examples of the present disclosure should be determined with reference to the appended claims, along with the full range of equivalents to which such claims are entitled.