加勒比久久综合,国产精品伦一区二区,66精品视频在线观看,一区二区电影

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

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

    极品尤物一区| 爱啪啪综合导航| 警花av一区二区三区| 国产亚洲一区二区手机在线观看| 国内精品福利| 秋霞一区二区| 91精品国产一区二区在线观看| 国产免费拔擦拔擦8x在线播放 | 成人四虎影院| 国产美女精品| 亚洲小说区图片区| 精品久久国产一区| 亚洲色图88| 久久亚洲精品人成综合网| 久热re这里精品视频在线6| 99tv成人| 美女国产精品久久久| 高清一区二区| 欧美亚洲在线| 亚洲成a人片| 欧美残忍xxxx极端| 亚洲专区一区二区三区| 开心激情综合| av男人一区| 日韩三级av| 国产探花一区| 99久久久国产| 欧美日韩中文| 日本视频免费一区| 久久精品国产精品亚洲毛片| 天堂av在线网| 裤袜国产欧美精品一区| 亚洲在线播放| 一区在线视频观看| 成人a'v在线播放| 欧美一级精品片在线看| 国产 日韩 欧美 综合 一区| 精品视频国内| 日韩va亚洲va欧美va久久| 高清久久精品| av在线播放一区二区| 另类小说视频一区二区| 久久国产人妖系列| 久久久久久一区二区三区四区别墅| 日韩免费特黄一二三区| 成人欧美一区二区三区的电影| 蜜臀av在线播放一区二区三区| 最新国产乱人伦偷精品免费网站| 蜜桃成人av| 狠狠爱成人网| 免播放器亚洲| 噜噜噜躁狠狠躁狠狠精品视频| 一本色道88久久加勒比精品| 国产亚洲福利| 美女精品在线| 男人的天堂久久精品| 日韩影院精彩在线| 成人一级福利| av亚洲一区二区三区| 成人国产综合| 麻豆精品视频在线观看免费| 日本视频在线一区| 99久热在线精品视频观看| 国产免费av一区二区三区| 日韩av中文字幕一区| 午夜视频一区二区在线观看| 国内视频在线精品| 亚洲午夜久久久久久尤物| 午夜精品亚洲| 鲁大师成人一区二区三区| 成人一级福利| 成人国产一区| 国内揄拍国内精品久久| 日韩高清成人在线| 精品国内亚洲2022精品成人| 激情欧美一区二区三区| 午夜一区在线| 欧产日产国产精品视频| 日韩综合在线视频| 希岛爱理av免费一区二区| 欧美三级第一页| 黑人操亚洲人| 国产精品久久观看| 欧美v亚洲v综合v国产v仙踪林| 一区二区三区四区日韩| 日韩av在线发布| 久久久五月天| 免费看黄色91| www.26天天久久天堂| 伊人久久大香伊蕉在人线观看热v| 日韩成人在线看| 国产99久久久国产精品成人免费 | 999在线精品| 性欧美欧美巨大69| 大桥未久在线视频| 日本不卡视频在线| 秋霞一区二区| 最新日韩av| 亚洲爱爱视频| 亚洲盗摄视频| 国产中文一区| 中文在线а√在线8| 欧美日韩 国产精品| 9l视频自拍蝌蚪9l视频成人| 伊人成人在线视频| 成人国产精品入口免费视频| 国产欧美欧美| 欧美精选一区二区三区| 色网在线免费观看| 国产精品99久久免费| 久久国产中文字幕| 欧美激情电影| 国产精品日本一区二区不卡视频| 美女网站色精品尤物极品姐弟| 视频一区欧美精品| 日本美女一区二区三区视频| 粉嫩久久久久久久极品| 日本午夜一区| 国产精品分类| 亚洲网站啪啪| 亚洲成a人片777777久久| 日本一不卡视频| 免费日韩一区二区| 毛片一区二区三区| 久久精品亚洲人成影院 | 欧美日本精品| 欧美一区三区| 久久精品资源| 清纯唯美亚洲综合一区| 操人在线观看| 香蕉国产成人午夜av影院| 亚洲欧美日韩国产| 91精品麻豆| 黑丝一区二区三区| 亚洲天天影视网| 狠狠操综合网| 日本特黄久久久高潮| 国产99久久| 日韩高清在线观看| 欧美一区2区| 欧美a一区二区| 自拍亚洲一区| 亚洲精品乱码久久久久久蜜桃麻豆| 久久久夜夜夜| 久久精品网址| 亚洲激精日韩激精欧美精品| 亚洲五月综合| 在线亚洲伦理| 国色天香久久精品国产一区| 亚洲欧美日韩精品一区二区 | 在线观看日韩| 欧美日本国产| 国产视频一区在线观看一区免费| 综合久久99| 亚洲综合精品四区| 西野翔中文久久精品字幕| 波多野一区二区| av男人一区| 久久精品久久久精品美女| 欧美一二区在线观看| 亚洲日本视频| 日韩专区在线视频| 亚洲免费一区三区| 亚洲国产精选| 一区二区三区视频免费观看| 麻豆国产精品视频| 制服诱惑一区二区| 亚洲第一二三区| 男人天堂视频在线观看| 欧美午夜精彩| 国产亚洲精品美女久久久久久久久久| 免费人成在线不卡| 国产伦理久久久久久妇女| 美女视频一区二区| 国产亚洲精品v| 911亚洲精品| 四虎精品一区二区免费| 伊人久久亚洲影院| 视频精品国内| 三级成人在线视频| 噜噜噜在线观看免费视频日韩| 7m精品国产导航在线| 色综合久久久| 午夜亚洲视频| 日本电影一区二区| 一区二区在线| 日本免费久久| 最新日韩欧美| 日韩亚洲精品在线观看| 免费在线观看成人av| 爽成人777777婷婷| 久久久777| 久久99国产精品视频| 天堂久久一区| 蜜臀久久99精品久久久久宅男| 久久精品观看| 日韩av一区二区在线影视| 国产日韩一区| 欧洲av一区二区| 老司机精品视频网站|