Motohiro Kawahito - Academia.edu (original) (raw)

Motohiro Kawahito

Uploads

Papers by Motohiro Kawahito

Research paper thumbnail of Automatic Optimize-time Validation for Binary Optimizers

Journal of Information Processing, 2022

We propose an approach called automatic optimize-time validation for binary optimizers. Our appro... more We propose an approach called automatic optimize-time validation for binary optimizers. Our approach does not involve executing the whole program for validation but selecting a small part of code (1 to 100 instructions) for the target test code. It executes the target code and its optimized code with several input data during binary optimization. One benefit is that we can test a small part of an actual customer's code during binary optimization. Our approach can be used to test several input data not included in the target code, which is the most beneficial aspect of the approach. If the results are the same after execution, we will use the optimized code for the final output code. If the results differ, we can consider a couple of option, e.g., while developing a binary optimizer, we can abort the compilation with an error message to easily detect a bug. After a binary optimizer becomes generally available, we can use the input code for the final output code to maintain compatibility. Our goal is for the output binary code to be compatible, fast, and small. We focused on how to improve compatibility in this study. We implemented our approach in our binary optimizer and successfully detected one new bug. We used a very small binary program to observe the worst case of increased compilation time and output binary file size. Our implementation showed that our approach increases optimization time by only 0.02% and output binary file size by 8%.

Research paper thumbnail of Re-constructing high-level information for language-specific binary re-optimization

Proceedings of the 2016 International Symposium on Code Generation and Optimization, 2016

Interpretation: Analysis for EFA ! Take advantage of knowledge about data structures and register... more Interpretation: Analysis for EFA ! Take advantage of knowledge about data structures and register usages of COBOL.

Research paper thumbnail of Effective Null Pointer Check Optimization for Java

Research paper thumbnail of Program conversion and data processor

Research paper thumbnail of Program compilation and optimization

Research paper thumbnail of Program, Apparatus, and Method of Optimizing a Java Object

Research paper thumbnail of Method and apparatus for eliminating redundant array range checks in a compiler

Research paper thumbnail of Compiler, compilation and storage

Research paper thumbnail of Program optimization method and compiler using the program optimization method

Research paper thumbnail of Method and apparatus for generating code for array range check and method and apparatus for versioning

Research paper thumbnail of Compiling system and method for optimizing binary code

Research paper thumbnail of Compiler device, method, program and recording medium

Research paper thumbnail of Compiler for Optimizing Program

Research paper thumbnail of Executing scalar replacement in program optimization

Research paper thumbnail of Computer program conversion and compilation

Research paper thumbnail of Program conversion method, computer using it and program

Research paper thumbnail of Method, Computer Program and Computer System for Assisting in Analyzing Program

A method for grouping algorithms included in a program into groups and thus for assisting in anal... more A method for grouping algorithms included in a program into groups and thus for assisting in analyzing the program. The method includes the steps of: converting each of the algorithms into a directed graph; judging, as to each representative directed graph stored in a storage unit of a computer system, whether or not the directed graph obtained by the conversion is similar to the representative directed graph; and determining a group to which the directed graph obtained by the conversion belongs from among groups stored in the storage unit in accordance with the similarity judgment. A computer system for performing the above method and a computer program for causing a computer system to perform the above method are also described.

Research paper thumbnail of Method using array range check information for generating versioning code before a loop for execution

Research paper thumbnail of Program compilation and optimization

Research paper thumbnail of Eliminating exception checks and partial redundancies for java just-in-time compilers

Research paper thumbnail of Automatic Optimize-time Validation for Binary Optimizers

Journal of Information Processing, 2022

We propose an approach called automatic optimize-time validation for binary optimizers. Our appro... more We propose an approach called automatic optimize-time validation for binary optimizers. Our approach does not involve executing the whole program for validation but selecting a small part of code (1 to 100 instructions) for the target test code. It executes the target code and its optimized code with several input data during binary optimization. One benefit is that we can test a small part of an actual customer's code during binary optimization. Our approach can be used to test several input data not included in the target code, which is the most beneficial aspect of the approach. If the results are the same after execution, we will use the optimized code for the final output code. If the results differ, we can consider a couple of option, e.g., while developing a binary optimizer, we can abort the compilation with an error message to easily detect a bug. After a binary optimizer becomes generally available, we can use the input code for the final output code to maintain compatibility. Our goal is for the output binary code to be compatible, fast, and small. We focused on how to improve compatibility in this study. We implemented our approach in our binary optimizer and successfully detected one new bug. We used a very small binary program to observe the worst case of increased compilation time and output binary file size. Our implementation showed that our approach increases optimization time by only 0.02% and output binary file size by 8%.

Research paper thumbnail of Re-constructing high-level information for language-specific binary re-optimization

Proceedings of the 2016 International Symposium on Code Generation and Optimization, 2016

Interpretation: Analysis for EFA ! Take advantage of knowledge about data structures and register... more Interpretation: Analysis for EFA ! Take advantage of knowledge about data structures and register usages of COBOL.

Research paper thumbnail of Effective Null Pointer Check Optimization for Java

Research paper thumbnail of Program conversion and data processor

Research paper thumbnail of Program compilation and optimization

Research paper thumbnail of Program, Apparatus, and Method of Optimizing a Java Object

Research paper thumbnail of Method and apparatus for eliminating redundant array range checks in a compiler

Research paper thumbnail of Compiler, compilation and storage

Research paper thumbnail of Program optimization method and compiler using the program optimization method

Research paper thumbnail of Method and apparatus for generating code for array range check and method and apparatus for versioning

Research paper thumbnail of Compiling system and method for optimizing binary code

Research paper thumbnail of Compiler device, method, program and recording medium

Research paper thumbnail of Compiler for Optimizing Program

Research paper thumbnail of Executing scalar replacement in program optimization

Research paper thumbnail of Computer program conversion and compilation

Research paper thumbnail of Program conversion method, computer using it and program

Research paper thumbnail of Method, Computer Program and Computer System for Assisting in Analyzing Program

A method for grouping algorithms included in a program into groups and thus for assisting in anal... more A method for grouping algorithms included in a program into groups and thus for assisting in analyzing the program. The method includes the steps of: converting each of the algorithms into a directed graph; judging, as to each representative directed graph stored in a storage unit of a computer system, whether or not the directed graph obtained by the conversion is similar to the representative directed graph; and determining a group to which the directed graph obtained by the conversion belongs from among groups stored in the storage unit in accordance with the similarity judgment. A computer system for performing the above method and a computer program for causing a computer system to perform the above method are also described.

Research paper thumbnail of Method using array range check information for generating versioning code before a loop for execution

Research paper thumbnail of Program compilation and optimization

Research paper thumbnail of Eliminating exception checks and partial redundancies for java just-in-time compilers

Log In