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综合_亚洲视频一区二区三区
    亚洲女子a中天字幕| 国产精品激情电影| 国产精品久久久久影院亚瑟| 日韩一级二级三级| 欧美视频一区二区三区| 久久婷婷丁香| 色婷婷av一区二区三区大白胸| 欧美日韩国产综合视频在线观看| 一本色道a无线码一区v| 久久久夜精品| 91福利视频网站| 欧美色网站导航| 91精品国产综合久久蜜臀| 日本乱人伦aⅴ精品| 欧美色爱综合网| 欧美三级电影网站| 欧美军同video69gay| 欧美日韩电影一区| 欧美一区二区视频在线观看2022 | 欧美在线3区| 欧美日韩日本国产亚洲在线| 国产精品a级| 亚洲国产专区| 国产区二精品视| 日本道免费精品一区二区三区| 欧美体内she精视频| 日韩视频一区在线观看| 色噜噜偷拍精品综合在线| 伊人精品成人久久综合软件| 免费久久精品视频| 狠狠狠色丁香婷婷综合激情| 国产高清精品久久久久| 92精品国产成人观看免费| 欧美三级网页| 国产视频一区欧美| 欧美精品三级在线观看| 精品久久久网站| 欧美激情一区二区| 性做久久久久久免费观看欧美| 亚洲va欧美va人人爽午夜| 美腿丝袜亚洲综合| 国产sm精品调教视频网站| 欧美一区91| 久久精品欧洲| 久久新电视剧免费观看| 亚洲一区在线观看视频| 国产精品一品二品| 国产成人av电影免费在线观看| 韩国女主播一区| 9191久久久久久久久久久| 久久狠狠婷婷| 日韩精品一区二区三区视频播放 | 中文字幕一区二区三| 日日欢夜夜爽一区| 色综合天天视频在线观看| 亚洲影院免费| 久久女同性恋中文字幕| 亚洲综合网站在线观看| 国产一区二区三区四区在线观看| 久久99国产精品麻豆| 久久国产精品无码网站| 国产一区二区精品久久91| 欧美在线亚洲| 国产伦精品一区二区三区视频青涩| 欧美日韩国产首页在线观看| 久久精品72免费观看| 国产精品久久久一区二区| 一本色道综合亚洲| 国产精品高潮呻吟| 成人18精品视频| 国产一区二三区| 亚洲国产精品一区二区久久恐怖片| 欧美成人免费网站| 亚洲精品欧美综合四区| 亚洲欧美成aⅴ人在线观看| 久热这里只精品99re8久| 欧美一区二区在线免费播放| 一片黄亚洲嫩模| 蜜臀av性久久久久蜜臀aⅴ流畅| 国产福利一区二区三区在线视频| 91欧美一区二区| 欧美日韩亚州综合| 国产精品久久福利| 激情综合一区二区三区| 国产午夜精品一区二区三区欧美| 欧美精品播放| 国产高清在线精品| 女人色偷偷aa久久天堂| 久久久久久久久久久久久9999| 国产色产综合色产在线视频| 日韩一区欧美二区| 国产精品永久| 1000精品久久久久久久久| 欧美一区免费视频| 精品国产第一区二区三区观看体验| 久久99深爱久久99精品| 久久久久成人精品免费播放动漫| 日韩理论电影院| 欧美.www| 国产日韩影视精品| 美国精品在线观看| 久久一区欧美| 亚洲欧洲一区二区在线播放| 色综合亚洲欧洲| 日韩免费看网站| 日本美女一区二区三区视频| 国产一区二区三区高清| 国产精品三级av在线播放| 高清国产一区二区| 欧美一级一级性生活免费录像| 精品一区二区三区欧美| 久久婷婷人人澡人人喊人人爽| 洋洋av久久久久久久一区| 国产精品久久久免费| 亚洲精品乱码久久久久久黑人 | 亚洲一区精品视频| 亚洲永久免费av| 一本综合精品| 夜夜精品视频一区二区| 久久久久国内| 国产精品1区二区.| 日韩精品中文字幕一区| 99久久国产综合色|国产精品| 国产欧美一区二区三区沐欲| 午夜久久美女| 亚洲综合色婷婷| 在线观看日韩精品| 日韩不卡在线观看日韩不卡视频| 色婷婷一区二区三区四区| 美女一区二区三区| 欧美日韩国产片| 波多野结衣亚洲一区| xfplay精品久久| 亚洲国产婷婷| 麻豆精品一区二区综合av| 久久天天狠狠| 国产成人免费视频| 国产精品高清亚洲| 在线一区二区三区四区五区| 国产精品一区二区不卡| 精品视频一区 二区 三区| 国产一区二区三区香蕉| 成人精品亚洲人成在线| 欧美精品一区二区高清在线观看 | 国产日韩欧美精品| 国产在线精品免费| 国产欧美一区二区精品忘忧草| a91a精品视频在线观看| 精品在线播放午夜| 亚洲国产精品av| 在线观看av不卡| 欧美国产视频在线观看| 一区二区三区资源| 欧美日韩精品欧美日韩精品一 | 99麻豆久久久国产精品免费优播| 日韩美女视频19| 欧美日韩一区二区三区四区五区 | 波多野结衣一区二区三区| 亚洲va中文字幕| 久久久久久日产精品| 在线影院国内精品| 91麻豆自制传媒国产之光| 五月天激情小说综合| 国产日韩亚洲欧美综合| 在线观看免费视频综合| 亚洲第一黄色| 成人激情动漫在线观看| 老司机午夜精品| 国产日本一区二区| 欧美久久久久久久久久| 国产精品国色综合久久| 国产成人在线看| 日本亚洲天堂网| 亚洲欧美一区二区三区极速播放 | 国产福利91精品一区二区三区| 亚洲欧洲另类国产综合| 欧美综合在线视频| 激情久久一区| kk眼镜猥琐国模调教系列一区二区| 亚洲精品欧美二区三区中文字幕| 久久精品欧美日韩精品 | 秋霞午夜av一区二区三区 | 成年人网站91| 日本不卡不码高清免费观看 | 国内成人在线| 国产精品一级在线| 蜜臀av国产精品久久久久| 亚洲视频一区二区在线| 久久亚洲精华国产精华液| 精品少妇一区二区三区免费观看| 久久国产毛片| 国产日产高清欧美一区二区三区| 91视频com| 波波电影院一区二区三区| 国产中文字幕一区| 蜜臀av一区二区在线观看 | 一个色在线综合| 久久蜜臀中文字幕| 精品日韩欧美在线| 欧美videos大乳护士334|