91精品国产91久久久久久_国产精品二区一区二区aⅴ污介绍_一本久久a久久精品vr综合_亚洲视频一区二区三区

合肥生活安徽新聞合肥交通合肥房產生活服務合肥教育合肥招聘合肥旅游文化藝術合肥美食合肥地圖合肥社保合肥醫院企業服務合肥法律

CMPT 489代做、Program Synthesis編程設計代寫

時間:2023-12-07  來源:合肥網hfw.cc  作者:hfw.cc 我要糾錯



CMPT 489 / 980 Program Synthesis
Final Project
Phase I is due by 11:59pm PT on Wednesday Nov 8, 2023. Phase II is due by 11:59pm PT on Tuesday
Dec 5, 2023. Please submit them to Canvas on time. No late submission is accepted.
Requirements:
• This project must be your own work. No collaboration is permitted.
• The programming language of this project is Java 11.
• You can learn the code on slides and start from it.
• You can use third-party libraries but not existing synthesizers. However, you can implement the
algorithms in existing synthesizers by yourself.
1 Problem Description
Consider the following context-free grammar G
E ::= Ite(B, E, E) | Add(E, E) | Multiply(E, E) | x | y | z | 1 | 2 | 3
B ::= Lt(E, E) | Eq(E, E) | And(B, B) | Or(B, B) | Not(B)
x, y, z ∈ Variables 1, 2, 3 ∈ Constants
Here, E is the start symbol. E and B are non-terminals; all other symbols are terminals. The meaning
of terminal symbols are self-explanatory. Specifically, Ite is the if-then-else operator. Add is the addition
(+) operator. Multiply is the multiplication (∗) operator. x, y, z are integer variables. 1, 2, 3 are integer
constants. Lt is the less-than (<) operator. Eq is the equals (==) operator. And is the logical conjunction
(&&). Or is the logical disjunction (||). Not is the logical negation (!).
In this project, you need to write an example-based program synthesizer in Java. Specifically, the
synthesizer takes as input a list of input-output examples and the context-free grammar G and produces
as output an implementation of f(x, y, z) in the language of G such that f(x, y, z) is consistent with the
provided examples. You can assume f only uses three variables x, y, z, and all their types are Int. The return
type of f is also Int. If the synthesis succeeds, your program should print the program, e.g., Add(Add(y,
z), x), to the console. Otherwise, if the synthesis fails, the program should print null.
2 Codebase
A codebase is provided as the starting point. It contains the basic framework for the synthesizer. Details
are explained as follows.
Package synth.cfg
This package defines the data structure for the context-free grammar (CFG). It has the following classes
• Symbol. An abstract class for symbols in the CFG.
• Terminal. A subclass of Symbol that corresponds to terminals in the CFG.
• NonTerminal. A subclass of Symbol that corresponds to non-terminals in the CFG.
1
• Production. A class for productions in the CFG. A production is of the form
ReturnSymbol ::= Operator(ArgSymbol, ..., ArgSymbol)
• CFG. A class for representing the CFG. The most important method is getProductions, which takes
as input a non-terminal symbol N and returns as output a list of all productions with N being the
left-hand-side of the production.
Package synth.core
This package contains the classes for synthesizers, examples, programs, and interpreters.
• ASTNode. A class for general Abstract Syntax Tree (AST) nodes. The symbol fields corresponds to
the symbol in the CFG. The children field corresponds to the children nodes.
• Program. A class for representing a program. It only has one field root, which is the root node of the
corresponding AST.
• Example. A class that defines the data structure of an example. The input field is a map from variable
names to their values. The output field is the output value.
• Interpreter. A class that defines an interpreter of the language of G. The most important method
is the static method evaluate, which takes as input a program and an environment and returns as
output the evaluation result. The environment is essentially a map from variable names to their values,
just like the input field of Example. Concrete examples on how to use Interpreter.evaluate are
provided in the test class synth.core.InterpreterTests.
• ISynthesizer. An interface that defines the input and output of a synthesizer. The inputs are a CFG
and a list of examples. The output is a program.
• TopDownEnumSynthesizer. A top-down enumerative synthesizer that implements the ISynthesizer
interface. You need to implement this class.
Package synth.util
This package contains the utility classes and methods.
• FileUtils. A class for file operations. The readLinesFromFile static method reads a file into a list
of strings, where each line of the file is a string.
• Parser. A class for parsing the examples. The parseAnExample static method parses text of the form
“x=a, y=b, z=c -> d” to an object of class Example. The parseAllExamples static method parses
a list of examples from a list of strings, where each string corresponds to an example. It ignores empty
strings.
Class synth.Main
The main class of the framework. It has two methods.
• main. It is the entry of the program. It takes one command-line argument args[0] for the path to
the examples file.
• buildCFG. It builds the CFG G in Section 1.
Tests
JUnit tests are provided in the src/test directory. You are welcome to add more!
• synth.core.InterpreterTests. It contains several unit tests for the interpreter, which is also helpful
for understanding the usage of the interpreter.
2
Other Files
• pom.xml. The configuration file for Maven.
• examples.txt. A sample examples file.
3 Compilation and Execution
Compilation. This codebase uses the Maven build system. Suppose you enter the Synth directory, the
project can be easily compiled with one command
$ mvn package
Then you should be able to see the message “BUILD SUCCESS”. A directory called target will be created
and a jar file called synth-1.0.jar will be generated inside the target.
Execution. In the Synth directory, you can execute the program using the following command (use ;
instead of : in Windows)
$ java -cp lib:target/synth-1.0.jar synth.Main <path-to-examples-file>
where <path-to-examples-file> is the path to the examples file. For example, you can run
$ java -cp lib:target/synth-1.0.jar synth.Main examples.txt
You will see a runtime exception with message “To be implemented”, because the synthesizer is not implemented yet. After you finish implementing the synthesizer, you should see something like (not unique)
Add(Add(y, z), x)
4 Phase I
In Phase I, you need to implement a top-down enumerative synthesizer in synth.core.TopDownEnumSynthesizer.
Deliverable
A zip file called Phase1 Firstname Lastname.zip that contains at least the followings:
• The entire Synth directory. You can change existing code if you want, but please make sure the project
can be compiled and executed as explained in Section 3.
• A short report (**2 pages) called Phase1 Firstname Lastname.pdf that explains the design choices,
features, tests, issues (if any), and anything else that you want to explain about your program.
5 Phase II
In Phase II, you can implement any synthesis algorithm that improves the performance of the synthesizer on
the same problem. You also need to create a small benchmark set and evaluate your algorithm
over the benchmarks.
A zip file called Phase2 Firstname Lastname.zip that contains at least the followings:
• The entire Synth directory. You can change existing code if you want, but please make sure the project
can be compiled and executed as explained in Section 3.
• A long report (5-6 pages) called Phase2 Firstname Lastname.pdf that explains the algorithms,
benchmarks, evaluation results, design choices, features, tests, issues (if any), and anything else
that you want to explain about your program.
請加QQ:99515681 或郵箱:99515681@qq.com   WX:codehelp

掃一掃在手機打開當前頁
  • 上一篇:CS 202代寫、代做Operating Systems設計
  • 下一篇:CPT109程序代做、代寫C/C++編程語言
  • 無相關信息
    合肥生活資訊

    合肥圖文信息
    2025年10月份更新拼多多改銷助手小象助手多多出評軟件
    2025年10月份更新拼多多改銷助手小象助手多
    有限元分析 CAE仿真分析服務-企業/產品研發/客戶要求/設計優化
    有限元分析 CAE仿真分析服務-企業/產品研發
    急尋熱仿真分析?代做熱仿真服務+熱設計優化
    急尋熱仿真分析?代做熱仿真服務+熱設計優化
    出評 開團工具
    出評 開團工具
    挖掘機濾芯提升發動機性能
    挖掘機濾芯提升發動機性能
    海信羅馬假日洗衣機亮相AWE  復古美學與現代科技完美結合
    海信羅馬假日洗衣機亮相AWE 復古美學與現代
    合肥機場巴士4號線
    合肥機場巴士4號線
    合肥機場巴士3號線
    合肥機場巴士3號線
  • 短信驗證碼 目錄網 排行網

    關于我們 | 打賞支持 | 廣告服務 | 聯系我們 | 網站地圖 | 免責聲明 | 幫助中心 | 友情鏈接 |

    Copyright © 2025 hfw.cc Inc. All Rights Reserved. 合肥網 版權所有
    ICP備06013414號-3 公安備 42010502001045

    91精品国产91久久久久久_国产精品二区一区二区aⅴ污介绍_一本久久a久久精品vr综合_亚洲视频一区二区三区
    秋霞影院一区二区| 91麻豆免费视频| 亚洲二区在线视频| 久久只精品国产| 日韩精品一区二区三区老鸭窝| 欧美精品在线观看一区二区| 欧美这里有精品| 欧美日韩美女一区二区| 欧美性一二三区| 欧美日韩国产高清一区| 欧美精品v国产精品v日韩精品| 91久久人澡人人添人人爽欧美| 欧美亚洲免费| 色94色欧美sute亚洲线路一ni | 韩国女主播成人在线| 久久aⅴ国产欧美74aaa| 国产一区二区看久久| 国产91高潮流白浆在线麻豆| 成人激情黄色小说| 欧美不卡在线| 国产一区导航| 欧美三级中文字| 日韩免费高清视频| 中文字幕二三区不卡| 最好看的中文字幕久久| 一区二区欧美国产| 玖玖九九国产精品| 高清视频一区二区| 欧美精品一区二区三区在线看午夜| 在线免费观看欧美| 久久蜜桃资源一区二区老牛| 欧美久久一区二区| 久久久久久久久伊人| 一区二区欧美精品| 久久疯狂做爰流白浆xx| 成人黄色一级视频| 黑人巨大精品欧美一区二区小视频| 99精品视频免费全部在线| 91黄色免费看| 精品三级在线看| 亚洲精品国久久99热| 狠狠v欧美v日韩v亚洲ⅴ| 91蝌蚪porny| 国产精品夜夜夜一区二区三区尤| 欧美精品一级二级| 国产精品日日摸夜夜摸av| 日本亚洲三级在线| 99热在这里有精品免费| 欧美资源在线| 26uuu色噜噜精品一区二区| 一区二区三区 在线观看视频| 国内外精品视频| 在线观看成人av电影| 欧美在线播放高清精品| 国产女主播一区| 日韩和欧美的一区| 欧美国产先锋| 在线精品视频一区二区三四 | 偷拍日韩校园综合在线| 91在线一区二区三区| 午夜一级久久| 国产欧美一区二区精品婷婷| 热久久一区二区| 色综合欧美在线| 欧美日韩国产天堂| 亚洲综合一区二区三区| 91丨porny丨户外露出| 91黄色免费网站| 亚洲欧美视频在线观看| 成人激情开心网| 欧美日韩日日摸| 午夜欧美在线一二页| 欧美性大战久久久久| 日韩视频免费观看高清在线视频| 亚洲午夜激情网页| 欧美日韩国产一区精品一区| 精品视频资源站| 午夜精品久久久久影视| 欧美日本国产| 亚洲精品一区二区三区福利| 国产精品香蕉一区二区三区| 尤物在线精品| 国产日韩精品一区二区三区| 国产一二三精品| 色呦呦国产精品| 午夜久久福利影院| 日韩亚洲国产欧美| 国产精品二区一区二区aⅴ污介绍| 懂色av中文字幕一区二区三区 | 国产精品人妖ts系列视频| 国产成人在线视频网站| 欧美午夜免费电影| 亚洲成人免费观看| 国产日韩欧美三区| 亚洲视频一二三| 国内精品视频在线播放| 国产精品色呦呦| 欧美在线播放一区| 精品动漫一区二区三区在线观看| 国产一区二区在线视频| 欧美日韩视频一区二区| 开心九九激情九九欧美日韩精美视频电影 | 国产乱码精品一区二区三区忘忧草 | 欧美专区日韩专区| 日韩二区三区四区| 欧美在线三级电影| 美女诱惑一区二区| 欧洲一区在线观看| 国产乱码精品1区2区3区| 欧美日本一区二区三区四区| 美女mm1313爽爽久久久蜜臀| 欧美日韩中文字幕一区二区| 久久99久久久久| 欧美日韩国产首页| 精品中文字幕一区二区| 日韩一卡二卡三卡四卡| a美女胸又www黄视频久久| 欧美精品一区二区久久婷婷| 99国产精品一区| 国产精品久久久久aaaa樱花| 亚洲免费黄色| 肉肉av福利一精品导航| 欧美日韩国产首页| 成人av在线电影| 国产精品欧美一级免费| 国产美女诱惑一区二区| 免费成人av资源网| 日韩写真欧美这视频| 欧美一区亚洲| 亚洲图片欧美综合| 欧美日韩aaaaa| 色综合久久中文字幕综合网| 亚洲图片另类小说| 91久久精品一区二区三区| 国产高清视频一区| 国产欧美精品日韩区二区麻豆天美| 亚洲午夜精品久久久久久浪潮| 亚洲午夜精品网| 欧美一区二区三区思思人| 91麻豆精品在线观看| 亚洲国产欧美日韩另类综合| 欧美影片第一页| 国产日韩一区二区| 久久精品久久综合| 国产三级精品三级| 国产美女在线精品免费观看| 国产精品77777竹菊影视小说| 国产区在线观看成人精品| 美女视频一区免费观看| 国产白丝网站精品污在线入口| 国产精品免费观看视频| 欧美三级乱人伦电影| 91视视频在线观看入口直接观看www| 亚洲精品你懂的| 欧美精品久久一区| 韩日精品视频| 九色porny丨国产精品| 国产精品网站在线播放| 欧美亚洲国产怡红院影院| 欧美日韩国产亚洲一区| 日产国产高清一区二区三区 | 福利一区在线观看| 亚洲综合在线免费观看| 欧美精品一区二区三区久久久| 久久久精品性| 欧美日韩在线不卡一区| 国产揄拍国内精品对白| 亚洲影院理伦片| 国产色产综合产在线视频| 精品视频在线看| 国产精品区免费视频| 欧美人与禽性xxxxx杂性| 国产乱子伦视频一区二区三区| 洋洋成人永久网站入口| 国产日产欧美一区二区三区| 欧美亚洲日本国产| 亚洲深夜福利| 国内不卡一区二区三区| 不卡一区在线观看| 久久69国产一区二区蜜臀| 亚洲最快最全在线视频| 欧美国产1区2区| 精品久久久久久综合日本欧美| 色播五月激情综合网| 99精品视频免费观看视频| 欧美黄色一区| 成人av在线看| 国产成人午夜视频| 久久国产精品72免费观看| 亚洲国产成人高清精品| 依依成人精品视频| 中国av一区二区三区| 精品国产乱码久久久久久老虎| 欧美色国产精品| 色偷偷成人一区二区三区91| 国产精品亚洲综合色区韩国| 亚洲国产精品久久久久久女王| 午夜国产精品视频免费体验区| a4yy欧美一区二区三区| 高清国产一区二区|