Papers by Bor-Yuh Evan Chang
Proceedings of the 2016 ACM SIGPLAN International Conference on Generative Programming: Concepts and Experiences, 2016
Bookmarks Related papers MentionsView impact
Springer eBooks, 2002
Bookmarks Related papers MentionsView impact
Bookmarks Related papers MentionsView impact
arXiv (Cornell University), Nov 16, 2015
Bookmarks Related papers MentionsView impact
Proceedings of the 43rd ACM SIGPLAN International Conference on Programming Language Design and Implementation
Bookmarks Related papers MentionsView impact
A linear syntax for natural deduction proofs in first-order intuitionistic logic is presented, wh... more A linear syntax for natural deduction proofs in first-order intuitionistic logic is presented, which has been an effective tool for teaching logic. The proof checking algorithm is also given, which is the core of the tutorial proof checker Tutch. This syntax is then extended to proofs on the assertion level which resemble single inferences one would make in a rigorous proof. The resulting language has only four constructs. Checking of these proofs is decidable, and an efficient algorithm is given.
Bookmarks Related papers MentionsView impact
To make development of grid applications less arduous, a natural, powerful, and convenient progra... more To make development of grid applications less arduous, a natural, powerful, and convenient programming interface is required. First, we propose an expressive grid programming language which we hope will provide such an interface. Then we show how to map programs in this language onto a low-level, more compact architecture that can more easily provide the fault tolerance and inexpensive scheduling suit- able for grid computing. Finally, we discuss programming techniques for taking advantage of the underlying architecture, as well as issues to be resolved in future work.
Bookmarks Related papers MentionsView impact
We reexamine the foundations of linear logic, developing a system of natural deduction following ... more We reexamine the foundations of linear logic, developing a system of natural deduction following Martin-Löf's separation of judgments from propositions. Our construction yields a clean and elegant formulation that accounts for a rich set of multiplicative, additive, and exponential connectives, extending dual intuitionistic linear logic but differing from both classical linear logic and Hyland and de Paiva's full intuitionistic linear logic. We also provide a corresponding sequent calculus that admits a simple proof of the admissibility of cut by a single structural induction. Finally, we show how to interpret classical linear logic (with or without the MIX rule) in our system, employing a form of double-negation translation.
Bookmarks Related papers MentionsView impact
The aim of static analysis is to infer invariants about programs that are precise enough to estab... more The aim of static analysis is to infer invariants about programs that are precise enough to establish semantic properties, such as the absence of run-time errors. Broadly speaking, there are two major branches of static analysis for imperative programs. Pointer and shape analyses focus on inferring properties of pointers, dynamically-allocated memory, and recursive data structures, while numeric analyses seek to derive invariants on numeric values. Although simultaneous inference of shape-numeric invariants is often needed, this case is especially challenging and is not particularly well explored. Notably, simultaneous shape-numeric inference raises complex issues in the design of the static analyzer itself. In this paper, we study the construction of such shape-numeric, static analyzers. We set up an abstract interpretation framework that allows us to reason about simultaneous shape-numeric proper-ties by combining shape and numeric abstractions into a modular, expressive abstract ...
Bookmarks Related papers MentionsView impact
Proceedings of the 42nd ACM SIGPLAN International Conference on Programming Language Design and Implementation, 2021
Bookmarks Related papers MentionsView impact
Proceedings of the ACM on Programming Languages, 2019
Static analysis tools for JavaScript must strike a delicate balance, achieving the level of preci... more Static analysis tools for JavaScript must strike a delicate balance, achieving the level of precision required by the most complex features of target programs without incurring prohibitively high analysis time. For example, reasoning about dynamic property accesses sometimes requires precise relational information connecting the object, the dynamically-computed property name, and the property value. Even a minor precision loss at such critical program locations can result in a proliferation of spurious dataflow that renders the analysis results useless. We present a technique by which a conventional non-relational static dataflow analysis can be combined soundly with a value refinement mechanism to increase precision on demand at critical locations. Crucially, our technique is able to incorporate relational information from the value refinement mechanism into the non-relational domain of the dataflow analysis. We demonstrate the feasibility of this approach by extending an existing ...
Bookmarks Related papers MentionsView impact
ACM SIGPLAN Notices, 2017
To infer complex structural invariants, shape analyses rely on expressive families of logical pro... more To infer complex structural invariants, shape analyses rely on expressive families of logical properties. Many such analyses manipulate abstract memory states that consist of separating conjunctions of basic predicates describing atomic blocks or summaries. Moreover, they use finite disjunctions of abstract memory states in order to account for dissimilar shapes. Disjunctions should be kept small for the sake of scalability, though precision often requires to keep additional case splits. In this context, deciding when and how to merge case splits and to replace them with summaries is critical both for the precision and for the efficiency. Existing techniques use sets of syntactic rules, which are tedious to design and prone to failure. In this paper, we design a semantic criterion to clump abstract states based on their silhouette which applies not only to the conservative union of disjuncts, but also to the weakening of separating conjunction of memory predicates into inductive sum...
Bookmarks Related papers MentionsView impact
Lecture Notes in Computer Science, 2013
Bookmarks Related papers MentionsView impact
Proceedings of the 41st ACM SIGPLAN-SIGACT Symposium on Principles of Programming Languages, 2014
Bookmarks Related papers MentionsView impact
Electronic Proceedings in Theoretical Computer Science, 2013
Bookmarks Related papers MentionsView impact
Lecture Notes in Computer Science, 2014
Bookmarks Related papers MentionsView impact
ACM SIGPLAN Notices, 2008
Shape analyses are concerned with precise abstractions of the heap to capture detailed structural... more Shape analyses are concerned with precise abstractions of the heap to capture detailed structural properties. To do so, they need to build and decompose summaries of disjoint memory regions. Unfortunately, many data structure invariants require relations be tracked across disjoint regions, such as intricate numerical data invariants or structural invariants concerning back and cross pointers. In this paper, we identify issues inherent to analyzing relational structures and design an abstract domain that is parameterized both by an abstract domain for pure data properties and by user-supplied specifications of the data structure invariants to check. Particularly, it supports hybrid invariants about shape and data and features a generic mechanism for materializing summaries at the beginning, middle, or end of inductive structures. Around this domain, we build a shape analysis whose interesting components include a pre-analysis on the user-supplied specifications that guides the abstra...
Bookmarks Related papers MentionsView impact
Static Analysis
Bookmarks Related papers MentionsView impact
Proceedings of the 2012 International Symposium on Software Testing and Analysis, 2012
Bookmarks Related papers MentionsView impact
Lecture Notes in Computer Science, 2010
Bookmarks Related papers MentionsView impact
Uploads
Papers by Bor-Yuh Evan Chang