Skip to main content

Internal tools to use the SGE grid at Idiap Research Institute

Project description

GridSearch-like on the grid

Searching good combinaisons of parameters happen quite ofter in ML-related task. I wrote a tool that help to achieve that. If you worked with the unix system call fork, you will see a similar approach with the API.

The only requirement is jinja2

Hello World example

In this example we wrote all combinaisons of hello/hi world/Idiap.

from easy_grid.experiences_manager import ExperienceBase

if __name__ == '__main__':
    if ExperienceBase.is_in_SGE(): # Write your task
        parameters = ExperienceBase.load_only_current()
        first = parameters['first']
        second = parameters['second']
        print('{} {}'.format(first, second))
    else: # Configure your task
        my_experience = ExperienceBase(python_executable='python3')
        my_experience.add_experience_key_values('first', ['hello', 'hi'])
        my_experience.add_experience_key_values('second', ['world', 'idiap'])

        my_experience.add_grid_parameter('-P', 'rise')
        my_experience.add_grid_parameter('-cwd', '')
        my_experience.add_grid_parameter('-N', 'hello_world')

        my_experience.add_export_parameter('PYTHONPATH', '.:$PYTHONPATH')

        my_experience.run(sync=True)

Run the example python3 -m examples.hello_world then check the results after running the script (and waiting a little bit) ls -1 output/hello_world.o*

output/hello_world.o5439319.1
output/hello_world.o5439319.2
output/hello_world.o5439319.3
output/hello_world.o5439319.4

Each file contains the result of a combinaison. Let's check the content of the first one cat output/hello_world.o5439319.1

hello world

Get all results at once cat output/hello_world.o*

hello world
hi world
hello idiap
hi idiap

FizzBuzz example

We can also use task over a single parameter, like in fizzbuzz, which depend of n. Here an example with fizzbuzz from [1, 100]

from easy_grid.experiences_manager import ExperienceBase

if __name__ == '__main__':
    if ExperienceBase.is_in_SGE(): # Write your task
        parameters = ExperienceBase.load_only_current()
        n = parameters['n']
        my_str = ''
        if n % 3 == 0: 
            my_str += 'Fizz'
        if n % 5 == 0: 
            my_str += 'Buzz'
        if my_str == '': 
            my_str = str(n)
        print('(n={:04d}) -> {}'.format(n, my_str))
    else: # Configure your task
        my_experience = ExperienceBase()
        my_experience.add_experience_key_values('n', list(range(1, 101)))

        my_experience.add_grid_parameter('-P', 'rise')
        my_experience.add_grid_parameter('-cwd', '')
        my_experience.add_grid_parameter('-N', 'fizzbuzz')

        my_experience.add_export_parameter('PYTHONPATH', '.:$PYTHONPATH')

        my_experience.run(sync=True)

Run the example python3 -m examples.fizzbuzz

Get all results at once and sort by n cat output/fizzbuzz.o* | sort

(n=0001) -> 1
(n=0002) -> 2
(n=0003) -> Fizz
(n=0004) -> 4
(n=0005) -> Buzz
(n=0006) -> Fizz
(n=0007) -> 7
(n=0008) -> 8
(n=0009) -> Fizz
(n=0010) -> Buzz
(n=0011) -> 11
...
(n=0090) -> FizzBuzz
(n=0091) -> 91
(n=0092) -> 92
(n=0093) -> Fizz
(n=0094) -> 94
(n=0095) -> Buzz
(n=0096) -> Fizz
(n=0097) -> 97
(n=0098) -> 98
(n=0099) -> Fizz
(n=0100) -> Buzz

Using with conda environment

You can use conda run with the python_executable parameter

my_experience = ExperienceBase(python_executable="/idiap/user/wdroz/conda_stuff/miniconda3/condabin/conda run -n rise-baseline python3")

you need to specify the full path of conda

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

easy_grid-wdroz-0.0.8.tar.gz (5.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

easy_grid_wdroz-0.0.8-py3-none-any.whl (5.9 kB view details)

Uploaded Python 3

File details

Details for the file easy_grid-wdroz-0.0.8.tar.gz.

File metadata

  • Download URL: easy_grid-wdroz-0.0.8.tar.gz
  • Upload date:
  • Size: 5.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.2.0.post20200714 requests-toolbelt/0.9.1 tqdm/4.48.0 CPython/3.8.3

File hashes

Hashes for easy_grid-wdroz-0.0.8.tar.gz
Algorithm Hash digest
SHA256 aee09c4318827a5c0c3ca9fb4d732afeb02f664e84cf50bc75380e43c74afd0d
MD5 e47478e295c7e8b83cf039727aaa4c94
BLAKE2b-256 648bae3d76de7f8f05c06f51f52c1344153200558b0763657c641998e96a6837

See more details on using hashes here.

File details

Details for the file easy_grid_wdroz-0.0.8-py3-none-any.whl.

File metadata

  • Download URL: easy_grid_wdroz-0.0.8-py3-none-any.whl
  • Upload date:
  • Size: 5.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.2.0.post20200714 requests-toolbelt/0.9.1 tqdm/4.48.0 CPython/3.8.3

File hashes

Hashes for easy_grid_wdroz-0.0.8-py3-none-any.whl
Algorithm Hash digest
SHA256 c7e3d88f72270541700e48f4cf78bd625aa9f668a9b9369c83f3d1d970c9f914
MD5 971d699a82f8b7e04b96e313ea48aa4d
BLAKE2b-256 1e38da4fc763da98ffdf041d67e20502f73a22a2fc6ca0e4fff95f9cea84bcdf

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page