目次
2. 詳細設計
ホームページ テクノロジー周辺機器 AI ChatGPT はプログラマの中核機能を脅かし始めています。

ChatGPT はプログラマの中核機能を脅かし始めています。

Apr 04, 2023 am 11:50 AM
プログラマー chatgpt 評価

より重要な問題は、その答えが正しいかどうかをどのように識別するかということですが、現在、標準的な答えが手元にあり、それを評価することができます。実際のプロジェクトでは未知の部分に直面することがありますが、経験がなければ、GPT-4 で与えられた設計が有効であるかどうかをどうやって知ることができるのでしょうか。それで問題は解決できるでしょうか?

ChatGPT はプログラマーにとって優れたヘルパーですか?それともプログラマーを殺したいですか?

コードを生成する能力だけではなく、より重要なのは、強力な設計能力を備えているかどうかだと思います。

設計機能には 2 つのレベルがあり、1 つはアーキテクチャ設計やシステム設計などの高レベルです。

1 つは比較的低レベルの設計機能で、主に特定のクラスとインターフェイスを設計します。

今日は、これら 2 つの側面でのパフォーマンスを見ていきます。

ChatGPT の回答は特に長文なので、一部の詳細を削除し、重要な部分のみを残します。

会社の機密保持のため、実際のプロジェクトを使用することはできず、テストには書籍に掲載されているケースのみを使用できます。

#1. アーキテクチャ設計

ここで使用するケースはカスタマー サービス チケットですシステム は、「プログラマーからアーキテクトへ」という本から抜粋したもので、実際の事例がたくさん載っているので、皆さんにもお勧めです。

カスタマー サービス作業指示システムのおおよその要件は次のとおりです。

MySQL データベースを使用するカスタマー サービス システムがあります。毎年発生する作業指示書は、品目数が3,000万件以上、各作業指示書には5~6件の作業があり、これらの作業も記録する必要があるため、年間1億5,000万件以上の作業記録が存在することになります。

カスタマー サービスが作業指示書を表示するためにシステムを開くと、速度が非常に遅く、開くまでに 10 秒かかります。現在、SQL ステートメント、インデックスなどが最適化されています。極端であり、これ以上改善することはできません。

現在、システムのパフォーマンスが顧客サービスの処理効率に深刻な影響を及ぼしており、顧客はこの問題を 1 週間以内に解決することを要求していますが、これは非常に短い期間です。

業務プロセスを分析した結果、作業指示書が処理されると「終了」ステータスが追加されることがわかりました。このような作業指示書は年に数回オープンできるわけではありません。

チームはこれまでデータベース パーティショニングを使用したことがなく、1 週間以内に解決できるかどうか確信が持てず、データベース パーティショニング計画を断念しました。

この問題に対する、本書の解決策は「ホット データベース」と「コールド データベース」の分離です。「ホット データベース」の毎日の操作により、「クローズされた」作業指示書が新しい「コールド データベース」に移動されますが、ホット データとコールド データ プロセス中に、データの一貫性の問題に対処する必要があります。

この要件を GPT-4 に投げて、それがどのように答えられるかを確認してください。

GPT-4: この場合、パフォーマンスの問題を解決するには次の 2 つの方法をお勧めします:

1. データベースのアーカイブ : 以降クローズされたチケットの大部分はアクセスする必要がなくなり、チケット データをメイン データベースからアーカイブ データベースに移動できます。このようにして、メイン データベースのサイズが大幅に削減され、クエリ速度が向上します。アーカイブ データベースは定期的に (毎月または四半期ごとなど) 更新でき、終了した作業指示書をアーカイブ データベースに移動できます...

具体的な操作手順は次のとおりです。

##a. アーカイブ データを保存するための新しい MySQL データベースを作成します。

b. 終了した作業指示書とそれに関連する操作記録をマスター データ データベースからアーカイブ データベースに定期的に移動し、データの一貫性を確保するスクリプトを作成します。

c. 顧客サービス システムを変更して、デフォルトでメイン データベース内のアーカイブされていないデータのみをクエリするようにします。

d. カスタマー サービス担当者が必要に応じてアーカイブ データ ライブラリ内のデータをクエリできるように、別のインターフェイスまたはツールを提供します。

キャッシュ:...わずかに...

はい、すぐに要点を捉えました、データベースアーカイブスキームと具体的な操作手順が示されています。

ただし、要件にはヒントがあり、この解決策は簡単に思いつきます。

Liu Xin: 操作手順で、データの一貫性を確保するにはどうすればよいですか? ここでは 2 つのデータベースを操作する必要があります

GPT-4 : それデータの一貫性を確保するために非常に重要です。 2 つのデータベースを操作する場合、次の方法を使用してデータの一貫性を確保できます。

トランザクションを使用する: トランザクションを使用すると、一連の操作がすべて成功するかすべて失敗するかを確認できます。 .....省略....

Liu Xin: トランザクションを使用する場合、2 つのデータベースにまたがるトランザクションをどのように開始できますか?

GPT-4: 申し訳ありませんが、前の回答で間違いがありました。 MySQL では、2 つの異なるデータベース間で単一のトランザクションを直接使用することはできません。この場合、データの一貫性を確保するために他の戦略を使用することを検討してください。考えられるアプローチの 1 つは、2 フェーズ コミット (2PC) を使用することです。 ....省略....

Liu Xin: 2 フェーズ コミット プロトコルは非常に脆弱です。メインデータベース。アーカイブデータベースに?

GPT-4: 申し訳ありませんが、以前のソリューションはニーズを完全には満たしていませんでした。ここでは、メッセージ キュー (RabbitMQ、Kafka、Amazon SQS など) を使用してデータ移行プロセスの一貫性を確保する新しいソリューションを提供します。このアプローチでは、データ移行プロセスを 2 つの別々のステップに分割し、何か問題が発生した場合に簡単にロールバックできるようにします。 .....省略....

Liu Xin: MQ を使用せずに自分でコードを作成する場合、データ移行プロセス中の一貫性をどのように確保できますか?

GPT-4: メッセージ キューを使用したくない場合は、次の方法を使用して独自のコードを作成し、データ移行中の一貫性を確保できます。

  1. ロック フィールドとマーク フィールドを使用する:

a. レコードが移行されたかどうかをマークするために、「is_maigrated」という名前のブール フィールドを作業指示書テーブルと操作レコード テーブルにそれぞれ追加します。

b. 移行条件を満たすレコードをマスター データベースにクエリするためのスクリプトまたはプログラムを作成します (たとえば、終了した作業指示書と "is_maigrated" が false)。

......少し......

まあ、この時点で、ようやく解決策が見つかりました。これは、この本と多少似ています。これは、フィールドを使用して「移行されたかどうか」をマークすることです。

しかし、どのように促しても冪等にする方法は提案されないので、諦めました。

Liu Xin: アーカイブ データベースのデータ量は非常に多く、クエリは非常に遅いですが、クエリは基本的に「顧客 ID に基づいて作業指示書を検索し、 「作業指示書 ID に基づいて作業指示書を見つけます」「すべての処理レコードが単独で発生します」これを解決する方法はありますか?

GPT-4: このクエリ モードでは、アーカイブ データベースのクエリ パフォーマンスを最適化するために次の戦略を採用できます。

  1. は顧客 ID です。および作業指示書 ID インデックスの作成: ......省略...
  2. データベース テーブル パーティション: ......省略...
  3. データベース ビュー:... .. ..わずかに...
  4. 結果キャッシュ:...わずかに...
  5. 読み取りと書き込みの負荷を分割:.... .わずかに...
  6. ハードウェアと構成の最適化:...少し...

これらの解決策は、問題を効果的に解決することはできません。正しい解決策は、HBase のような NoSQL データベースを使用することです。予想外です。

2. 詳細設計

私が使用するケースはやはり給与支払いです。これは古典的な書籍『アジャイル ソフトウェア開発: 原則、パターン、実践』から抜粋されたものです。

このケースの要件は次のとおりです:

システムは企業データベースと従業員関連データで構成されます。時間通りに更新される ルールに従って従業員に給与を支払う

従業員には 3 つのタイプがあります

1. 時給制の従業員。固定給が支払われます。 1時間当たりの賃金を毎日提出し、労働日と労働時間を記録したカードを提出し、1日8時間以上働いた場合は1.5倍の賃金が支払われます。毎週金曜日に給料が支払われます。

2. 月給制の従業員、給与は固定で毎月の最終勤務日に支払われます

3. 売上高給与は固定ですが、売上に応じて一定額の歩合給が支払われ、売上日と売上数量を記録した領収書を提出します。給料は隔週金曜日に支払われます。

従業員は支払い方法を選択でき、指定した住所に小切手を郵送したり、財務部門に保存しておいていつでも引き出す​​ことができ、または直接入金をリクエストすることもできます。指定された銀行口座に振り込みます。

この要件を読んだ後の一般的な設計は次のようになります:

ChatGPT はプログラマの中核機能を脅かし始めています。

Employee は、さまざまな種類の従業員クラスが継承する基本クラスとして機能します。

ただし、この要件は変更されます。顧客は、従業員タイプを変更できることを要求しています (たとえば、時間給従業員から月給従業員に)。そのため、上記の設計は機能しません。

現時点では、抽象化を作成し、PaymentClassification クラスを使用して支払い分類を表現し、このインスタンスを Employee クラスに保持させます。簡単に言うと、継承ではなく組み合わせを使用します。 。

ChatGPT はプログラマの中核機能を脅かし始めています。

#これは罠です、これはまた、ChatGPT がどのように処理するかを確認するために、ChatGPT 用の穴も掘られました。

正式にスタートし、要件を伝えて設計を任せました。

思いがけず、思い浮かぶとすぐに Python コードを書き始めましたが、詳細が多すぎたので、すぐに出力を中止しました。

#Liu Xin: コードを示す必要はありません。クラスについて説明するだけです。

GPT-4 : OK、ニーズに応じて、次のクラスと関連するプロパティとメソッドを設計できます:

  1. 基本クラス Employee: ......省略...
  2. Employee クラスから継承された HourlyEmployee クラス: ......省略...
  3. Employee クラスから継承された SalariedEmployee クラス: ......省略...
  4. #SalariedEmployee クラスから継承された SalesEmployee クラス: ......省略... ...
  5. PaymentMethod クラス: わずか

は非常に優れており、要件を「理解」して要件を抽出します 名詞はクラスの設計に使用されます。それによって設計された、SalariedEmployee、SalesEmployee は、最初の UML 図とほぼ同じです。

オブジェクト指向設計の初級レベルに到達しました。

それでは、詳しく調べてみましょう:

Liu Xin: 上記のクラスはうまく設計されていますが、ある人がパートタイム労働者である場合、最初は、その後、月給制の社員になり、上記の設計では対応できなくなったのですが、どうすればよいでしょうか?

GPT-4: あなたが指摘した問題を解決するには、従業員の給与計算戦略を Employee クラスから分離し、戦略パターンを使用して設計します。このようにして、Employee クラスの給与計算戦略を変更せずに動的に変更できます。

#この設計では、元のクラス構造にいくつかの調整を行う必要があります。

基本クラス Employee を保持します:
  • 新しいメソッド: set_salary_strategy、従業員の給与計算戦略の設定に使用されます

給与計算戦略を Employee クラスから分離するため、元のサブクラス HourlyEmployee、SalariedEmployee、SalesEmployee を削除します。
  • 給与計算戦略の基本クラスとして抽象クラス SalaryStrategy を追加しました。
  • 新しい特定の戦略クラスを追加しました:
  • SalaryStrategy クラスから継承された HourlySalary クラス

SalariedSalary クラス、SalaryStrategy クラスから継承

SalesSalary クラス、SalaryStrategy クラスから継承

上記の調整により、次のことができるようになります。従業員クラスの場合、給与計算方針は動的に変更されます。従業員が時間給から月給に変更する場合は、新しい給与計算ポリシーを設定するだけです。

GPT-4 は非常に強力であると言わざるを得ません。

戦略パターンを使用して給与計算戦略 SalaryStrategy を抽象化します。

2 番目の UML 図と比較すると、名前が異なることを除いて、基本的に同じです。

これができれば多くのプログラマーを超えることができると言えます。

#支払いサイクルの問題に対処していないことに気づきました。

Liu Xin: 当初の要求には支払い時間も含まれていました。たとえば、時間給労働者の給与は毎週金曜日に支払われます。これはどのように設計すべきですか?

GPT-4: さまざまなタイプの従業員の支払い時間を処理するために、給与を支払う必要があるかどうかを決定する抽象メソッド should_pay_today を SalaryStrategy 基本クラスに導入できます。現在の日付に基づいて。次に、このメソッドを特定のストラテジー クラスに実装します。

......少し......

ここで間違いがあり、支払いサイクルが給与に組み込まれてしまいました。コンピューティング戦略では、「保守と拡張が容易」とも言われます。

Liu Xin: 支払い時間と給与計算戦略は両立しない 2 つの概念です。最大限の柔軟性を実現するにはどうすればよいでしょうか?

GPT-4: おっしゃるとおり、支払い時期と給与計算戦略は 2 つの異なる概念です。設計をより柔軟にするために、給与計算戦略から支払時間を分離し、支払時間のロジックを処理する新しい抽象クラス PaymentSchedule を作成できます。このようにして、従業員ごとに給与計算戦略と支払時期戦略を個別に設定できます。

次は、調整されたクラス構造です:

基本クラス Employee:

Attributes: name、ID、address## を保持します。

    #メソッド: set_payment_method、従業員の支払い方法の設定に使用されます
  • メソッド: set_salary_strategy、従業員の給与計算方針の設定に使用されます

新しいメソッド: set_payment_schedule、従業員の給与計算方法の設定に使用されます従業員支払時間戦略

抽象クラス SalaryStrategy とその特定の戦略クラスは変更せずに保持されます。

抽象クラス PaymentSchedule を支払い時間戦略の基本クラスとして追加します:... わずかに...
  • 特定の支払い時間戦略クラスを追加し、PaymentSchedule を継承します:
  • WeeklyPayment クラス...わずかに...
  • MonthlyPayment クラス...わずかに...

BiweeklyPayment クラス...わずかに...

PaymentMethod クラスとそのサブクラスを変更せずに保持します。

  • とても素晴らしい!PaymentScheduleとSalaryStrategyが分離されていて、私が何を考えているかを理解しているようです!

    # これまでのところ、この本の中でおそらく最高の最終的なデザインが完成しています。

    ChatGPT はプログラマの中核機能を脅かし始めています。

    ##3. 概要

    詳細設計レベルでは、 GPT-4 のパフォーマンスは、アーキテクチャ設計よりもはるかに強力です。

    プログラマーになった古い読者は、私が昨年給与支払いのケースで GPT-3.5 をテストしたことを知っています。要件。 。

    しかし、GPT-4 は異なります。その設計機能はさらに一歩進んでおり、プログラマーの指示に従って、彼は懸念事項を分離することを学びました。

    アーキテクチャ設計の観点から見ると、GPT-4 は多くの知識を習得していると感じますが、複雑な問題に効果的に適用することはできません。GPT-4 が提供するソリューションは非常にわかりにくく、遠くにあります。私たちが望むものから、遠くまで。

    より重要な問題は、その答えが正しいかどうかをどのように識別するかということですが、現在、標準的な答えが手元にあり、それを評価することができます。実際のプロジェクトでは未知の部分に直面することがありますが、経験がなければ、GPT-4 で与えられた設計が有効であるかどうかをどうやって知ることができるのでしょうか。それで問題は解決できるでしょうか?

以上がChatGPT はプログラマの中核機能を脅かし始めています。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

ChatGPT では、無料ユーザーが 1 日あたりの制限付きで DALL-E 3 を使用して画像を生成できるようになりました ChatGPT では、無料ユーザーが 1 日あたりの制限付きで DALL-E 3 を使用して画像を生成できるようになりました Aug 09, 2024 pm 09:37 PM

DALL-E 3は、前モデルより大幅に改良されたモデルとして2023年9月に正式導入されました。これは、複雑な詳細を含む画像を作成できる、これまでで最高の AI 画像ジェネレーターの 1 つと考えられています。ただし、発売当初は対象外でした

ChatGPT と Python の完璧な組み合わせ: インテリジェントな顧客サービス チャットボットの作成 ChatGPT と Python の完璧な組み合わせ: インテリジェントな顧客サービス チャットボットの作成 Oct 27, 2023 pm 06:00 PM

ChatGPT と Python の完璧な組み合わせ: インテリジェント カスタマー サービス チャットボットの作成 はじめに: 今日の情報化時代において、インテリジェント カスタマー サービス システムは企業と顧客の間の重要なコミュニケーション ツールとなっています。より良い顧客サービス体験を提供するために、多くの企業が顧客相談や質問応答などのタスクを完了するためにチャットボットに注目し始めています。この記事では、OpenAI の強力なモデル ChatGPT と Python 言語を使用して、インテリジェントな顧客サービス チャットボットを作成し、顧客サービスを向上させる方法を紹介します。

携帯電話にchatgptをインストールする方法 携帯電話にchatgptをインストールする方法 Mar 05, 2024 pm 02:31 PM

インストール手順: 1. ChatGTP ソフトウェアを ChatGTP 公式 Web サイトまたはモバイル ストアからダウンロードします; 2. それを開いた後、設定インターフェイスで言語を中国語を選択します; 3. ゲーム インターフェイスでヒューマン マシン ゲームを選択し、中国スペクトル; 4 . 起動後、チャット ウィンドウにコマンドを入力してソフトウェアを操作します。

どのAIプログラマーが一番優れているでしょうか? Devin、Tongyi Lingma、SWE エージェントの可能性を探る どのAIプログラマーが一番優れているでしょうか? Devin、Tongyi Lingma、SWE エージェントの可能性を探る Apr 07, 2024 am 09:10 AM

世界初の AI プログラマー Devin の誕生から 1 か月も経たない 2022 年 3 月 3 日、プリンストン大学の NLP チームはオープンソース AI プログラマー SWE-agent を開発しました。 GPT-4 モデルを利用して、GitHub リポジトリの問題を自動的に解決します。 SWE ベンチ テスト セットにおける SWE エージェントのパフォーマンスは Devin と同様で、平均 93 秒かかり、問題の 12.29% を解決しました。専用端末と対話することで、SWE エージェントはファイルの内容を開いて検索したり、自動構文チェックを使用したり、特定の行を編集したり、テストを作成して実行したりできます。 (注: 上記の内容は元の内容を若干調整したものですが、原文の重要な情報は保持されており、指定された文字数制限を超えていません。) SWE-A

ChatGPT と Java を使用してインテリジェントなチャットボットを開発する方法 ChatGPT と Java を使用してインテリジェントなチャットボットを開発する方法 Oct 28, 2023 am 08:54 AM

この記事では、ChatGPT と Java を使用してインテリジェントなチャットボットを開発する方法を紹介し、いくつかの具体的なコード例を示します。 ChatGPT は、OpenAI によって開発された生成事前トレーニング トランスフォーマーの最新バージョンです。これは、自然言語を理解し、人間のようなテキストを生成できるニューラル ネットワーク ベースの人工知能テクノロジーです。 ChatGPT を使用すると、適応型チャットを簡単に作成できます

C言語の魅力に迫る ~プログラマーの可能性を引き出す~ C言語の魅力に迫る ~プログラマーの可能性を引き出す~ Feb 24, 2024 pm 11:21 PM

C言語学習の魅力:プログラマーの可能性を引き出す テクノロジーの発展に伴い、コンピュータプログラミングは大きな注目を集めている分野です。数あるプログラミング言語の中でもC言語は常にプログラマーに愛されています。そのシンプルさ、効率性、幅広い用途により、C 言語の学習は、多くの人にとってプログラミングの分野に入る最初のステップとなっています。この記事では、C言語を学ぶ魅力と、C言語を学ぶことでプログラマーの可能性を引き出す方法について解説します。 C言語学習の魅力は、まずその簡単さにあります。他のプログラミング言語と比較すると、C言語は

中国でもchatgptは使えますか? 中国でもchatgptは使えますか? Mar 05, 2024 pm 03:05 PM

chatgpt は中国でも使用できますが、香港やマカオでも登録できません。ユーザーが登録したい場合は、外国の携帯電話番号を使用して登録できます。登録プロセス中にネットワーク環境を切り替える必要があることに注意してください。外国のIP。

ChatGPTとPythonを使ってユーザー意図認識機能を実装する方法 ChatGPTとPythonを使ってユーザー意図認識機能を実装する方法 Oct 27, 2023 am 09:04 AM

ChatGPT と Python を使用してユーザー意図認識機能を実装する方法 はじめに: 今日のデジタル時代において、人工知能技術はさまざまな分野で徐々に不可欠な部分になりました。その中で、自然言語処理 (Natural Language Processing、NLP) テクノロジーの開発により、機械が人間の言語を理解して処理できるようになります。 ChatGPT (Chat-GeneratingPretrainedTransformer) は、

See all articles