


元の言葉を書き直しました: 予期せぬ発見は、当初バグとみなされていたものが、実際には Protobuf の設計上の機能であるということです。
みなさんこんにちは、私はすごいです。
最近、私たちのプロジェクトでは、データを保存するためのキャリアとして protobuf 形式を使用しています。うっかり大きな穴を自分で埋めてしまいましたが、発見するまでに時間がかかりました。
protobuf の概要
protobuf の正式名は Protocol Buffers で、Google によって開発され、クロス言語、クロスプラットフォーム、スケーラブルなシリアル化データ メカニズムです。 XML に似ていますが、XML よりも小さく、高速で、シンプルです。データの構造を一度定義するだけで、その生成ツールを使用して、シリアル化および逆シリアル化操作を含むソース コードを生成できます。構造化データは、さまざまなプログラミング言語を使用して、さまざまなデータ ストリームに対して簡単に書き込みおよび読み取りを行うことができます。
proto2 バージョンは、Java、Python、Objective-C、および C でのコード生成をサポートしています。新しい proto3 言語バージョンでは、Kotlin、Dart、Go、Ruby、PHP、C# など多くの言語も使用できます。 #########どうやって分かったの?
新しいプロジェクトでは、protobuf 形式を使用して実行されたプロジェクトのデータを保存します。このようにして、デバッグ プロセス中に、現場で記録されたデータに基づいてローカル デバッグを実行することがあります。 message ImageData {
// ms
int64 timestamp = 1;
int32 id = 2;
Data mat = 3;
}
message PointCloud {
// ms
int64 timestamp = 1;
int32 id = 2;
PointData pointcloud = 3;
}
message State {
// ms
int64 timestamp = 1;
string direction = 2;
}
message Sensor {
repeated PointCloud point_data = 1;
repeated ImageData image_data = 2;
repeated State vehicle_data = 3;
}
ログイン後にコピー
このようなデータセットを定義し、保存する際、Sensor の 3 つのデータソースのフレームレートが異なるため、実際には 1 つの Sensor には 1 セットのデータしか含まれません。 , 2種類のデータは付属しておりません。 単一パックのみを録音した場合には問題は発生しませんでした。単一のパケットを長時間記録できないと感じるまでは、パケットを分割する解決策を見つける必要があります。 その時は「これは簡単だろう」と思い、パッケージが 500M に達したら、それ以降のデータを新しいパッケージに保存するように設定しました。とてもスムーズに書き終えて、データ記録のために現場に置きました。しばらく録音した後、パッケージを持ち帰り、新しいプログラムのテストをシミュレートしました。一部のパッケージのデータ解析に問題があることが判明しました。プログラムが実行途中で停止してしまいます。多くのテストを行った結果、一部のパッケージにこの問題があることが判明しました。 当初私たちが疑ったのは、ファイルサイズの判断方法が間違っており、外注先に影響を及ぼしたのではないかということでした。ファイルサイズを判断する際にファイルが開かれるためです。しかし、ファイルを開けない他の方法がいくつかあると判断した結果、分割が実行されました。記録されたパッケージの一部で依然として問題が発生しました。 そのとき初めて、protobuf にはデータを保存するための特別な要件があるのではないかと思いました。その後、いくつかの記事を読んで、protobuf では複数のデータセットを 1 つのファイルに保存するために識別子が必要であることを知りました。そうしないと、ファイルから解析を戻すときに、protobuf は単一データのストップ キャラクタがどこにあるのか認識できず、データ解析エラーが発生します。 ここで、この穴が現れます。 message ImageData { // ms int64 timestamp = 1; int32 id = 2; Data mat = 3; } message PointCloud { // ms int64 timestamp = 1; int32 id = 2; PointData pointcloud = 3; } message State { // ms int64 timestamp = 1; string direction = 2; } message Sensor { repeated PointCloud point_data = 1; repeated ImageData image_data = 2; repeated State vehicle_data = 3; }
一連のデータを区切り操作を行わずに 1 つのパッケージに保存します。 protobuf が解析すると、ファイル内のすべての内容が 1 つのセンサーに解析されます。センサーにはすべてのデータが含まれており、protobuf は保存されているすべてのデータをアクティブにマージします。
このとき、過去にシングルパケットを記録したときはすべて正しいデータだったことがわかり、本当に幸運でした。 protobuf はたまたま正常に解析されました。
どうすれば解決できますか?
protobuf がこのように動作することがわかったので、あとは protobuf を分割する方法を知る必要があるだけです。この方法を使用する私たちのような人が少なすぎるため、この方法を見つけるのは本当に困難です。中国語の検索ではこのコンテンツがまったく見つかりません。おそらく誰もがデータの保存に protobuf を使用していないでしょう。誰もが使用する方法は、複数のサービス間の対話のシナリオであるはずです。
stackoverflow のいくつかの回答を通じて最終的に答えを見つけました。回答から、このソリューションは protobuf 3.3 に正式にマージされただけであることがわかりました。この機能は実際にはあまり使われないようです。bool SerializeDelimitedToOstream(const MessageLite& message, std::ostream* output); bool ParseDelimitedFromZeroCopyStream( MessageLite* message, io::ZeroCopyInputStream* input, bool* clean_eof);
結論
何度も試行錯誤した結果、最終的にこのセグメンテーションの落とし穴を解決することができました。利用シーンが比較的ニッチなため、まったく見つからない情報が多くなる可能性があります。私はソースコードを自分で調べてこれらの問題を発見しました。 C のソース コードは非常に読みにくく、テンプレート メソッドやテンプレート クラスが多数あるため、細部を見落としがちです。最後にC#のコードを見て最終的に確認しました。
以上が元の言葉を書き直しました: 予期せぬ発見は、当初バグとみなされていたものが、実際には Protobuf の設計上の機能であるということです。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック









1. はじめに モバイル デバイスの普及とコンピューティング能力の向上に伴い、画像セグメンテーション技術が研究のホットスポットになっています。 MobileSAM (MobileSegmentAnythingModel) は、モバイル デバイス向けに最適化された画像セグメンテーション モデルであり、高品質のセグメンテーション結果を維持しながら計算の複雑さとメモリ使用量を削減し、リソースが限られたモバイル デバイスで効率的に実行することを目的としています。この記事では、MobileSAM の原理、利点、適用シナリオについて詳しく紹介します。 2. MobileSAM モデルの設計思想 MobileSAM モデルの設計思想には主に次の側面が含まれます: 軽量モデル: モバイル デバイスのリソース制限に適応するために、MobileSAM モデルは軽量モデルを採用します。

人工知能技術の継続的な発展に伴い、画像セマンティックセグメンテーション技術は画像分析分野で人気の研究方向となっています。画像セマンティック セグメンテーションでは、画像内のさまざまな領域をセグメント化し、各領域を分類して、画像の包括的な理解を実現します。 Python はよく知られたプログラミング言語であり、その強力なデータ分析機能とデータ視覚化機能により、人工知能技術研究の分野で最初に選択されます。この記事では、Python で画像セマンティック セグメンテーション技術を使用する方法を紹介します。 1. 前提知識が深まる

場合によっては、大きなファイルを他の人に送信する必要がありますが、電子メールの添付ファイルのサイズ制限などの送信チャネルの制限や、ネットワークの状態があまり良くないため、大きなファイルを小さなファイルに分割する必要があります。ファイルを複数回送信してから、これらの小さなファイルをマージします。今回はPythonを使って大きなファイルを分割・結合する方法を紹介します。考え方と実装 テキストファイルであれば行数で区切ることができます。テキストファイルでもバイナリファイルでも、指定したサイズに応じて分割できます。 Python のファイル読み取りおよび書き込み機能を使用すると、ファイルの分割とマージ、各ファイルのサイズの設定、指定されたサイズのバイトの読み取りと新しいファイルへの書き込みが可能です。受信側は小さなファイルを順番に読み取り、バイトは順番にファイルに書き込まれるため、

Golang と FFmpeg: オーディオ合成とセグメンテーションを実装する方法、特定のコード サンプルが必要です 概要: この記事では、Golang と FFmpeg ライブラリを使用してオーディオ合成とセグメンテーションを実装する方法を紹介します。読者の理解を深めるために、いくつかの具体的なコード例を使用します。はじめに: オーディオ処理技術の継続的な開発により、オーディオの合成とセグメンテーションは日常生活や仕事における一般的な機能要件になりました。高速かつ効率的で、作成と保守が簡単なプログラミング言語である Golang と FFmpeg の組み合わせ

多くの友人が事務作業で画面を録画したり、ファイルを転送したりする必要がありますが、ファイルが大きすぎる問題が原因で多くのトラブルが発生することがあります。以下にファイルが大きすぎる問題の解決策を示します。 win10 画面録画ファイルが大きすぎる場合の対処方法: 1. ソフトウェア Format Factory をダウンロードしてファイルを圧縮します。ダウンロードアドレス >> 2. メインページに入り、「Video-MP4」オプションをクリックします。 3. 変換形式ページで「ファイルの追加」をクリックし、圧縮するMP4ファイルを選択します。 4. ページ上の「出力構成」をクリックして、出力品質に従ってファイルを圧縮します。 5. ドロップダウン構成リストから「低品質とサイズ」を選択し、「OK」をクリックします。 6. 「OK」をクリックしてビデオファイルのインポートを完了します。 7. 「開始」をクリックして変換を開始します。 8. 完了したら、次のことができます。

みなさんこんにちは、私はすごいです。最近、私たちのプロジェクトでは、データを保存するためのキャリアとして protobuf 形式を使用しました。うっかり大きな穴を自分で埋めてしまいましたが、発見するまでに時間がかかりました。 protobuf の概要 protobuf の正式名は Protocalbuffers で、Google によって開発され、データをシリアル化するためのクロス言語、クロスプラットフォーム、スケーラブルなメカニズムです。 XML に似ていますが、XML よりも小さく、高速で、シンプルです。データの構造を一度定義するだけで、その生成ツールを使用して、シリアル化および逆シリアル化操作を含むソース コードを生成できます。さまざまなデータ ストリームから、さまざまなプログラミング言語を使用して簡単に作成できます。

PHP 開発では、データを処理しやすくするために、文字列を複数の部分文字列に分割する必要があることがよくあります。現時点では、PHP はこの目標の達成に役立つexplode() 関数を提供しています。 explode() 関数の基本構文は次のとおりです。explode(string$delimiter,string$string[,int$limit=PHP_MAXPATHLEN])where, $delimiter

最近、浙江大学の ReLER 研究室は、SAM とビデオ セグメンテーションを深く組み合わせ、Segment-and-TrackAnything (SAM-Track) をリリースしました。 SAM-Track は、SAM にビデオ ターゲットを追跡する機能を提供し、複数のインタラクション方法 (ポイント、ブラシ、テキスト) をサポートします。これに基づいて、SAM-Track は複数の従来のビデオ セグメンテーション タスクを統合し、あらゆるビデオ内のあらゆるターゲットのワンクリック セグメンテーション トラッキングを実現し、従来のビデオ セグメンテーションをユニバーサル ビデオ セグメンテーションに推定します。 SAM-Track は優れたパフォーマンスを備えており、複雑なシナリオでも 1 枚のカードで数百のターゲットを高品質で安定して追跡できます。プロジェクトアドレス: https://github.co
