Assignment 1: Finding the minimum in a 2D space

Deadline: Nov, 20 2023 14:00 CET

Finding the minimum point of functions is an important topic in many disciplines, including machine learning and natural language processing. In this exercise, we will work on a simpler (in some ways more difficult) form of the problem. Given a matrix (2D grid) of values that come from a strictly convex function, we want to find the minimum value in the matrix. We further assume that the true minimum is within our grid.

A visualization of an example concave function is provided below. You can re-genrate the visualization, or visualize other potential input matrices using visualization script.

example data

The above simplifications means you are working with a constrained problem, where a greedy algorithm (possibly with some memoization) can work faster than a general purpose min() implementation.

Exercise

Implement the function find_minimum() in the template. Your code should run for any matrix whose values are sampled from a strictly convex function given a grid of (x, y) values.

Furthermore, your function should be faster than the generic min() implementation from numpy.

As usual, your implementation should pass the provided tests.

Wrapping up

Do not forget to