Wow, this is a tough one. I usually have an easy time figuring out how to solve small problems like this, but I'm stuck.
I'm trying to write a function that return which tile the mouse is currently hovering over on an isometric map. The code I sue to draw the tiles is the same as in the tutorial:
I suggest you make functions for going between the two coordinate systems. Write it out the maths. Let (x,y) be the old coordinates and (s,t) the new. There are some constants a,b,c,d,e,f such that
s = ax + by + c
t = dx + ey + f
For you, a would be map.tile_w / 2 , b would be -map.tile_w / 2 etc. All you have to do is invert it, i.e. express x in terms of s and t by cancelling out y, and then the same for y while cancelling out x. (although I would get rid of c and f and leave that for the view)
The case that Robin is referring to is considerably more advanced since your screen coordinates - a 2D space - in general does not correspond to a unique point in a rendered 3D space. Instead they have to generate all the possible candidates and see if there is a corresponding tile. You can use it for inspiration but beware that they are doing much more than you need to.