Skip to content

oceans404/nada-linear-regression-housing

Repository files navigation

Linear regression on housing data with blind inference

Inference is the process of using a trained model to make predictions or decisions based on new, unseen data. It is the phase where the model is applied to input data to generate an output, such as a prediction or classification.

In this example I ran blind inference on Nillion to predict the house price of a new input home based on 12 features: area, bedrooms, bathrooms, stories, mainroad, guestroom, basement, hotwaterheating, airconditioning, parking, prefarea, furnishingstatus. The inference is "blind" because the party running the price prediction with the new input never sees the trained model state. Instead, the trained model state is provided to the Nada program as a secret.

Result of running main.py:

  • Screenshot 2024-06-24 at 10 23 45 AM

Model trained with this housing dataset: https://www.kaggle.com/datasets/yasserh/housing-prices-dataset/data

How it works

Two parties, Party0 and Party1, are involved in the blind inference process. The Nada program linear_regression_12.py is designed to handle 12 specific housing features.

Party0's Role:

  • Party0 stores the linear_regression_12 Nada program in the network.
  • Party0 takes the housing dataset and trains a linear regression model using scikit-learn.
  • After training, Party0 stores the model state as a secret in Nillion, giving Party1 computation permissions for this secret.

Party1's Role:

  • Party1 creates a new input with an array of features (e.g., area, bedrooms, bathrooms, etc.).
  • Party1 computes with the linear_regression_12 program to run blind inference on the secret trained model. This involves passing their new input as a compute-time secret.
  • Party1 receives the output of linear_regression_12, which is the predicted price of a house based on their input features without ever seeing the trained model state, ensuring the model parameters remain confidential.

Run this example

Install the nillion sdk

Install nilup:

curl https://nilup.nilogy.xyz/install.sh | bash

Install and set your version of the nillion sdk - this installs nillion-devnet and other tools

nilup install latest
nilup use latest

Spin up the local nillion-devnet

In one terminal, run the nillion-devnet

nillion-devnet --seed my-seed

Keep the devnet running. Open a new command line tab and copy the output from "🌄 environment file written to {your nillion env} to .env to create a .env file with the configuration from nillion-devnet. Alternatively, fill in these values manually using

Modify this command based on your nillion-devnet.env path:

cp /Users/steph/.config/nillion/nillion-devnet.env .env

Install dependencies

python3 -m venv .venv
source .venv/bin/activate
pip install -r requirements.txt

Optionally update home feature values in the main.py file to change new_input to your desired home traits

Run python3 main.py

About

linear regression with nada on nillion using housing data

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages