Programming by example is a computer program development technique in which example input(s) and corresponding example output(s) are provided to a program synthesizer to teach the program synthesizer functionality to be incorporated into a computer program. For instance, programming by example may enable a person who is not a professional software developer to create or modify a computer program.
A variety of programming by example techniques have been proposed.
However, each such technique has its limitations. For example, computer programs that are synthesized using conventional programming by example techniques typically are relatively complex (e.g., more complex than necessary), include non-conventional functions and combinations thereof, and use template-based variable names that are unnatural or contextually non-intuitive. For instance, a pre-defined name template may be populated with a counter that is incremented to produce new variable names. Traditionally, the synthesized computer programs are not presented for viewing by a user and are not designed to be human-readable.
The underlying domain-specific language (DSL) that is used to generate a computer program in accordance with the conventional programming by example techniques often is relatively unexpressive. The underlying DSL may be relatively small and ambiguous, and searching in the DSL may be relatively inefficient. The conventional programming by example techniques usually require a user to manually inspect the outputs that are produced when the synthesized computer programs are applied to unlabeled inputs. The conventional programming by example techniques usually do not provide a way to gauge confidence in the synthesized computer programs or to provide feedback regarding the synthesized computer programs.
Various approaches are described herein for, among other things, synthesizing a computer program to include idiomatic function(s) and semantically-meaningful variable(s) using programming by example. An idiomatic function is a function (e.g., a code snippet or a statement) that conforms to a convention (e.g., generally accepted practices) of a target domain-specific language, which is associated with a textual representation of a computer program that is to be displayed to a user. For example, the idiomatic function may be configured to perform a common task in a common way for the target domain-specific language. In another example, the idiomatic function may include at least one idiom that is associated with (e.g., specific to) the target domain-specific language. A semantically-meaningful variable is a variable having a name that is derived from a vocabulary of a language and that is based at least in part on a context in which the semantically-meaningful variable is used. For instance, the semantically-meaningful variable may have a name that is associated with a lexicon.
In an example approach, an intent of a user to synthesize a computer program to include functionality that is configured to generate sample output(s) from respective input(s) is determined based at least in part on receipt of information, which includes the sample input(s) and the respective sample output(s), from the user. Based at least in part on the determined intent, the computer program is synthesized to include idiomatic function(s) by configuring the idiomatic function(s) to have the functionality and to conform to a convention of a target domain-specific language, which is associated with a textual representation of the computer program that is to be displayed to the user. At least one non-semantically-meaningful variable that is included among the idiomatic function(s) is replaced with at least one respective semantically-meaningful variable. Each semantically-meaningful variable has a name that is derived from a vocabulary of a language and is based at least in part on a context in which the semantically-meaningful variable is used. Each non-semantically-meaningful variable has a name that is not derived from the vocabulary of the language and/or is not based at least in part on the context in which the semantically-meaningful variable is used. The textual representation of the computer program, including the idiomatic function(s) and the at least one semantically-meaningful variable therein, is caused to be displayed to the user from whom the sample input(s) and the respective sample output(s) are received.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used to limit the scope of the claimed subject matter. Moreover, it is noted that the invention is not limited to the specific embodiments described in the Detailed Description and/or other sections of this document. Such embodiments are presented herein for illustrative purposes only. Additional embodiments will be apparent to persons skilled in the relevant art(s) based on the teachings contained herein.
The accompanying drawings, which are incorporated herein and form part of the specification, illustrate embodiments of the present invention and, together with the description, further serve to explain the principles involved and to enable a person skilled in the relevant art(s) to make and use the disclosed technologies.
The features and advantages of the disclosed technologies will become more apparent from the detailed description set forth below when taken in conjunction with the drawings, in which like reference characters identify corresponding elements throughout. In the drawings, like reference numbers generally indicate identical, functionally similar, and/or structurally similar elements. The drawing in which an element first appears is indicated by the leftmost digit(s) in the corresponding reference number.
The following detailed description refers to the accompanying drawings that illustrate exemplary embodiments of the present invention. However, the scope of the present invention is not limited to these embodiments, but is instead defined by the appended claims. Thus, embodiments beyond those shown in the accompanying drawings, such as modified versions of the illustrated embodiments, may nevertheless be encompassed by the present invention.
References in the specification to “one embodiment,” “an embodiment,” “an example embodiment,” or the like, indicate that the embodiment described may include a particular feature, structure, or characteristic, but every embodiment may not necessarily include the particular feature, structure, or characteristic. Moreover, such phrases are not necessarily referring to the same embodiment. Furthermore, when a particular feature, structure, or characteristic is described in connection with an embodiment, it is submitted that it is within the knowledge of one skilled in the relevant art(s) to implement such feature, structure, or characteristic in connection with other embodiments whether or not explicitly described.
Descriptors such as “first”, “second”, “third”, etc. are used to reference some elements discussed herein. Such descriptors are used to facilitate the discussion of the example embodiments and do not indicate a required order of the referenced elements, unless an affirmative statement is made herein that such an order is required.
Example embodiments described herein are capable of synthesizing a computer program to include idiomatic function(s) and semantically-meaningful variable(s) using programming by example. An idiomatic function is a function (e.g., a code snippet or a statement) that conforms to a convention (e.g., generally accepted practices) of a target domain-specific language, which is associated with a textual representation of a computer program that is to be displayed to a user. For example, the idiomatic function may be configured to perform a common task in a common way for the target domain-specific language. In another example, the idiomatic function may include at least one idiom that is associated with (e.g., specific to) the target domain-specific language. A semantically-meaningful variable is a variable having a name that is derived from a vocabulary of a language and that is based at least in part on a context in which the semantically-meaningful variable is used. For instance, the semantically-meaningful variable may have a name that is associated with a lexicon.
Example techniques described herein have a variety of benefits as compared to conventional techniques for synthesizing a computer program using programming by example. For instance, the example techniques may be capable of generating a computer program that is less complex and easier to read, as compared to the conventional techniques. For example, the computer program may include conventional functions and combinations thereof, use natural or contextually intuitive variable names, and be human-readable. For instance, mechanistically derived intermediate variable names may be replaced with the natural or contextually intuitive variable names by querying a pre-trained language model with a prompt that includes the generated code up to (and excluding) the next intermediate variable name that is to be renamed. Each instance of the intermediate variable name may be replaced with the natural or contextually intuitive variable name throughout the synthesized computer program.
The example techniques may use an underlying domain-specific language (DSL) that is more expressive than DSL used by the conventional techniques, and searching in the underlying DSL may be more efficient. For instance, the underlying DSL may incorporate operations that are sufficiently expressive for common string transformations while being more closely aligned with the string operations available in common programming languages, such as the Excel® formula language, the Python™ programming language, and the PowerFx™ programming language. For example, the underlying DSL may incorporate string splitting on a constant substring and/or string slicing. In another example, dates and/or times may be extracted from an existing string into any of multiple date-time formats. In yet another example, numbers may be extracted from an existing string into any of multiple number formats. The underlying DSL may contribute to simplification of a synthesized computer program and to causing the synthesized computer program to be human-readable. For instance, the synthesized computer program may be readable in a variety of target languages.
The example techniques may be capable of presenting a synthesized computer program for viewing by a user. By enabling the synthesized computer program to be presented for viewing by the user, the example techniques may enable the user to gauge and increase confidence in the synthesized computer program. The example techniques may enable the user to provide feedback regarding the synthesized computer program. The example techniques may obviate a need for a user to manually inspect outputs that are produced when the computer program is applied to unlabeled inputs.
The example techniques may utilize a guarded context-free grammar, which may enable a search procedure to be discontinued if a suitable computer program is produced by one of the earlier options detailed in the guarded context-free grammar. By expressing coarse preferences via the guarded context-free grammar, a relatively simpler program ranking mechanism may be used. For instance, a holistic ranking mechanism may be employed to compute program features over the leaves in the synthesized computer program (e.g., along with penalties based on internal node operators), rather than strictly compositionally based on sub-programs. Utilization of the guarded context-free grammar and the holistic ranking mechanism may increase efficiency and simplicity of the computer program synthesis process.
The example techniques may be capable of presenting selected inputs of a synthesized computer program to a user for annotation. The selected inputs may be those having corresponding outputs for which an uncertainty is greater than a user-defined threshold. If the outputs for all corresponding inputs have an uncertainty that is less than the user-defined threshold, the user need not necessarily be contacted for purposes of annotation. Accordingly, the example techniques may reduce the number of inputs that a user manually validates.
The example techniques may reduce an amount of time and/or resources (e.g., processor cycles, memory, network bandwidth) that is consumed to validate outputs that are produced by a synthesized computer program based on (e.g., based at least in part on) respective inputs. For example, by identifying a subset of the inputs based on each input in the subset constituting a significant input, such validation efforts can be limited to only those outputs corresponding to inputs that are included in the subset. The example techniques may reduce an amount of time and/or resources that is consumed to modify a synthesized computer program to include user-defined functionality. For example, by configuring the synthesized computer program to be human-readable, the example techniques may enable a user to more quickly determine a change that is to be made to the synthesized computer program to achieve the user-defined functionality. In accordance with this example, the user (or a computing system that is used by the user to determine the change) may consume less time and/or resources.
By configuring a synthesized computer program to be human readable, the example techniques may increase efficiency of a user who provides sample input(s) and sample output(s) on which the synthesized computer program is based. For instance, the human-readability of the synthesized computer program may reduce an amount of time that the user spends to establish confidence in the synthesized computer program and/or to identify changes that are to be made to the synthesized computer program to achieve a desired functionality.
As shown in
The user devices 102A-102M are processing systems that are capable of communicating with servers 106A-106N. An example of a processing system is a system that includes at least one processor that is capable of manipulating data in accordance with a set of instructions. For instance, a processing system may be a computer, a personal digital assistant, etc. The user devices 102A-102M are configured to provide requests to the servers 106A-106N for requesting information stored on (or otherwise accessible via) the servers 106A-106N. For instance, a user may initiate a request for executing a computer program (e.g., an application) using a client (e.g., a Web browser, Web crawler, or other type of client) deployed on a user device 102 that is owned by or otherwise accessible to the user. In accordance with some example embodiments, the user devices 102A-102M are capable of accessing domains (e.g., Web sites) hosted by the servers 104A-104N, so that the user devices 102A-102M may access information that is available via the domains. Such domain may include Web pages, which may be provided as hypertext markup language (HTML) documents and objects (e.g., files) that are linked therein, for example.
Each of the user devices 102A-102M may include any client-enabled system or device, including but not limited to a desktop computer, a laptop computer, a tablet computer, a wearable computer such as a smart watch or a head-mounted computer, a personal digital assistant, a cellular telephone, an Internet of things (IoT) device, or the like. It will be recognized that any one or more of the user devices 102A-102M may communicate with any one or more of the servers 106A-106N.
The servers 106A-106N are processing systems that are capable of communicating with the user devices 102A-102M. The servers 106A-106N are configured to execute computer programs that provide information to users in response to receiving requests from the users. For example, the information may include documents (Web pages, images, audio files, video files, etc.), output of executables, or any other suitable type of information. Any one or more of the computer programs may be a cloud computing service. A cloud computing service is a service that executes at least in part in the cloud. The cloud may be a remote cloud, an on-premises cloud, or a hybrid cloud. It will be recognized that an on-premises cloud may use remote cloud services. Examples of a cloud computing service include but are not limited to Microsoft 365® (or Excel® or Word™ therein) developed and distributed by Microsoft Corporation, Google Docs Editors™ (or Google Sheets™ or Google Docs™ therein) developed and distributed by Google Inc., and iWork® (or Numbers™ or Pages™ therein) developed and distributed by Apple Inc. In accordance with some example embodiments, the servers 106A-106N are configured to host respective Web sites, so that the Web sites are accessible to users of the semantic idiomatic program synthesis system 100.
The first server(s) 106A are shown to include semantic idiomatic program synthesis logic 108 for illustrative purposes. The semantic idiomatic program synthesis logic 108 is configured to synthesize a computer program to include idiomatic function(s) and semantically-meaningful variable(s) using programming by example. In an example implementation, the semantic idiomatic program synthesis logic 108 determines an intent of a user to synthesize the computer program to include functionality that is configured to generate sample output(s) based on (e.g., based at least in part on) respective input(s) as a result of receiving information, which includes the sample input(s) and the respective sample output(s), from the user. The semantic idiomatic program synthesis logic 108 synthesizes the computer program to include the idiomatic function(s) by configuring the idiomatic function(s) to have the functionality and to conform to a convention of a target domain-specific language, which is associated with a textual representation of the computer program that is to be displayed to the user, based at least in part on the determined intent. The semantic idiomatic program synthesis logic 108 replaces at least one non-semantically-meaningful variable that is included among the idiomatic function(s) with at least one respective semantically-meaningful variable. Each semantically-meaningful variable has a name that is derived from a vocabulary of a language and is based at least in part on a context in which the semantically-meaningful variable is used. Each non-semantically-meaningful variable has a name that is not derived from the vocabulary of the language and/or is not based at least in part on the context in which the semantically-meaningful variable is used. The semantic idiomatic program synthesis logic 108 causes the textual representation of the computer program, including the idiomatic function(s) and the at least one semantically-meaningful variable therein, to be displayed to the user from whom the sample input(s) and the respective sample output(s) are received.
The computer program may be configured to perform any of a variety of operations. For example, the sample input(s) may be in a first column of a table, and the sample output(s) may be in a second column of the table. In accordance with this example, the computer program may be configured to automatically fill additional values (i.e., outputs) in the second column based on other corresponding values (i.e., inputs) in the first column.
The semantic idiomatic program synthesis logic 108 may use machine learning to perform at least some of its operations. For instance, the semantic idiomatic program synthesis logic 108 may use the machine learning to develop and refine the computer program that is synthesized by the semantic idiomatic program synthesis logic 108, including the idiomatic function(s) and/or the semantically-meaningful variable(s) therein, and/or a language model that is used to determine the semantically-meaningful variable(s). The semantic idiomatic program synthesis logic 108 may use the machine learning to analyze the sample input(s) that are received from the user, the corresponding sample output(s) that are received from the user, functionality of functions that are available to be incorporated into the computer program, names of variables in one or more of those functions, and/or other synthesized computer programs to synthesize the computer program to include the idiomatic function(s) and the semantically-meaningful variable(s).
The semantic idiomatic program synthesis logic 108 may use a neural network to perform the machine learning to synthesize a computer program to include idiomatic function(s) and semantically-meaningful variable(s) using programming by example. Examples of a neural network include but are not limited to a feed forward neural network and a long short-term memory (LSTM) neural network. A feed forward neural network is an artificial neural network for which connections between units in the neural network do not form a cycle. In an example embodiment, the semantic idiomatic program synthesis logic 108 employs a feed forward neural network to train a machine learning model that is used to determine ML-based confidences. Such ML-based confidences may be used to determine likelihoods that events will occur.
An LSTM neural network is a recurrent neural network that has memory and allows data to flow forward and backward in the neural network. The LSTM neural network is capable of remembering values for short time periods or long time periods. Accordingly, the LSTM neural network may keep stored values from being iteratively diluted over time. In one example, the LSTM neural network may be capable of storing information, such as the sample input(s) that are received from the user, the corresponding sample output(s) that are received from the user, functionality of functions, names of variables, and/or other synthesized computer programs over time. For instance, the LSTM neural network may synthesize the computer program by utilizing such information. In another example, the LSTM neural network may be capable of remembering relationships between features, such as sample input(s), sample output(s), functionality of functions, names of variables, other synthesized computer programs, probabilities that the functions define relationships between sample inputs and sample outputs, and ML-based confidences that are derived therefrom.
The semantic idiomatic program synthesis logic 108 may include training logic and inference logic. The training logic is configured to train a machine learning algorithm that the inference logic uses to determine (e.g., infer) the ML-based confidences. For instance, the training logic may provide sample inputs, sample outputs, sample functionality of functions, sample names of variables, sample synthesized computer programs sample probabilities that the functions define relationships between the sample inputs and the sample outputs, and sample confidences as inputs to the algorithm to train the algorithm. The sample data may be labeled. The machine learning algorithm may be configured to derive relationships between the features (e.g., sample input(s), sample output(s), functionality of functions, names of variables, other synthesized computer programs, probabilities that the functions define relationships between sample inputs and sample outputs) and the resulting ML-based confidences. The inference logic is configured to utilize the machine learning algorithm, which is trained by the training logic, to determine the ML-based confidence when the features are provided as inputs to the algorithm.
The semantic idiomatic program synthesis logic 108 may be implemented in various ways to synthesize a computer program to include idiomatic function(s) and semantically-meaningful variable(s) using programming by example, including being implemented in hardware, software, firmware, or any combination thereof. For example, the semantic idiomatic program synthesis logic 108 may be implemented as computer program code configured to be executed in one or more processors. In another example, at least a portion of the semantic idiomatic program synthesis logic 108 may be implemented as hardware logic/electrical circuitry. For instance, at least a portion of the semantic idiomatic program synthesis logic 108 may be implemented in a field-programmable gate array (FPGA), an application-specific integrated circuit (ASIC), an application-specific standard product (ASSP), a system-on-a-chip system (SoC), a complex programmable logic device (CPLD), etc. Each SoC may include an integrated circuit chip that includes one or more of a processor (a microcontroller, microprocessor, digital signal processor (DSP), etc.), memory, one or more communication interfaces, and/or further circuits and/or embedded firmware to perform its functions.
The semantic idiomatic program synthesis logic 108 may be partially or entirely incorporated in a cloud computing service, though the example embodiments are not limited in this respect.
The semantic idiomatic program synthesis logic 108 is shown to be incorporated in the first server(s) 106A for illustrative purposes and is not intended to be limiting. It will be recognized that the semantic idiomatic program synthesis logic 108 (or any portion(s) thereof) may be incorporated in any one or more of the user devices 102A-102M. For example, client-side aspects of the semantic idiomatic program synthesis logic 108 may be incorporated in one or more of the user devices 102A-102M, and server-side aspects of semantic idiomatic program synthesis logic 108 may be incorporated in the first server(s) 106A. In another example, the semantic idiomatic program synthesis logic 108 may be distributed among the user devices 102A-102M. In yet another example, the semantic idiomatic program synthesis logic 108 may be incorporated in a single one of the user devices 102A-102M. In another example, the semantic idiomatic program synthesis logic 108 may be distributed among the server(s) 106A-106N. In still another example, the semantic idiomatic program synthesis logic 108 may be incorporated in a single one of the servers 106A-106N.
As shown in
At step 204, based at least in part on the received information, an intent of the user to synthesize the computer program to include functionality that is configured to generate the sample output(s) from the respective input(s) is determined. In an example implementation, based at least in part on the received information, the intent logic 612 determines the intent of the user to synthesize the computer program 638 to include functionality that is configured to generate the sample output(s) 628 from the respective sample input(s) 626. The intent logic 612 may generate intent information 636 to indicate the determined intent. For instance, the intent information 636 may indicate the functionality that is to be included in the computer program. The intent information 636 may further indicate the sample input(s) 626 and the sample output(s) 628.
At step 206, based at least in part on the determined intent, the computer program is synthesized to include the idiomatic function(s) by configuring the idiomatic function(s) to have the functionality and to conform to a convention of a target domain-specific language, which is associated with a textual representation of the computer program that is to be displayed to the user. The idiomatic functions may be configured to mimic human-written functions. For instance, the idiomatic functions may be derived based on (e.g., based at least in part on) analysis of historical human-written functions. Examples of a domain-specific language include but are not limited to the Excel® formula language, the Python™ programming language, and the PowerFx™ programming language. In an example implementation, the program generation logic 614 synthesizes the computer program 638 to include the idiomatic function(s) 640 by configuring the idiomatic function(s) 640 to have the functionality and to conform to the convention of the target domain-specific language, based at least in part on the determined intent that is indicated by the intent information 636. Synthesizing the computer program 638 to include the idiomatic function(s) 640 may reduce an amount of time and/or resources that is consumed by the computing system 600 to modify the computer program 638 to include user-defined functionality and/or may increase efficiency of the user (e.g., by causing the computer program 638 to be less complex and/or more human-readable).
In an example embodiment, synthesizing the computer program at step 206 includes selecting an idiomatic function of the idiomatic function(s) from multiple possible idiomatic functions by using a guarded context-free grammar. The guarded context-free grammar includes multiple ordered rules having multiple respective rankings in a hierarchical ranking order. The ordered rules are configured to generate the respective possible idiomatic functions. The idiomatic function is selected based at least in part on the ranking corresponding to the idiomatic function relative to the ranking corresponding to each other possible idiomatic function. Describing the context-free grammar as “guarded” means that the ordered rules that are ranked lower in the hierarchical ranking order than the ordered rule that is configured to generate the selected idiomatic function are not taken into consideration as a result of the selected idiomatic function being selected.
In another example embodiment, synthesizing the computer program at step 206 includes configuring at least one of the idiomatic function(s) to extract date-time information from a string, select a date-time format from multiple date-time formats based at least in part on a determination that a sample output of the sample output(s) results from application of the selected date-time format to a corresponding sample input of the sample input(s), and apply the selected date-time format to the date-time information that is extracted from the string. The date-time information indicates a date and/or a time.
In yet another example embodiment, synthesizing the computer program at step 206 includes configuring at least one of the idiomatic function(s) to extract a number from a string, select a number format from multiple number formats based at least in part on a determination that a sample output of the sample output(s) results from application of the selected number format to a corresponding sample input of the sample input(s), and apply the selected number format to the number that is extracted from the string.
At step 208, at least one non-semantically-meaningful variable that is included among the idiomatic function(s) is replaced with at least one respective semantically-meaningful variable. Each semantically-meaningful variable has a name that is derived from a vocabulary of a language and is based at least in part on a context in which the semantically-meaningful variable is used. Each non-semantically-meaningful variable has a name that is not derived from the vocabulary of the language and/or is not based at least in part on the context in which the semantically-meaningful variable is used. In an example implementation, the replacement logic 616 replaces at least one non-semantically-meaningful variable that is included among the idiomatic function(s) 640 with at least one respective semantically-meaningful variable 632 to provide an updated computer program 642. Replacing at least one non-semantically-meaningful variable that is included among the idiomatic function(s) 640 with at least one respective semantically-meaningful variable 632 may reduce an amount of time and/or resources that is consumed by the computing system 600 to modify the computer program 638 to include user-defined functionality and/or may increase efficiency of the user (e.g., by causing the computer program 638 to be more human-readable).
At step 210, the textual representation of the computer program, including the idiomatic function(s) and the at least one semantically-meaningful variable therein, is caused to be displayed to the user from whom the sample input(s) and the respective sample output(s) are received. For instance, causing the textual representation of the computer program to be displayed to the user may enable the user to understand the functionality that is defined by the computer program. In an example implementation, the display logic 618 causes the textual representation of the updated computer program 642, which includes the idiomatic function(s) 640 and the at least one semantically-meaningful variable 632 therein, to be displayed to the user from whom the sample input(s) 626 and the respective sample output(s) 628 are received. For instance, the display logic 618 may generate a display instruction 648, which is configured to cause the textual representation of the updated computer program 642 to be displayed. Causing the textual representation of the updated computer program 642 to be displayed to the user may reduce an amount of time and/or resources that is consumed by the computing system 600 to modify the updated computer program 642 to include user-defined functionality and/or may increase efficiency of the user (e.g., by reducing an amount of time that the user spends to establish confidence in the updated computer program 642 and/or to identify changes that are to be made to the updated computer program 642 to achieve the user-defined functionality).
In an example embodiment, the method of flowchart 200 further includes identifying a designated non-semantically-meaningful variable using a string splitting technique or a string splicing technique. The at least one non-semantically-meaningful variable includes the designated non-semantically-meaningful variable. A string splitting technique is a technique in which multiple portions of a string are defined based on delimiter(s) in the string. For instance, consecutive portions of the string may be separated by a respective delimiter. A string slicing technique is a technique in which a portion of a string is defined based on a starting point and an ending point of the portion. For instance, the portion may be defined by a pattern having identifiable starting and ending points.
In some example embodiments, one or more steps 202, 204, 206, 208, and/or 210 of flowchart 200 may not be performed. Moreover, steps in addition to or in lieu of steps 202, 204, 206, 208, and/or 210 may be performed. For instance, in an example embodiment, the method of flowchart 200 includes one or more of the steps shown in flowchart 300 of
At step 304, the respective semantically-meaningful variable is received from the pre-trained language model as a response to the query. In an example implementation, the replacement logic 616 receives the respective semantically-meaningful variable 632 from the pre-trained language model 620 as a response to the query 630.
At step 306, the respective non-semantically-meaningful variable in the computer program is replaced with the respective semantically-meaningful variable based at least in part on receipt of the respective semantically-meaningful variable from the pre-trained language model. It will be recognized that step 208 shown in
In another example embodiment, the method of flowchart 200 further includes one or more of the steps shown in flowchart 400 of
In an example implementation, the ranking logic 622 assigns the rankings to the respective possible computer programs. In an aspect of this implementation, the ranking logic 622 identifies the possible computer programs to include the updated computer program 642 and other possible computer program(s) 634, all of which are configured to generate the sample output(s) 628 from (e.g., based on) the sample input(s) 626. In accordance with this aspect, the ranking logic 622 analyzes the updated computer program 642 and the other possible computer program(s) 634 to determine readability of each possible computer program. In further accordance with this aspect, the ranking logic 622 assigns the respective ranking to each possible computer program based on the readability of the respective possible computer program that is determined by the analysis. For instance, a relatively higher readability for a possible computer program may result in a relatively higher ranking of the respective possible computer program. A relatively lower readability for a possible computer program may result in a relatively lower ranking of the respective possible computer program. The ranking logic 622 may generate ranking information 644 to indicate the rankings that are assigned to the respective possible computer programs.
At step 404, the computer program is selected from the possible computer programs based at least in part on the ranking of the computer program being no less than (e.g., being greater than) the ranking of each other possible computer program that is capable of producing an expected result. The computer program may be selected from the possible computer programs further based at least in part on the computer program being capable of producing the expected result, though the example embodiments are not limited in this respect. In an example implementation, the selection logic 624 selects the updated computer program 642 from the possible computer programs based at least in part on the ranking of the updated computer program 642 being no less than (e.g., being greater than) the ranking of each other possible computer program that is capable of producing an expected result. The selection logic 624 may analyze the possible computer programs to determine whether each possible computer program is capable of producing an expected result. For example, the selection logic 624 may apply each possible computer program against the sample input(s) 626 (or portion thereof) to determine whether the respective possible computer program produces the corresponding sample output(s) 628 (or portion thereof). In another example, the selection logic 624 may apply each possible computer program against unlabeled input(s) to determine whether expected outputs are produced based on a probability analysis. The selection logic 624 may generate selection information 652 to indicate that the computer program is selected. For instance, the display logic 642 may perform any one or more of its operations based on the selection information 652 indicating that the computer program is selected.
In yet another example embodiment, the method of flowchart 200 includes one or more of the steps shown in flowchart 500 of
At step 504, a user interface element is caused to be displayed to the user from whom the sample input(s) and the respective sample output(s) are received based at least in part on the significant input being identified. The user interface is configured to request the ground truth output that corresponds to the significant input from the user. In an example implementation, the display logic 618 causes the user interface element to be displayed to the user from whom the sample input(s) 626 and the respective sample output(s) 628 are received based at least in part on the significant input being identified. For instance, the display logic 618 may generate a display instruction 648 that instructs a display, which may be included in the computing system 600 or external to the computing system 600, to display the user interface. The display instruction 648 may include the significant input or the indication thereof from the ground truth request 646. In accordance with this implementation, the user interface is configured to request the ground truth output 650 that corresponds to the significant input from the user.
At step 506, the ground truth output that corresponds to the significant input is received from the user. In an example implementation, the intent logic 612 receives the ground truth output 650 that corresponds to the significant input from the user.
At step 508, a set of possible computer programs from which the computer program is to be selected is identified based at least in part on each possible computer program in the set having the functionality further configured to generate the ground truth output from the significant input. Accordingly, each of the possible computer programs in the set is capable of generating the sample output(s) from the respective sample input(s) and is further capable of generating the ground truth output from the significant input. It will be recognized that step 206 shown in
It will be recognized that the computing system 600 may not include one or more of the semantic idiomatic program synthesis logic 608, the intent logic 612, the program generation logic 614, the replacement logic 616, the display logic 618, the pre-trained language model 620, the ranking logic 622, and/or the selection logic 624. Furthermore, the computing system 600 may include components in addition to or in lieu of the semantic idiomatic program synthesis logic 608, the intent logic 612, the program generation logic 614, the replacement logic 616, the display logic 618, the pre-trained language model 620, the ranking logic 622, and/or the selection logic 624.
The viability of the semantic idiomatic program synthesis logic 608 may depend on any of a variety of factors. One example of such a factor is the domain-specific language, which may define the search space of computer programs. Another example of such a factor is the ranking functionality of the ranking logic 622, which may pick one of the computer programs that are consistent with the sample input(s) 626 and the sample output(s) 628. Bloating the domain-specific language by including several operators that are potentially redundant may increase the program search space and may increase complexity of the ranking functionality.
The guarded context-free grammar may be capable of addressing both challenges. In a context-free grammar, if we have two production rules X→α and X→β for the same nonterminal X, we often write the two rules as X→α where is the (non-deterministic) choice operator. Guarded context-free grammars allow a new operator, |>, that introduces an ordering on the various choices. Thus, X→α|>β informally says to prefer X→α over X→β, meaning the branch is explored only if the branch a failed to produce a program. By writing the domain-specific language using a guarded context-free grammar, learning may be performed more efficiently, and ranking may be simplified.
Variable names may be inherently about the meaning of the data, which may be challenging to capture in a purely rules-based way. This challenge may be overcome by exploiting a large pre-trained model, for example. The pre-trained model may be capable of semantically understanding data and words.
A guarded context-free grammar G may be represented as a 4-tuple (V, Σ, R, S), where
Rules in regular context-free grammars are of the form V→w, where w ∈ (V ∪ Σ)*. These rules may be referred to as “simple rules.” Rules in guarded context-free grammars can have multiple options on the right-hand side that are ordered. A rule with more than one option is referred to as a “guarded rule.”
Consider a simple rule V→w, which will be called r for purposes of illustration. This rule induces a binary relation, denoted by →r, on (V ∪ Σ)* as follows: w′→r w″ if w′=w1 V w2 and w″=w1w w2. A guarded rule V→w1|>w2|> . . . |>wk is viewed as a tuple of simple rules, where the i-th element of the tuple is V→wi. We will call V→wi the i-th constituent rule of the original guarded rule. A partial order may be defined on simple rules by saying V→wiV→wj if both these rules are the i-th and j-th constituent rules of the same guarded rule and i<j. We say the rule r1 is preferred to rule r2 if r1r2.
A derivation in a guarded context-free grammar G is a sequence of words, written as S→w1→w2→ . . . →wn, that (a) starts with the start symbol S, (b) ends with a word wn ∈ Σ*, and (c) each pair of consecutive words is related by some simple rule in the guarded context-free grammar. Note that the simple rule can be a constituent of a guarded rule. The above derivation in G is succinctly written as S→*Gwn.
A derivation is leftmost if, in every step w1Vw2→w1w w2, it is the case that w1 ∈ Σ*. We can take the preference partial order on simple rules and lexicographically extend it to leftmost derivations. Specifically, we define a partial order on two leftmost derivations: S→*GwnS→*Gwm if (a) the two derivation share the first i steps (i can be 0), (b) if the i+1-th steps in the two derivations are induced respectively by rule r and r′, then rr′.
The notion of (leftmost) derivation in a guarded context-free grammar is the same as the notion of a (leftmost) derivation in a context-free grammar that contains all constituent simple rules of every guarded rule as separate simple rules. Guarded context-free grammars allow us to define a partial order on different (leftmost) derivations.
In a first example, consider a guarded context-free grammar G:=(V, Σ, R,S), where V:={S,S1,S2}, Σ:={a,b,c,d,e}, S:=S, and R is the set containing S→S1,S2, S1→a|>b, S1→S, S2→c|>d. Note that R has two simple rules, and two guarded rules for illustrative purposes. We can also write the rules for S1 as S S1→(a|>b)|e. The strings ac, ad, bc, bd, ec, and ed have leftmost derivation in G.
We now define the key new notion of a derivation in the context L. Let L ⊂Σ* be a language (a set of words). Given a guarded context-free grammar G and a language L, a word w is said to have a derivation in G in the context L if (a) w Σ L and there is a leftmost derivation S→*Gw, call it d, (b) there is no w′ ∈ L such that there is a leftmost derivation S→*Gw′, call it d′, and d′d.
In a second example, consider a guarded context-free grammar G from the first example discussed above. Let L={ad,bc}. There is a leftmost derivation for ad in the context L, but there is no leftmost derivation for bc in the context L. This is because the rule S1→a is preferred over S1→b. Note also that there is a leftmost derivation for bc in the context {bc}. The rule S1→e is incomparable to the constituent rules S1→a and S1→b. Consequently, both ec and ad have derivations in the context {ec,ad,bc}.
A key aspect of guarded context-free grammars is that the property of accepting a word from a set, say L, is invariant to whether we consider acceptance in the context L. By considering derivations in the context L, guarded context-free grammars provide a mechanism to order the elements they accept from that set L.
If G is a guarded context-free grammar and L is any set of words, then the following are equivalent:
In the programming by example context, L will be the set of programs consistent with the given input sample(s) and output sample(s). If we search for programs that have derivations (using a guarded context-free grammar) in context L, then we can automatically eliminate “less preferred” programs.
FlashFill++ is an example implementation of semantic idiomatic program synthesis logic 600 shown in
Although FlashFill can perform some datetime and number operations using text manipulation (such as “01/01/2020”→“2020” or “10.01”→“10”), it is unable to express other sophisticated datetime and number operations. For instance, FlashFill cannot get the date of week from a date (such as “01/01/2020”→“Wednesday”), or round up a number (e.g., “10.49”→“10.5”). This motivates us to add two new rules to support richer datetime (rule formatDate) and number (rule formatNumber) transformations. Learning these rules requires identifying the potential date and number substrings in the input and output and applying fuzzy matching between them to determine which could possibly correspond.
The next major differences are in the substr and pos rules. FlashFill has a single Slice operator that selects a substring defined by its start and end positions, which can be defined either as absolute positions or with the complicated RegPos operator that finds the kth place in the string bounded by the two given regular expressions. While this is expressive enough to cover any desired substring selection and all of the operators in FlashFill++ can technically be expressed in terms of it, in FlashFill++we chose a wider collection of operators that mimics what developers do in practice (which makes translating these operators to the target languages much easier). In particular, instead of only allowing substrings to be defined as a Slice with their start and end positions, FlashFill++ adds a Split operator to select the kth element in a sequence of repeated delimiters and a MatchFull operator to find the kth match of a regular expression. Additionally, in FlashFill++ the pos rule replaces the operator RegPos (which relies on a pair of regular expressions to identify a position) with a Find of a constant string in the input and a Match/MatchEnd of a regular expression. Although these newly introduced operators may overlap in their expressiveness (potentially increasing synthesis time and potentially lowering ranking effectiveness), we can minimize the effect by leveraging guarded rules to prioritize the search. Our evaluation shows that FlashFill++ is much faster than FlashFill.
In contrast, the design of the FlashFill++ DSL was guided by the need for readable code generation. Consequently, most operators in the DSL are those that have direct analogous operators in the target language. This makes the process of translation to the target fairly straightforward, and also guarantees that the translation is natural to some extent.
Codex is an example implementation of the pre-trained language model 620 shown in
Each renaming task maps the pair of (I/O examples, FlashFill++ program) to the desired renamed program. The prompt includes two static samples of such tasks, followed by the “question”, which is the pair (I/O examples, FlashFill++ program) that are to be renamed. Given this prompt, Codex responds with the renamed program that it learns from the task samples. This capability is called few-shot learning.
In some cases, Codex may respond with a program that is semantically different from FlashFill++'s program in the question. This is understandable because Codex does not have any guarantees on the output; it repeatedly samples the vocabulary based on what it has seen so far. To preserve the program semantics, the computer program can be frozen, leaving only variables as holes for Codex to complete. Since Codex cannot perform infilling (i.e., filling in the blanks surrounded by texts), multiple calls can be made to Codex, each time to rename a variable in left-to-right order. A stopword may be chosen so that Codex stops as soon as it completes the variable. Once a variable is renamed where it is defined, all of instances of the variable that appear later in the program may be renamed. In the next iteration, the frozen text may be appended to the prompt after the most recently renamed variable, until the next not-yet-renamed variable is encountered. A new call may then be made to Codex to rename the new variable. The process continues until all variables are renamed.
The renaming process performed by Codex is similar to constrained decoding, where the goal is to force language models to abide to some external constraints. Two static samples are used in the prompt for illustrative purposes. Although prompt-engineering may be performed to select samples that are similar to the question, static samples may be sufficient.
Input samples and output samples (a.k.a. “input-output samples” or “input-output examples”) provide an incomplete specification for a computer program. Consequently, given a few input-output examples, each of multiple computer programs in the DSL may be capable of transforming the given inputs to the corresponding outputs. A ranking function is used to determine which of the computer programs is to be returned to the user.
Given a guarded context-free grammar G:=(V, Σ, R,S) of the DSL, a ranking function ƒ is a mapping from the words over Σ to a totally ordered domain (D, ); thus, ƒ:Σ*D. A word w is preferred over w′ if ƒ(w)ƒ(w′).
The semantic idiomatic program synthesis logic 606 may use a ranking function to select one out of many candidate programs that may be consistent with the input-output examples. Typically, ranking functions have been defined compositionally; that is, ƒ(w1w2)=g(ƒ(w1), ƒ(w2)), where g is some fixed function g:D×DD.
The domain D may be a feature space. The function ƒ may extract features of a program by taking features of subprograms and combining them using the aggregation function g. Several choices are to be made when designing a ranking function: the set of features that help define D, the aggregation function g, and the ordering on the domain. It can take many man-months to converge on a good ranking function. The ranking function of FlashFill has been fine-tuned over a long period of time, which has been crucial for its success.
The FlashFill++ programming by example system solves the ranking challenge in two ways: (1) using guarded context-free grammars as the grammar for the domain-specific language, and (2) using a holistic ranking function.
First, the use of a guarded context-free grammar as the underlying grammar for the domain-specific language helps substantially by encoding some high-level ranking preferences. For example, if we have a guarded rule, say S1→w1|>w2, then this implicitly encodes the preference for any subprogram generated by w1 over any subprogram generated by w2. Consequently, the ranking function need not necessarily compare a subprogram generated by w1 with a subprogram generated by w2. The ranking function can thus be much simpler. The following theorem formally states this property.
Let G be an unambiguous guarded context-free grammar. Let S1 and S2 be two strings such that if S1 is generated as X→w1→*s1, then S2 is generated as X→w2→*s2, and X→w1X→w2. Then, for any substrings S1, Sr, S′r, the strings S1, S1, Sr and S1, S2, S′r cannot both have derivations in context L, for any L.
Second, the ranking function for FlashFill++ is not built directly from subprograms. Instead, it is a simple average of the scores of the leaf (literal and variable) nodes plus a penalty computed for each operator (not considering its arguments or context) and literal value. This simplifies writing the ranking function as how to combine the values does not have to be considered carefully, and each piece of the domain-specific language is ranked independently.
The Codex ranking function may fail a monotonicity criterion that requires the ranking function ƒ to satisfy the property: if ƒ(w)>ƒ(w′), then ƒ(H (w))>ƒ(H (w′)) must hold for all domain-specific language operators H in order to guarantee that the true top-ranked program will get returned. In practice, it is sufficient to pad k when computing the top-k programs (e.g., request the top-5 when you really only care about the top-2 and the result will usually contain the true top-2 programs). In practice, monotonic ranking functions may be undesirable because they do not allow for the rank of a subprogram to depend strongly on the context in which the subprogram appears.
Consider a scenario in which a user is working with a table with many rows, and the user wants to derive a new column from the existing data. If the user does not know how to write a program to do so, the user may provide an example by filling the first cell of the empty new column. At this point, semantic idiomatic program synthesis logic (e.g., the semantic idiomatic program synthesis logic 606) may synthesize a computer program from the one input-output example. This computer program can be run on all the rows to fill the values in the new column.
The user can then verify that the values populated in the new column are correct. For example, the user may manually review all the rows to find one that is incorrect. In another example, the semantic idiomatic program synthesis logic may cause the generated readable code to be shown to the user, but this may assume that the user can understand the code and that the user understands the data well enough to notice edge cases potentially missed by the computer program. To help the user, the concept of significant inputs may be employed.
Information-theoretic principles may be used to define a significant input, which may be an input about whose output we are most uncertain. Let Pr:Σ*[0, 1] be a probability distribution over the set of valid programs. A internal state of the semantic idiomatic program synthesis logic can be modeled as such a probability distribution. The probability distribution represents the semantic idiomatic program synthesis logic's current belief of what the user wants, updated whenever the logic processes a new input-output (i,o) example. Given a set of input-examples E={(i1,o1), (i2,o2), . . . }, the notation Pr (.|E) represents the logic's state after processing E; in particular, Pr (p|E) is the probability of program p being the correct program after processing E.
Assume the synthesizer has processed the set E of input-output examples. Given an input i, let Pri(.|E) denote a probability distribution over the output space defined as: Pri(o|E)=ΣPr (p|E)
p∈Σ*,p(i)=o
The entropy En(Pr) of a probability distribution Pr over domain D is defined as Σd∈D−Pr (d) log(Pr (d)). An input i from a set Inputs is a significant input in a synthesizer state Pr (.|E) if i=argmaxi∈InputsEn(Pri(.|E)), where Pri(.|E) is defined as set forth above.
Entropy is a measure of uncertainty; higher values indicate more uncertainty. Intuitively, a significant input may be the input about whose output there is greatest uncertainty, given the knowledge of the input-output examples E.
Let Pr (.|E) model the state of the semantic idiomatic program synthesis logic after the logic processes the set E of input-output examples. Let i ∈ Inputs be a significant input in the state Pr (.|E). Then, En(Pr (.|E, (i, .)))≤En(Pr (.|E, (j, .))) for all j ∈ Inputs, where Pr (.|E, (j, .)) is a probability distribution over programs defined as Pr (p|E, (j, .))=Σo∈Outputs Pr (p|E, (j,o)).
The theorem above informally says that a program synthesizer will benefit the most (in terms of getting into a least entropy state) from the output for the input it is least certain about (the significant input). Note that this is a greedy algorithm for converging to the correct program. It may not be optimal because once the user provides the output for the (significant) input, the posterior probabilities change in unknown ways. Finding the globally smallest set of inputs to converge to the correct program can be shown to be NP-hard by a reduction from set cover. The greedy approach, based on entropy, works well in practice.
The probability distribution in the formalism may not exist explicitly in the internal state of most program synthesizers; however, the program synthesizers may generate many candidate programs and also have a ranking function that can order these candidates. This ranked list of candidates may be mapped into a probabilistic belief state. The set of candidates is only a sample of all valid programs given E, but that is sufficient for our purposes of estimating Pr (.|E).
In an example implementation, thresholding may be used to present only those significant inputs to the user whose uncertainty (entropy) measure is above a certain threshold. Not presenting significant inputs whose entropy is below the threshold to the user may be a way for the program synthesizer to indicate to the user that the program synthesizer is relatively confident about the correctness of the learned program.
The mobile device 1200 may include a processor 1210 (e.g., signal processor, microprocessor, ASIC, or other control and processing logic circuitry) for performing such tasks as signal coding, data processing, input/output processing, power control, and/or other functions. An operating system 1212 may control the allocation and usage of the components 1202 and support for one or more applications 1214 (a.k.a. application programs). The applications 1214 may include common mobile computing applications (e.g., email applications, calendars, contact managers, web browsers, messaging applications) and any other computing applications (e.g., word processing applications, mapping applications, media player applications).
The mobile device 1200 may include memory 1220. The memory 1220 may include non-removable memory 1222 and/or removable memory 1224. The non-removable memory 1222 may include RAM, ROM, flash memory, a hard disk, or other well-known memory storage technologies. The removable memory 1224 may include flash memory or a Subscriber Identity Module (SIM) card, which is well known in GSM communication systems, or other well-known memory storage technologies, such as “smart cards.” The memory 1220 may store data and/or code for running the operating system 1212 and the applications 1214. Example data may include web pages, text, images, sound files, video data, or other data sets to be sent to and/or received from one or more network servers or other devices via one or more wired or wireless networks. Memory 1220 may store a subscriber identifier, such as an International Mobile Subscriber Identity (IMSI), and an equipment identifier, such as an International Mobile Equipment Identifier (IMEI). Such identifiers may be transmitted to a network server to identify users and equipment.
The mobile device 1200 may support one or more input devices 1230, such as a touch screen 1232, microphone 1234, camera 1236, physical keyboard 1238 and/or trackball 1240 and one or more output devices 1250, such as a speaker 1252 and a display 1254. Touch screens, such as the touch screen 1232, may detect input in different ways. For example, capacitive touch screens detect touch input when an object (e.g., a fingertip) distorts or interrupts an electrical current running across the surface. As another example, touch screens may use optical sensors to detect touch input when beams from the optical sensors are interrupted. Physical contact with the surface of the screen is not necessary for input to be detected by some touch screens. For example, the touch screen 1232 may support a finger hover detection using capacitive sensing, as is well understood in the art. Other detection techniques may be used, including but not limited to camera-based detection and ultrasonic-based detection. To implement a finger hover, a user's finger is typically within a predetermined spaced distance above the touch screen, such as between 0.1 to 0.25 inches, or between 0.25 inches and 0.5 inches, or between 0.5 inches and 0.75 inches, or between 0.75 inches and 1 inch, or between 1 inch and 1.5 inches, etc.
The mobile device 1200 may include semantic idiomatic program synthesis logic 1292. The semantic idiomatic program synthesis logic 1292 is configured to synthesize a computer program to include idiomatic function(s) and semantically-meaningful variable(s) using programming by example in accordance with any one or more of the techniques described herein.
Other possible output devices (not shown) may include piezoelectric or other haptic output devices. Some devices may serve more than one input/output function. For example, touch screen 1232 and display 1254 may be combined in a single input/output device. The input devices 1230 may include a Natural User Interface (NUI). An NUI is any interface technology that enables a user to interact with a device in a “natural” manner, free from artificial constraints imposed by input devices such as mice, keyboards, remote controls, and the like. Examples of NUI methods include those relying on speech recognition, touch and stylus recognition, gesture recognition both on screen and adjacent to the screen, air gestures, head and eye tracking, voice and speech, vision, touch, gestures, and machine intelligence. Other examples of a NUI include motion gesture detection using accelerometers/gyroscopes, facial recognition, 3D displays, head, eye, and gaze tracking, immersive augmented reality and virtual reality systems, all of which provide a more natural interface, as well as technologies for sensing brain activity using electric field sensing electrodes (EEG and related methods). Thus, in one specific example, the operating system 1212 or applications 1214 may include speech-recognition software as part of a voice control interface that allows a user to operate the mobile device 1200 via voice commands. Furthermore, the mobile device 1200 may include input devices and software that allows for user interaction via a user's spatial gestures, such as detecting and interpreting gestures to provide input to a gaming application.
Wireless modem(s) 1270 may be coupled to antenna(s) (not shown) and may support two-way communications between the processor 1210 and external devices, as is well understood in the art. The modem(s) 1270 are shown generically and may include a cellular modem 1276 for communicating with the mobile communication network 1204 and/or other radio-based modems (e.g., Bluetooth® 1274 and/or Wi-Fi 1272). At least one of the wireless modem(s) 1270 is typically configured for communication with one or more cellular networks, such as a GSM network for data and voice communications within a single cellular network, between cellular networks, or between the mobile device and a public switched telephone network (PSTN).
The mobile device may further include at least one input/output port 1280, a power supply 1282, a satellite navigation system receiver 1284, such as a Global Positioning System (GPS) receiver, an accelerometer 1286, and/or a physical connector 1290, which may be a USB port, IEEE 1394 (FireWire) port, and/or RS-232 port. The illustrated components 1202 are not required or all-inclusive, as any components may be deleted and other components may be added as would be recognized by one skilled in the art.
Although the operations of some of the disclosed methods are described in a particular, sequential order for convenient presentation, it should be understood that this manner of description encompasses rearrangement, unless a particular ordering is required by specific language set forth herein. For example, operations described sequentially may in some cases be rearranged or performed concurrently. Moreover, for the sake of simplicity, the attached figures may not show the various ways in which the disclosed methods may be used in conjunction with other methods.
Any one or more of the semantic idiomatic program synthesis logic 108, the semantic idiomatic program synthesis logic 608, the intent logic 612, the program generation logic 614, the replacement logic 616, the display logic 618, the pre-trained language model 620, the ranking logic 622, the selection logic 624, the semantic idiomatic program synthesis logic 1292, flowchart 200, flowchart 300, flowchart 400, and/or flowchart 500 may be implemented in hardware, software, firmware, or any combination thereof.
For example, any one or more of the semantic idiomatic program synthesis logic 108, the semantic idiomatic program synthesis logic 608, the intent logic 612, the program generation logic 614, the replacement logic 616, the display logic 618, the pre-trained language model 620, the ranking logic 622, the selection logic 624, the semantic idiomatic program synthesis logic 1292, flowchart 200, flowchart 300, flowchart 400, and/or flowchart 500 may be implemented, at least in part, as computer program code configured to be executed in one or more processors.
In another example, any one or more of the semantic idiomatic program synthesis logic 108, the semantic idiomatic program synthesis logic 608, the intent logic 612, the program generation logic 614, the replacement logic 616, the display logic 618, the pre-trained language model 620, the ranking logic 622, the selection logic 624, the semantic idiomatic program synthesis logic 1292, flowchart 200, flowchart 300, flowchart 400, and/or flowchart 500 may be implemented, at least in part, as hardware logic/electrical circuitry. Such hardware logic/electrical circuitry may include one or more hardware logic components. Examples of a hardware logic component include but are not limited to a field-programmable gate array (FPGA), an application-specific integrated circuit (ASIC), an application-specific standard product (ASSP), a system-on-a-chip system (SoC), a complex programmable logic device (CPLD), etc. For instance, a SoC may include an integrated circuit chip that includes one or more of a processor (e.g., a microcontroller, microprocessor, digital signal processor (DSP), etc.), memory, one or more communication interfaces, and/or further circuits and/or embedded firmware to perform its functions.
As shown in
Computer 900 also has one or more of the following drives: a hard disk drive 914 for reading from and writing to a hard disk, a magnetic disk drive 916 for reading from or writing to a removable magnetic disk 918, and an optical disk drive 920 for reading from or writing to a removable optical disk 922 such as a CD ROM, DVD ROM, or other optical media. Hard disk drive 914, magnetic disk drive 916, and optical disk drive 920 are connected to bus 906 by a hard disk drive interface 924, a magnetic disk drive interface 926, and an optical drive interface 928, respectively. The drives and their associated computer-readable storage media provide nonvolatile storage of computer-readable instructions, data structures, program modules and other data for the computer. Although a hard disk, a removable magnetic disk and a removable optical disk are described, other types of computer-readable storage media can be used to store data, such as flash memory cards, digital video disks, random access memories (RAMs), read only memories (ROM), and the like.
A number of program modules may be stored on the hard disk, magnetic disk, optical disk, ROM, or RAM. These programs include an operating system 930, one or more application programs 932, other program modules 934, and program data 936. Application programs 932 or program modules 934 may include, for example, computer program logic for implementing any one or more of (e.g., at least a portion of) the semantic idiomatic program synthesis logic 108, the semantic idiomatic program synthesis logic 608, the intent logic 612, the program generation logic 614, the replacement logic 616, the display logic 618, the pre-trained language model 620, the ranking logic 622, the selection logic 624, the semantic idiomatic program synthesis logic 1292, flowchart 200 (including any step of flowchart 200), flowchart 300 (including any step of flowchart 300), flowchart 400 (including any step of flowchart 400), and/or flowchart 500 (including any step of flowchart 500), as described herein.
A user may enter commands and information into the computer 900 through input devices such as keyboard 938 and pointing device 940. Other input devices (not shown) may include a microphone, joystick, game pad, satellite dish, scanner, touch screen, camera, accelerometer, gyroscope, or the like. These and other input devices are often connected to the processing unit 902 through a serial port interface 942 that is coupled to bus 906, but may be connected by other interfaces, such as a parallel port, game port, or a universal serial bus (USB).
A display device 944 (e.g., a monitor) is also connected to bus 906 via an interface, such as a video adapter 946. In addition to display device 944, computer 900 may include other peripheral output devices (not shown) such as speakers and printers.
Computer 900 is connected to a network 948 (e.g., the Internet) through a network interface or adapter 950, a modem 952, or other means for establishing communications over the network. Modem 952, which may be internal or external, is connected to bus 906 via serial port interface 942.
As used herein, the terms “computer program medium” and “computer-readable storage medium” are used to generally refer to media (e.g., non-transitory media) such as the hard disk associated with hard disk drive 914, removable magnetic disk 918, removable optical disk 922, as well as other media such as flash memory cards, digital video disks, random access memories (RAMs), read only memories (ROM), and the like. A computer-readable storage medium is not a signal, such as a carrier signal or a propagating signal. For instance, a computer-readable storage medium may not include a signal. Accordingly, a computer-readable storage medium does not constitute a signal per se. Such computer-readable storage media are distinguished from and non-overlapping with communication media (do not include communication media). Communication media embodies computer-readable instructions, data structures, program modules or other data in a modulated data signal such as a carrier wave. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wireless media such as acoustic, RF, infrared and other wireless media, as well as wired media. Example embodiments are also directed to such communication media.
As noted above, computer programs and modules (including application programs 932 and other program modules 934) may be stored on the hard disk, magnetic disk, optical disk, ROM, or RAM. Such computer programs may also be received via network interface 950 or serial port interface 942. Such computer programs, when executed or loaded by an application, enable computer 900 to implement features of embodiments discussed herein. Accordingly, such computer programs represent controllers of the computer 900.
Example embodiments are also directed to computer program products comprising software (e.g., computer-readable instructions) stored on any computer-useable medium. Such software, when executed in one or more data processing devices, causes data processing device(s) to operate as described herein. Embodiments may employ any computer-useable or computer-readable medium, known now or in the future. Examples of computer-readable mediums include, but are not limited to storage devices such as RAM, hard drives, floppy disks, CD ROMs, DVD ROMs, zip disks, tapes, magnetic storage devices, optical storage devices, MEMS-based storage devices, nanotechnology-based storage devices, and the like.
It will be recognized that the disclosed technologies are not limited to any particular computer or type of hardware. Certain details of suitable computers and hardware are well known and need not be set forth in detail in this disclosure.
Although the subject matter has been described in language specific to structural features and/or acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the specific features or acts described above. Rather, the specific features and acts described above are disclosed as examples of implementing the claims, and other equivalent features and acts are intended to be within the scope of the claims.