<div dir="ltr">Can you elaborate more on prior work / the state of affairs in other language ecosystems? In the talk you reference Python "eating Java's lunch" - do they have a comparable set of features or some mechanism that serves the same goal (write code in Python, derive GPU kernel/autodiffed/etc. code)?</div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Wed, Sep 6, 2023 at 12:44 PM Paul Sandoz <<a href="mailto:paul.sandoz@oracle.com">paul.sandoz@oracle.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">I hereby invite discussion of a new Project, Babylon, whose primary goal<br>
will be to extend the reach of Java to foreign programming models such as <br>
SQL, differentiable programming, machine learning models, and GPUs.<br>
<br>
Focusing on the last example, suppose a Java developer wants to write a GPU <br>
kernel in Java and execute it on a GPU. The developer’s Java code must, <br>
somehow, be analyzed and transformed into an executable GPU kernel. A Java <br>
library could do that, but it requires access to the Java code in symbolic <br>
form. Such access is, however, currently limited to the use of non-standard <br>
APIs or to conventions at different points in the program’s life cycle <br>
(compile time or run time), and the symbolic forms available (abstract <br>
syntax trees or bytecodes) are often ill-suited to analysis and transformation.<br>
<br>
Babylon will extend Java's reach to foreign programming models with an <br>
enhancement to reflective programming in Java, called code reflection. This <br>
will enable standard access, analysis, and transformation of Java code in a <br>
suitable form. Support for a foreign programming model can then be more <br>
easily implemented as a Java library.<br>
<br>
Babylon will ensure that code reflection is fit for purpose by creating a <br>
GPU programming model for Java that leverages code reflection and is <br>
implemented as a Java library. To reduce the risk of bias we will also <br>
explore, or encourage the exploration of, other programming models such as <br>
SQL and differentiable programming, though we may do so less thoroughly.<br>
<br>
Code reflection consists of three parts:<br>
<br>
1) The modeling of Java programs as code models, suitable for access,<br>
   analysis, and transformation.<br>
2) Enhancements to Java reflection, enabling access to code models at compile<br>
   time and run time.<br>
3) APIs to build, analyze, and transform code models.<br>
<br>
For further details please see the JVM Language Summit 2023 presentations <br>
entitled "Code Reflection" [1] and "Java and GPU … are we nearly there yet?" <br>
[2].<br>
<br>
I propose to lead this Project with an initial set of Reviewers that<br>
includes, but is not limited to, Maurizio Cimadamore, Gary Frost, and<br>
Sandhya Viswanathan.<br>
<br>
For code reflection this Project will start with a clone of the current JDK <br>
main-line release, JDK 22, and track main-line releases going forward.<br>
For the GPU programming model this Project will create a separate repository,<br>
that is dependent on code reflection features as they are developed.<br>
<br>
We expect to deliver Babylon over time, in a series of JEPs that will likely<br>
span multiple feature releases.<br>
We do not currently plan to deliver the GPU programming model into the JDK.<br>
However, work on that model could identify JDK features and enhancements of <br>
general utility which could be addressed in future work.<br>
<br>
Comments?<br>
<br>
Paul.<br>
<br>
[1] <a href="https://cr.openjdk.org/~psandoz/conferences/2023-JVMLS/Code-Reflection-JVMLS-23-08-07.pdf" rel="noreferrer" target="_blank">https://cr.openjdk.org/~psandoz/conferences/2023-JVMLS/Code-Reflection-JVMLS-23-08-07.pdf</a><br>
    <a href="https://youtu.be/xbk9_6XA_IY" rel="noreferrer" target="_blank">https://youtu.be/xbk9_6XA_IY</a><br>
<br>
[2] <a href="https://youtu.be/lbKBu3lTftc" rel="noreferrer" target="_blank">https://youtu.be/lbKBu3lTftc</a><br>
<br>
</blockquote></div>