成a人片国产精品_色悠悠久久综合_国产精品美女久久久久久2018_日韩精品一区二区三区中文精品_欧美亚洲国产一区在线观看网站_中文字幕一区在线_粉嫩一区二区三区在线看_国产亚洲欧洲997久久综合_不卡一区在线观看_亚洲欧美在线aaa_久久99精品国产_欧美卡1卡2卡_国产精品你懂的_日韩精品91亚洲二区在线观看_国内一区二区视频_91丨国产丨九色丨pron

INFS 2042代做、代寫 Java 編程設計

時間:2024-05-27  來源:  作者: 我要糾錯



 INFS 2042 Data Structures Advanced Assignment 2 – Contact Tracing
UniSA STEM
The University of South Australia 2024
Originally written by Brandon Matthews Modified by Daniel Ablett, and Gun Lee
   Warning: This material has been reproduced and communicated to you by or on behalf of the University of South Australia in accordance with section 113P of the Copyright Act 1968 (Act). The material in this communication may be subject to copyright under the Act. Any further reproduction or communication of this material by you may be the subject of copyright protection under the Act.
 1

1. Introduction
To track and reduce the spread of a disease during an epidemic or pandemic situation it is critical that authorities and health experts can trace who has been in contact with whom, when the contact occurred and where. This is known as contact tracing. Efficiently searching potentially millions of people and where they have been will require an efficient way to store and navigate through the data.
In this assignment, you are tasked with building a basic contact tracing system. You must use your knowledge of data structures and search algorithms to efficiently store and process large quantities of contact tracing data. You are not restricted to the data structures and algorithms explored in this course. You may also make use of structures and algorithms from the Data Structures Essentials course.
2. Requirements
Your client has provided you with a strict set of system requirements that the program must meet. How you achieve those requirements and which algorithms or data structures you use are up to you. You must implement the program in Java using OpenJDK 11 or newer. You should also aim to make the program as efficient as possible. For example, exhaustively searching lists in nested loops would not be the most efficient implementation in many cases.
Generally, it is easier to design with optimisation in mind. When using the following data structures: Binary Search Tree, Self-Balancing Search Tree, Graph, Skip List, Blockchain, Hash Map, Hash Set etc. you must implement the data structure yourself. It is expected that a selection of these structures will be required to meet the client requirements as efficiently as possible.
You may use provided data structures in Java libraries (such as Linked List, Queue, Stack etc.) only if they are not a part of the content covered in this course to support the implementation of other structures and store data where necessary. Be wary of functions that are built into provided data structures, if you do use them ensure you consider their performance impact.
You are also required to provide supporting documentation, in this, you must explain each data structure you used, what they were used for and why. This includes cases where you have used Java’s built-in data structures. Consider your implementation in the context of a real contact tracing application. The data provided for this assignment, as described below, is for 40 people, with 80 visits to 6 locations. In a real application we likely have millions of people, with tens or hundreds of millions of visits to hundreds of thousands of locations. Your implementation should be efficient for storage and processing of large amounts of data.
Remember, it is not enough that your system implements the requirements, it must implement them efficiently.
2

2.1 System Requirements
Below are a set of requirements for the operation of the program as provided by your client.
• The system administrator would like the ability to load existing data from the provided .csv files. The code to read the files is already provided by the client however they have not implemented a method
to store the data.
• In addition, public health officials need the ability to add a new Person, Location or Visit to the data.
The client has provided the input command parsing code to support this however they have not
implemented the functionality.
• Public health officials need the ability to search for a Person by name. This should show them all details
about the person. This includes listing all visits the Person has made.
o Hint: This would require an efficient means of searching for the Person and all Visits in which
the Person has visited any Location.
o If a startDate and endDate are provided, this should also filter the list of Visits to only include
those between these times.
• Public health officials need the ability to search for a Location by name. This should show them all
details about the location. This includes listing all people that have visited the location.
o If a startDate and endDate are provided, this should also filter the list of Visits to only include
those between these times.
• The public health officials would like the ability to produce a list of potential contacts up to (n) levels
away from a given person (including known contacts).
o If n = 1, the list will contain only direct contacts of the given person.
o If n = 2, the list will contain all direct contacts (n=1) of the given person and all contacts of
those contacts (n=2).
o If n=r, the list will contain all n=1 to n=r-1 contacts of the given person and all contacts of those
contacts (n=r).
o Hint: This would require an efficient method of identifying contacts of a given person based
on their visits.
• Public health officials also need the ability to specify if the person is a new Active Case (i.e., they have
become infected with the virus).
o When an Active Case is added, they also need to see an estimation of where, when and from
whom the person likely contracted the virus. Your program should output the most likely contact source including the location and time of contact. Note: The most likely contact source is the pair of people with the highest Chance of Spread (C) as defined later in this document.
o If a new Active Case has no immediate contacts that are also an Active Case, the program should instead find the nearest or most likely Active Case. That is, the existing Active Case for which each contact between them and the new Active Case have the highest total Chance of Spread (C).
o Hint: This would require a method for identifying the person from which the visit during which the person most likely contracted the virus.
• The public health officials would like to output a trace of the transmission of the virus from its original source to a target person. In this process this trace should ensure the date each person along the path was infected is correct by verifying the start date of their infection is the day after the contact with the highest Chance of Spread (C). In a ‘real world’ data set this would be useful for identifying different branches of the virus as it spreads and tracing the virus back to its original source.
o Hint: this would require a method for tracing the path through each person backwards from the given person until no previous source case can be found (in the provided data).
• The public health officials would like to be able to produce a list of all active cases.
• The program must be robust and user friendly, so it does not crash but print proper messages.
3

2.2 Supporting Documentation
You must provide a document to support your program design and demonstrate your program meets the requirements. This must include:
• One-page summary of your program design and the reasoning behind your design decision.
Explain all data structures and algorithms you used, what they were used for, and your reasoning for selecting them. (e.g., estimate of overall performance, space and time-efficiency)
• Sample outputs from your program. (no page limit)
This is to demonstrate that your program meets the requirements. Provide headings to clarify what requirement does the provided sample output demonstrates.
3. Data and Code
For simplicity, a limited data set is provided. A person is only considered infectious if they are currently an active case and only the dates between which they are infections is recorded. All of the data is artificial data that has been procedurally generated. A person is only considered an active case if they have an activeStartDate, and they either don’t have an activeEndDate or the activeEndDate is after the “current date”.
3.1 Provided Data Format
The data in the provided CSV files are structured as follows:
• Person.csv – A list of people where each person has:
o name
▪ The person’s full name, or the purposes of this assignment you can assume the
person’s full name is unique within the data set o activeStartDate
▪ The date after the person is estimated to have contracted the virus the virus (empty if they have not contracted the virus)
o activeEndDate
▪ The date the person stopped being contagious (or is estimated to stop if after the
“current date”).
• Location – A list of locations where each location has:
o name
▪ Thelocation’sname,orthepurposesofthisassignmentyoucanassumetheperson’s
full name is unique within the data set
• Visit – A list of visits by a person to a location where each visit has:
o personName
▪ Name of the person that visited the location
o locationName
▪ Name of the location the person visited
o date
▪ Date of the visit
o entryTime
▪ Time the person entered the location
o exitTime
▪ Time the person exited the location
4

3.2 Provided Code
The client has provided the basic interface commands they wish to use to handle the data. You are free to add commands for your testing purposes if you wish, however you must keep the commands listed here the same. The provided base code handles the parsing of these commands and provides some supporting types and functions. It is recommended that you retain the command functionality and build upon it, however you are free to modify the base code however you want/need to meet the requirements. See testfiles/test.txt in the provided code for a set of example commands.
The program is configured with an artificial “CURRENT_DATE” variable that relates to the provided data files. You should use whenever referring to the current date. This is configured by an initialization command in the test files.
For simplicity, a limited data set is provided. A person is only considered infectious if they are currently an active case and only the dates between which they are infections is recorded. All of the data is artificial data that has been procedurally generated. A person is only considered an active case if they have an activeStartDate, and they either don’t have an activeEndDate or the activeEndDate is after the “current date”.
   Command INIT
LOAD_DATA
ADD_PERSON ADD_LOCATION
Purpose
Initializes the program and sets the artificial CURRENT_DATE
Loads data from the
People, Locations and
files
Adds a new person
Adds a new location
Parameters
currentDate – the artificial current date for the program
peoplePath – path to people csv locationPath – path to location csv
visitPath – path to visit csv
personName – name of the person to add
locationName – name of the location to add
      provided Visits CSV
       ADD_VISIT
   Adds a new visit
  personName – name of the person locationName – name of the location date – date of the visit
entryTime – time visit started exitTime – time visit ended
    GET_PERSON
   Finds the Person by name and lists all visits (or a filtered list of visits between startDate and endDate)
   personName – name of the person to get startDate (optional) – filter visit list by this start time
endDate (optional) – filter visit list by this end time
   GET_LOCATION
  Finds the Location by name and lists all visits (or a filtered list of visits between startDate and endDate)
  locationName – name of the location to get startDate (optional) – filter visit list by this start time
endDate (optional) – filter visit list by this end time
 LIST_CONTACTS
   Finds the Person by name and lists all contacts within (n) contacts of the given person. i.e. n=1 is direct contact, n=2 is contact with an n=1 contact ... n=N is contact with an n=N-1 contact.
  personName – person to get contacts of n – number of levels of contact
  CURRENTLY_ACTIVE
Lists all currently active people. 5
   
  NEW_CASE
   Sets the given Person to now be an active case and the date and time they tested positive. Also outputs the most likely infection source for the target and updates the activeStartDate for the person (1 day after the contact took place), if no viable contact is detected, sets the activeStartDate to the CURRENT_DATE variable in DateHelpers.
   personName – name of the person to make a new case
  TRACE_PATH Traces the path that the virus personName – name of the person to trace travelled from person to person the virus transmission for
until it reaches the target.
3.3 Calculating the Chance of Spread
For this assignment, we have an imaginary virus that has a high chance of spreading and becomes detectable and contagious the following day. That is. if John is detected as an active case on 5/1/2021, they must have caught the virus some day before 5/1/2021
For this virus the chance of contact between an active case and another person resulting in a spread to that person is based on the overlap in time spent by two people at a given location, the time since the active case contracted the virus and the incubation time. The chance is the percentage of one hour spent in contact (in the same location).
Let D be the time spent by two people in the same location (in minutes) The Chance of Spread (C) is:
𝐶=(𝐷 ×100) 60
Note that C cannot be less than 0% or greater than 100%. 3.4 Running the Provided Code
To run the provided code you will need to pass it the path to the test file as a program argument through the “Run Configuration” in eclipse. The default included test file is at the relative location “testfiles/test.txt”. Throughout development it may help to create your own test files and data sets that you can use to help with implementation of specific functions. If you are using your own test file, make sure you update the “Arguments” under the “Run Configuration” in eclipse. Note that a different test file may be used for marking.
   6

 4. Submission Details
All assignments must be submitted via the learnonline submission system through the course webpage. You must submit two files, a report and a zip file containing your programming solution.
Report
Submit a single pdf file with the name emailID.pdf (replace emailID with your own!) as outlined in section 2.2
Code
Make sure you add your name and email ID into the comments on all of the Java file you have modified. Create a single zip file with the name emailID.zip. When unzipped it should contain a functional eclipse project. You may work on the project in another IDE however you must ensure it works as an eclipse project as it will be marked based on eclipse.
7
 
Late Submissions and Extensions
Late submissions will be penalised by scaling the marks by 70% unless with pre-approved extension. Application for extension should be lodged through the course website and it requires a document proving acceptable reasons for extension (e.g., medical certificate, or a letter from your work supervisor). Please check the course outline available on the course website for further details on late submission and extensions.
Academic Misconduct
Students must be aware of the academic misconduct guidelines available from the University of South Australia website. Deliberate academic misconduct such as plagiarism is subject to penalties. Information about Academic integrity can be found in Section 9 of the Assessment policies and procedures manual at: https://i.unisa.edu.au/policies-and-procedures/codes/assessment-policies/
All of the assignments are compared using special tools designed to look for similarities between Java programs. The plagiarism checking programs do not just compare the actual Java code, but instead perform comparisons on the code after it has been compiled. Performing cosmetic changes such as reformatting code, renaming variables, or reordering code may fool a human under casual inspection but will still be detected by the plagiarism checker as being similar. Beware that if you use generative AI tools, this may result in another person using the same tool submitting solutions with high similarities.
Any assignments found to be in violation of the university’s rules on academic misconduct will become subject of Academic Integrity investigation which will decide the penalty. Furthermore, you may also fail the course and/or receive an official note in your academic transcript.
The best way to avoid being penalised for plagiarism is to not cheat on your assignment. Do not share your code with anyone, do not let anyone else do your assignment for you, and do not leave your computer unattended or share your password with anyone. If you are working with friends it is ok to discuss the assignment and possible ways of solving it, but you should not share your code. Sharing code with others is still considered academic misconduct. The golden rule for working on your assignments is never show another student the material you intend on handing up.
 8

5. Assessment Criteria
• Program Code (70%)
o Runs without any errors or crashing (5%) o Meets Client Requirements (40%)
o Quality of Implementation and Code (25%)
 •
▪ Is the code well-structured and logical?
▪ Is the code readable?
▪ Have efficient control-flow elements been used (while loops, for loops)?
▪ Sufficient comments. Also, name and email ID must be added in comments. ▪ Code reusability
▪ Choices of data structure and algorithm ▪ Efficient usage of space
▪ Efficient computation time
 Report (30%)
 o
Logical reasoning for Data Structure and Algorithm selection is documented in supporting
 documentation. (25%)
o Provided sample outputs are relevant to the requirements. (5%)
請加QQ:99515681  郵箱:99515681@qq.com   WX:codinghelp















 

標簽:

掃一掃在手機打開當前頁
  • 上一篇:代做 EBU5376、MATLAB 語言程序代寫
  • 下一篇:代寫 CPT204 Intelligent Rogue Chars
  • 無相關信息
    昆明生活資訊

    昆明圖文信息
    蝴蝶泉(4A)-大理旅游
    蝴蝶泉(4A)-大理旅游
    油炸竹蟲
    油炸竹蟲
    酸筍煮魚(雞)
    酸筍煮魚(雞)
    竹筒飯
    竹筒飯
    香茅草烤魚
    香茅草烤魚
    檸檬烤魚
    檸檬烤魚
    昆明西山國家級風景名勝區
    昆明西山國家級風景名勝區
    昆明旅游索道攻略
    昆明旅游索道攻略
  • NBA直播 短信驗證碼平臺 幣安官網下載 歐冠直播 WPS下載

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

    Copyright © 2025 kmw.cc Inc. All Rights Reserved. 昆明網 版權所有
    ICP備06013414號-3 公安備 42010502001045

    成a人片国产精品_色悠悠久久综合_国产精品美女久久久久久2018_日韩精品一区二区三区中文精品_欧美亚洲国产一区在线观看网站_中文字幕一区在线_粉嫩一区二区三区在线看_国产亚洲欧洲997久久综合_不卡一区在线观看_亚洲欧美在线aaa_久久99精品国产_欧美卡1卡2卡_国产精品你懂的_日韩精品91亚洲二区在线观看_国内一区二区视频_91丨国产丨九色丨pron
    奇米精品一区二区三区在线观看 | 制服.丝袜.亚洲.另类.中文| 亚洲成人三级小说| 亚洲在线视频一区| 欧洲生活片亚洲生活在线观看| 麻豆精品新av中文字幕| 欧美精品一区二区久久久| 日韩av不卡一区二区| 国产一区二区美女诱惑| 91久久奴性调教| 日本亚洲欧美天堂免费| 精品久久久久久久久久久久久久久久久 | 国产精品丝袜一区| 在线亚洲免费视频| 国产精品麻豆一区二区| 亚洲综合在线观看视频| 欧美一级搡bbbb搡bbbb| 久久精品亚洲乱码伦伦中文| 久久99精品视频| 国内精品久久久久影院薰衣草| 国产亚洲欧美激情| 7777精品伊人久久久大香线蕉完整版| 韩国女主播成人在线| 综合久久综合久久| 欧美一区二区三区思思人| 精品国产百合女同互慰| 日本欧美在线观看| 国产精品久久久久精k8| 国产精品区一区二区三区| 精品一区二区三区蜜桃| 国产一区二区三区免费| 99精品国产热久久91蜜凸| 成人午夜免费av| 欧美羞羞免费网站| 免费在线观看日韩欧美| 色婷婷av一区二区三区gif| 欧美中文字幕一二三区视频| 欧美日韩激情在线| 国产精品福利在线播放| 亚洲电影一级片| 中文字幕一区二区三区在线不卡 | 18涩涩午夜精品.www| 成人av电影在线网| 国产色产综合产在线视频| 色综合欧美在线视频区| 国产欧美久久久精品影院| 国产不卡视频在线观看| 成人免费观看av| 一本大道久久a久久精二百| 97久久超碰国产精品| 国产精品天美传媒沈樵| 国产精品护士白丝一区av| 亚洲精品中文在线影院| 国产盗摄视频一区二区三区| 亚洲在线免费播放| 亚洲欧洲韩国日本视频| 麻豆91在线观看| 亚洲成人777| 久久久不卡影院| 久久综合九色综合久久久精品综合| 欧美一区二区三区思思人| 日本欧美大码aⅴ在线播放| 亚洲伊人色欲综合网| 精品视频在线免费| 久久久精品综合| 国产精品影视网| 日韩一二在线观看| 一区二区三区四区不卡在线| 91麻豆免费视频| 欧美久久一二三四区| 成人妖精视频yjsp地址| 亚洲小说欧美激情另类| 蜜臀国产一区二区三区在线播放| 欧美最新大片在线看| 一区二区三区资源| 99视频精品在线| 日韩精品一区二区三区老鸭窝 | 狠狠色狠狠色综合| 国产高清久久久久| 欧美不卡一区二区三区| 亚洲一区二区在线观看视频| 五月综合激情日本mⅴ| 丁香五精品蜜臀久久久久99网站 | 在线观看日韩电影| 欧美一二三四区在线| 日本不卡123| 亚洲精品乱码久久久久久久久 | 久久综合久久鬼色中文字| 成年人网站91| 免费成人在线影院| 美美哒免费高清在线观看视频一区二区 | 欧美丝袜丝nylons| 97精品久久久久中文字幕| 国产精品毛片无遮挡高清| 欧美日韩成人一区| 午夜视频一区二区三区| 欧美三级视频在线| 激情综合五月婷婷| 日韩欧美在线网站| 色综合久久久久| 亚洲精品成人少妇| 99精品久久久久久| 欧美日韩国产系列| 蜜臀久久99精品久久久久宅男| 久久九九99视频| 91网站在线播放| 亚洲成a人片在线观看中文| 26uuu色噜噜精品一区| 91论坛在线播放| 美女视频一区二区| 中文字幕欧美国产| 91超碰这里只有精品国产| 成人精品在线视频观看| 青青草91视频| 亚洲精品日韩专区silk| 欧美性一区二区| 天堂av在线一区| 国产精品女主播av| 日韩欧美亚洲一区二区| 91农村精品一区二区在线| 亚洲成a人在线观看| 日韩精品一区二区在线观看| 91麻豆精品秘密| 国产尤物一区二区| 亚洲成人一区二区在线观看| 国产精品亲子伦对白| 色av一区二区| 国产精品91一区二区| 午夜电影久久久| 精品国产a毛片| 欧美日韩国产影片| 99这里只有精品| 国产在线视视频有精品| 日韩av中文字幕一区二区| 精品精品国产高清a毛片牛牛| 欧美亚洲国产一区二区三区| 九一九一国产精品| 国产米奇在线777精品观看| 午夜视频久久久久久| 亚洲欧美日韩国产综合| 一本大道久久a久久精二百| 国产成人精品亚洲午夜麻豆| 国产亚洲视频系列| 日韩精品专区在线影院重磅| 91精品综合久久久久久| 欧美亚洲综合色| 亚洲男人的天堂av| 日韩精品最新网址| 高清不卡在线观看| 国产在线观看免费一区| 美女一区二区在线观看| 日韩欧美一区二区在线视频| 欧美日韩精品一区二区三区| 97精品国产97久久久久久久久久久久 | 亚洲国产日韩在线一区模特| 中文字幕亚洲成人| 国产亚洲成av人在线观看导航| 日韩一卡二卡三卡国产欧美| 欧美裸体一区二区三区| 欧美在线看片a免费观看| 91浏览器打开| 国产乱对白刺激视频不卡| 处破女av一区二区| 91麻豆免费看| 成人av手机在线观看| 国产乱理伦片在线观看夜一区| 日本强好片久久久久久aaa| 亚洲电影中文字幕在线观看| 夜夜嗨av一区二区三区网页| 国产精品对白交换视频 | 91精品久久久久久久久99蜜臂| 在线看国产日韩| 色婷婷香蕉在线一区二区| 99国产精品久久久久| 成人中文字幕电影| 国产一本一道久久香蕉| 国产一区视频导航| 久久97超碰国产精品超碰| 久久精品国产999大香线蕉| 精品在线观看免费| 免费人成黄页网站在线一区二区| 婷婷综合五月天| 午夜精品久久久久久不卡8050| 亚洲综合偷拍欧美一区色| 一区二区三区在线播| 亚洲男人都懂的| 亚洲欧洲性图库| 亚洲国产精品传媒在线观看| 久久久久成人黄色影片| 亚洲一区在线电影| 亚洲一区二区精品久久av| 亚洲精品国产无天堂网2021| 亚洲黄色小说网站| 亚洲免费观看高清| 亚洲精品国产视频| 亚洲一区二区三区激情| 亚洲一二三区不卡| 日本视频一区二区| 美女mm1313爽爽久久久蜜臀| 久久99在线观看|