Skip to main content

A library aiding to create challenges for the AnoMed competition platform.

Project description

Code style: black pipeline status coverage

Challenge

A library aiding to create challenges for the AnoMed competition platform.

Usage Example

The following example will create a Falcon-based web app that serves the famous iris dataset and uses plain binary accuracy as an evaluation metric. In more detail, these routes are offered (some may have query parameters not mentioned here):

  • [GET] / (this displays an "alive message")
  • [GET] /data/anonymizer/training (this will serve X_train and y_train)
  • [GET] /data/anonymizer/tuning (this will serve X_tune)
  • [GET] /data/anonymizer/validation (this will serve X_val)
  • [GET] /data/deanonymizer/members (this will serve a subset of X_train and y_train)
  • [GET] /data/deanonymizer/non-members (this will serve a subset of X_val and y_val)
  • [GET] /data/attack-success-evaluation (this will serve data from the complement of members and also from the complement of non-members).
  • [POST] /utility/anonymizer (this will evaluate the quality of an anonymizer's prediction compared to y_tune or y_val.)
  • [POST] /utility/deanonymizer (this will evaluate the quality of a denanonymizer's prediction compared to attack-success-evaluation)
import anomed_challenge as anochal
from sklearn import datasets, model_selection

iris = datasets.load_iris()

X = iris.data  # type: ignore
y = iris.target  # type: ignore

X_train, X_other, y_train, y_other = model_selection.train_test_split(
    X, y, test_size=0.3, random_state=42
)
X_tune, X_val, y_tune, y_val = model_selection.train_test_split(
    X_other, y_other, test_size=0.5, random_state=21
)

example_challenge = anochal.SupervisedLearningMIAChallenge(
    training_data=anochal.InMemoryNumpyArrays(X=X_train, y=y_train),
    tuning_data=anochal.InMemoryNumpyArrays(X=X_tune, y=y_tune),
    validation_data=anochal.InMemoryNumpyArrays(X=X_val, y=X_val),
    anonymizer_evaluator=anochal.strict_binary_accuracy,
    MIA_evaluator=anochal.evaluate_MIA,
)

# This is what GUnicorn expects
application = anochal.supervised_learning_MIA_challenge_server_factory(
    example_challenge
)

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

anomed_challenge-0.0.13.tar.gz (14.1 kB view details)

Uploaded Source

Built Distribution

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

anomed_challenge-0.0.13-py3-none-any.whl (13.4 kB view details)

Uploaded Python 3

File details

Details for the file anomed_challenge-0.0.13.tar.gz.

File metadata

  • Download URL: anomed_challenge-0.0.13.tar.gz
  • Upload date:
  • Size: 14.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.16

File hashes

Hashes for anomed_challenge-0.0.13.tar.gz
Algorithm Hash digest
SHA256 7d020801ff214e9ef25337d07abf03c425ad1c8e371d7b019c79b5230e4b9351
MD5 a89ed63dfe076b4da8d11bfde1faef5b
BLAKE2b-256 0766ed77ad55b9b7d9501a902feb837fd3a51e522f04e4950c419a86300c2fc5

See more details on using hashes here.

File details

Details for the file anomed_challenge-0.0.13-py3-none-any.whl.

File metadata

File hashes

Hashes for anomed_challenge-0.0.13-py3-none-any.whl
Algorithm Hash digest
SHA256 da6c839ef08730a5442a36d95016b2c33abf19d8e80e2eca92cd1427647df602
MD5 7219a14a8975ecbcd22bbc73a3645953
BLAKE2b-256 e110dcf86d9bba68b2aa722052e119c4c58629cb5dda2a50ffbe83b48b48a28e

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