Coder Social home page Coder Social logo

umutto / hill-climbing-irl Goto Github PK

View Code? Open in Web Editor NEW
3.0 1.0 0.0 23.62 MB

Hill climbing algorithms (including gradient descent variations) applied on real world surface.

License: MIT License

Python 73.33% HTML 26.67%
python machine-learning gradient-descent hill-climbing visualization optimization-algorithms

hill-climbing-irl's Introduction

Hill Climbing IRL

This repository is based on well thought Physical Gradient Descent repository from Chris Foster's blog post.

Thought it was pretty neat, and wanted to see how other Hill climbing algorithms would fare with each other in a real world (literally) use case. While doing that, refactored the code for my better understanding.

Unfortunately, real world geography is not a good test case for gradient descent kind of algorithms since the aim of reaching ocean is very easy to do (just have bigger steps.). Meanwhile hill climbing or gradient ascent fits perfectly.

Luckly, this can be easily solved by turning the world inside out, thus turning it into a great problem for finding global/local minima or just reversing the loss / slope and changing the algorithms adapt for finding the global/local maxima. Inversing the world was the easiest, so I've done that.

In this repository, I've experimented with climbing the mountain my university sits on from a nearby seaside. It works pretty well and can see interesting paths from different algorithms (like mostly momentum based algorithms overshooting at first).

You can change the starting location from params.json

{
    "_comment": "Starting coordinates",
    "center": {
        "lat": 40.953845,
        "lng": 29.095831
    },
    "_comment": "output path for the CSV files, if changed need to change visualizer.html too",
    "output": "outputs/",
    "_comment": "number of steps to take until convergence",
    "iters": 500,
    "_comment": "elevation map from SRTM Tile Grabber",
    "tif": "tifs/srtm_42_04.tif"
}

If you only want some of the algorithms visualized, or want a different color scheme, you can edit the methods dictionary in run.py

"""
fun: function
  Function reference for the algorithm used, gets a custom RasterMap object, start coordinates and hyperparameters
color: string
  Color to use for visualization.
"""
methods = {
    'Gradient Descent': {'fun': opt.gradient_descent, 'color': '#FF0000'},
    'Momentum': {'fun': opt.gradient_descent_w_momentum, 'color': '#009933'},
    'NAG': {'fun': opt.gradient_descent_w_nesterov, 'color': '#9900FF'},
    'Adagrad': {'fun': opt.adagrad, 'color': '#0066FF'},
    'RMSprop': {'fun': opt.RMSprop, 'color': '#000000'},
    'Adam': {'fun': opt.adam, 'color': '#FFFF00'},
    'Simulated Annealing': {'fun': opt.simulated_annealing, 'color': '#ED7504'},
    'Stochastic Hill Climb': {'fun': opt.stochastic_hill_climb, 'color': '#F442C5'},
    'Tabu Search': {'fun': opt.tabu_search, 'color': '#56FCFF'}
}

If you want to add new optimizer algorithms, you can add function reference with a similar signature to methods dictionary.

Results:

Hill Climbing From Bostanci
Cost per itration plot for common gradient descent algorithms.

Hill Climbing From Bostanci
Example output of common gradient descent algorithms.

You can follow the original instructions from Chris Foster below, it should work for this repository as well.


This is code for adapting the gradient descent algorithm to run on earth's actual geometry. You can read more about this in the attached blog post.

Running gradient descent

You'll need Python 3, and can install the dependencies with:

> virtualenv -p python3 env
> source env/bin/activate
> pip install -r requirements.txt

And run gradient descent like so:

(env)> python gradientdescent.py 47.801686 -123.709083 ~/Downloads/srtm_12_03/srtm_12_03.tif

A number of parameter tweaking options are supported:

usage: gradientdescent.py [-h] [--output OUTPUT] [--alpha ALPHA]
                          [--gamma GAMMA] [--iters ITERS]
                          lat lon tif

You can get TIF files from this tile grabber!

Running the visualizer

The visualizer makes AJAX requests, so you will need to serve it from a web server instead of just opening the HTML file on the filesystem. You can do that easily with Python if you prefer, which will serve the local directory:

> python -m http.server

Then access http://localhost:8000 and the visualizer will start. You may have to update the key used inside the HTML by editing the file to your own Google Maps API key.

hill-climbing-irl's People

Contributors

umutto avatar

Stargazers

 avatar  avatar  avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.