首页
网站开发
桌面应用
管理软件
微信开发
App开发
嵌入式软件
工具软件
数据采集与分析
其他
首页
>
> 详细
CITS1401代写、代做Python编程语言
项目预算:
开发周期:
发布时间:
要求地区:
CITS1401 Computational Thinking with Python
Project 1, Semester 2, 2024
Page 1 of 9
Department of Computer Science and Soffware Engineering
The University of Western Australia
CITS1401
Computational Thinking with Python
Project 1, Semester 2, 2024
(Individual project)
Submission deadline: 23:59 PM, 13 September 2024.
Total Marks: 30
Project Submission Guidelines:
You should construct a Python 3 program containing your solution to the given problem and
submit your program electronically on Moodle. The name of the file containing your code
should be your student ID e.g. 12345678.py. No other method of submission is allowed. Please
note that this is an individual project.
• Your program will be automatically run on Moodle for sample test cases provided in
the project sheet if you click the “check” link. However, this does not test all required
criteria and your submission will be thoroughly tested manually for grading purposes
after the due date. Remember you need to submit the program as a single file and copypaste
the same program in the provided text box.
• You have only one attempt to submit, so don’t submit until you are satisfied with your
attempt.
• All open submissions at the time of the deadline will be automatically submitted. There
is no way in the system to open/modify/reverse your submission.
• You must submit your project before the deadline listed above. Following UWA policy,
a late penalty of 5% will be deducted for each day (or part day) i.e., 24 hours after the
deadline, that the assignment is submitted.
• No submissions will be allowed after 7 days following the deadline except approved
special consideration cases.
You are expected to have read and understood the University's guidelines on academic conduct.
In accordance with this policy, you may discuss with other students the general principles
required to understand this project, but the work you submit must be the result of your own
effort. Plagiarism detection, and other systems for detecting potential malpractice, will CITS1401 Computational Thinking with Python
Project 1, Semester 2, 2024
Page 2 of 9
therefore be used. Besides, if what you submit is not your own work then you will have learnt
little and will therefore, likely, fail the final exam.
Project Overview:
In the rapidly expanding world of e-commerce, platforms like Amazon provide vast amounts
of data that can offer valuable insights into various aspects of product performance. This project
aims to analyze Amazon data for different products within specific categories, utilizing key
parameters such as product ID, product name, category, discounted price, actual price, ratings,
rating count etc., The data set includes a diverse range of categories, each with multiple
products, allowing us to identify trends and patterns specific to each category.
You are required to write a Python 3 program that will read two different files: a CSV file and
a TXT file. Your program will perform four different tasks outlined below. While the CSV file
is required to solve all the tasks (Tasks1-4), the TXT file is only required for the last task (Task
4).
After reading the CSV file, your program is required to complete the following:
• Task 1: Identify Extreme Discount Prices
Find the product ID with the highest discounted price and the product ID with the
lowest discounted price for a specific category.
• Task 2: Summarize Price Distribution
Provide a summary of the ‘actual price’ distribution i.e., mean, median and mean
absolute deviation of products for a specific category, considering only the products
with a rating count higher than 1000.
• Task 3: Calculate Standard Deviation of Discounted Percentages
Calculate the standard deviation of the discounted percentages for products with rating
in the range 3.3≤rating≤4.3, for each category.
• Task 4: Correlate Sales Data
Find the correlations between the sales of the products identified in Task 1 (products
with highest and lowest discounted prices for a specific category).
Steps:
o Read the TXT file which contains the sales data for several years, such as 1998-
2021. Each line lists product IDs and the units sold for that year. If a product ID
is not mentioned in a line, it means zero units sold for that year. CITS1401 Computational Thinking with Python
Project 1, Semester 2, 2024
Page 3 of 9
o Create two lists, one for the sales of the product with the highest discounted
price and another for the sales of the product with the lowest discounted price
identified in Task 1.
o Process each line of the TXT file to determine the number of units sold each
year.
o Each list should have one entry per year, with the total number of entries
matching the number of lines in the TXT file.
Finally, calculate the correlation coefficient between the two sales lists.
Requirements:
1) You are not allowed to import any external or internal module in python. While use of
many of these modules, e.g., csv or math is a perfectly sensible thing to do in production
setting, it takes away much of the point of different aspects of the project, which is about getting
practice opening text files, processing text file data, and use of basic Python structures, in this
case lists and loops.
2) Ensure your program does NOT call the input() function at any time. Calling the
input() function will cause your program to hang, waiting for input that automated testing
system will not provide (in fact, what will happen is that if the marking program detects the
call(s), it will not test your code at all which may result in zero grade).
3) Your program should also not call print()function at any time except for the case of
graceful termination (if needed). If your program encounters an error state and exits gracefully,
it should return a correlation/standard deviation/mean/median value of zero and print an
appropriate error message. At no point should you print the program’s outputs or provide a
printout of the program’s progress in calculating such outputs. Outputs should be returned by
the program instead.
4) Do not assume that the input file names will end in .csv or .txt. File name suffixes such
as .csv and .txt are not mandatory in systems other than Microsoft Windows. Do not
enforce within your program that the file must end with a specific extension, nor should you
attempt to add an extension to the provided file name. Doing so can result in loss of marks.
CITS1401 Computational Thinking with Python
Project 1, Semester 2, 2024
Page 4 of 9
Input:
Your program must define the function main with the following syntax:
def main(CSVfile, TXTfile, category):
The input arguments for this function are:
1. CSVfile: The name of the CSV file (as string) containing the record of the Amazon’s
product data.
2. TXTfile: The name of the TXT file (as string) containing the record of Amazon’s
product sales.
3. category: A string representing the category to be analysed. The Amazon’s product
data contains multiple categories.
Output:
The following four outputs are expected:
i) OP1= [Product ID1, Product ID2]: A list that contains two items, ID of
the product with the highest discounted price, ID of the product with the lowest
discounted price. Your output should be stored in a list in the following order:
[highest discounted price product ID, lowest discounted price product ID]
For example: ['b07vtfn6hm', 'b08y5kxr6z']
Note: If multiple products have the same highest discounted price, select the product
ID that comes first when the product IDs are sorted in ascending order. Apply the same
rule for the lowest discounted price.
ii) OP2= [mean, median, mean absolute deviation]: A list containing
three statistical measures i.e., mean, median, and mean absolute deviation of the actual
price for products within a given category, considering only those products with a
rating count higher than 1000. The output should be stored in a list in the following
order:
[mean, median, mean absolute deviation]
For example: [2018.8, 800.0, 2132.48]
CITS1401 Computational Thinking with Python
Project 1, Semester 2, 2024
Page 5 of 9
iii) OP3= [STD1, STD2, ..., STDN]: A list containing the standard deviation of
the discounted percentages for products within the rating in the range 3.3 to 4.3 (3.3 ≤
rating ≤ 4.3) of each category. The output should be sorted in the descending order. The
expected output is a list with values sorted in the descending order.
For example: [0.297, 0.2654, 0.2311, 0.198, 0.1701, 0.1596,
0.0071]
iv) OP4= Correlation: A numeric value representing the correlation between the
sales of a product with the highest discounted price and the lowest discounted price
found in the task 1 above. The expected output is a single float value.
For example: -0.0232
All returned numeric outputs (both in lists and individual) must contain values rounded to four
decimal places (if required to be rounded off). Do not round the values during calculations.
Instead, round them only at the time when you save them into the final output variables.
Examples:
Download Amazon_products.csv and Amazon_sales.txt from the folder of Project
1 on LMS or Moodle. An example of how you can call your program from the Python shell
(and examine the results it returns) is provided below:
>>>OP1, OP2, OP3, OP4= main('Amazon_products.csv',
'Amazon_sales.txt', 'Computers&Accessories')
>>>OP1
['b07vtfn6hm', 'b08y5kxr6z']
>>> OP2
[2018.8, 800.0, 2132.48]
>>> OP3
[0.297, 0.2654, 0.2311, 0.198, 0.1701, 0.1596, 0.0071]
>>> OP4
-0.0232
CITS1401 Computational Thinking with Python
Project 1, Semester 2, 2024
Page 6 of 9
Assumptions:
Your program can assume the following:
1. Anything that is meant to be string (e.g., header) will be a string, and anything that is
meant to be numeric will be numeric.
2. All string data in the CSV file and TXT file is case-insensitive, which means
“Computers&accessories” is same as “Computers&Accessories” or “B08Y5KXR6Z” is
same as “b08y5kxr6z”. Your program needs to handle the situation to consider both
strings to be the same.
3. In the CSV file, the order of columns in each row will follow the order of the headings
provided in the first row. However, rows can be in random order except the first row
which contains the headings.
4. No data will be missing in the CSV file; however, values can be zero and must be
accounted for when calculating averages and standard deviations.
[In case any part of the calculation cannot be performed due to zero values or other
boundary conditions, do a graceful termination by printing an error message and
returning a zero value (for numbers), None for (string) or empty list depending on the
expected outcome. Your program must not crash.]
5. Each line in the TXT file will correspond to a unique year, with no repetition of years.
The number of years may vary, so avoid hard coding.
6. All the product IDs in the CSV file will be unique.
7. The main() will always be provided with valid input parameters.
8. The necessary formulas are provided at the end of this document.
Important grading instruction:
Note that you have not been asked to write specific functions. The task has been left to you.
However, it is essential that your program defines the top-level function main(CSVfile,
TXTfile, category) (commonly referred to as ‘main()’ in the project documents to
save space when writing it. Note that when main() is written it still implies that it is defined
with its three input arguments). The idea is that within main(), the program calls the other
functions. (Of course, these functions may then call further functions.) This is important
because when your code is tested on Moodle, the testing program will call your main()
function. So, if you fail to define main(), the testing program will not be able to test your CITS1401 Computational Thinking with Python
Project 1, Semester 2, 2024
Page 7 of 9
code and your submission will be graded zero. Don’t forget the submission guidelines provided
at the start of this document.
Marking rubric:
Your program will be marked out of 30 (later scaled to be out of 15% of the final mark).
24 out of 30 marks will be awarded automatically based on how well your program completes
a number of tests, reflecting normal use of the program, and how the program handles various
states including, but not limited to, different numbers of rows in the input file and / or any error
states. You need to think creatively what your program may face. Your submission will be
graded by data files other than the provided data file. Therefore, you need to be creative to
investigate corner or worst cases. I have provided few guidelines from ACS Accreditation
manual at the end of the project sheet which will help you to understand the expectations.
6 out of 30 marks will be awarded on style (3/6) “the code is clear to read” and efficiency (3/6)
“your program is well constructed and run efficiently”. For style, think about use of comments,
sensible variable names, your name at the top of the program, student ID, etc. (Please watch
the lectures where this is discussed).
Style Rubric:
0
Gibberish, impossible to understand
1 Style is really poor or fair.
2
Style is good or very good, with small lapses.
3 Excellent style, really easy to read and follow
Your program will be traversing text files of various sizes (possibly including large csv files)
so you need to minimise the number of times your program looks at the same data items.
Efficiency rubric:
0 Code too complicated to judge efficiency or wrong problem tackled
1 Very poor efficiency, additional loops, inappropriate use of readline()
2 Acceptable or good efficiency with some lapses
3 Excellent efficiency, should have no problem on large files, etc.
Automated testing is being used so that all submitted programs are being tested the same way.
Sometimes it happens that there is one mistake in the program that means that no tests are
passed. If the marker can spot the cause and fix it readily, then they are allowed to do that and
your - now fixed - program will score whatever it scores from the tests, minus 4 marks, because CITS1401 Computational Thinking with Python
Project 1, Semester 2, 2024
Page 8 of 9
other students will not have had the benefit of marker intervention. Still, that's way better than
getting zero. On the other hand, if the bug is hard to fix, the marker needs to move on to other
submissions.
Extract from Australian Computing Society Accreditation manual 2019:
As per Seoul Accord section D, a complex computing problem will normally have some or
all the following criteria:
- involves wide-ranging or conflicting technical, computing, and other issues.
- has no obvious solution and requires conceptual thinking and innovative analysis to
formulate suitable abstract models.
- a solution requires the use of in-depth computing or domain knowledge and an
analytical approach that is based on well-founded principles.
- involves infrequently encountered issues.
- are outside problems encompassed by standards and standard practice for professional
computing.
- involves diverse groups of stakeholders with widely varying needs.
- has significant consequences in a range of contexts.
- is a high-level problem possibly including many component parts or sub-problems.
- identification of a requirement or the cause of a problem is ill defined or unknown.
Necessary formulas:
i) Median
Mathematically, median is represented as:
X = ordered list of values in the data set.
n = number of values in the data set.
ii) Mean absolute Deviation
MD = average value of X
n = number of data values
xi = data values in X
CITS1401 Computational Thinking with Python
Project 1, Semester 2, 2024
Page 9 of 9
iii) Standard deviation:
Mathematically, standard deviation is represented as: 𝑖𝑖=1
𝑁𝑁 − 1
where are observed value in sample data. 𝑥𝑥̅ is the mean value of observations
and is the number of sample observations.
iv) Correlation coefficient:
Mathematical formula to calculate correlation is as follows:
where and are the values of sales in each year (mentioned in the sales.txt file) for the
product with the highest and the lowest discounted price respectively. 𝑥𝑥̅ is the mean of sales of
product with the highest discounted price and 𝑦𝑦 is the mean of the sales of the product with the
lowest discounted price.
Note: Any updates regarding the project will be posted on Moodle help forum.
软件开发、广告设计客服
QQ:99515681
邮箱:99515681@qq.com
工作时间:8:00-23:00
微信:codinghelp
热点项目
更多
代做 program、代写 c++设计程...
2024-12-23
comp2012j 代写、代做 java 设...
2024-12-23
代做 data 编程、代写 python/...
2024-12-23
代做en.553.413-613 applied s...
2024-12-23
代做steady-state analvsis代做...
2024-12-23
代写photo essay of a deciduo...
2024-12-23
代写gpa analyzer调试c/c++语言
2024-12-23
代做comp 330 (fall 2024): as...
2024-12-23
代写pstat 160a fall 2024 - a...
2024-12-23
代做pstat 160a: stochastic p...
2024-12-23
代做7ssgn110 environmental d...
2024-12-23
代做compsci 4039 programming...
2024-12-23
代做lab exercise 8: dictiona...
2024-12-23
热点标签
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
软件定制开发网!