Maybe Robots Dream of Electric Sheep, But Can They Do Science?Researchers use algorithm developed for selfrepairing robots to uncover scientific laws hidden in raw data
Listen to a teleconference with Cornell University professor Hod Lipson, doctoral student Michael Schmidt and reporters. Using the digital mind that guides their selfrepairing robot, researchers at Cornell University have created a computer program that uses raw observational data to tease out fundamental physical laws. The breakthrough may aid the discovery of new scientific truths, particularly for biological systems, that have until now eluded detection. Reporting in the April 3, 2009, issue of Science, Cornell University Mechanical Engineering professor Hod Lipson and his doctoral student Michael Schmidt report that their algorithm can distill fundamental natural laws from mere observations of a swinging double pendulum and other simple systems. Without any prior instruction about the laws of physics, geometry or kinematics, the algorithm driving the computer's number crunching was able to determine that the swinging, bouncing and oscillating of the devices arose from specific fundamental processes. The algorithm deciphered in hours the same Laws of Motion and other properties that took Isaac Newton and his successors centuries to realize. The new breakthrough is not far removed from Lipson's earlier NSF CAREER award work to develop Starfish, a robot with a "selfimage" that could repair itself when damaged. "The way the robot managed to recover from damage was to create a dynamical model, a selfimage," said Lipson. "It then used that model to make predictions about itself." A dynamical model is a mathematical representation of the way in which a system's components influence each other over time. Lipson and Schmidt realized that if a robot can create dynamical models from data about itself, why not attempt to model the surrounding world as well? When Lipson and Schmidt experimented with that approach, they learned their algorithm was rediscovering laws that were well known to scientists and engineers, suggesting the algorithm should be able to help uncover new laws for data sets that are less well understood. "What is fascinating is that in the same way a robot created a dynamical model of itself using robot pieces, we now can create models not from motors and joints, but from components of mathematical objects, like variables, symbols like + and , and other mathematical operators and functions," said Lipson. While the algorithm can work with almost any data set, for this experiment Lipson and Schmidt used motioncapture data of pendulums and oscillatorssimilar to the motion capture techniques used for movie specialeffects. The researchers then fed the data to a computer running the new algorithm, a process modeled on the one driving their Starfish robot. The computer began its analysis with a broad suite of mathematical building blocks, expressions that the computer could combine to recreate patterns in the data set. Using a computational process called symbolic regression, a process inspired by biological evolution, the computer then took the assemblage of expressions and competed them against each other to find matches that reflected the data. The goal was to find those aspects of the data that were invariant, that did not change from one observation to the next. "When you look at a pendulum, for example, some things go up, some go down," said Lipson. "But to recognize that when something goes up another specific thing always go down to keep the total sum constant, this is a key to understanding the observations in a deeper sensesuch as recognizing the laws of conservation." The computer retained the mathematical expressions that were invariant and abandoned those that were not, leaving a set of expressions that matched the data set and predicted future behavior. Because such a process could find patterns that are merely coincidental, the new algorithm also contains a critical step that compares subcomponent expressions, evaluating invariant equations to show that they are meaningful and represent actual natural laws, proof that the results are truly predictive. Ultimately, a human still has to take the final list of a dozen or so expressions and figure out what they reflect in realityfor example, which expressions are describing a motion or energyconservation law, or something totally new. Humans are still critical to the process: the computer serves as a data miner to find the laws, but a human must interpret them and give them meaning. "Physicists like Newton and Kepler could have used a computer running this algorithm to figure out the laws that explain a falling apple or the motion of the planets with just a few hours of computation," said Schmidt, "but a human still needs to pick the appropriate buildingblocks and framework, as well as give words and interpretation to laws found by the computer." In the future, Lipson and Schmidt plan to use the new approach for biological systems. Biology is notoriously complicated to model, and finding fundamental laws for such systems can be difficult. With the new algorithm, the enormous data sets researchers collect about biological systems may yield invariants, unchanging aspects that may reveal underlying fundamental laws. For this study, Michael Schmidt was supported by an NSF GRFP fellowship. Hod Lipson was supported by NSF CAREER Award 0547376 and NSF CreativeIT grant 0757478. NSF
Media Contacts
Program Contacts
Principal Investigators
CoInvestigators Related Websites
The National Science Foundation (NSF) is an independent federal agency that supports fundamental research and education across all fields of science and engineering. In fiscal year (FY) 2016, its budget is $7.5 billion. NSF funds reach all 50 states through grants to nearly 2,000 colleges, universities and other institutions. Each year, NSF receives more than 48,000 competitive proposals for funding and makes about 12,000 new funding awards. NSF also awards about $626 million in professional and service contracts yearly. Useful NSF Web Sites:

