亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

目次
目次
はじめに
なぜ大規(guī)模な言語(yǔ)モデルを微調(diào)整するのでしょうか?
ソリューションの概要
コンポーネントとテクノロジー
環(huán)境設(shè)定
前提條件
Python を使用したトレーニングと微調(diào)整
5.1 仮想環(huán)境のセットアップ
5.2 依存関係をインストールする
5.3 Azure Machine Learning ワークスペースを作成する
5.4 微調(diào)整スクリプト (train.py)
5.5 Azure へのモデルの登録
微調(diào)整されたモデルを .NET Core に統(tǒng)合する
6.1 .NET Core Web API プロジェクトを作成する
6.2 依存関係を追加する
6.3 ModelConsumerService.cs
6.4 LLMController.cs
6.5 .NET Core アプリケーションの構(gòu)成
Azure へのデプロイ
ベストプラクティス
結(jié)論
ホームページ バックエンド開発 Python チュートリアル .NET Core、Python、Azure を使用した大規(guī)模言語(yǔ)モデル (LLM) の微調(diào)整

.NET Core、Python、Azure を使用した大規(guī)模言語(yǔ)モデル (LLM) の微調(diào)整

Jan 14, 2025 am 07:11 AM

Fine-Tuning Large Language Models (LLMs) with .NET Core, Python, and Azure

目次

  1. はじめに
  2. なぜ大規(guī)模な言語(yǔ)モデルを微調(diào)整するのでしょうか?
  3. ソリューションの概要
  4. 環(huán)境設(shè)定
  5. Python を使用したトレーニングと微調(diào)整
  6. 微調(diào)整されたモデルを .NET Core に統(tǒng)合する
  7. Azure へのデプロイ
  8. ベストプラクティス
  9. 結(jié)論

  1. はじめに

大規(guī)模言語(yǔ)モデル (LLM) は、人間のようなテキストを理解して生成する能力で広く注目を集めています。ただし、多くの組織は、汎用モデルでは完全には捕捉できない可能性のある、獨(dú)自のドメイン固有のデータ セットと語(yǔ)彙を持っています。 微調(diào)整により、開発者はこれらの大規(guī)模なモデルを特定の環(huán)境や業(yè)界に適応させ、精度と関連性を向上させることができます。

この記事では、Python を使用して LLM を微調(diào)整し、その結(jié)果のモデルを .NET Core C# アプリケーションに統(tǒng)合してデプロイする方法について説明します。スケーラビリティと利便性を高めるために、すべてを Microsoft Azure 上で実行します。


  1. なぜ大規(guī)模な言語(yǔ)モデルを微調(diào)整するのでしょうか?

  2. ドメインの特異性: LLM は、業(yè)界固有の用語(yǔ)、製品名、専門用語(yǔ)を使用するように微調(diào)整できます。

  3. パフォーマンスの向上: 微調(diào)整により、多くの場(chǎng)合、エラーが減少し、顧客サービス、調(diào)査、分析などのユースケースでの関連性が向上します。

  4. コストの削減: モデルを最初から構(gòu)築する代わりに、既存の強(qiáng)力な LLM をカスタマイズできます。

  5. 効率の向上: 事前トレーニングされた重みを利用し、最終レイヤーまたはパラメーターのみを調(diào)整することで、プロセスを高速化します。


  1. ソリューションの概要

コンポーネントとテクノロジー

  1. 微調(diào)整用の Python

    • 一般的に使用されるライブラリ (例: Hugging Face Transformers、PyTorch)
    • 事前トレーニングされたモデルのロードと調(diào)整のプロセスを簡(jiǎn)素化しました
  2. 統(tǒng)合用の .NET Core C#

    • モデルを微調(diào)整するためのバックエンド サービスまたは API を公開する
    • 多くのエンタープライズ開発者に馴染みのある、厳密に型指定された言語(yǔ)
  3. Azure サービス

    • トレーニングとモデル管理のための Azure Machine Learning
    • データとモデル アーティファクト用の
    • Azure Storage
    • Azure App Service または .NET Core アプリケーションをホストするための Azure Function
    • Azure Key Vault (オプション) 資格情報(bào)を保護(hù)するため

  1. 環(huán)境設(shè)定

前提條件

  • Azure サブスクリプション: Machine Learning Workspace や App Service などのリソースを作成するために必要です。
  • Python 3.8 : モデルの微調(diào)整のためにローカルにインストールされます。
  • .NET 6/7/8 SDK: .NET Core C# アプリケーションの作成と実行用。
  • Visual Studio 2022 または Visual Studio Code: 推奨される IDE。
  • Azure CLI: ターミナルを介して Azure サービスを構(gòu)成および管理するために使用されます。
  • Docker (オプション): 必要に応じてアプリケーションをコンテナ化するために使用できます。

  1. Python を使用したトレーニングと微調(diào)整

この例では、最も広く採(cǎi)用されている LLM 微調(diào)整ライブラリの 1 つである Hugging Face Transformers を使用します。

5.1 仮想環(huán)境のセットアップ

<code>python -m venv venv
source venv/bin/activate  # 在 Windows 上:venv\Scripts\activate</code>

5.2 依存関係をインストールする

<code>pip install torch transformers azureml-sdk</code>

5.3 Azure Machine Learning ワークスペースを作成する

  1. リソース グループ および ワークスペース:
<code>   az group create --name LLMFinetuneRG --location eastus
   az ml workspace create --name LLMFinetuneWS --resource-group LLMFinetuneRG</code>
  1. ワークスペースに接続するためのローカル環(huán)境を構(gòu)成します (config.json ファイルまたは環(huán)境変數(shù)を使用)。

5.4 微調(diào)整スクリプト (train.py)

<code>import os
import torch
from transformers import AutoModelForCausalLM, AutoTokenizer, TrainingArguments, Trainer
from azureml.core import Workspace, Run

# 連接到 Azure ML
ws = Workspace.from_config()
run = Run.get_context()

model_name = "gpt2"  # 示例模型
tokenizer = AutoTokenizer.from_pretrained(model_name)
model = AutoModelForCausalLM.from_pretrained(model_name)

# 加載自定義數(shù)據(jù)集(本地或來自 Azure 存儲(chǔ))
# 示例:Azure ML 中的文本文件或數(shù)據(jù)集
train_texts = ["此處輸入您的特定領(lǐng)域文本..."]  # 簡(jiǎn)化版
train_encodings = tokenizer(train_texts, truncation=True, padding=True)

class CustomDataset(torch.utils.data.Dataset):
    def __init__(self, encodings):
        self.encodings = encodings
    def __len__(self):
        return len(self.encodings["input_ids"])
    def __getitem__(self, idx):
        return {k: torch.tensor(v[idx]) for k, v in self.encodings.items()}

train_dataset = CustomDataset(train_encodings)

training_args = TrainingArguments(
    output_dir="./results",
    num_train_epochs=3,
    per_device_train_batch_size=2,
    save_steps=100,
    logging_steps=100
)

trainer = Trainer(
    model=model,
    args=training_args,
    train_dataset=train_dataset,
)

trainer.train()

# 保存微調(diào)后的模型
trainer.save_model("./fine_tuned_model")
tokenizer.save_pretrained("./fine_tuned_model")</code>

5.5 Azure へのモデルの登録

<code>from azureml.core.model import Model

model = Model.register(
    workspace=ws,
    model_path="./fine_tuned_model",
    model_name="myFineTunedLLM"
)</code>

この時(shí)點(diǎn)で、簡(jiǎn)単にアクセスしてバージョンを管理できるように、微調(diào)整されたモデルは Azure Machine Learning に保存されます。


  1. 微調(diào)整されたモデルを .NET Core に統(tǒng)合する

6.1 .NET Core Web API プロジェクトを作成する

<code>dotnet new webapi -n FineTunedLLMApi
cd FineTunedLLMApi</code>

6.2 依存関係を追加する

    Azure エンドポイントまたはローカル推論 API を呼び出すための
  • HttpClient
  • Newtonsoft.Json (シリアル化に JSON.NET を使用したい場(chǎng)合)
  • Azure リソースへの安全なアクセスのための
  • Azure.Storage.Blobs または Azure.Identity
<code>dotnet add package Microsoft.Extensions.Http
dotnet add package Microsoft.Azure.Storage.Blob
dotnet add package Newtonsoft.Json</code>

6.3 ModelConsumerService.cs

微調(diào)整されたモデルを Web サービスとしてデプロイしていると仮定します (たとえば、Azure Container Instance または Azure ML のカスタム エンドポイントを使用)。次のコード スニペットは、サービスを呼び出して完了結(jié)果を取得します。

<code>using Newtonsoft.Json;
using System.Net.Http;
using System.Text;
using System.Threading.Tasks;

public class ModelConsumerService
{
    private readonly HttpClient _httpClient;

    public ModelConsumerService(IHttpClientFactory httpClientFactory)
    {
        _httpClient = httpClientFactory.CreateClient("FineTunedModel");
    }

    public async Task<string> GetCompletionAsync(string prompt)
    {
        var requestBody = new { prompt = prompt };
        var content = new StringContent(
            JsonConvert.SerializeObject(requestBody),
            Encoding.UTF8, 
            "application/json");

        var response = await _httpClient.PostAsync("/predict", content);
        response.EnsureSuccessStatusCode();
        return await response.Content.ReadAsStringAsync();
    }
}</code>

6.4 LLMController.cs

<code>using Microsoft.AspNetCore.Mvc;
using System.Threading.Tasks;

[ApiController]
[Route("[controller]")]
public class LLMController : ControllerBase
{
    private readonly ModelConsumerService _modelService;

    public LLMController(ModelConsumerService modelService)
    {
        _modelService = modelService;
    }

    [HttpPost("complete")]
    public async Task<IActionResult> CompletePrompt([FromBody] PromptRequest request)
    {
        var result = await _modelService.GetCompletionAsync(request.Prompt);
        return Ok(new { Completion = result });
    }
}

public class PromptRequest
{
    public string Prompt { get; set; }
}</code>

6.5 .NET Core アプリケーションの構(gòu)成

Program.cs または Startup.cs:

<code>var builder = WebApplication.CreateBuilder(args);

// 注冊(cè) HttpClient
builder.Services.AddHttpClient("FineTunedModel", client =>
{
    client.BaseAddress = new Uri("https://your-model-endpoint/");
});

// 注冊(cè) ModelConsumerService
builder.Services.AddTransient<ModelConsumerService>();

builder.Services.AddControllers();
var app = builder.Build();

app.MapControllers();
app.Run();</code>

  1. Azure へのデプロイ

  2. Azure App Service:

    • 多くの .NET Core アプリケーションにとって、これが最も簡(jiǎn)単なパスです。
    • Azure portal または CLI 経由で、新しい Web アプリ を作成します。
<code>python -m venv venv
source venv/bin/activate  # 在 Windows 上:venv\Scripts\activate</code>
  1. Azure 関數(shù) (オプション):

    • 使用が斷続的またはスケジュールされている場(chǎng)合に、サーバーレスのイベント駆動(dòng)型ロジックを?qū)g行するのに最適です。
  2. Azure Kubernetes Service (AKS) (詳細(xì)):

    • 大規(guī)模な導(dǎo)入に最適です。
    • Docker を使用してアプリケーションをコンテナー化し、Azure Container Registry (ACR) にプッシュします。

  1. ベストプラクティス

  2. データ プライバシー: 特にモデルのトレーニング中に、機(jī)密データや専有データを責(zé)任を持って取り扱うようにします。

  3. 監(jiān)視とログ: Azure Application Insights と統(tǒng)合して、パフォーマンスの監(jiān)視、使用狀況の追跡、異常の検出を行います。

  4. セキュリティ: Azure Key Vault を使用してキー (API キー、接続文字列) を保存します。

  5. モデルのバージョン管理: 必要に応じて、Azure ML でモデルのさまざまな微調(diào)整されたバージョンを追跡し、古いバージョンにロールバックします。

  6. ヒント エンジニアリング: 微調(diào)整されたモデルから最良の結(jié)果を得るためにヒントを調(diào)整します。


  1. 結(jié)論

PythonAzure Machine Learning を使用して LLM を微調(diào)整し、それらを .NET Core アプリケーションに統(tǒng)合して、強(qiáng)力なドメイン固有の AI を構(gòu)築できるようにしますソリューション。この組み合わせは、Azure の拡張性をすべて活用した Python の AI エコシステムと .NET のエンタープライズ機(jī)能を活用したい組織にとって優(yōu)れた選択肢です。

セキュリティ、データ ガバナンス、DevOps を慎重に計(jì)畫することで、実世界のニーズを満たす本番環(huán)境に対応したソリューションを立ち上げ、強(qiáng)力で保守が容易なフレームワークで正確なドメイン固有の言語(yǔ)機(jī)能を提供できます。

以上が.NET Core、Python、Azure を使用した大規(guī)模言語(yǔ)モデル (LLM) の微調(diào)整の詳細(xì)內(nèi)容です。詳細(xì)については、PHP 中國(guó)語(yǔ) Web サイトの他の関連記事を參照してください。

このウェブサイトの聲明
この記事の內(nèi)容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰屬します。このサイトは、それに相當(dāng)する法的責(zé)任を負(fù)いません。盜作または侵害の疑いのあるコンテンツを見つけた場(chǎng)合は、admin@php.cn までご連絡(luò)ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脫衣畫像を無料で

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード寫真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

寫真から衣服を削除するオンライン AI ツール。

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡(jiǎn)単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中國(guó)語(yǔ)版

SublimeText3 中國(guó)語(yǔ)版

中國(guó)語(yǔ)版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強(qiáng)力な PHP 統(tǒng)合開発環(huán)境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Pythonクラスの多型 Pythonクラスの多型 Jul 05, 2025 am 02:58 AM

Pythonオブジェクト指向プログラミングのコアコンセプトであるPythonは、「1つのインターフェイス、複數(shù)の実裝」を指し、異なるタイプのオブジェクトの統(tǒng)一処理を可能にします。 1。多型は、メソッドの書き換えを通じて実裝されます。サブクラスは、親クラスの方法を再定義できます。たとえば、Animal ClassのSOCK()方法は、犬と貓のサブクラスに異なる実裝を持っています。 2.多型の実用的な用途には、グラフィカルドローイングプログラムでdraw()メソッドを均一に呼び出すなど、コード構(gòu)造を簡(jiǎn)素化し、スケーラビリティを向上させる、ゲーム開発における異なる文字の共通の動(dòng)作の処理などが含まれます。 3. Pythonの実裝多型を満たす必要があります:親クラスはメソッドを定義し、子クラスはメソッドを上書きしますが、同じ親クラスの継承は必要ありません。オブジェクトが同じ方法を?qū)g裝する限り、これは「アヒル型」と呼ばれます。 4.注意すべきことには、メンテナンスが含まれます

Pythonジェネレーターと反復(fù)器を説明します。 Pythonジェネレーターと反復(fù)器を説明します。 Jul 05, 2025 am 02:55 AM

イテレータは、__iter __()および__next __()メソッドを?qū)g裝するオブジェクトです。ジェネレーターは、単純化されたバージョンのイテレーターです。これは、収量キーワードを介してこれらのメソッドを自動(dòng)的に実裝しています。 1. Iteratorは、次の()を呼び出すたびに要素を返し、要素がなくなると停止例外をスローします。 2。ジェネレーターは関數(shù)定義を使用して、オンデマンドでデータを生成し、メモリを保存し、無限シーケンスをサポートします。 3。既存のセットを処理するときに反復(fù)器を使用すると、大きなファイルを読み取るときに行ごとにロードするなど、ビッグデータや怠zyな評(píng)価を動(dòng)的に生成するときにジェネレーターを使用します。注:リストなどの反復(fù)オブジェクトは反復(fù)因子ではありません。イテレーターがその端に達(dá)した後、それらは再作成する必要があり、発電機(jī)はそれを一度しか通過できません。

PythonでAPI認(rèn)証を処理する方法 PythonでAPI認(rèn)証を処理する方法 Jul 13, 2025 am 02:22 AM

API認(rèn)証を扱うための鍵は、認(rèn)証方法を正しく理解して使用することです。 1。Apikeyは、通常、リクエストヘッダーまたはURLパラメーターに配置されている最も単純な認(rèn)証方法です。 2。BasicAuthは、內(nèi)部システムに適したBase64エンコード送信にユーザー名とパスワードを使用します。 3。OAUTH2は、最初にclient_idとclient_secretを介してトークンを取得し、次にリクエストヘッダーにbearertokenを持ち込む必要があります。 4。トークンの有効期限に対処するために、トークン管理クラスをカプセル化し、トークンを自動(dòng)的に更新できます。要するに、文書に従って適切な方法を選択し、重要な情報(bào)を安全に保存することが重要です。

Pythonの主張を説明します。 Pythonの主張を説明します。 Jul 07, 2025 am 12:14 AM

Assertは、Pythonでデバッグに使用されるアサーションツールであり、條件が満たされないときにアサーションエラーを投げます。その構(gòu)文は、アサート條件とオプションのエラー情報(bào)であり、パラメーターチェック、ステータス確認(rèn)などの內(nèi)部ロジック検証に適していますが、セキュリティまたはユーザーの入力チェックには使用できず、明確な迅速な情報(bào)と組み合わせて使用??する必要があります。例外処理を置き換えるのではなく、開発段階での補(bǔ)助デバッグにのみ利用できます。

一度に2つのリストを繰り返す方法Python 一度に2つのリストを繰り返す方法Python Jul 09, 2025 am 01:13 AM

Pythonで2つのリストを同時(shí)にトラバースする一般的な方法は、Zip()関數(shù)を使用することです。これは、複數(shù)のリストを順番にペアリングし、最短になります。リストの長(zhǎng)さが一貫していない場(chǎng)合は、itertools.zip_longest()を使用して最長(zhǎng)になり、欠損値を入力できます。 enumerate()と組み合わせて、同時(shí)にインデックスを取得できます。 1.Zip()は簡(jiǎn)潔で実用的で、ペアのデータ反復(fù)に適しています。 2.zip_longest()は、一貫性のない長(zhǎng)さを扱うときにデフォルト値を入力できます。 3. Enumerate(Zip())は、トラバーサル中にインデックスを取得し、さまざまな複雑なシナリオのニーズを満たすことができます。

Python Iteratorsとは何ですか? Python Iteratorsとは何ですか? Jul 08, 2025 am 02:56 AM

inpython、iteratoratorSareObjectsthatallopingthroughcollectionsbyimplementing __()and__next __()

Pythonタイプのヒントとは何ですか? Pythonタイプのヒントとは何ですか? Jul 07, 2025 am 02:55 AM

タイプヒントシンパソコンの問題と、ポテンシャルを使用して、dynamivitytedcodedededevelowingdeexpecifeedtypes.theyenhanceReadeadability、inableearlybugdetection、およびrequrovetoolingsusingsupport.typehintsareadddeduneadddedusingolon(:)

Python Fastapiチュートリアル Python Fastapiチュートリアル Jul 12, 2025 am 02:42 AM

Pythonを使用して最新の効率的なAPIを作成するには、Fastapiをお?jiǎng)幛幛筏蓼?。?biāo)準(zhǔn)のPythonタイプのプロンプトに基づいており、優(yōu)れたパフォーマンスでドキュメントを自動(dòng)的に生成できます。 FastAPIおよびASGIサーバーUVICORNをインストールした後、インターフェイスコードを記述できます。ルートを定義し、処理機(jī)能を作成し、データを返すことにより、APIをすばやく構(gòu)築できます。 Fastapiは、さまざまなHTTPメソッドをサポートし、自動(dòng)的に生成されたSwaggeruiおよびRedocドキュメントシステムを提供します。 URLパラメーターはパス定義を介してキャプチャできますが、クエリパラメーターは、関數(shù)パラメーターのデフォルト値を設(shè)定することで実裝できます。 Pydanticモデルの合理的な使用は、開発の効率と精度を改善するのに役立ちます。

See all articles