%0 Journal Article %T A Partial Evaluator for A Parallel Lambda Language %A Kuang Hairong %A Sun Yongqiang %A Lin Kai %A
Kuang Hairong %A Sun Yongqiang %A Lin Kai %J 计算机科学技术学报 %D 1997 %I %X This paper describes theoretical and practical aspects of a partial evaluator that treats a parallel lambda language. The parallel language presented is a combination of lambda calculus and message passing communication mechanism. This parallel language can be used to write a programming language's denotational semantics which extracts the parallelism in the program. From this denotational definition of the programming language, the partial evaluator can generate parallel compiler of the language by self application.The key technique of partial evaluation is binding time analysis that determines in advance which parts of the source program can be evaluated during partial evaluation, and which parts cannot. A binding time analysis is described based upon type inference. A new type chcode is introduced into the type system, which denotes the type of those expressions containing residual channel operations. A well-formedness criterion is given which ensures that partial evaluation not only doesn't commit type errors but also doesn't change the sequence of channel operations. Before binding time analysis, channel analysis is used to analyze the communication relationship between send and receive processes. %K Partial evaluation %K binding time analysis %K parallel lambda language
程序变换 %K 程序理论 %K 并行入语言 %U http://www.alljournals.cn/get_abstract_url.aspx?pcid=5B3AB970F71A803DEACDC0559115BFCF0A068CD97DD29835&cid=8240383F08CE46C8B05036380D75B607&jid=F57FEF5FAEE544283F43708D560ABF1B&aid=739CE12BAD72203AEE8476E7256C08EE&yid=5370399DC954B911&vid=59906B3B2830C2C5&iid=94C357A881DFC066&sid=5319469C819FCFF1&eid=D0E8F9CBDBE0070C&journal_id=1000-9000&journal_name=计算机科学技术学报&referenced_num=0&reference_num=0