 
                In this problem, you will create a graph from provided Facebook data. Creating the facebook graph is all you have to do for this problem, as we will use this graph for Problems 6, 7, and 8.
The facebook-links-small.txt file in your homework5 directory is courtesy of the Max Planck Institute for Software Systems. Here is a slightly clarified version of the documentation for this file:
Description: The file
facebook-links-small.txtcontains a list of all of the user-to-user links from the Facebook New Orleans networks. These links are undirected on Facebook.Format: Each line contains two numeric user identifiers, meaning the second user appeared in the first user’s friend list, and the first user appeared in the second user’s friend list. Finally, the third column is a UNIX timestamp with the time of link establishment (if it could be determined, otherwise it is ‘N‘).
Info
A Unix timestamp is the number of seconds since January 1, 1970. You may ignore timestamps in this assignment. (Facebook does use the recency of your activity to help it make recommendations.)
A snippet of the file appears below:
35467    17494    1197992662
35467    4190    \N
35467    18822    1209937599
37188    7741    1219156787
37188    8561    1199853037
Important
When reading in this data you should be sure to convert the numeric user identifiers into ints. Storing them as ints will make your life easier and is the output format that we require for printing (Do NOT print a user ID as the string '19611'; instead print it as the integer 19611.) This means your code should work whether nodes are named with strings (as we did with the practice graphs) or ints (as we are doing with the facebook data). In NetworkX, nodes can be strings or integers.
Create a graph named facebook from the Facebook data in file facebook-links-small.txt. You should implement get_facebook_graph() as a helper function. As in Part 1, use the Graph class from the NetworkX module.
Note
facebook-links-small.txt can be used to test your code. Sample output for this file is found in facebook-links-small-output.txt. You can use the Diff Checker tool to compare your output to the sample output. Feel free to make even smaller files of your own for testing purposes! Although data in facebook-links-small.txt isn’t sorted, your solution should produce sorted output regardless of how original data is organized in the file.
You do not need to read in the file name from the command line as we did in previous homeworks. Instead, you can assume that the file facebook-links-small.txt will be present in the same directory as social_network.py and use the filename "facebook-links-small.txt" in your program as needed.
Tip
You may find it useful to refer to the slides about File I/O.
Tip
We recommend that you run the program from the command line as you have before, although hitting the triangle button in VSCode should also work.
In order to test your function, change facebook-links-small.txt to facebook-links.txt and run your code to make sure it passes both assert statements in social_network.py, which check that the number of nodes and edges in your graph. Are there other tests you could write to convince yourself that the graph was created correctly?
Make sure to change your code to use facebook-links-small.txt and comment out both assert statements before submitting.
For every Facebook user with a user id that is a multiple of 1000, print a list containing the first 10 friend recommendations, as determined by “number of common friends” friendship score. If there are fewer than 10 recommendations, print all the recommendations.
You can review more details about the format for the printed output in the Setup section. This is a sample of part of what you would expect for your output (you should be printing more lines than this, and they should be listed in ascending order of userID as shown below (e.g. user 28000, followed by user 29000, etc.):
...
 28000 (by num_common_friends): [23, 1445, 4610, 7996, 10397, 11213, 56, 85, 471, 522]
 29000 (by num_common_friends): [28606]
 30000 (by num_common_friends): [862, 869, 919, 941, 3154, 8180, 8269, 8614, 14473, 14495]
...
Tip
List slices may be useful for Problem 6 and 7.
Important
You should be printing more lines than this, and they should be listed in ascending order of userID (e.g. user 28000, followed by user 29000, etc.)
For every Facebook user with a user id that is a multiple of 1000, print a list containing the first 10 friend recommendations as determined by the “influence” friendship score. If there are fewer than 10 recommendations, print all the recommendations. Again, the format for the printed output is in the Output Format section. This is a sample of part of what you would expect for your output:
...
28000 (by influence): [7033, 17125, 15462, 33049, 51105, 16424, 23, 7996, 725, 1539]
29000 (by influence): [28606]
30000 (by influence): [862, 869, 919, 941, 3154, 8269, 14473, 14495, 17951, 19611]
...
Important
You should be printing more lines than this, and they should be listed in ascending order of userID (e.g. user 28000, followed by user 29000, etc.)
Considering only those 63 Facebook users with an id that is a multiple of 1000, compute and print the number of Facebook users who have the same first 10 friend recommendations under both recommendation systems, and the number of Facebook users who have different first 10 friend recommendations under the two recommendation systems.
For example, in the data above, user 29000 has the same first ten recommendations under both recommendation systems, while user 28000 and user 30000 both have different recommendations under the two recommendation systems. This program may take some time to compute (possibly a minute or so) depending on the efficiency of your solution.
The format of this problem’s printed output is given in the Output Format section.
Be sure that your code is in its final version before turning it in.
facebook.facebook graph is using the data from facebook-links-small.txt and not facebook-links.txt. Not doing so will cause our autograder to fail. We will be replacing the file in the background with contents in facebook-links-small.txt, so don’t be surprised if the autograder shows a different output than the one you see on your computer.