首页
网站开发
桌面应用
管理软件
微信开发
App开发
嵌入式软件
工具软件
数据采集与分析
其他
首页
>
> 详细
program代做、Python设计程序代写
项目预算:
开发周期:
发布时间:
要求地区:
Part 1: Fork and Set Up the Repository
1. Please fork the GitHub repository located at https://github.com/CambioML/uniflow
2. Clone your forked repository to your local machine.
3. When you finish this interview question, share you forked GitHub repo for review.
2
Part 2: Setup dev environment and understand basic flow
1. You need to setup your dev environment
a. create a conda dev environment and activate it.
b. install poetry through pip install poetry
c. cd into uniflow root folder and install all uniflow dependency through poetry
install --no-root . This will install all dependencies under in pyproject.toml.
2. understand the basic copy flow which is doing nothing but copy the input as output
using a copy_op.
3. each Op for example copy_op takes one or more nodes as input and output one or
more nodes. Each node hold has a value_dict to hold the value.
4. Before exit a flow, value_dict is extracted from the node and return as flow output
with root node for viz.
5. Flow client interface is to execute the copy flow in this example notebook. For this
basic flow , it inputs and outputs as like below shown.
Input:
[{"a": 1, "b": 2}, {"c": 3, "d": 4}, {"e": 5, "f": 6}, {"g": 7,
Output:
[{'output': [{'a': 1, 'b': 2}],
'root':
},
{'output': [{'c': 3, 'd': 4}],
'root':
},
{'output': [{'e': 5, 'f': 6}],
'root':
},
{'output': [{'g': 7, 'h': 8}],
'root':
}]
Uniflow behind the scene build and execute a computational DAG as below. You can
use the should be able to access the root node from output and viz the computational
graph as below in this example notebook as well.
If you can run each cell of this example notebook locally, you setup is good and you can
continue.
Part 3: Implement a ExpandReduceFlow and corresponding
ExpandOp and ReduceOp
1. Create a file named expand_op.py and implement a class named ExpandOp that
inherits from the Op class within this directory. The ExpandOp class should accept a
root node as input and produce two nodes as output. If the root node has a
value_dict with n elements, the first output node, expand_1 , should contain the first
n//2 key-value pairs from value_dict, and the second output node, expand_2 , should
contain the remaining key-value pairs from indices n//2 to n in its value_dict.
ExpandOp class constructor should also take a function argument to configure for
other options to split root into expand_1 and expand_2.
root node:
value_dict: {"1": "2", "3": "4", "5": "6", "7": "8"}
expand_1 node:
value_dict: {"1": "2", "3": "4"}
expand_2 node:
value_dict: {"5": "6", "7": "8"}
2. Create a file named reduce_op.py and implement a class called ReduceOp that
extends the Op class in this directory. The ReduceOp class should take expand_1 and
expand_2 as inputs and produce a single output node, reduce_1 . Following the
invocation of ReduceOp, the value_dict of the reduce_1 node should be a merged
version of the key-value pairs from both expand_1 and expand_2 . Additionally, the
constructor of the ReduceOp class should accept a function as a parameter,
allowing for alternative strategies to combine the value_dict of expand_1 and
expand_2 into reduce_1 .
expand_1 node:
value_dict: {"1": "2", "3": "4"}
expand_2 node:
value_dict: {"5": "6", "7": "8"}
reduce_1 node:
value_dict: {"1 5": "2 6", "3 7": "4 8"}
3. Create a file named expand_reduce_flow.py and implement ExpandReduceFlow class
inherit Flow base class. ExpandReduceFlow should use both newly implemented
ExpandOp and ReduceOp .
4. Register your newly ExpandReduceFlow into flow_dict in this constants.py for client to
invoke.
4. Now, run this notebook to execute your ExpandReduceFlow and make sure everything
working as expected.
5
5. Write one unit test for demo purpose for expand_op.py, reduce_op.py, or
expand_reduce_flow.py
6. Your code should also be able to handle ALL POSSIBLE EDGE CASE without
crashing!!!
Part 4: Dockerize the Application
1. Create a Dockerfile to containerize your new Uniflow application with latest change.
Ensure that all the necessary dependencies are installed.
2. Write instructions on how to build and run the Docker container.
Part 5: Deploy on Kubernetes
1. Create a Kubernetes Deployment YAML file to deploy the latest Uniflow application.
2. Include necessary Kubernetes resources like Service, ConfigMap, or Secret if
needed.
3. Write instructions on how to deploy the application on a Kubernetes cluster.
Part 6: Integrate Local Database
1. Select a local database system, such as SQLite or PostgreSQL, and incorporate it
into the Uniflow application.
2. Following the execution of ExpandReduceFlow , ensure to store the resulting output keyvalue pair in the database. Your implementation must be devoid of errors,
particularly concerning potential race conditions, as Uniflow operates in a multithreaded environment.
Part 7: Develop Client-Facing APIs
7.1 Asynchronous RESTful Invocation of ExpandReduceFlow
1. Create an API endpoint that allows for the ExpandReduceFlow function to be initiated
asynchronously.
2. Upon calling this API, a unique identifier for the job should be provided for
subsequent tracking of its progress.
3. Add necessary extra database if you needed.
7.2 Synchronous RESTful Endpoint to Verify Async Call Status
1. Establish an API endpoint that facilitates the checking of the current status of the
ExpandReduceFlow asynchronous execution, utilizing the previously provided job ID.
2. The API needs to respond with the current status of the job (options could include
states like "pending" or "completed").
7.3 Synchronous RESTful Endpoint to Retrieve All key-value Pairs
1. Construct an API endpoint that is capable of retrieving all key-value pairs resulting
from the ExpandReduceFlow process, directly from the database.
2. The API should be equipped to manage pagination, ensuring smooth functionality
even when dealing with a substantial number of key-value pairs.
Part 8: Documentation
1. Document the setup and installation process for the entire application, including
Docker and Kubernetes here.
2. Provide API documentation, including endpoints, request/response format, and
examples.
Evaluation Criteria
Code Quality: Assess the readability, consistency, and simplicity of the code.
Problem Solving: Evaluate the candidate’s ability to solve problems and implement
solutions.
Knowledge: Assess the candidate’s understanding of Docker, Kubernetes,
databases, and API design.
Documentation: Evaluate the clarity and completeness of the provided
documentation.
软件开发、广告设计客服
QQ:99515681
邮箱:99515681@qq.com
工作时间:8:00-23:00
微信:codinghelp
热点项目
更多
代写dts207tc、sql编程语言代做
2024-12-25
cs209a代做、java程序设计代写
2024-12-25
cs305程序代做、代写python程序...
2024-12-25
代写csc1001、代做python设计程...
2024-12-24
代写practice test preparatio...
2024-12-24
代写bre2031 – environmental...
2024-12-24
代写ece5550: applied kalman ...
2024-12-24
代做conmgnt 7049 – measurem...
2024-12-24
代写ece3700j introduction to...
2024-12-24
代做adad9311 designing the e...
2024-12-24
代做comp5618 - applied cyber...
2024-12-24
代做ece5550: applied kalman ...
2024-12-24
代做cp1402 assignment - netw...
2024-12-24
热点标签
mktg2509
csci 2600
38170
lng302
csse3010
phas3226
77938
arch1162
engn4536/engn6536
acx5903
comp151101
phl245
cse12
comp9312
stat3016/6016
phas0038
comp2140
6qqmb312
xjco3011
rest0005
ematm0051
5qqmn219
lubs5062m
eee8155
cege0100
eap033
artd1109
mat246
etc3430
ecmm462
mis102
inft6800
ddes9903
comp6521
comp9517
comp3331/9331
comp4337
comp6008
comp9414
bu.231.790.81
man00150m
csb352h
math1041
eengm4100
isys1002
08
6057cem
mktg3504
mthm036
mtrx1701
mth3241
eeee3086
cmp-7038b
cmp-7000a
ints4010
econ2151
infs5710
fins5516
fin3309
fins5510
gsoe9340
math2007
math2036
soee5010
mark3088
infs3605
elec9714
comp2271
ma214
comp2211
infs3604
600426
sit254
acct3091
bbt405
msin0116
com107/com113
mark5826
sit120
comp9021
eco2101
eeen40700
cs253
ece3114
ecmm447
chns3000
math377
itd102
comp9444
comp(2041|9044)
econ0060
econ7230
mgt001371
ecs-323
cs6250
mgdi60012
mdia2012
comm221001
comm5000
ma1008
engl642
econ241
com333
math367
mis201
nbs-7041x
meek16104
econ2003
comm1190
mbas902
comp-1027
dpst1091
comp7315
eppd1033
m06
ee3025
msci231
bb113/bbs1063
fc709
comp3425
comp9417
econ42915
cb9101
math1102e
chme0017
fc307
mkt60104
5522usst
litr1-uc6201.200
ee1102
cosc2803
math39512
omp9727
int2067/int5051
bsb151
mgt253
fc021
babs2202
mis2002s
phya21
18-213
cege0012
mdia1002
math38032
mech5125
07
cisc102
mgx3110
cs240
11175
fin3020s
eco3420
ictten622
comp9727
cpt111
de114102d
mgm320h5s
bafi1019
math21112
efim20036
mn-3503
fins5568
110.807
bcpm000028
info6030
bma0092
bcpm0054
math20212
ce335
cs365
cenv6141
ftec5580
math2010
ec3450
comm1170
ecmt1010
csci-ua.0480-003
econ12-200
ib3960
ectb60h3f
cs247—assignment
tk3163
ics3u
ib3j80
comp20008
comp9334
eppd1063
acct2343
cct109
isys1055/3412
math350-real
math2014
eec180
stat141b
econ2101
msinm014/msing014/msing014b
fit2004
comp643
bu1002
cm2030
联系我们
- QQ: 9951568
© 2021
www.rj363.com
软件定制开发网!