Inductive programming
Inductive programming (IP) is a special area of automatic programming, covering research from artificial intelligence and programming, which addresses learning of typically declarative (logic or functional) and often recursive programs from incomplete specifications, such as input/output examples or constraints.
Depending on the programming language used, there are several kinds of inductive programming. Inductive functional programming, which uses functional programming languages such as Lisp or Haskell, and most especially inductive logic programming, which uses logic programming languages such as Prolog and other logical representations such as description logics, have been more prominent, but other (programming) language paradigms have also been used, such as constraint programming or probabilistic programming.
Definition
Inductive programming incorporates all approaches which are concerned with learning programs or algorithms from incomplete (formal) specifications. Possible inputs in an IP system are a set of training inputs and corresponding outputs or an output evaluation function, describing the desired behavior of the intended program, traces or action sequences which describe the process of calculating specific outputs, constraints for the program to be induced concerning its time efficiency or its complexity, various kinds of background knowledge such as standard data types, predefined functions to be used, program schemes or templates describing the data flow of the intended program, heuristics for guiding the search for a solution or other biases.
Output of an IP system is a program in some arbitrary programming language containing conditionals and loop or recursive control structures, or any other kind of Turing-complete representation language.
In many applications the output program must be correct with respect to the examples and partial specification, and this leads to the consideration of inductive programming as a special area inside automatic programming or program synthesis,[1][2] usually opposed to 'deductive' program synthesis,[3][4][5] where the specification is usually complete.
In other cases, inductive programming is seen as a more general area where any declarative programming or representation language can be used and we may even have some degree of error in the examples, as in general machine learning, the more specific area of structure mining or the area of symbolic artificial intelligence. A distinctive feature is the number of examples or partial specification needed. Typically, inductive programming techniques can learn from just a few examples.
The diversity of inductive programming usually comes from the applications and the languages that are used: apart from logic programming and functional programming, other programming paradigms and representation languages have been used or suggested in inductive programming, such as functional logic programming, constraint programming, probabilistic programming, abductive logic programming, modal logic, action languages, agent languages and many types of imperative languages.
History
Research on the inductive synthesis of recursive functional programs started in the early 1970s and was brought onto firm theoretical foundations with the seminal THESIS system of Summers[6] and work of Biermann.[7] These approaches were split into two phases: first, input-output examples are transformed into non-recursive programs (traces) using a small set of basic operators; second, regularities in the traces are searched for and used to fold them into a recursive program. The main results until the mid 1980s are surveyed by Smith.[8] Due to limited progress with respect to the range of programs that could be synthesized, research activities decreased significantly in the next decade.
The advent of logic programming brought a new elan but also a new direction in the early 1980s, especially due to the MIS system of Shapiro[9] eventually spawning the new field of inductive logic programming (ILP).[10] The early works of Plotkin,[11][12] and his "relative least general generalization (rlgg)", had an enormous impact in inductive logic programming. Most of ILP work addresses a wider class of problems, as the focus is not only on recursive logic programs but on machine learning of symbolic hypotheses from logical representations. However, there were some encouraging results on learning recursive Prolog programs such as quicksort from examples together with suitable background knowledge, for example with GOLEM.[13] But again, after initial success, the community got disappointed by limited progress about the induction of recursive programs[14][15][16] with ILP less and less focusing on recursive programs and leaning more and more towards a machine learning setting with applications in relational data mining and knowledge discovery.[17]
In parallel to work in ILP, Koza[18] proposed genetic programming in the early 1990s as a generate-and-test based approach to learning programs. The idea of genetic programming was further developed into the inductive programming system ADATE[19] and the systematic-search-based system MagicHaskeller.[20] Here again, functional programs are learned from sets of positive examples together with an output evaluation (fitness) function which specifies the desired input/output behavior of the program to be learned.
The early work in grammar induction (also known as grammatical inference) is related to inductive programming, as rewriting systems or logic programs can be used to represent production rules. In fact, early works in inductive inference considered grammar induction and Lisp program inference as basically the same problem.[21] The results in terms of learnability were related to classical concepts, such as identification-in-the-limit, as introduced in the seminal work of Gold.[22] More recently, the language learning problem was addressed by the inductive programming community.[23][24]
In the recent years, the classical approaches have been resumed and advanced with great success. Therefore, the synthesis problem has been reformulated on the background of constructor-based term rewriting systems taking into account modern techniques of functional programming, as well as moderate use of search-based strategies and usage of background knowledge as well as automatic invention of subprograms. Many new and successful applications have recently appeared beyond program synthesis, most especially in the area of data manipulation, programming by example and cognitive modelling (see below).
Other ideas have also been explored with the common characteristic of using declarative languages for the representation of hypotheses. For instance, the use of higher-order features, schemes or structured distances have been advocated for a better handling of recursive data types and structures;[25][26][27] abstraction has also been explored as a more powerful approach to cumulative learning and function invention.[28][29]
One powerful paradigm that has been recently used for the representation of hypotheses in inductive programming (generally in the form of generative models) is probabilistic programming (and related paradigms, such as stochastic logic programs and Bayesian logic programming).[30][31][32][33]
Application areas
The first workshop on Approaches and Applications of Inductive Programming (AAIP) held in conjunction with ICML 2005 identified all applications where "learning of programs or recursive rules are called for, [...] first in the domain of software engineering where structural learning, software assistants and software agents can help to relieve programmers from routine tasks, give programming support for end users, or support of novice programmers and programming tutor systems. Further areas of application are language learning, learning recursive control rules for AI-planning, learning recursive concepts in web-mining or for data-format transformations".
Since then, these and many other areas have shown to be successful application niches for inductive programming, such as end-user programming,[34] the related areas of programming by example[35] and programming by demonstration,[36] and intelligent tutoring systems.
Other areas where inductive inference has been recently applied are knowledge acquisition,[37] artificial general intelligence,[38] reinforcement learning and theory evaluation,[39][40] and cognitive science in general.[41][42] There may also be prospective applications in intelligent agents, games, robotics, personalisation, ambient intelligence and human interfaces.
See also
- Automatic programming
- Declarative programming
- Evolutionary programming
- Functional programming
- Genetic programming
- Grammar induction
- Inductive reasoning
- Inductive logic programming
- Inductive functional programming
- Logic programming
- Machine learning
- Probabilistic programming language
- Program synthesis
- Programming by example
- Programming by demonstration
- Structure mining
- Test-driven development
External links
- Inductive Programming community page, hosted by the University of Bamberg.
Further reading
- Flener, P.; Schmid, U. (2008). "An introduction to inductive programming". Artificial Intelligence Review. Springer. 29 (1): 45–62. doi:10.1007/s10462-009-9108-7.
- Kitzelmann, E. (2010). "Inductive programming: A survey of program synthesis techniques". Approaches and Applications of Inductive Programming. Springer: 50–73.
- Partridge, D. (1997). "The case for inductive programming". Computer. IEEE. 30 (1): 36–41. doi:10.1109/2.562924.
- Flener, P.; Partridge, D. (2001). "Inductive Programming". Automated Software Engineering. Springer. 8 (2): 131–137. doi:10.1023/a:1008797606116.
- Hofmann, M.; Kitzelmann, E. (2009). "A unifying framework for analysis and evaluation of inductive programming systems". Proceedings of the Second Conference on Artificial General Intelligence: 55–60.
- Muggleton, S.; De Raedt, L. (1994). "Inductive Logic Programming: Theory and methods". The Journal of Logic Programming. 19-20: 629–679. doi:10.1016/0743-1066(94)90035-3.
- Lavrac, N.; Dzeroski, S. (1994). Inductive Logic Programming: Techniques and Applications. New York: Ellis Horwood. ISBN 0-13-457870-8.
- Muggleton, S.; De Raedt, Luc.; Poole, D.; Bratko, I.; Flach, P.; Inoue, K.; Srinivasan, A. (2012). "ILP turns 20". Machine Learning. Springer. 86 (1): 3–23. doi:10.1007/s10994-011-5259-2.
References
- ↑ Biermann, A.W. (1992). Shapiro, S.C., ed. "Automatic programming". Encyclopedia of artificial intelligence. Wiley: 18–35.
- ↑ Rich, C.; Waters, R.C. (1993). Yovits, M.C., ed. "Approaches to automatic programming". Advances in computers. Academic Press. 37.
- ↑ Lowry, M.L.; McCarthy, R.D., eds. (1991). Automatic software design.
- ↑ Manna, Z.; Waldinger, R. (1992). "Fundamentals of deductive program synthesis". IEEE Trans Softw Eng. 18 (8): 674–704. doi:10.1109/32.153379.
- ↑ Flener, P. (2002). Kakas, A.; Sadri, F., eds. "Achievements and prospects of program synthesis". Computational logic: logic programming and beyond; essays in honour of Robert A. Kowalski. Springer. LNAI 2407: 310–346. doi:10.1007/3-540-45628-7_13.
- ↑ Summers, P.D. (1977). "A methodology for LISP program construction from examples". J ACM. 24 (1): 161–175. doi:10.1145/321992.322002.
- ↑ Biermann, A.W. (1978). "The inference of regular LISP programs from examples". IEEE Trans Syst Man Cybern. 8 (8): 585–600. doi:10.1109/tsmc.1978.4310035.
- ↑ Smith, D.R. (1984). Biermann, A.W.; Guiho, G., eds. "The synthesis of LISP programs from examples: a survey". Automatic program construction techniques. Macmillan: 307–324.
- ↑ Shapiro, E.Y. (1983). Algorithmic program debugging. The MIT Press.
- ↑ Muggleton, S. (1991). "Inductive logic programming". New Generation Computing. 8 (4): 295–318. doi:10.1007/BF03037089.
- ↑ Plotkin, Gordon D. (1970). Meltzer, B.; Michie, D., eds. "A Note on Inductive Generalization". Machine Intelligence. Edinburgh University Press. 5: 153–163.
- ↑ Plotkin, Gordon D. (1971). Meltzer, B.; Michie, D., eds. "A Further Note on Inductive Generalization". Machine Intelligence. Edinburgh University Press. 6: 101–124.
- ↑ Muggleton, S.H.; Feng, C. (1990). "Efficient induction of logic programs". Proceedings of the Workshop on Algorithmic Learning Theory. the Japanese Society for AI. 6: 368–381.
- ↑ Quinlan, J.R.; Cameron-Jones, R.M. (1993). "Avoiding Pitfalls When Learning Recursive Theories". IJCAI: 1050–1057.
- ↑ Quinlan, J.R.; Cameron-Jones, R.M. (1995). "Induction of logic programs: FOIL and related systems". 13(3-4). Springer: 287–312.
- ↑ Flener, P.; Yilmaz, S. (1999). "Inductive synthesis of recursive logic programs: Achievements and prospects". The Journal of Logic Programming. 41 (2): 141–195. doi:10.1016/s0743-1066(99)00028-x.
- ↑ Džeroski, Sašo (1996), "Inductive Logic Programming and Knowledge Discovery in Databases", in Fayyad, U.M.; Piatetsky-Shapiro, G.; Smith, P.; Uthurusamy, R., Advances in Knowledge Discovery and Data Mining, MIT Press, pp. 117–152
- ↑ Koza, J.R. (1992). Genetic Programming: vol. 1, On the programming of computers by means of natural selection. MIT Press.
- ↑ Olsson, J.R. (1995). "Inductive functional programming using incremental program transformation". Artificial Intelligence. Elsevier. 74 (1): 55–83. doi:10.1016/0004-3702(94)00042-y.
- ↑ Katayama, Susumu (2008). "Efficient exhaustive generation of functional programs using Monte-Carlo search with iterative deepening". PRICAI 2008: Trends in Artificial Intelligence: 199–210.
- ↑ Angluin, D.; C.H., Smith (1983). "Inductive inference: Theory and methods". ACM Computing Surveys. ACM. 15: 237–269. doi:10.1145/356914.356918.
- ↑ Gold, E.M. (1967). "Language identification in the limit". Information and Control. Elsevier. 10 (5): 447–474. doi:10.1016/s0019-9958(67)91165-5.
- ↑ Muggleton, Stephen (1999). "Inductive Logic Programming: Issues, Results and the Challenge of Learning Language in Logic". Artificial Intelligence. 114: 283–296. doi:10.1016/s0004-3702(99)00067-3.; here: Sect.2.1
- ↑ Olsson, J.R.; Powers, D.M.W. (2003). "Machine learning of human language through automatic programming". Proceedings of the International Conference on Cognitive Science. University of New South Wales: 507–512.
- ↑ Lloyd, J.W. (2001). "Knowledge Representation, Computation, and Learning in Higher-order Logic".
- ↑ Lloyd, J.W. (2003). Logic for learning: learning comprehensible theories from structured data. Springer.
- ↑ Estruch, V.; Ferri, C.; Hernandez-Orallo, J.; Ramirez-Quintana, M.J. (2014). "Bridging the gap between distance and generalization". Computational Intelligence. Wiley.
- ↑ Henderson, R.J.; Muggleton, S.H. (2012). "Automatic invention of functional abstractions". Advances in Inductive Logic Programming. Imperial College Press.
- ↑ Irvin, H.; Stuhlmuller, A.; Goodman, N.D. (2011). "Inducing probabilistic programs by Bayesian program merging". arXiv:1110.5667.
- ↑ Muggleton, S. (2000). "Learning stochastic logic programs". Electron. Trans. Artif. Intell. 4(B): 141–153.
- ↑ De Raedt, L.; Kersting, K. (2008). Probabilistic inductive logic programming. Springer.
- ↑ Irvin, H.; Stuhlmuller, A.; Goodman, N.D. (2011). "Inducing probabilistic programs by Bayesian program merging". arXiv:1110.5667.
- ↑ Stuhlmuller, A.; Goodman, N.D. (2012). "Reasoning about reasoning by nested conditioning: Modeling theory of mind with probabilistic programs". Cognitive Systems Research. Elsevier.
- ↑ Lieberman, H.; Paternò, F.; Wulf, V. (2006). End user development. Springer.
- ↑ Lieberman, H. (2001). Your wish is my command: Programming by example. Morgan Kaufmann.
- ↑ Cypher, E.; Halbert, D.C. "Watch what I do: programming by demonstration".
- ↑ Schmid, U.; Hofmann, M.; Kitzelmann, E. (2009). "Analytical inductive programming as a cognitive rule acquisition devise". Proceedings of the Second Conference on Artificial General Intelligence: 162–167.
- ↑ Crossley, N.; Kitzelmann, E.; Hofmann, M.; Schmid, U. (2009). "Combining analytical and evolutionary inductive programming". Proceedings of the Second Conference on Artificial General Intelligence: 19–24.
- ↑ Hernandez-Orallo, J. (2000). "Constructive reinforcement learning". International Journal of Intelligent Systems. 15 (3): 241–264. doi:10.1002/(sici)1098-111x(200003)15:3<241::aid-int6>3.0.co;2-z.
- ↑ Kemp, C.; Goodman, N.; Tenenbaum, J.B. (2007). "Learning and using relational theories". Advances in Neural Information Processing Systems: 753–760.
- ↑ Schmid, U.; Kitzelmann, E. (2011). "Inductive rule learning on the knowledge level". Cognitive Systems Research. 12 (3): 237–248. doi:10.1016/j.cogsys.2010.12.002.
- ↑ Stuhlmuller, A.; Goodman, N.D. (2012). "Reasoning about reasoning by nested conditioning: Modeling theory of mind with probabilistic programs". Cognitive Systems Research. Elsevier.