Exemplo n.º 1
0
def main():
    # Setup container manager.
    # k8 = KubernetesContainerManager(kubernetes_proxy_addr="127.0.0.1:8080",
    #                                 useInternalIP=True)
    # clipper_conn = ClipperConnection(k8)
    swarm = DockerContainerManager()
    clipper_conn = ClipperConnection(swarm)
    clipper_conn.stop_all()
    clipper_conn.start_clipper()

    # Register application.
    clipper_conn.register_application(name="sum-app", 
                                      input_type="doubles", 
                                      default_output="-1.0", 
                                      slo_micros=10000000)

    # Model deployement.
    python_deployer.deploy_python_closure(clipper_conn, 
                                          name="sum-model", 
                                          version=1, 
                                          input_type="doubles", 
                                          func=sum)

    # Link application to model.
    clipper_conn.link_model_to_app(app_name="sum-app", 
                                   model_name="sum-model")

    # Test
    headers = {"Content-type": "application/json"}
    response = requests.post("http://localhost:1337/sum-app/predict", 
                             headers=headers, 
                             data=json.dumps({"input": list(np.random.random(10))})).json()
    print(response)
Exemplo n.º 2
0
    def test_deployed_python_closure_queried_successfully(self):
        model_version = 1

        def predict_func(inputs):
            return [str(len(x)) for x in inputs]

        input_type = "doubles"
        deploy_python_closure(self.clipper_conn, self.model_name_1,
                              model_version, input_type, predict_func)

        self.clipper_conn.link_model_to_app(self.app_name_1, self.model_name_1)
        time.sleep(60)

        received_non_default_prediction = False
        addr = self.clipper_conn.get_query_addr()
        url = "http://{addr}/{app}/predict".format(addr=addr,
                                                   app=self.app_name_1)
        test_input = [101.1, 99.5, 107.2]
        req_json = json.dumps({'input': test_input})
        headers = {'Content-type': 'application/json'}
        for i in range(0, 40):
            response = requests.post(url, headers=headers, data=req_json)
            parsed_response = response.json()
            print(parsed_response)
            output = parsed_response["output"]
            if output == self.default_output:
                time.sleep(20)
            else:
                received_non_default_prediction = True
                self.assertEqual(int(output), len(test_input))
                break

        self.assertTrue(received_non_default_prediction)
def auth_deploy_python_model(clipper_conn,
                             model_name,
                             wave_obj,
                             recipient_entity,
                             ciphertext,
                             version=1,
                             input_type="doubles"):
    '''Deploy a Python function with a python model.

    Parameters
    ----------
    clipper_conn : :py:meth:`clipper_admin.ClipperConnection`
        A ``ClipperConnection`` object connected to a running Clipper cluster.
    name : str
        The name to be assigned to both the registered application and deployed model.
    version : str
        The version to assign this model. Versions must be unique on a per-model
        basis, but may be re-used across different models.
    input_type : str
        The input_type to be associated with the registered app and deployed model.
        One of "integers", "floats", "doubles", "bytes", or "strings".
    func : function
        The prediction function. Any state associated with the function will be
        captured via closure capture and pickled with Cloudpickle.
    wave_obj: wave object
    recipient_entity: parameter for wave decrypt call
    ciphertext: text to be decoded
    '''
    decrypt_response = wave_obj.DecryptMessage(
        wv.DecryptMessageParams(perspective=wv.Perspective(
            entitySecret=wv.EntitySecret(DER=recipient_entity.SecretDER)),
                                ciphertext=ciphertext,
                                resyncFirst=True))
    if decrypt_response.error.code != 0:
        raise Exception("Incorrect authentication")

    model = cloudpickle.loads(decrypt_response.content)

    # temporarily put the predict method here...
    def predict(inputs):
        # model.predict returns a list of predictions
        preds = model.predict(inputs)
        return [str(p) for p in preds]

    py_deployer.deploy_python_closure(
        clipper_conn,
        name=model_name,
        version=version,
        input_type=input_type,
        func=predict,
        pkgs_to_install=["numpy", "scipy", "pandas", "sklearn"])
def main(version, label):
    from clipper_admin import ClipperConnection, KubernetesContainerManager
    clipper_conn = ClipperConnection(
        KubernetesContainerManager(useInternalIP=True))
    clipper_conn.connect()
    from clipper_admin.deployers import python as python_deployer
    registry = 'localhost:5000'
    python_deployer.deploy_python_closure(clipper_conn,
                                          name="sum-model",
                                          version=version,
                                          input_type="doubles",
                                          func=feature_sum,
                                          labels=[label],
                                          registry=registry)
Exemplo n.º 5
0
    def test_test_predict_function(self):
        def predict_func(xs):
            return [sum(x) for x in xs]

        self.clipper_conn.register_application(name="hello-world",
                                               input_type="doubles",
                                               default_output="-1.0",
                                               slo_micros=100000)

        deploy_python_closure(self.clipper_conn,
                              name="sum-model",
                              version=1,
                              input_type="doubles",
                              func=predict_func)
        self.clipper_conn.link_model_to_app(app_name="hello-world",
                                            model_name="sum-model")
        time.sleep(60)

        addr = self.clipper_conn.get_query_addr()

        # Added a trailing slash on predict url for test
        url = "http://{addr}/hello-world/predict/".format(addr=addr,
                                                          app='hello-world')

        headers = {"Content-type": "application/json"}
        test_input = [1.1, 2.2, 3.3]
        pred = requests.post(url,
                             headers=headers,
                             data=json.dumps({"input": test_input})).json()
        test_predict_result = self.clipper_conn.test_predict_function(
            query={"input": test_input},
            func=predict_func,
            input_type="doubles")
        logger.info("test pred output {}".format(pred))
        self.assertEqual([pred['output']],
                         test_predict_result)  # tests single input

        test_batch_input = [[1.1, 2.2, 3.3], [4.4, 5.5, 6.6]]
        batch_pred = requests.post(
            url,
            headers=headers,
            data=json.dumps({"input_batch": test_batch_input})).json()
        test_batch_predict_result = self.clipper_conn.test_predict_function(
            query={"input_batch": test_batch_input},
            func=predict_func,
            input_type="doubles")
        batch_predictions = batch_pred['batch_predictions']
        batch_pred_outputs = [batch['output'] for batch in batch_predictions]
        self.assertEqual(batch_pred_outputs,
                         test_batch_predict_result)  # tests batch input
Exemplo n.º 6
0
    def test_python_closure_deploys_successfully(self):
        model_name = "m2"
        model_version = 1

        def predict_func(inputs):
            return ["0" for x in inputs]

        input_type = "doubles"
        deploy_python_closure(self.clipper_conn, model_name, model_version,
                              input_type, predict_func)
        model_info = self.clipper_conn.get_model_info(model_name,
                                                      model_version)
        self.assertIsNotNone(model_info)

        docker_client = get_docker_client()
        py_minor_version = (sys.version_info.major, sys.version_info.minor)
        if py_minor_version < (3, 0):
            containers = docker_client.containers.list(
                filters={
                    "ancestor":
                    "clipper/python-closure-container:{}".format(
                        clipper_version)
                })

        elif py_minor_version == (3, 5):
            containers = docker_client.containers.list(
                filters={
                    "ancestor":
                    "clipper/python35-closure-container:{}".format(
                        clipper_version)
                })
        elif py_minor_version == (3, 6):
            containers = docker_client.containers.list(
                filters={
                    "ancestor":
                    "clipper/python36-closure-container:{}".format(
                        clipper_version)
                })
        else:
            msg = (
                "Python closure deployer only supports Python 2.7, 3.5, and 3.6. "
                "Detected {major}.{minor}").format(
                    major=sys.version_info.major, minor=sys.version_info.minor)
            logger.error(msg)

        self.assertGreaterEqual(len(containers), 1)
def deploy_and_test_model(clipper_conn,
                          model,
                          version,
                          predict_fn,
                          link_model=False):
    deploy_python_closure(clipper_conn,
                          model_name,
                          version,
                          "integers",
                          predict_fn,
                          batch_size=1,
                          pkgs_to_install=['xgboost'])
    time.sleep(5)

    if link_model:
        clipper_conn.link_model_to_app(app_name, model_name)
        time.sleep(5)

    test_model(clipper_conn, app_name, version)
Exemplo n.º 8
0
def deployModelToClipper():
    """Deploy model to clipper and replace its entry."""
    global app_name, model_name, model_version

    print('Deploying model to clipper, model_name={}, model_version={}'.format(
        model_name, model_version))

    # Setup clipper and deploy model
    clipper_conn = ClipperConnection(DockerContainerManager(redis_port=6380))
    try:
        clipper_conn.start_clipper()
    except:
        clipper_conn.connect()
    try:
        # input_type must be bytes as inputs will be serialized into bytes with pickle
        clipper_conn.register_application(name=app_name,
                                          input_type="bytes",
                                          default_output="-1.0",
                                          slo_micros=1000000)
    except Exception as e:
        print(e)
    try:
        deploy_python_closure(clipper_conn,
                              name=model_name,
                              version=model_version,
                              input_type="bytes",
                              batch_size=1,
                              func=predict,
                              base_image='hysia-clipper-base-container-gpu')
    except Exception as e:
        print(e)
    try:
        clipper_conn.link_model_to_app(app_name=app_name,
                                       model_name=model_name)
    except Exception as e:
        print(e)

    replaceDefaultEntry()
    print('{} deployed to clipper!'.format(model_name))
Exemplo n.º 9
0
    def test_fixed_batch_size_model_processes_specified_query_batch_size_when_saturated(
            self):
        model_version = 1

        def predict_func(inputs):
            time.sleep(.5)
            batch_size = len(inputs)
            return [str(batch_size) for _ in inputs]

        fixed_batch_size = 9
        total_num_queries = fixed_batch_size * 50
        deploy_python_closure(self.clipper_conn,
                              self.model_name_4,
                              model_version,
                              self.input_type,
                              predict_func,
                              batch_size=fixed_batch_size)
        self.clipper_conn.link_model_to_app(self.app_name_4, self.model_name_4)
        time.sleep(60)

        addr = self.clipper_conn.get_query_addr()
        url = "http://{addr}/{app}/predict".format(addr=addr,
                                                   app=self.app_name_4)
        test_input = [[float(x) + (j * .001) for x in range(5)]
                      for j in range(total_num_queries)]
        req_json = json.dumps({'input_batch': test_input})
        headers = {'Content-type': 'application/json'}
        response = requests.post(url, headers=headers, data=req_json)
        parsed_response = response.json()
        num_max_batch_queries = 0
        for prediction in parsed_response["batch_predictions"]:
            batch_size = prediction["output"]
            if batch_size != self.default_output and int(
                    batch_size) == fixed_batch_size:
                num_max_batch_queries += 1

        self.assertGreaterEqual(num_max_batch_queries,
                                int(total_num_queries * .7))
Exemplo n.º 10
0
def setup_clipper():

    app_name = 'predict-app'
    model_name = "predict-model"
    clipper_conn = ClipperConnection(DockerContainerManager())
    clipper_conn.connect()

    deploy_python_closure(clipper_conn,
                          name="predict-model",
                          version='1',
                          input_type="bytes",
                          func=join_predict)

    clipper_conn.register_application(name=app_name,
                                      input_type="bytes",
                                      default_output="-1.0",
                                      slo_micros=10000000)  # 10s

    clipper_conn.link_model_to_app(app_name=app_name, model_name=model_name)

    print(
        "url: ", "http://{addr}/{app_name}/predict".format(addr="",
                                                           app_name=app_name))
Exemplo n.º 11
0
    print(class_n)
    print(ret)
    return pred


# In[ ]:

from clipper_admin.deployers import python as python_deployer

# In[ ]:

# Deploy the "feature_sum" function as a model. Notice that the application and model
# must have the same input type.
python_deployer.deploy_python_closure(clipper_conn,
                                      name="sum-model",
                                      version=1,
                                      input_type="doubles",
                                      func=feature_sum)

# In[ ]:

# Deploy the "iris_predict" function as a model. Notice that the application and model
# must have the same input type.
python_deployer.deploy_python_closure(
    clipper_conn,
    name="iris-model",
    version=1,
    input_type="doubles",
    func=iris_predict,
    pkgs_to_install=['numpy', 'scipy', 'scikit-learn'])
Exemplo n.º 12
0
    print("inputs {}".format(X))
    try:
        result = clf.predict(X)
        print("result is {}".format(result))
        ret = [str(i) for i in result]
        print("return is {}".format(ret))
        return ret
    except Exception as e:
        print(e)
        return [str(e)]


manager = KubernetesContainerManager(kubernetes_proxy_addr=K8S_ADDR,
                                     namespace=K8S_NS)
clipper_conn = ClipperConnection(manager)
clipper_conn.connect()

# clipper_conn.delete_application(APP_NAME)
# clipper_conn.register_application(
#    name = APP_NAME, input_type = 'doubles', default_output = '0', slo_micros = 100000000)

python_deployer.deploy_python_closure(clipper_conn,
                                      name=PREDICT_NAME,
                                      version=VERSION,
                                      input_type="doubles",
                                      func=predict_wrapper,
                                      registry=REGISTRY,
                                      pkgs_to_install=['sklearn'])

# clipper_conn.link_model_to_app(app_name=APP_NAME, model_name=PREDICT_NAME)
# make predictions
predictions = predict(test_examples.values)
print("Predict instances in test set using custom defined scoring function...")
predictions

# In[7]:

from clipper_admin.deployers import python as python_deployer
# We specify which packages to install in the pkgs_to_install arg.
# For example, if we wanted to install xgboost and psycopg2, we would use
# pkgs_to_install = ['xgboost', 'psycopg2']
print("Deploy predict function closure using Clipper...")
python_deployer.deploy_python_closure(clipper_conn,
                                      name='xgboost-model',
                                      version=1,
                                      input_type="doubles",
                                      func=predict,
                                      pkgs_to_install=['xgboost'])

time.sleep(5)

# In[8]:

print("Link Clipper connection to model application...")
clipper_conn.link_model_to_app('xgboost-airlines', 'xgboost-model')

# In[22]:

import requests, json
# Get Address
addr = clipper_conn.get_query_addr()
Exemplo n.º 14
0
    return l


clipper_conn = ClipperConnection(
    KubernetesContainerManager(useInternalIP=True))
# clipper_conn = ClipperConnection(DockerContainerManager())
clipper_conn.start_clipper()

#Deploy lin_model_1
clipper_conn.register_application(name="linear1",
                                  input_type="doubles",
                                  default_output="-1.0",
                                  slo_micros=100000)
deploy_python_closure(clipper_conn,
                      name="lin-model-1",
                      version=1,
                      input_type="doubles",
                      func=lin_model_1,
                      registry="hsubbaraj")
clipper_conn.link_model_to_app(app_name="linear1", model_name="lin-model-1")
print("deployed model 1")

#Deploy lin_model_2
clipper_conn.register_application(name="linear2",
                                  input_type="doubles",
                                  default_output="-1.0",
                                  slo_micros=100000)
deploy_python_closure(clipper_conn,
                      name="lin-model-2",
                      version=1,
                      input_type="doubles",
                      func=lin_model_2,
from clipper_admin import ClipperConnection, KubernetesContainerManager
clipper_conn = ClipperConnection(
    KubernetesContainerManager(useInternalIP=True))
clipper_conn.connect()

clipper_conn.register_application(name="hello-world",
                                  input_type="doubles",
                                  default_output="-1.0",
                                  slo_micros=100000)
clipper_conn.get_all_apps()


def feature_sum(xs):
    return [str(sum(x)) for x in xs]


from clipper_admin.deployers import python as python_deployer

registry = 'localhost:5000'
python_deployer.deploy_python_closure(clipper_conn,
                                      name="sum-model",
                                      version=1,
                                      input_type="doubles",
                                      func=feature_sum,
                                      registry=registry)
Exemplo n.º 16
0
        Accepts list of JSON string as argument
        """
        ret = []
        for param in params:
            args = json.loads(param)
            zone = args['zone']
            date = str(args['date'])
            schedule = args['schedule']
            temps, actions = execute_schedule(date, schedule, models[zone], 65)
            ret.append(temps)
        return ret

    from clipper_admin.deployers import python as python_deployer
    python_deployer.deploy_python_closure(clipper_conn,
                                          name='thermal-model-ciee',
                                          version=1,
                                          input_type='strings',
                                          func=execute_thermal_model,
                                          base_image="xbospy")
    clipper_conn.link_model_to_app(app_name="ciee_thermal",
                                   model_name="thermal-model-ciee")
except:
    clipper_conn.connect()

import time
import requests
time.sleep(10)
inp = json.dumps({
    'zone': 'http://buildsys.org/ontologies/ciee#CentralZone',
    'date': '2018-02-06 00:00:00 UTC',
    'schedule': normal_schedule
})
Exemplo n.º 17
0
clipper_conn = ClipperConnection(DockerContainerManager())
clipper_conn.start_clipper()
clipper_addr = clipper_conn.get_query_addr()

def preprocess(inputs):
	inputArr = (inputs[0]).split(",")
	floats = inputArr[:-1]
	rounded = [round(float(i),1) for i in floats]
	rounded.append(inputArr[-1])
	output = [(str(rounded))[1:-1]]
	return output

python_deployer.deploy_python_closure(
    clipper_conn,
    name="process-iris",  # The name of the model in Clipper
    version=1,  # A unique identifier to assign to this model.
    input_type="string",  # The type of data the model function expects as input
    func=preprocess # The model function to deploy
)

clipper_conn.register_application(
    name="process-app",
    input_type="strings",
    default_output="-1",
    slo_micros=9000000) #will return default value in 9 seconds

clipper_conn.link_model_to_app(app_name="process-app", model_name="process-iris")


Exemplo n.º 18
0
# Access the trained model via closure capture
def predict(inputs):
    global model
    pred = model.predict(inputs)
    return [str(p) for p in pred]


# Point to the gradient boosting model
model = model

# Deploy the 'predict' function as a model
deploy_python_closure(
    clipper_conn,
    name="gb-model",
    version=1,
    input_type="doubles",
    func=predict,
    pkgs_to_install=['scikit-learn', 'pandas', 'numpy', 'scipy'],
    registry="gkip")

# Routes requests for the application 'kddtutorial' to the model 'gb-model'
clipper_conn.link_model_to_app(app_name="kddtutorial", model_name="gb-model")

inputs = X.loc[200, X.columns != 'classification']  # use random data point
headers = {"Content-type": "application/json"}
addr = clipper_conn.get_query_addr()
response = requests.post("http://%s/%s/predict" % (addr, 'kddtutorial'),
                         headers=headers,
                         data=json.dumps({"input": list(inputs)})).json()
print(response)
Exemplo n.º 19
0
    return pred


clipper_conn = ClipperConnection(DockerContainerManager(redis_port=6380))
try:
    clipper_conn.start_clipper()
except:
    clipper_conn.connect()

clipper_conn.register_application(name=APP_NAME,
                                  input_type="integers",
                                  default_output="-1.0",
                                  slo_micros=100000)
# Check all apps
print(clipper_conn.get_all_apps())

deploy_python_closure(clipper_conn,
                      name=MODEL_NAME,
                      version="1",
                      input_type="integers",
                      func=predict)
clipper_conn.link_model_to_app(app_name=APP_NAME, model_name=MODEL_NAME)

import json
inputs = cv2.imread('test1.jpg')
headers = {"Content-type": "aplication/json"}
result = requests.post("http://localhost:1337/" + APP_NAME + "/predict",
                       headers=headers,
                       data=json.dumps({"input": list(inputs)})).json()
print(result)
Exemplo n.º 20
0
from clipper_admin import ClipperConnection, DockerContainerManager
clipper_conn = ClipperConnection(DockerContainerManager())
clipper_conn.connect()

import sys
sys.path.append('./')
print(sys.path)

from predict_example import python

from clipper_admin.deployers import python as python_deployer

python_deployer.deploy_python_closure(clipper_conn,
                                      name="sum-model",
                                      version=1,
                                      input_type="doubles",
                                      func=python.predict)
Exemplo n.º 21
0
        response = apply_forecast_impl(parameters[0].decode("utf-8").split(','))
        code = '202' 
    except Exception as e:
        response = str(e)
        code = '500'
    return [str(code+', '+response) for _ in parameters]

if __name__ == '__main__':
    # setup logging format
    format = "%(asctime)-15s %(message)s"
    logging.basicConfig(
        filename='./timeseries/log.log', level=logging.DEBUG, format=format)
    # set up logging to console
    console = logging.StreamHandler(sys.stdout)
    console.setLevel(logging.ERROR)
    logging.getLogger().addHandler(console)

    signal.signal(signal.SIGINT, signal_handler)
    conn = ClipperConnection(DockerContainerManager())
    conn.start_clipper()
    try:
        conn.register_application(name="forecast",input_type="strings",default_output="500, Error executing call.",slo_micros=100000000)
        python_deployer.deploy_python_closure(conn, name="do-forecast", version=1, input_type="strings", func=do_forecast, base_image='wamsiv/timeseries:latest')
        conn.link_model_to_app(app_name="forecast", model_name='do-forecast')
        print(subprocess.getoutput(["docker update --restart=on-failure $(docker ps -a | grep 'clipper/query_frontend:0.3.0' | awk '{ print $1 }')"]))
        input("Server started. Press ctrl+c to stop server.\n")
    except Exception as e:
        logging.error("Encountered {}. Stopping server...".format(e))
        conn.stop_all()
    conn.stop_all()
            requests.post("http://" + clipper_url + ":1337/" + app_name +
                          "/predict",
                          headers=headers,
                          data=data_input).json()['output'])
    return results


#################################################
#################################################
#################################################

from clipper_admin.deployers import python as python_deployer

python_deployer.deploy_python_closure(clipper_conn,
                                      name="query-agent-model",
                                      input_type="doubles",
                                      func=query_agent_function,
                                      version=9)

clipper_conn.link_model_to_app(app_name="query_agent",
                               model_name="query-agent-model")

# Debugging
clipper_conn.set_model_version(name="query-agent-model", version="3")

import requests, json, time, sys, numpy as np
headers = {"Content-type": "application/json"}
clipper_url = "192.168.56.101"  # default: "localhost"
app_name = "query_agent"
# data_input = json.dumps({"input": list(np.random.random(input_size))})
data_input = json.dumps(
Exemplo n.º 23
0
def predict(delay):
    #delay = eval(delay)
    future_r = model_r.make_future_dataframe(periods=30, freq='D')
    forecast_r = model_r.predict(future_r)
    #forecast_r.index = forecast_r['ds']
    #forecast
    #pred_r = pd.DataFrame(forecast_r['yhat'][len(forecast_r)-delay:len(forecast_r)])
    #pred_r=pred_r.reset_index()
    #pred_r = pred_r.to_json()
    return forecast_r.to_json()


from clipper_admin.deployers import python as python_deployer

python_deployer.deploy_python_closure(
    clipper_conn,
    name="p1model",
    version=1,
    input_type="strings",
    func=predict,
    pkgs_to_install=['pandas', 'fbprophet==0.4'])

clipper_conn.link_model_to_app(app_name="p1app", model_name="p1model")

#import requests, json, numpy as np
#headers = {"Content-type": "application/json"}
#datas = json.dumps({"input": list(np.random.random(10))})

#requests.post("http://10.65.47.80:1337/p1app/predict", headers=headers, data=datas).json()
Exemplo n.º 24
0
    def test_query_specific_model_version(self):
        model_name = "testmodel"
        app_name = "testapp"

        def predict_func1(xs):
            return ["1" for _ in xs]

        def predict_func2(xs):
            return ["2" for _ in xs]

        self.clipper_conn.register_application(name=app_name,
                                               input_type="doubles",
                                               default_output="DEFAULT",
                                               slo_micros=100000)

        deploy_python_closure(self.clipper_conn,
                              name=model_name,
                              version="v1",
                              input_type="doubles",
                              func=predict_func1)

        self.clipper_conn.link_model_to_app(app_name, model_name)

        time.sleep(30)

        deploy_python_closure(self.clipper_conn,
                              name=model_name,
                              version="v2",
                              input_type="doubles",
                              func=predict_func2)

        time.sleep(60)

        addr = self.clipper_conn.get_query_addr()
        url = "http://{addr}/{app}/predict".format(addr=addr, app=app_name)

        headers = {"Content-type": "application/json"}
        test_input = [1.0, 2.0, 3.0]

        pred1_raw = requests.post(url,
                                  headers=headers,
                                  data=json.dumps({
                                      "input": test_input,
                                      "version": "v1"
                                  }))
        try:
            pred1 = pred1_raw.json()
            self.assertFalse(pred1["default"])
            self.assertEqual(pred1['output'], 1)
        except ValueError:
            logger.error(pred1_raw.text)
            self.assertTrue(False)

        pred2_raw = requests.post(url,
                                  headers=headers,
                                  data=json.dumps({"input": test_input}))
        try:
            pred2 = pred2_raw.json()

            self.assertFalse(pred2["default"])
            self.assertEqual(pred2['output'], 2)
        except ValueError:
            logger.error(pred2_raw.text)
            self.assertTrue(False)

        # Query a version that doesn't exist:
        bad_version_name = 'skjfhkdjshfjksdhkjf'
        pred3 = requests.post(url,
                              headers=headers,
                              data=json.dumps({
                                  "input": test_input,
                                  "version": bad_version_name
                              }))
        logger.info(pred3.text)
        self.assertFalse(pred3.status_code == requests.codes.ok)
        self.assertEqual(
            pred3.json()['cause'],
            "Requested version: {version_name} does not exist for model: {model_name}"
            .format(version_name=bad_version_name, model_name=model_name))
Exemplo n.º 25
0
heatmap = ''


#input is type bytes string
def predict(input):
    print(input)

    return [[2, heatmap], [0]]


model_name = "test1"
model_version = 2

python_deployer.deploy_python_closure(
    clipper_conn,
    name=model_name,
    version=model_version,
    input_type="bytes",
    func=predict,
    #pkgs_to_install=['json']
)

# #link model with application
# clipper_conn.link_model_to_app(
#     app_name = app_name,
#     model_name = model_name
# )

print(clipper_conn.get_all_apps())

print(clipper_conn.cm.get_num_replicas(name=model_name, version=model_version))
Exemplo n.º 26
0
#input is type string
def predict(input):
    logger = init_logging()
    logger.debug("DEBUGINGG>>>>>>>>>>>")
    logger.debug((input[0]).encode())
    #print("xxkdjkfjdkfjd", file=sys.stderr)
    #df = pd.read_json(input[0], orient="columns")
    #df.to_csv('bla.csv')
    #return df['nausea'].tolist()[0]
    return [[2, True], []]


model_name = "consultation"
model_version = 31

python_deployer.deploy_python_closure(clipper_conn,
                                      name=model_name,
                                      version=model_version,
                                      input_type="strings",
                                      func=predict,
                                      pkgs_to_install=["pandas"])

# #link model with application
# clipper_conn.link_model_to_app(
#     app_name = app_name,
#     model_name = model_name
# )

print(clipper_conn.get_all_apps())

print(clipper_conn.cm.get_num_replicas(name=model_name, version=model_version))
Exemplo n.º 27
0
# Deploy Sum function
clipper_conn.register_application(name="Sum",
                                  input_type="doubles",
                                  default_output="-1.0",
                                  slo_micros=100000)


# Define model func
def feature_sum(xs):
    return [str(sum(x)) for x in xs]


# Deploy python model
python_deployer.deploy_python_closure(clipper_conn,
                                      name="sum-model",
                                      version=1,
                                      input_type="doubles",
                                      func=feature_sum)

data = json.dumps({"app_name": "Sum", "model_names": ["sum-model"]})
r = requests.post('http://localhost:1338/admin/add_model_links', data=data)
print(r.status_code, r.text)

# Deploy average function
clipper_conn.register_application(name="Average",
                                  input_type="doubles",
                                  default_output="-1.0",
                                  slo_micros=100000)


# Define model func
Exemplo n.º 28
0
    else:
        if len(info['linked_models']) > 0:
            model_name = info['linked_models'][0]
            version = str(
                int(clipper_conn.get_current_model_version(model_name)) + 1)
        else:
            version = '1'
        new_app = False
    print('    version: %s' % (version))

    #-----------------------------------------------------------------------
    if args.deploy == 'python':
        if input_type == 'double':
            deploy_python_closure(clipper_conn,
                                  name=model_name,
                                  version=version,
                                  input_type=input_type,
                                  func=testmodel1)
        elif input_type == 'string':
            deploy_python_closure(clipper_conn,
                                  name=model_name,
                                  version=version,
                                  input_type=input_type,
                                  func=testmodel2)
    elif args.deploy == 'pyspark':
        if input_type == 'double':
            deploy_python_closure(clipper_conn,
                                  name=model_name,
                                  version=version,
                                  input_type=input_type,
                                  func=testmodel5)
Exemplo n.º 29
0
    slo_micros=10000000)  # 10,000,000 micros == 10 sec

clipper_conn.get_all_apps()

#################################################
######### Define Own Prediction Function ########
#################################################

import sklearn
import numpy as np
from sklearn.neural_network import MLPClassifier
from sklearn.externals import joblib
from clipper_admin.deployers import python as python_deployer

for version_postfix in ["10x1k", "10x2k", "20x1k", "15x2k"]:

    model_path = "../../models/sklearn/"
    model_name = "dig_nn_model_" + version_postfix + ".sav"
    clf = joblib.load(model_path + model_name)

    def clf_predict(xs):
        return clf.predict(xs)

    python_deployer.deploy_python_closure(clipper_conn,
                                          name="digit-nn-model",
                                          version=version_postfix,
                                          input_type="doubles",
                                          func=clf_predict)

clipper_conn.link_model_to_app(app_name="digit", model_name="digit-nn-model")
# clipper_conn.stop_all()
Exemplo n.º 30
0
            clipper_query_port=1337 + node_id,
            clipper_management_port=2337 + node_id,
            clipper_rpc_port=7000 + node_id,
            redis_ip=None,
            redis_port=6379 + node_id,
            prometheus_port=9090 + node_id,
            # WARING: DO NOT CHANGE THE RULE OF NETWORK NAMES
            docker_network='clipper_network_{}'.format(node_id),
            # SINCE THIS IS USED BY reset.sh TO IDENTIFY CLIPPER CONTAINERS
            extra_container_kwargs={})
    )  # for node_id in range(args.num_nodes)]

    try:
        clipper_conn.start_clipper()
        clipper_conn.register_application(name="default",
                                          input_type="string",
                                          default_output="",
                                          slo_micros=100000)

        python_deployer.deploy_python_closure(clipper_conn,
                                              name="echo-model",
                                              version=1,
                                              input_type="string",
                                              func=echo_model)
        clipper_conn.link_model_to_app(app_name="default",
                                       model_name="echo-model")
    except:
        exit(1)

    exit(0)