Skip to content

Latest commit

 

History

History
25 lines (15 loc) · 2.02 KB

README.md

File metadata and controls

25 lines (15 loc) · 2.02 KB

Performance (part 2)

Build Status

This assignment helps you explore concepts from the analysis of algorithms, specifically the "big-O" notation and its use in evaluating implementations.

Steps:

  1. Fill out the (minimal) starter code in src/. Make sure the (minimal) tests pass on your implementations.

  2. Answer the following question: why do the tests for unique_set use sort, but the test for unique_2loops do not? If you get stuck, see ?Set.

  3. Create the benchmarks in benchmarks/run_benchmarks.jl. The end result should be a few global variables that store information about the sizes of the lists and the runtime needed to execute the algorithm(s).

  4. Pick a plotting package (your choice): popular options include Makie, Plots, and PyPlot. Makie is not recommended for this assignment unless you're running at least Julia 1.9. (Makie is the most sophisticated and a good investment for anyone considering Julia for the long term, but it currently has long load and precompilation times; Plots or PyPlot are leaner options. Any of these should be more than sufficient for this assignment.)

  5. Plot your results, filling out a plotting script in plot_benchmarks.jl.

  6. In big-O notation, what order is unique_2loops when there are only 10 unique items? What is its order when the number of unique items is half the length of the list? For the same two cases, what order is unique_set?

  7. To get a glimpse of how Sets work, fill out the exercise in examples/hashtable.jl. Then fill out the number of "hash collisions" (slots in the table that got more than one item inserted in them) for tables of the following sizes:

    • 16:
    • 32:
    • 64:
    • 128: