Giter Site home page Giter Site logo

thomaswong2022 / numerapi Goto Github PK

View Code? Open in Web Editor NEW

This project forked from uuazed/numerapi

0.0 1.0 0.0 520 KB

Python API and command line interface for the numer.ai machine learning competition

Home Page: http://numerapi.readthedocs.io

License: MIT License

Python 100.00%

numerapi's Introduction

Build Status codecov PyPI Docs Requirements Status

Numerai Python API

Automatically download and upload data for the Numerai machine learning competition.

This library is a Python client to the Numerai API. The interface is programmed in Python and allows downloading the training data, uploading predictions, and accessing user, submission and competitions information. It works for both, the main competition and the newer Numerai Signals competition.

If you encounter a problem or have suggestions, feel free to open an issue.

Installation

pip install --upgrade numerapi

Usage

Numerapi can be used as a regular, importable Python module or from the command line.

Some actions (like uploading predictions or staking) require a token to verify that it is really you interacting with Numerai's API. These tokens consists of a public_id and secret_key. Both can be obtained by login in to Numer.ai and going to Account -> Custom API Keys. Tokens can be passed to the Python module as parameters or you can be set via environment variables (NUMERAI_PUBLIC_ID and NUMERAI_SECRET_KEY).

Python module

Usage example - main competition

import numerapi
# some API calls do not require logging in
napi = numerapi.NumerAPI(verbosity="info")
# download current dataset
napi.download_current_dataset(unzip=True)
# get competitions
all_competitions = napi.get_competitions()
# get current leaderboard
leaderboard = napi.get_leaderboard()
# check if a new round has started
if napi.check_new_round():
    print("new round has started within the last 24hours!")
else:
    print("no new round within the last 24 hours")

# provide api tokens
example_public_id = "somepublicid"
example_secret_key = "somesecretkey"
napi = numerapi.NumerAPI(example_public_id, example_secret_key)

# upload predictions
model_id = napi.get_models()['uuazed']
napi.upload_predictions("preds.csv", model_id=model_id)
# check submission status
napi.submission_status(model_id)
# increase your stake by 1.2 NMR
napi.stake_increase(1.2)

# convert results to a pandas dataframe
import pandas as pd
df = pd.DataFrame(napi.daily_user_performances("uuazed"))

Usage example - Numerai Signals

import numerapi

napi = numerapi.SignalsAPI()
# get current leaderboard
leaderboard = napi.get_leaderboard()

# setup API with api tokens
example_public_id = "somepublicid"
example_secret_key = "somesecretkey"
napi = numerapi.SignalsAPI(example_public_id, example_secret_key)

# upload predictions
model_id = napi.get_models()['uuazed']
napi.upload_predictions("preds.csv", model_id=model_id)

# get submission status and invalid tickers
status = napi.submission_status(model_id)
invalid_tickers = status['invalidTickers']

# get daily performance as pandas dataframe
import pandas as pd
df = pd.DataFrame(napi.daily_user_performances("uuazed"))

Command line interface

To get started with the cli interface, let's take a look at the help page:

$ numerapi --help
Usage: numerapi [OPTIONS] COMMAND [ARGS]...

  Wrapper around the Numerai API

  Options:
    --help  Show this message and exit.

  Commands:
    account                         Get all information about your account!
    check-new-round                 Check if a new round has started within...
    competitions                    Retrieves information about all...
    current-round                   Get number of the current active round.
    daily-model-performances        Fetch daily performance of a model.
    daily-submissions-performances  Fetch daily performance of a user's...
    dataset-url                     Fetch url of the current dataset.
    download-dataset                Download specified file for the given...
    download-dataset-old            Download dataset for the current active...
    leaderboard                     Get the leaderboard.
    list-datasets                   List of available data files
    models                          Get map of account models!
    profile                         Fetch the public profile of a user.
    stake-decrease                  Decrease your stake by `value` NMR.
    stake-drain                     Completely remove your stake.
    stake-get                       Get stake value of a user.
    stake-increase                  Increase your stake by `value` NMR.
    submission-filenames            Get filenames of your submissions
    submission-status               checks the submission status
    submit                          Upload predictions from file.
    transactions                    List all your deposits and withdrawals.
    user                            Get all information about you! DEPRECATED...
    version                         Installed numerapi version.

Each command has it's own help page, for example:

$ numerapi submit --help
Usage: numerapi submit [OPTIONS] PATH

  Upload predictions from file.

Options:
  --tournament INTEGER  The ID of the tournament, defaults to 1
  --model_id TEXT       An account model UUID (required for accounts with
                        multiple models

  --help                Show this message and exit.

API Reference

Checkout the detailed API docs to learn about all available methods, parameters and returned values.

numerapi's People

Contributors

uuazed avatar wsteitz avatar xanderdunn avatar atreichel avatar philipcmonk avatar liamhz avatar jparyani avatar mangstad avatar dhj-io avatar benschreyer avatar stoyandimov avatar ndharasz avatar jeethu avatar wtvr-ai avatar michael-phillips-data avatar joerenner avatar habakan avatar dependabot[bot] avatar algonell avatar talhaasmal avatar npezolano avatar ledmaster avatar kwgoodman avatar jpmcd12 avatar jrdi avatar jkom329 avatar gerstej9 avatar edoffagne avatar cshanes avatar kumikoda avatar

Watchers

James Cloos 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.