联系方式

  • QQ:99515681
  • 邮箱:99515681@qq.com
  • 工作时间:8:00-21:00
  • 微信:codinghelp

您当前位置:首页 >> C/C++编程C/C++编程

日期:2020-06-20 11:06

BUSA90501 Machine Learning

Syndicate Project Description

Weight: 30%

1 Overview

Pairwise relationships are prevalent in real life. For example, friendships between people, communication links between

computers and pairwise similarity of images. Networks provide a way to represent a group of relationships.

The entities in question are represented as network nodes and the pairwise relations as edges.

In real network data, there are often missing edges between nodes. This can be due to a bug or deficiency in

the data collection process, a lack of resources to collect all pairwise relations or simply there is uncertainty about

those relationships. Analysis performed on incomplete networks with missing edges can bias the final output, e.g.,

if we want to find the shortest path between two cities in a road network, but we are missing information of major

highways between these cities, then no algorithm will able to find this actual shortest path.

Furthermore, we might want to predict if an edge will form between two nodes in the future. For example, in disease

transmission networks, if health authorities determine a high likelihood of a transmission edge forming between

an infected and uninfected person, then the authorities might wish to vaccinate the uninfected person.

In this way, being able to predict (and correct for) missing edges is an important task.

Your task:

In this project, you will be learning from a training network and trying to predict whether edges exist among test node

pairs.

The training network is a fragment of an academic co-authorship graph. The nodes in the network—authors—

have been given randomly assigned IDs, and an undirected edge between node A and B represents that authors A

and B have published a paper together as co-authors. The training network is a network of a time period (2010-2017),

focusing on individuals in a specific academic subcommunity.

Your task is to predict if an edge will form between two nodes in the future, we provide development set and test

set as future link information to validate and evaluate your works. The development set is a list of 4,866 edges, contain

2,433 real edges in the year after the time period of the training set (2018) , and also 2,433 fake edges (pairs of nodes

that are not connected). The test data is a list of 4,460 edges, 2,230 of these test edges are real in the next year after

development set (2019), while the other 2,230 do not actually exist.

To make the project fun, we will run it as a Kaggle in-class competition. Your assessment will be partially based

on your final ranking in the privately-held competition, partially based on your absolute performance and partially

based on your report.

2 Data Format

All data will be available in raw text. The training graph data will be given in a (tab delimited) edge list format, where

each row represents a node and its neighbours. For example:

Figure 1: Network diagram for the adjacency list example.

represents the network illustrated in Figure 1.

In addition to the edges, you are also provided with a file including several features of the nodes (authors). This

file, “nodes.json” is in JSON format and includes information in 2010-2017 for each author:

• their id in the graph

• the number of years since their first and last publication to 2017 (e.g. first:3 means author published first

paper at 2014)

• their number of publications in total, num_papers

• presence of specific keywords in the titles and abstracts of their publications (denoted keyword_X where X ∈

{0, 1,..., 53}, each being a binary value and only listed if its value is 1)

• publication at specific venues (denoted venue_X where X ∈ {0, 1,..., 303}, each being a binary value and only

listed if its value is 1)

This gives you some additional information beside the network structure for your prediction task.1

The test edge set is in a comma separated values (CSV) edge list format, which includes a one line header, followed

by a line for each (source node, target node) edge. Your implemented algorithm should take the test CSV file as input

and return a 4,461 row CSV file that has a) in the first row, the string “Id,Predicted”; b) in all subsequent rows, a

consecutive integer ID, a comma, then a float in the range [0,1]. These floats are your “guesses” or predictions as to

whether the corresponding test edge was from the co-authorship network or not. Higher predictions correspond to

being more confident that the edge is real.

For example, given the test edge set of {(3, 5), (4, 12)} as represented in CSV format by

Id,Source,Sink

1,3,5

2,4,12

if your prediction probabilities are 0.1 for edge (3,5), 0.99 for edge (4,12), then your output file should be:

Id,Predicted

1,0.1

2,0.99

The test set will be used to generate an AUC for your performance; you may submit test predictions multiple

times per day (if you wish). During the competition AUC on a 33% subset of the test set will be used to rank you in the

public leaderboard. We will use the complete test set to determine your final AUC and ranking. The split of test set

during/after the competition, is used to discourage you from constructing algorithms that overfit on the leaderboard.

The training graph “train.txt”, the development edges “dev.csv”,labels for development “dev-labels.csv”, the test edges

“test-public.csv”, and a sample submission file “sample.csv” will be available within the Kaggle competition website.

You should use development set for hyperparameters tuning and model selection, then make prediction on test set

and submit to Kaggle competition.

1These features were calculated after excluding from the network the hidden test edges, to invalidate trivial approaches for prediction.

2

3 Links and Check List

Competition link: https://www.kaggle.com/t/aedc05f00c12488792c251818b2dd99e

Team registration: https://forms.gle/C1KTR6GtEavcXHnb7

The Kaggle in class competition allows you to compete and benchmark against your peers. Please do the following

by: June 18th 11pm

1. Setup one account on Kaggle with uni email ending @student.unimelb.edu.au.

2. Your project team is your syndicate team.

3. Connect with your team mates on Kaggle as a Kaggle team.2 Only submit via the team!

4. Register your team using the ‘team registration’ Google Forms link above. One registration per team.

5. Complete and upload the ‘Group Agreement’ form from Canvas, to Canvas to record team-mate expectations

within your syndicate.

4 Student Groups

Teams should match assigned syndicate groups. We will mark all teams based on our expectations of what a typical

syndicate team could achieve: you might consider roles such as researcher, feature engineering, learning, work-

flows/scripting, experimentation, ensembling of team models, generating validation data, etc. and divide your identified

roles among your team. We expect you to complete a ‘Group Agreement’ found on Canvas with this spec, and

upload it to Canvas. We recommend tools such as Slack or Trello for group coordination—you may use your platform

of choice.

By the date listed above, please enter the UoM and Kaggle usernames for each team member, along with Kaggle

team name—so that we may match teams to students—with the above registration Google Form (one response per

team, please).

We encourage active discussion among teams, but please refrain from colluding. Given your marks are partially

dependent on your final ranking in the competition, it is in your interest not to collude.

The ‘Group Agreement’ is important in the process of group work, in setting internal expectations. And platforms

like Slack/Trello/Git logs can be used to document contribution (or lack thereof ). In the rare circumstance a student

is penalised for lack of contribution, that student will have the opportunity to appeal. Again, we don’t expect this

process to come into effect for any teams—from past experience in a class of this size. In the past students report that

this kind of project work is challenging, rewarding and fun.

5 Report

1. A brief description of the problem and introduction of any notation that you adopt in the report.

2. Description of your final approach(s) to link prediction, the motivation and reasoning behind it, and why you

think it performed well/not well in the competition.

3. Any other alternatives you considered and why you chose your final approach over these (this may be in the

form of empirical evaluation, but it must be to support your reasoning - examples like “method A, got AUC 0.6

and method B, got AUC 0.7, hence we use method B”, with no further explanation, will be marked down).

2See e.g. https://www.quora.com/How-do-I-form-a-team-in-Kaggle

3

Your description of the algorithm should be clear and concise. You should write it at a level that a postgraduate student

can read and understand without difficulty. If you use any existing algorithms, please do not rewrite the complete

description, but provide a summary that shows your understanding and references to the relevant literature. In the

report, we will be interested in seeing evidence of your thought processes and reasoning for choosing one algorithm

over another.

Dedicate space to describing the features you used and tried, hyperparameters tuning, any interesting details

about software setup or your experimental pipeline, and any problems you encountered and what you learned. In

many cases these issues are at least as important as the learning algorithm, if not more important.

Report format rules. The report should be submitted as a PDF, and be no more than five pages, single column. The

font size should be 11 or above. If a report is longer than five pages in length, we will only read and assess the report

up to page five and ignore further pages. (Don’t waste space on cover pages.)

6 Submission

In addition to pre-submission of the ‘team registration’ Google Form and ‘group agreement’ PDF to Canvas, the final

submission will consist of three parts by the overall project deadline:

• A valid submission to the Kaggle in class competition. This submission must be of the expected format as

described above, and produce a place somewhere on the leaderboard. Invalid submissions do not attract marks

for the competition portion of grading (see Section 7).

• To Canvas, a zip archive of your source code of your link prediction algorithm in any language including any

scripts for automation, and a README.txt describing in just a few lines what files are for (but no data please).

• To Canvas, a written research report in PDF format (see Section 5).

The submission link will be visible in Canvas prior to deadline.

7 Assessment

The project will be marked out of 30 and contribute 30 percent towards your subject total mark. No late submissions

accepted. You must inform your lecturer about sickness well before the deadline. Submit early and often to guard

against unexpected last minute issues.

The assessment in this project will be broken down into two components. The following criteria will be considered

when allocating marks.

Based on our experimentation with the project task, we expect that all reasonable efforts at the project will achieve

a passing grade or higher.

Kaggle Competition (15/30):

Your final mark for the Kaggle competition is based on your rank in that competition. Assuming N teams of

enrolled students compete, there are no ties and you come in at R place (e.g. first place is 1, last is N) with an AUC of

A ∈ [0, 1] then your mark is calculated as

12×

max{min{A, 0.80}−0.4, 0}

0.40

+3×

N −R

N −1

.

Ties are handled so that you are not penalised by the tie: tied teams receive the rank of the highest team (as if no

team were tied). This expression can result in marks from 0 to 15. For example, if teams A, B, C, D, E came 1st, 4th,

2nd, 2nd, 5th, then the rank-based mark terms (out of 5) for the five teams would be 3, 0.75, 2.25, 2.25, 0.

4

This complicated-looking expression can result in marks from 0 all the way to 15. We are weighing more towards

your absolute AUC than your ranking. The component out of 12 for AUC gives a score of 0/12 for AUC of 0.4 or lower;

12/12 for AUC of 0.8 or higher; and linearly scales over the interval of AUCs [0.4, 0.8]. We believe that much higher

than 0.5 (random classifier) AUC is achievable with minimal work, while 0.8 AUC is an excellent result deserving of full

marks. For example, an AUC of 0.7 for a team coming last would yield 9/15; or 10.5/15 if coming mid-way in the class.

The rank-based term encourages healthy competition and discourages collusion. The other AUC-based term -

rewards teams who don’t place in the top but none-the-less achieve good absolute results.

Note that invalid submissions will come last and will attract a mark of 0 for this part, so please ensure your output

conforms to the specified requirements.

Report (15/30):

The below marking rubric outlines the criteria that will be used to mark your report.

5

Critical Analysis Report Clarity and Structure

(Maximum = 10 marks) (Maximum = 5 marks)

10 marks 5 marks

Final approach is well motivated and its

advantages/disadvantages clearly discussed;

thorough and insightful analysis of why the final

approach works/not work for provided training

data; insightful discussion and analysis of other

approaches and why they were not used

Very clear and accessible description of all that has

been done, a postgraduate student can pick up the

report and read with no difficulty.

8 marks 4 marks

Final approach is reasonably motivated and its

advantages/disadvantages somewhat discussed;

good analysis of why the final approach

works/not work for provided training data; some

discussion and analysis of other approaches and

why they were not used

Clear description for the most part, with some minor

deficiencies/loose ends.

6 marks 3 marks

Final approach is somewhat motivated and its

advantages/disadvantages are discussed; limited

analysis of why the final approach works/not

work for provided training data; limited

discussion and analysis of other approaches and

why they were not used

Generally clear description, but there are notable

gaps and/or unclear sections.

4 marks 2 mark

Final approach is marginally motivated and its

advantages/disadvantages are discussed; little

analysis of why the final approach works/not

work for provided training data; little or no

discussion and analysis of other approaches and

why they were not used

The report is unclear on the whole and the reader

has to work hard to discern what has been done.

2 marks 1 mark

Final approach is barely or not motivated and its

advantages/disadvantages are not discussed; no

analysis of why the final approach works/not

work for provided training data; little or no

discussion and analysis of other approaches and

why they were not used

The report completely lacks structure, omits all

key references and is barely understandable.

Plagiarism policy: You are reminded that all submitted project work in this subject is to be your own individual

team work. Automated similarity checking software will be used to compare submissions. It is University policy that

academic integrity be enforced. For more details, please see the policy at http://academichonesty.unimelb.edu.

au/policy.html.

6


版权所有:编程辅导网 2021 All Rights Reserved 联系方式:QQ:99515681 微信:codinghelp 电子信箱:99515681@qq.com
免责声明:本站部分内容从网络整理而来,只供参考!如有版权问题可联系本站删除。 站长地图

python代写
微信客服:codinghelp