Jul 30, 2018  
Memoryprocessing unit could bring memristors to the masses(Nanowerk News) A new way of arranging advanced computer components called memristors on a chip could enable them to be used for general computing, which could cut energy consumption by a factor of 100. 

This would improve performance in low power environments such as smartphones or make for more efficient supercomputers, says a University of Michigan researcher.  
"Historically, the semiconductor industry has improved performance by making devices faster. But although the processors and memories are very fast, they can't be efficient because they have to wait for data to come in and out," said Wei Lu, UM professor of electrical and computer engineering and cofounder of memristor startup Crossbar Inc.  
Memristors might be the answer. Named as a portmanteau of memory and resistor, they can be programmed to have different resistance statesmeaning they store information as resistance levels. These circuit elements enable memory and processing in the same device, cutting out the data transfer bottleneck experienced by conventional computers in which the memory is separate from the processor.  
This is an electron microscope image of the memristor array. (Image: Yeonjoo Jeong, Nanoelectronics group, University of Michigan)  
However, unlike ordinary bits, which are 1 or 0, memristors can have resistances that are on a continuum. Some applications, such as computing that mimics the brain (neuromorphic), take advantage of the analog nature of memristors. But for ordinary computing, trying to differentiate among small variations in the current passing through a memristor device is not precise enough for numerical calculations.  
Lu and his colleagues got around this problem by digitizing the current outputsdefining current ranges as specific bit values (i.e., 0 or 1). The team was also able to map large mathematical problems into smaller blocks within the array, improving the efficiency and flexibility of the system (Nature, "A general memristorbased partial differential equation solver").  
Computers with these new blocks, which the researchers call "memoryprocessing units," could be particularly useful for implementing machine learning and artificial intelligence algorithms. They are also well suited to tasks that are based on matrix operations, such as simulations used for weather prediction. The simplest mathematical matrices, akin to tables with rows and columns of numbers, can map directly onto the grid of memristors.  
Once the memristors are set to represent the numbers, operations that multiply and sum the rows and columns can be taken care of simultaneously, with a set of voltage pulses along the rows. The current measured at the end of each column contains the answers. A typical processor, in contrast, would have to read the value from each cell of the matrix, perform multiplication, and then sum up each column in series.  
"We get the multiplication and addition in one step. It's taken care of through physical laws. We don't need to manually multiply and sum in a processor," Lu said.  
His team chose to solve partial differential equations as a test for a 32x32 memristor arraywhich Lu imagines as just one block of a future system. These equations, including those behind weather forecasting, underpin many problems science and engineering but are very challenging to solve. The difficulty comes from the complicated forms and multiple variables needed to model physical phenomena.  
When solving partial differential equations exactly is impossible, solving them approximately can require supercomputers. These problems often involve very large matrices of data, so the memoryprocessor communication bottleneck is neatly solved with a memristor array. The equations Lu's team used in their demonstration simulated a plasma reactor, such as those used for integrated circuit fabrication. 
Source: University of Michigan  
Subscribe to a free copy of one of our daily Nanowerk Newsletter Email Digests with a compilation of all of the day's news. 
These articles might interest you as well: