Skip to content

Latest commit

 

History

History
182 lines (131 loc) · 9.08 KB

E2E_Phi-3-MLflow.md

File metadata and controls

182 lines (131 loc) · 9.08 KB

MLflow

MLflow 是一个开源平台,旨在管理端到端的机器学习生命周期。

MLFlow

MLFlow 用于管理机器学习生命周期,包括实验、可重复性、部署和中央模型注册表。MLFlow 目前提供四个组件:

  • MLflow Tracking: 记录和查询实验、代码、数据配置和结果。
  • MLflow Projects: 以一种格式打包数据科学代码,以便在任何平台上复现运行。
  • Mlflow Models: 在不同的服务环境中部署机器学习模型。
  • Model Registry: 在中央存储库中存储、注释和管理模型。

它包括跟踪实验、将代码打包成可复现的运行以及共享和部署模型的功能。MLFlow 集成到 Databricks 中,并支持各种机器学习库,使其与库无关。它可以与任何机器学习库和任何编程语言一起使用,因为它提供了一个方便的 REST API 和 CLI。

MLFlow

MLFlow 的主要功能包括:

  • 实验跟踪: 记录和比较参数和结果。
  • 模型管理: 将模型部署到各种服务和推理平台。
  • 模型注册表: 协作管理 MLflow 模型的生命周期,包括版本控制和注释。
  • 项目: 打包机器学习代码以供共享或生产使用。

MLFlow 还支持 MLOps 循环,包括准备数据、注册和管理模型、打包模型以供执行、部署服务和监控模型。它旨在简化从原型到生产工作流的过程,特别是在云和边缘环境中。

端到端场景 - 构建包装器并将 Phi-3 作为 MLFlow 模型使用

在这个端到端示例中,我们将展示两种不同的方法来围绕 Phi-3 小语言模型 (SLM) 构建包装器,然后将其作为 MLFlow 模型在本地或云中运行,例如在 Azure 机器学习工作区中。

MLFlow

项目 描述 位置
Transformer Pipeline 如果您想使用 HuggingFace 模型与 MLFlow 的实验性 transformers flavour,Transformer Pipeline 是构建包装器的最简单选择。 TransformerPipeline.ipynb
Custom Python Wrapper 在撰写本文时,transformer pipeline 不支持为 ONNX 格式的 HuggingFace 模型生成 MLFlow 包装器,即使使用实验性的 optimum Python 包也是如此。对于这种情况,您可以为 MLFlow 模式构建自定义 Python 包装器 CustomPythonWrapper.ipynb

项目: Transformer Pipeline

  1. 您需要从 MLFlow 和 HuggingFace 获取相关的 Python 包:

    import mlflow
    import transformers
  2. 接下来,您应该通过引用 HuggingFace 注册表中的目标 Phi-3 模型来启动 transformer pipeline。从 Phi-3-mini-4k-instruct 的模型卡可以看出,其任务是“文本生成”类型:

    pipeline = transformers.pipeline(
        task = "text-generation",
        model = "microsoft/Phi-3-mini-4k-instruct"
    )
  3. 现在,您可以将 Phi-3 模型的 transformer pipeline 保存为 MLFlow 格式,并提供额外的详细信息,如目标工件路径、特定模型配置设置和推理 API 类型:

    model_info = mlflow.transformers.log_model(
        transformers_model = pipeline,
        artifact_path = "phi3-mlflow-model",
        model_config = model_config,
        task = "llm/v1/chat"
    )

项目: Custom Python Wrapper

  1. 我们可以利用微软的 ONNX Runtime generate() API 来进行 ONNX 模型的推理和 token 编码/解码。您必须为目标计算选择 onnxruntime_genai 包,以下示例针对 CPU:

    import mlflow
    from mlflow.models import infer_signature
    import onnxruntime_genai as og
  2. 我们的自定义类实现了两个方法:load_context() 用于初始化 Phi-3 Mini 4K Instruct 的 ONNX 模型生成器参数tokenizerpredict() 用于生成提供的提示的输出 token:

    class Phi3Model(mlflow.pyfunc.PythonModel):
        def load_context(self, context):
            # Retrieving model from the artifacts
            model_path = context.artifacts["phi3-mini-onnx"]
            model_options = {
                 "max_length": 300,
                 "temperature": 0.2,         
            }
        
            # Defining the model
            self.phi3_model = og.Model(model_path)
            self.params = og.GeneratorParams(self.phi3_model)
            self.params.set_search_options(**model_options)
            
            # Defining the tokenizer
            self.tokenizer = og.Tokenizer(self.phi3_model)
    
        def predict(self, context, model_input):
            # Retrieving prompt from the input
            prompt = model_input["prompt"][0]
            self.params.input_ids = self.tokenizer.encode(prompt)
    
            # Generating the model's response
            response = self.phi3_model.generate(self.params)
    
            return self.tokenizer.decode(response[0][len(self.params.input_ids):])
  3. 现在,您可以使用 mlflow.pyfunc.log_model() 函数为 Phi-3 模型生成自定义 Python 包装器(以 pickle 格式),以及原始的 ONNX 模型和所需的依赖项:

    model_info = mlflow.pyfunc.log_model(
        artifact_path = artifact_path,
        python_model = Phi3Model(),
        artifacts = {
            "phi3-mini-onnx": "cpu_and_mobile/cpu-int4-rtn-block-32-acc-level-4",
        },
        input_example = input_example,
        signature = infer_signature(input_example, ["Run"]),
        extra_pip_requirements = ["torch", "onnxruntime_genai", "numpy"],
    )

生成的 MLFlow 模型的签名

  1. 在上述 Transformer Pipeline 项目的第 3 步中,我们将 MLFlow 模型的任务设置为“llm/v1/chat”。这样的指令生成了一个与 OpenAI 的 Chat API 兼容的模型 API 包装器,如下所示:

    {inputs: 
      ['messages': Array({content: string (required), name: string (optional), role: string (required)}) (required), 'temperature': double (optional), 'max_tokens': long (optional), 'stop': Array(string) (optional), 'n': long (optional), 'stream': boolean (optional)],
    outputs: 
      ['id': string (required), 'object': string (required), 'created': long (required), 'model': string (required), 'choices': Array({finish_reason: string (required), index: long (required), message: {content: string (required), name: string (optional), role: string (required)} (required)}) (required), 'usage': {completion_tokens: long (required), prompt_tokens: long (required), total_tokens: long (required)} (required)],
    params: 
      None}
  2. 因此,您可以以下列格式提交提示:

    messages = [{"role": "user", "content": "What is the capital of Spain?"}]
  3. 然后,使用与 OpenAI API 兼容的后处理,例如 response[0][‘choices’][0][‘message’][‘content’],将输出美化成如下内容:

    Question: What is the capital of Spain?
    
    Answer: The capital of Spain is Madrid. It is the largest city in Spain and serves as the political, economic, and cultural center of the country. Madrid is located in the center of the Iberian Peninsula and is known for its rich history, art, and architecture, including the Royal Palace, the Prado Museum, and the Plaza Mayor.
    
    Usage: {'prompt_tokens': 11, 'completion_tokens': 73, 'total_tokens': 84}
  4. 在上述 Custom Python Wrapper 项目的第 3 步中,我们允许 MLFlow 包根据给定的输入示例生成模型的签名。我们的 MLFlow 包装器的签名如下所示:

    {inputs: 
      ['prompt': string (required)],
    outputs: 
      [string (required)],
    params: 
      None}
  5. 因此,我们的提示需要包含 "prompt" 字典键,如下所示:

    {"prompt": "<|system|>You are a stand-up comedian.<|end|><|user|>Tell me a joke about atom<|end|><|assistant|>",}
  6. 然后,模型的输出将以字符串格式提供:

    Alright, here's a little atom-related joke for you!
    
    Why don't electrons ever play hide and seek with protons?
    
    Because good luck finding them when they're always "sharing" their electrons!
    
    Remember, this is all in good fun, and we're just having a little atomic-level humor!

免责声明: 本文档使用基于机器的AI翻译服务进行翻译。尽管我们努力确保准确性,但请注意,自动翻译可能包含错误或不准确之处。应将原文档的母语版本视为权威来源。对于关键信息,建议使用专业人工翻译。我们不对使用此翻译所产生的任何误解或误读承担责任。