ebook img

RIMS Symposia on Software Science and Engineering: Kyoto, 1982 Proceedings PDF

237 Pages·1983·5.454 MB·English
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview RIMS Symposia on Software Science and Engineering: Kyoto, 1982 Proceedings

Lecture Notes ni Computer Science Edited by .G Goos and .J Hartmanis 741 RIMS Symposia no Software Science dna gnireenignE ,otoyK 1982 sgnideecorP Edited by Eiichi Goto, Koichi Furukawa, Reiji ,amijakaN l ouk and Akinori Nakata, Yonezawa galreV-regnirpS Berlin Heidelberg NewYork 1983 Editorial Board .D Barstow .W Brauer Brinch R Hansen .D Cries ,D Luckham C, Moler A. Pnueli G. rellJimgeeS .J Stoer ,N Wirth Editors Eiichi Goto .tpeD of Information Science, Faculty of Science University of oykoT 1-3-7 Hongo, Tokyo Bunkyo-ku, ,311 napaJ Koichi Furukawa inst. for New Generation Computer Technology Mita Kokusai Building, 1-4-28 japan 108, Tokyo Minato-ku, Mita, Reiji amijakaN Research Institute for Sciences Mathematical Kyoto ,ytisrevinU 606, Kyoto napaJ i ouk atakaN .tsnI of Information Sciences dna Electronics University of 305, Ibaraki Niihari-gun, Sakuramura, Tsukuba, napaJ Akinori Yonezawa .tpeD of noitamrofnI ,ecneicS oykoT lnstitut of ,ygolonhceT ,amayakoO Tokyo Meguro-ku, t52, napaJ CR Subject Classifications :)2891( 2.D ISBN 3-540-11980-9 Berlin Springer-Verlag Heidelberg NewYork ISBN 0-387-11980-9 NewYork Springer-Verlag Heidelberg Berlin Library of Congress Cataloging in Publication Data. Main entry under title: RIMS symposia on software and engineering. (Lecturen otes in computer science; t47) .1 Electronic digital computers-Programming-Congresses. 2. Computer architecture-Congresses. .t Goto, EiicM, 193t-. LI Kyoto Daigaku. S~ri Kaiseki Kenkyujo. Title: ttL R.I.M.S. symposia on software and engineering. .VI Series. QA76.6.R55 1983 001.64'2 82q9669 ISBN 0-387-11980-9 (U.S.) This work is subject to copyright. All rights are reserved, whethtehre whole or part of the material i8 concerned, specifically those of translation, reprinting, re-use of illustrations, broadcasting, reproduction by photocopying machine or similar means, and storage in data banks. Under § 54 of the German Copyright Law where copies are made for other than private use, a fee is payable to "VerwertungsgeseHschaft Wort", Munich. © by Springer-VerlagB erlin Heidelberg 1983 Printed in Germany Printing and binding: BeltzO ffsetdruck, HemsbachtBergstr, 2145/3140-543210 PREFACE This volume contains selected papers from those presented at a series of symposia held at Kyoto University during the years of 1980 through 1982 under the title of "Software Science and Engineering". The symposia have been held once each year since 1979, sponsored by Research Institute for Mathematical Sciences (RIMS) of Kyoto University. The fields intended to be covered by the symposia include theoretical and practical aspects of programming languages and systems, programming styles and methodology, design and analysis of algorithms, database systems and machine architectures. The goal of the symposia is to promote research activities in software, to encourage publication of recent works by Japanese researchers and to circulate these results to the world-wide academic community. The editors thank all those who contributed either as referees or in organizing the conferences. Without their efforts, publication of this volume would not have been possible. Kyoto, October 1982 Editors Editorial Board Eiichi Goto (chief)~ University of Tokyo Koichi Furukawa~ !COT Reiji Nakajima~ Kyoto University !kuo Nakata~University of Tsukuba Akinori Yonezawa~ Tokyo Institute of Technology Referees M. Amamiyaj .S Arikawa~ S. Goto~ .T Katayama~ .S Kawai T° Mizoguchi~ To Sasaki, M. Sassa, N. Takagi, Y. Tanaka M. Tokoro~ .S Yajima, H. Yasuura~ T. Yuasa TABLE OF CONTENTS Yoshihiko FUTAMURA I Partial Computation of Programs Takuya KATAYAMA 35 Treatment of Big Values ni an Applicative Language HFP Marlo TOKORO 49 Towards the Design and Implementation of Object Oriented Architecture Shigeki GOTO 73 DURAL: an Extended Prolog Language Taisuke SATO 88 An Algorithm for Intelligent Backtracking Keiji KOJIMA 99 A Pattern Matching Algorithm ni Binary Trees Takeshi SHINOHARA 115 Polynomial Time Inference of Extended Regular Pattern Languages Kenichi HAGIHARA, Kouichi WADA and Nobukl TOKURA 128 Effects of Practical Assumption ni Area Complexity of VLSI Computation Shuzo YAJIMA and Hiroto YASUURA 147 Hardware Algorithms and Logic Design Automation - An Overview and Progress Report - Makoto AMAMIYA, Ryuzo HASEGAWA and Hirohide MIKAMI J65 List Processing with a Data Flow Machine Masaru KITSUREGAWA, Hidehiko TANAKA, and Tohru MOT0-0KA 19J Relational Algebra Machine GRACE Yuzuru TANAKA 2J5 Vocabulary Building for Database Queries Partial Computation of Programs Yoshihiko Futamura Central Research Laboratory, HITACHI,LTD. Kokubunji, Tokyo, Japan Abstract This paper attempts to clarify the difference between partial and ordinary computation. Partial computation of a computer program is by definition "specializing a general program based upon its operating environment into a more efficient program". It also shows the usefulness of partial computation. Finally, the formal theory of partial computation, technical problems in making it practical, and its future research problems are discussed. The main purpose of this paper is to make partial computation effectiveness widely known. However, two new results are also reported: (I) a partial computation compiler, and (2) a tabulation technique to terminate partial computation. .I Introduction Research on automating partial computation has been conducted in Sweden, Russia, the United States, Italy, Japan etc. for some time. Rapid progress has been made in this field in the last decade. Recent research achievements have indicated the practical utility of partial computation. Partial computation of a computer program is by definition "specializing a general program based upon its operating environment into a more efficient program" (This is also called mixed computation[14] or partial evaluation [6, ,61 20, 23 etc.]). For example, let us assume that a programmer has written program f having two input data k and uo Then let f(k,u) be the computation performed by f. Let us further assume that f is often used with k=5. In this case, it is more efficient to produce a new program, say f5' by substituting 5 for k in f and doing all possible computation based upon value ,5 as well as iteratively compute f5(u), than to compute f(5,u) iteratively changing values of u. Partial computation is an operation automatically producing f5 when f(5,u) is given. Contrary to partial computation, ordinary computation described, for example, in FORTRAN or COBOL does not produce f5 but produces an error message "u is undefined". Therefore, generating f5 from f(5,u) must be done by a FORTRAN or COBOL programmer by himself. Thus, present computer's lack of partial computation ability forces programmers to do partial computation by themselves to write efficient programs. Since general or standard program specialization is often performed in everyday program production activity, automating the specialization is expected to greately improve program productivity. This paper attempts to clarify the difference between partial and ordinary computation° It also shows the usefulness of partial computation° Finally~ the formal theory of partial computation, technical problems in making it practical, and its future research problems are discussed. .2 Partial Computation Algorithm Usually, a computer program is designed to produce desired result based upon given data° To make discussion easier, let us consider program f processing only two input data k (for known data) and u (for unknown data). Ordinary computation can start only when both k and u are given. This is called total computation (see Fig I). k u INPUT $ ~ OUTPUT ,,, ,, PROGRAM FINAL RESULT Fig. :I Total computation produces a final result. On the contrary, partial computation can start when one of the input data, say k, is given. Content of the computation is as follows: All computation in f that can be performed based upon k are finished. All the computation that cannot be performed without u are left intact. Thus, a new program is produced (see Fig 2). k u INPUT fk )u( PROGRAM INTERMEDIATE PROGRAM FINAL RESULT Fig. :2 Partial computation produces intermediate program fk based upon f and partial data k. For example, let f(k,u)=k*(k*(k+1)+u+1)+u*u and k=2 be given. Thus, an intermediate program (or projection of f at k=2) is f2(u)=2~(7÷U)+U~u When data u is given to f2' the f2(u) result is equal to that of f(2,u). Thus~the following equation holds for fk and f: fk(u)=f(k~u) ..... El Both total computation and computation via partial computation give identical results~ This fk is called a projection of f at k. Now, let us consider the reason partial computation is useful. Actually, there is a case in which partial computation is not useful. When f is computed just once with k=2 and u=1 in the above example~ computation via f2 is less efficient than direct computation of f(2~3)o However, when f(k~u) is iteratively computed with k fixed to 2, and u varied from I to !000 by ,I the situation may be reversed. The reason is obvious: Assume that each addition and multiplication takes time a, and producing an intermediate program f2 takes time p (see Fig 3). Produce intermediate I TIME marg°,r,P, f2 )u( ..... ~ P ~_I TIME 7a TIME 4a TOTAL COMPUTATION PARTIAL COMPUTATION Fig. :3 Partial computation is often useful when f is computed repeatedly (Programs in this figure are described in PAD. See Appendix I). time for computing f(2,u) : 7a time for computing f2(u) = 4a Therefore, if computation is repeated 1000 times it takes 7000a for total computation,and p + 4000a for partial computation. Thus, if p is less than 3000a, partial computation is more efficient. As described above, partial computation may be more efficient when a program is computed iteratively with a part of the input data fixd and the remaining data changed. A little more complex example[8] of partial computation is given below to clarify its difference from algebraic manipulation and symbolic execution. A program that computes 5 u and stores its value to z is shown in Fig 4. The partial computation result of f at k=5, i.e. an intermediate program, is shown in Fig .5 f(k,u) k Fig. :4 f computes z:=u lU*l=:i U:=U*U~ fs(U)=IU:=U*U| lu,z=,zI Fig. :5 fs(u)=f(5,u) Note that the result of partial computation (i.e. projection) is a program while that of algebraic manipulation or symbolic execution is an algebraic expression. A very important point is that partial computation procedure itself can be a computer program. This partial computation program is called projection machine, partial computer or partial evaluator. By

See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.