ইমেজ ম্যানিফেস্ট আপলোড

আপনার যদি কোড এডিটর UI বা 'আর্থেঞ্জিন' কমান্ড-লাইন টুলের upload কমান্ডের চেয়ে Google আর্থ ইঞ্জিনে (EE) ছবি আপলোড করার জন্য আরও নমনীয়তার প্রয়োজন হয়, তাহলে আপনি "মেনিফেস্ট" নামে পরিচিত একটি JSON ফাইল ব্যবহার করে একটি ইমেজ আপলোড বর্ণনা করে এবং কমান্ড-লাইন টুলের upload image --manifest কমান্ড ব্যবহার করে তা করতে পারেন।

এই Colab নোটবুকে একটি সম্পূর্ণ উদাহরণ দেখুন যা একটি ম্যানিফেস্ট ব্যবহার করে একটি একক সম্পদ হিসেবে ছবির টাইলস আপলোড করা দেখায়।

এককালীন সেটআপ

  1. ম্যানিফেস্ট আপলোডগুলি শুধুমাত্র Google ক্লাউড স্টোরেজে অবস্থিত ফাইলগুলির সাথে কাজ করে৷ Google ক্লাউড স্টোরেজ ব্যবহার শুরু করতে, একটি Google ক্লাউড প্রজেক্ট তৈরি করুন , যদি আপনার আগে থেকে না থাকে। নোট করুন যে সেটআপের জন্য বিলিং এর জন্য একটি ক্রেডিট কার্ড নির্দিষ্ট করা প্রয়োজন৷ EE নিজেই এই মুহুর্তে কাউকে চার্জ করছে না, তবে ফাইলগুলিকে EE এ আপলোড করার আগে Google ক্লাউড স্টোরেজে স্থানান্তর করার জন্য একটি ছোট খরচ হবে৷ সাধারণ আপলোড ডেটা আকারের জন্য (দশ বা শত গিগাবাইট), খরচ বেশ কম হবে।
  2. আপনার প্রকল্পের মধ্যে, ক্লাউড স্টোরেজ API চালু করুন এবং একটি বালতি তৈরি করুন
  3. আর্থ ইঞ্জিন পাইথন ক্লায়েন্ট ইনস্টল করুন । এতে earthengine কমান্ড-লাইন টুল রয়েছে, যা আমরা ডেটা আপলোড করার জন্য ব্যবহার করব।
  4. স্বয়ংক্রিয় আপলোডের জন্য, আপনি আপনার প্রকল্পের সাথে যুক্ত একটি Google ক্লাউড পরিষেবা অ্যাকাউন্ট ব্যবহার করতে চাইতে পারেন। পরীক্ষার জন্য আপনার একটি পরিষেবা অ্যাকাউন্টের প্রয়োজন নেই, কিন্তু যখন আপনার কাছে একটি মুহূর্ত থাকবে, অনুগ্রহ করে সেগুলি ব্যবহার করে নিজেকে পরিচিত করা শুরু করুন৷

খুব বড় সোর্স ফাইলগুলি (100 GB বা তার বেশি) দ্রুত আপলোড হতে পারে যদি সেগুলি একাধিক টাইলগুলিতে বিভক্ত হয়।

সম্পদ আইডি এবং নাম

ক্লাউড প্রকল্পের মালিকানাধীন সম্পদের জন্য, সম্পদের নামের জন্য এই নিয়মটি ব্যবহার করুন: projects/some-project-id/assets/some-asset-id

উত্তরাধিকার প্রকল্প এবং ব্যবহারকারীর মালিকানাধীন সম্পদের সম্পদের নাম সম্পর্কে জানুন

পুরানো লিগ্যাসি প্রোজেক্টের জন্য, ম্যানিফেস্টে থাকা সম্পদের নাম আর্থ ইঞ্জিনের অন্য কোথাও দৃশ্যমান সম্পদ আইডি থেকে কিছুটা আলাদা হতে হবে। যে সম্পদের আইডি users/some_user অথবা projects/some_project দিয়ে শুরু হয় সেই সম্পদগুলি আপলোড করতে, ম্যানিফেস্টে থাকা সম্পদের নাম আইডিতে স্ট্রিং projects/earthengine-legacy/assets/ আগে থেকে যুক্ত থাকতে হবে। উদাহরণ স্বরূপ, EE সম্পদ আইডি users/username/my_geotiff নাম projects/earthengine-legacy/assets/users/username/my_geotiff ব্যবহার করে আপলোড করা উচিত।

হ্যাঁ, এর মানে হল projects/some_projects/some_asset এর মতো আইডিগুলি এমন নামে রূপান্তরিত হয় যেখানে projects দুবার উল্লেখ করা হয়েছে: projects/earthengine-legacy/assets/projects/some_projects/some_asset । এটি বিভ্রান্তিকর কিন্তু Google ক্লাউড API মান মেনে চলার জন্য প্রয়োজনীয়।

ম্যানিফেস্ট ব্যবহার করে

নিম্নলিখিত কোড ব্লকে একটি মৌলিক ম্যানিফেস্ট দেখানো হয়েছে। এটি gs://earthengine-test নামে একটি Google ক্লাউড স্টোরেজ বাকেট থেকে small.tif নামে একটি ফাইল আপলোড করে।

{
  "name": "projects/some-project-id/assets/some-asset-id",
  "tilesets": [
    {
      "sources": [
        {
          "uris": [
            "gs://earthengine-test/small.tif"
          ]
        }
      ]
    }
  ]
}

এটি ব্যবহার করতে, manifest.json নামে একটি ফাইলে সংরক্ষণ করুন এবং চালান:

earthengine upload image --manifest /path/to/manifest.json

( gs://earthengine-test/small.tif ফাইলটি বিদ্যমান এবং সর্বজনীনভাবে পাঠযোগ্য-আপনি এটি পরীক্ষার জন্য ব্যবহার করতে পারেন।)

টাইলসেট

একটি সাধারণ আপলোড চ্যালেঞ্জ মোকাবেলা করার জন্য যথেষ্ট নমনীয়তা দেওয়ার জন্য JSON-এর কিছুটা জটিল ম্যানিফেস্ট কাঠামো প্রয়োজনীয়: একাধিক সোর্স ফাইল থেকে পিক্সেলগুলিকে একক সম্পদে একত্রিত করার সমস্ত সম্ভাব্য উপায়গুলি কীভাবে বর্ণনা করা যায়। বিশেষত, ফাইলগুলিকে একসাথে গ্রুপ করার দুটি স্বাধীন উপায় রয়েছে:

  • মোজাইক। কখনও কখনও একাধিক ফাইল একাধিক টাইল প্রতিনিধিত্ব করে (উদাহরণস্বরূপ, প্রতিটি টাইল একটি 1x1 ডিগ্রী বর্গক্ষেত্র)। এই ধরনের ফাইলগুলিকে অবশ্যই একটি EE সম্পদে একই ব্যান্ডে মোজাইক (একত্রে মার্জ) করতে হবে৷
  • আলাদা ব্যান্ড। কখনও কখনও, একাধিক ফাইল একাধিক ব্যান্ড প্রতিনিধিত্ব করে। এই ধরনের ফাইল একটি EE সম্পদে ব্যান্ড হিসাবে একসাথে স্ট্যাক করা আবশ্যক।

(উভয় উপায় একই সময়ে ব্যবহার করা হতে পারে, কিন্তু এটি একটি বিরল পরিস্থিতি।)

এই বিকল্পগুলি বর্ণনা করার জন্য, ম্যানিফেস্টগুলি একটি টাইলসেটের ধারণার পরিচয় দেয়। একটি একক টাইলসেট একটি একক GDAL উত্সের সাথে মিলে যায়৷ এই কারণে, একটি একক টাইলসেটের সমস্ত উত্স অবশ্যই একই GDAL কাঠামো থাকতে হবে (সংখ্যা এবং ব্যান্ডের ধরন, অভিক্ষেপ, রূপান্তর, অনুপস্থিত মান)। যেহেতু একটি GDAL উৎসের একাধিক ব্যান্ড থাকতে পারে, তাই একটি টাইলসেটে একাধিক EE ব্যান্ডের ডেটা থাকতে পারে।

মোজাইক ইনজেশনের জন্য, ম্যানিফেস্টটি দেখতে এইরকম হবে:

{
  "name": "projects/some-project-id/assets/some-asset-id",
  "tilesets": [
    {
      "sources": [
        {
          "uris": [
            "gs://bucket/N30W22.tif"
          ]
        },
        {
          "uris": [
            "gs://bucket/N31W22.tif"
          ]
        }
      ]
    }
  ]
}

পৃথক ব্যান্ডগুলির জন্য, ম্যানিফেস্টটি এইরকম দেখাবে (নিচে ব্যাখ্যা করা হিসাবে আপনাকে একটি bands বিভাগও যোগ করতে হবে):

{
  "name": "projects/some-project-id/assets/some-asset-id",
  "bands": ...,
  "tilesets": [
    {
      "id": "tileset_for_band1",
      "sources": [
        {
          "uris": [
            "gs://bucket/band1.tif"
          ]
        }
      ]
    },
    {
      "id": "tileset_for_band2",
      "sources": [
        {
          "uris": [
            "gs://bucket/band2.tif"
          ]
        }
      ]
    }
  ]
}

উল্লেখ্য যে পৃথক ব্যান্ডের ক্ষেত্রে আমাদের প্রতিটি টাইলসেটকে স্বচ্ছতার জন্য আলাদা টাইলসেট আইডি দিতে হবে। টাইলসেট আইডি একটি নির্বিচারে স্ট্রিং হতে পারে - এই স্ট্রিংগুলি আপলোড করা সম্পদে রাখা হয় না। টাইলসেট আইডিগুলি একে অপরের থেকে স্ট্যাক করা টাইলসেটগুলিকে আলাদা করতে শুধুমাত্র ইনজেশনে ব্যবহার করা হয়।

ব্যান্ড

দ্বিতীয় গুরুত্বপূর্ণ ধারণা হল উৎস ফাইলগুলিকে EE সম্পদ ব্যান্ডের সাথে মেলানো। এটি ম্যানিফেস্টের bands বিভাগ ব্যবহার করে করা হয়।

bands বিভাগটি বাদ দেওয়া যেতে পারে, এই ক্ষেত্রে ব্যান্ডগুলি প্রথমে প্রথম টাইলসেটের ফাইলগুলি থেকে তৈরি করা হয়, তারপরে পরবর্তী টাইলসেট থেকে ইত্যাদি। ডিফল্টরূপে, ব্যান্ডগুলির নাম "b1", "b2", ইত্যাদি। ডিফল্ট ব্যান্ডের নামগুলিকে ওভাররাইড করতে, শেষে একটি "ব্যান্ড" বিভাগ অন্তর্ভুক্ত করুন, যেমন:

{
  "name": "projects/earthengine-legacy/assets/users/username/some_folder/some_id",
  "tilesets": [
    {
      "sources": [
        {
          "uris": [
            "gs://bucket/rgb.tif"
          ]
        }
      ]
    }
  ],
  "bands": [
    {
      "id": "R",
      "tilesetBandIndex": 0
    },
    {
      "id": "G",
      "tilesetBandIndex": 1
    },
    {
      "id": "B",
      "tilesetBandIndex": 2
    }
  ]
}

EE ব্যান্ডের সংখ্যা সমস্ত টাইলসেটে মোট ব্যান্ডের সংখ্যার সমান হতে হবে।

আপনি যদি একটি ফাইল থেকে সমস্ত ব্যান্ড ইনজেস্ট করতে না চান, তাহলে GDAL ব্যান্ডগুলির মধ্যে কোনটি ইনজেস্ট করা উচিত তা নির্দেশ করতে আপনি tilesetBandIndex ক্ষেত্রটি ব্যবহার করতে পারেন৷ প্রথম ব্যান্ডের টাইলসেট ব্যান্ড ইনডেক্স 0।

উদাহরণ:

ধরুন সোর্স ফাইলের চারটি ব্যান্ড আছে: "tmin", "tmin_error", "tmax", "tmax_error"। আমরা শুধুমাত্র "tmin" এবং "tmax" গ্রহণ করতে চাই। প্রাসঙ্গিক ম্যানিফেস্ট বিভাগগুলি এইরকম দেখাবে:

{
  "name": "projects/earthengine-legacy/assets/users/username/some_folder/some_id",
  "tilesets": [
    {
      "id": "temperature",
      "sources": [
        {
          "uris": [
            "gs://bucket/temperature.tif"
          ]
        }
      ]
    }
  ],
  "bands": [
    {
      "id": "tmin",
      "tilesetBandIndex": 0,
      "tilesetId": "temperature"
    },
    {
      "id": "tmax",
      "tilesetBandIndex": 2,
      "tilesetId": "temperature"
    }
  ]
}

মাস্ক ব্যান্ড

ব্যান্ড মাস্কিং ম্যানিফেস্টের maskBands উপাদান দ্বারা নিয়ন্ত্রিত হয়। তিনটি সম্ভাব্য মাস্ক কনফিগারেশন সমর্থিত (কিন্তু মাস্ক ব্যান্ড সবসময় একটি নির্দিষ্ট ফাইলের শেষ ব্যান্ড হিসেবে ধরে নেওয়া হয়)।

  1. একই ফাইলে সমস্ত ডেটা ব্যান্ডের জন্য মাস্ক।
  2. অন্যান্য সমস্ত ফাইল থেকে আসা সমস্ত ডেটা ব্যান্ডের জন্য মুখোশ।
  3. কিছু ডেটা ব্যান্ডের জন্য মাস্ক।

1. সবচেয়ে সাধারণ ক্ষেত্রে একটি একক জিওটিআইএফএফ যার শেষ ব্যান্ডটি অন্যান্য ব্যান্ডের জন্য মাস্ক হিসাবে ব্যবহৃত হয়। এটি শুধুমাত্র বাইট ধরনের জিওটিআইএফএফ-এর জন্য কাজ করে। নিম্নলিখিত ম্যানিফেস্ট ব্যবহার করুন:

{
  "name": "projects/earthengine-legacy/assets/users/username/some_folder/some_id",
  "tilesets": [
    {
      "id": "data_tileset",
      "sources": [
        {
          "uris": [
            "gs://bucket/data_file.tif"
          ]
        }
      ]
    }
  ],
  "bands": [
    {
      "id": "data_band",
      "tilesetId": "data_tileset"
    },
    {
      "id": "qa_band",
      "tilesetId": "data_tileset"
    }
  ],
  "maskBands": [
    {
      "tilesetId": "data_tileset"
    }
  ]
}

2. অন্য জিওটিআইএফএফ-এ সমস্ত ব্যান্ডের জন্য একটি মাস্ক জিওটিআইএফএফ ব্যবহার করতে, নিম্নলিখিত ম্যানিফেস্টটি ব্যবহার করুন:

{
  "name": "projects/earthengine-legacy/assets/users/username/some_folder/some_id",
  "tilesets": [
    {
      "id": "data_tileset",
      "sources": [
        {
          "uris": [
            "gs://bucket/data_file.tif"
          ]
        }
      ]
    },
    {
      "id": "mask_tileset",
      "sources": [
        {
          "uris": [
            "gs://bucket/mask_file.tif"
          ]
        }
      ]
    }
  ],
  "bands": [
    {
      "id": "data_band",
      "tilesetId": "data_tileset"
    },
    {
      "id": "qa_band",
      "tilesetId": "data_tileset"
    }
  ],
  "maskBands": [
    {
      "tilesetId": "mask_tileset"
    }
  ]
}

3. অন্য ফাইলে একটি নির্দিষ্ট ব্যান্ডের জন্য একটি মাস্ক হিসাবে একটি জিওটিআইএফএফ ব্যবহার করতে, নিম্নলিখিত ম্যানিফেস্টটি ব্যবহার করুন (আগের ক্ষেত্রের সাথে পার্থক্য হল maskBands bandIds ক্ষেত্র সেট করা আছে):

{
  "name": "projects/earthengine-legacy/assets/users/username/some_folder/some_id",
  "tilesets": [
    {
      "id": "data_tileset",
      "sources": [
        {
          "uris": [
            "gs://bucket/data_file.tif"
          ]
        }
      ]
    },
    {
      "id": "mask_tileset",
      "sources": [
        {
          "uris": [
            "gs://bucket/mask_file.tif"
          ]
        }
      ]
    }
  ],
  "bands": [
    {
      "id": "data_band",
      "tilesetId": "data_tileset"
    },
    {
      "id": "qa_band",
      "tilesetId": "data_tileset"
    }
  ],
  "maskBands": [
    {
      "tilesetId": "mask_tileset",
      "bandIds": ["data_band"]
    }
  ]
}

শেষ উদাহরণে, আমরা data_tileset tileset থেকে দুটি ব্যান্ডের সাথে কাজ করছি, কিন্তু শুধুমাত্র একটি ব্যান্ডে ( data_band ) একটি মাস্ক প্রয়োগ করছি, যা শুধুমাত্র প্রদত্ত maskBands তালিকা অবজেক্টের bandIds ফিল্ড দ্বারা মনোনীত করা হয়েছে।

উল্লেখ্য যে maskBands উল্লিখিত টাইলসেটের শেষ ব্যান্ডটিই মাস্ক ব্যান্ড হিসেবে ব্যবহার করা হয়েছে।

পিরামিডিং নীতি

যখন আর্থ ইঞ্জিন ইনজেশনের সময় ইমেজ পিরামিড তৈরি করে, তখন এটিকে বারবার 2x2-পিক্সেল গ্রিডগুলিকে একটি একক পিক্সেলে কমাতে হয়, কিছু ফ্যাশনে পিক্সেল মান পরিবর্তন করে। ডিফল্টরূপে, পিক্সেল মান গড় করা হয়, যেটি বেশিরভাগ ক্ষেত্রে সঠিক কাজ যখন রাস্টার ব্যান্ড কম-বেশি একটানা ডেটা উপস্থাপন করে। যাইহোক, দুটি পরিস্থিতি আছে যখন ডিফল্টের উপর নির্ভর করলে ভুল ফলাফল পাওয়া যাবে, এই ক্ষেত্রে ব্যান্ড সংজ্ঞায় pyramidingPolicy ক্ষেত্রটি অবশ্যই সেট করতে হবে (সেট না থাকলে, এটির মান ডিফল্টরূপে "MEAN" বলে ধরে নেওয়া হয়)।

রাস্টার চিত্রগুলির শ্রেণীবিভাগের জন্য (উদাহরণস্বরূপ, ল্যান্ড কভার শ্রেণীবিভাগের জন্য) পিরামিডিং পিক্সেলের সবচেয়ে যৌক্তিক উপায় হল পরেরটি তৈরি করতে চারটি মানের বেশিরভাগ গ্রহণ করা। এটি "MODE" পিরামিডিং নীতি ব্যবহার করে করা হয়:

{
  "name": "projects/earthengine-legacy/assets/users/username/some_folder/some_id",
  "tilesets": [
    {
      "sources": [
        {
          "uris": [
            "gs://bucket/landcover.tif"
          ]
        }
      ]
    }
  ],
  "bands": [
    {
      "id": "landcover",
      "pyramidingPolicy": "MODE"
    }
  ]
}

রাস্টার ব্যান্ডের জন্য যেখানে "MEAN" বা "MODE" কোনটাই বোঝা যায় না (উদাহরণস্বরূপ, বিটপ্যাকড পিক্সেল), "SAMPLE" পিরামিডিং নীতি ব্যবহার করা উচিত। "নমুনা" সর্বদা প্রতিটি 2x2 গ্রিড থেকে উপরের বামদিকের পিক্সেলের মান নেয়৷ নিম্নলিখিত উদাহরণটি একটি ব্যান্ডকে "MEAN" পিরামিডিং নীতি নির্ধারণ করে যা একটি ক্রমাগত পরিবর্তনশীল ("NDVI") এবং ডেটার "QA" ব্যান্ডে "SAMPLE" প্রতিনিধিত্ব করে।

{
  "name": "projects/earthengine-legacy/assets/users/username/some_folder/some_id",
  "tilesets": [
    {
      "sources": [
        {
          "uris": [
            "gs://bucket/ndvi.tif"
          ]
        }
      ]
    }
  ],
  "bands": [
    {
      "id": "NDVI",
      "tilesetBandIndex": 0,
      "pyramidingPolicy": "MEAN"
    },
    {
      "id": "QA",
      "tilesetBandIndex": 1,
      "pyramidingPolicy": "SAMPLE"
    }
  ]
}

শুরু এবং শেষ সময়

ডেটাতে আরও প্রসঙ্গ দেওয়ার জন্য সমস্ত সম্পদের শুরু এবং শেষের সময় নির্দিষ্ট করা উচিত, বিশেষ করে যদি সেগুলি সংগ্রহে অন্তর্ভুক্ত করা হয়। এই ক্ষেত্রগুলির প্রয়োজন নেই, তবে আমরা যখনই সম্ভব তখন এগুলি ব্যবহার করার পরামর্শ দিই৷

শুরু এবং শেষের সময় সাধারণত পর্যবেক্ষণের সময় বোঝায়, উৎস ফাইলটি তৈরি করার সময় নয়।

শেষ সময়টিকে সরলতার জন্য একচেটিয়া সীমানা হিসাবে বিবেচনা করা হয়। উদাহরণস্বরূপ, ঠিক এক দিন বিস্তৃত সম্পদের জন্য, শুরু এবং শেষ সময়ের জন্য পরপর দুই দিনের মধ্যরাত ব্যবহার করুন (উদাহরণস্বরূপ, 1980-01-31T00:00:00 এবং 1980-02-01T00:00:00)। সম্পদের কোনো সময়কাল না থাকলে, শেষের সময় শুরুর সময়ের মতো সেট করুন। ISO 8601 স্ট্রিং হিসাবে ম্যানিফেস্টের সময়গুলিকে উপস্থাপন করে৷ তারিখের মানগুলিকে সহজ করার জন্য আমরা শেষ সময়কে একচেটিয়া (উদাহরণস্বরূপ, দৈনিক সম্পদের জন্য পরের দিনের মধ্যরাত) ধরে নেওয়ার পরামর্শ দিই।

উদাহরণ:

{
  "name": "projects/some-project-id/assets/some-asset-id",
  "tilesets": [
    {
      "sources": [
        {
          "uris": [
            "gs://bucket/img_20190612.tif"
          ]
        }
      ]
    }
  ],
  "startTime": "1980-01-31T00:00:00Z",
  "endTime": "1980-02-01T00:00:00Z"
}

ম্যানিফেস্ট গঠন রেফারেন্স

নিম্নলিখিত JSON কাঠামোতে সমস্ত সম্ভাব্য চিত্র আপলোড ম্যানিফেস্ট ক্ষেত্র অন্তর্ভুক্ত রয়েছে৷ নিম্নলিখিত ম্যানিফেস্ট ক্ষেত্রের সংজ্ঞা বিভাগে ক্ষেত্রের সংজ্ঞা খুঁজুন।

{
  "name": <string>,
  "tilesets": [
    {
      "dataType": <string>,
      "id": <string>,
      "crs": <string>,
      "sources": [
        {
          "uris": [
            <string>
          ],
          "affineTransform": {
            "scaleX": <double>,
            "shearX": <double>,
            "translateX": <double>,
            "shearY": <double>,
            "scaleY": <double>,
            "translateY": <double>
          }
        }
      ]
    }
  ],
  "bands": [
    {
      "id": <string>,
      "tilesetId": <string>,
      "tilesetBandIndex": <int32>,
      "missingData": {
        "values": [<double>]
      },
      "pyramindingPolicy": <string>
    }
  ],
  "maskBands": [
    {
      "tilesetId": <string>,
      "bandIds": [
        <string>
      ]
    }
  ],
  "footprint": {
    "points": [
      {
        "x": <double>,
        "y": <double>
      }
    ],
    "bandId": <string>
  },
  "missingData": {
     "values": [<double>]
  },
  "pyramidingPolicy": <string>,
  "uriPrefix": <string>,
  "startTime": {
    "seconds": <integer>
  },
  "endTime": {
    "seconds": <integer>
  },
  "properties": {
    <unspecified>
  }
}

ম্যানিফেস্ট ক্ষেত্রের সংজ্ঞা

নাম

string

সম্পদের নাম তৈরি করতে হবে। name "projects/*/assets/**" ফরম্যাটের (উদাহরণস্বরূপ, "projects/earthengine-legacy/assets/users/USER/ASSET")।

টাইলসেট

list

অভিধানের একটি তালিকা যা টাইল সেটের বৈশিষ্ট্য নির্ধারণ করে। আরও তথ্যের জন্য নিম্নলিখিত tilesets অভিধান উপাদান ক্ষেত্রগুলি দেখুন।

টাইলসেট[i]।ডেটা টাইপ

string

ডেটার সাংখ্যিক ডেটা টাইপ নির্দিষ্ট করে। ডিফল্ট হল সেই প্রকার যা GDAL রিপোর্ট করে, সেক্ষেত্রে সংজ্ঞায়িত করার প্রয়োজন নেই।

ডেটা টাইপ মান
অনির্দিষ্ট "DATA_TYPE_UNSPECIFIED"
8-বিট স্বাক্ষরিত পূর্ণসংখ্যা "INT8"
8-বিট স্বাক্ষরবিহীন পূর্ণসংখ্যা "UINT8"
16-বিট স্বাক্ষরিত পূর্ণসংখ্যা "INT16"
16-বিট স্বাক্ষরবিহীন পূর্ণসংখ্যা "UINT16"
32-বিট স্বাক্ষরিত পূর্ণসংখ্যা "INT32"
32-বিট স্বাক্ষরবিহীন পূর্ণসংখ্যা "UINT32"
32-বিট ফ্লোট "ফ্লোট৩২"
64-বিট ফ্লোট "FLOAT64"

টাইলসেট [i].id

string

টাইলসেটের আইডি। অ্যাসেট ম্যানিফেস্টে নির্দিষ্ট করা টাইলসেটগুলির মধ্যে অনন্য হতে হবে। এই আইডি প্রসেসিং ধাপের সময় বাতিল করা হয়; এটি শুধুমাত্র একটি ব্যান্ডের সাথে একটি টাইলসেট লিঙ্ক করতে ব্যবহৃত হয়। খালি স্ট্রিংটি একটি বৈধ আইডি।

টাইলসেট [i].crs

string

পিক্সেল গ্রিডের কোঅর্ডিনেট রেফারেন্স সিস্টেম, যেখানে সম্ভব একটি স্ট্যান্ডার্ড কোড হিসাবে নির্দিষ্ট করা হয়েছে (উদাহরণস্বরূপ, EPSG কোড), এবং অন্যথায় WKT ফর্ম্যাটে।

টাইলসেট [i]. উত্স

list

একটি চিত্র ফাইল এবং এর সাইডকারের বৈশিষ্ট্য সংজ্ঞায়িত অভিধানের একটি তালিকা। আরও তথ্যের জন্য নিম্নলিখিত sources অভিধান উপাদান ক্ষেত্র দেখুন.

টাইলসেট[i].উৎস [j].uris

list

ইনজেস্ট করা ডেটার URI-এর একটি তালিকা। শুধুমাত্র Google ক্লাউড স্টোরেজ ইউআরআই সমর্থিত। প্রতিটি URI অবশ্যই নিম্নলিখিত বিন্যাসে নির্দিষ্ট করতে হবে: gs://bucket-id/object-id । প্রাথমিক বস্তুটি তালিকার প্রথম উপাদান হওয়া উচিত এবং পরে তালিকাভুক্ত সাইডকারগুলি। প্রতিটি URI সেট করা থাকলে ImageManifest.uriPrefix এর সাথে প্রিফিক্স করা হয়।

টাইলসেট[i].উৎস [j].affineTransform

dictionary

একটি ঐচ্ছিক affine রূপান্তর. শুধুমাত্র তখনই নির্দিষ্ট করা উচিত যদি uris থেকে পাওয়া ডেটা (যেকোনো সাইডকার সহ) পিক্সেল স্থাপনের জন্য যথেষ্ট না হয়। নিম্নলিখিত কীগুলির সাথে একটি অভিধান হিসাবে সরবরাহ করা হয়েছে: "scaleX", "shearX", "translateX", "shearY", "scaleY", "translateY"। আরো তথ্যের জন্য এই রেফারেন্স দেখুন.

উদাহরণ কী এবং মান:

{
  "scaleX": 0.1,
  "shearX": 0.0,
  "translateX": -180.0,
  "shearY": 0.0,
  "scaleY": -0.1,
  "translateY": 90.0
}

ব্যান্ড

list

একটি টাইলসেট থেকে প্রাপ্ত একটি একক ব্যান্ডের বৈশিষ্ট্য সংজ্ঞায়িত করা অভিধানের একটি তালিকা৷ নোট করুন যে সম্পদের ব্যান্ড অর্ডার bands ক্রম হিসাবে একই। আরো তথ্যের জন্য নিম্নলিখিত bands অভিধান উপাদান ক্ষেত্র দেখুন.

ব্যান্ড [i].id

string

ব্যান্ডের আইডি (নাম)।

ব্যান্ড [i].tilesetId

string

ব্যান্ডের সাথে সম্পর্কিত টাইলসেটের আইডি।

ব্যান্ড [i].tilesetBandIndex

int32

ব্যান্ডের সাথে সম্পর্কিত টাইলসেট থেকে শূন্য-ভিত্তিক ব্যান্ড সূচক।

ব্যান্ড[i].missingData.values

list

মানগুলির একটি তালিকা (দ্বৈত প্রকার) যা ব্যান্ডে কোনও ডেটা উপস্থাপন করে না।

ব্যান্ড[i].পিরামিডিং পলিসি

string

পিরামিডিং নীতি। আরো তথ্যের জন্য এই লিঙ্ক দেখুন. বিকল্প অন্তর্ভুক্ত:

  • "MEAN" (ডিফল্ট)
  • "মোড"
  • "নমুনা"

মাস্কব্যান্ড

list

একটি টাইলসেট থেকে প্রাপ্ত একক মাস্ক ব্যান্ডের বৈশিষ্ট্য সংজ্ঞায়িত করা অভিধানের একটি তালিকা। সর্বাধিক 1টি মাস্ক ব্যান্ড প্রদান করা যেতে পারে। আরও তথ্যের জন্য নিম্নলিখিত maskBands অভিধান উপাদান ক্ষেত্রগুলি দেখুন।

maskBands[i].tilesetId

string

মাস্ক ব্যান্ডের সাথে সম্পর্কিত টাইলসেটের আইডি। টাইলসেটের শেষ ব্যান্ডটি সবসময় মাস্ক ব্যান্ড হিসেবে ব্যবহার করা হয়।

মাস্কব্যান্ডস[i].ব্যান্ডআইডস

list of strings

মাস্ক ব্যান্ড প্রযোজ্য ব্যান্ডের আইডিগুলির তালিকা৷ খালি থাকলে, মাস্ক ব্যান্ডটি সম্পদের সমস্ত ব্যান্ডে প্রয়োগ করা হয়। প্রতিটি ব্যান্ডে শুধুমাত্র একটি সংশ্লিষ্ট মাস্ক ব্যান্ড থাকতে পারে।

পদচিহ্ন

dictionary

একটি অভিধান একটি চিত্রের সমস্ত বৈধ পিক্সেলের পদচিহ্নের বৈশিষ্ট্যগুলিকে সংজ্ঞায়িত করে৷ খালি থাকলে, ডিফল্ট ফুটপ্রিন্ট পুরো চিত্র। আরো তথ্যের জন্য নিম্নলিখিত footprint অভিধান উপাদান ক্ষেত্র দেখুন.

ফুটপ্রিন্ট.পয়েন্ট

list

একটি চিত্রের সমস্ত বৈধ পিক্সেলের একটি পদচিহ্ন সংজ্ঞায়িত পয়েন্টগুলির একটি তালিকা৷ একটি বিন্দু একটি অভিধান দ্বারা সংজ্ঞায়িত করা হয় যার মধ্যে "x" এবং "y" কী ফ্লোট মান রয়েছে। পয়েন্টগুলির একটি তালিকা হল একটি রিং বর্ণনা করা যা একটি সাধারণ বহুভুজের বাইরের অংশ গঠন করে যাতে চিত্রের সমস্ত বৈধ পিক্সেলের কেন্দ্র থাকতে হবে। এটি অবশ্যই একটি রৈখিক রিং হতে হবে: শেষ বিন্দুটি অবশ্যই প্রথমটির সমান হতে হবে। স্থানাঙ্কগুলি bandId দ্বারা নির্দিষ্ট করা ব্যান্ডের অভিক্ষেপে থাকে।

দ্রষ্টব্য: প্রতিটি পিক্সেলের কেন্দ্রের মতো অ-পূর্ণসংখ্যা স্থানাঙ্ক ব্যবহার করুন কারণ পিক্সেল (একটি 1x1 আয়তক্ষেত্র) ফুটপ্রিন্টকে ছেদ করলে একটি পিক্সেল অন্তর্ভুক্ত করার জন্য footprint নেওয়া হয়। দুর্ঘটনাক্রমে প্রতিবেশী পিক্সেল নির্বাচন এড়াতে, পূর্ণসংখ্যা-মূল্যের স্থানাঙ্ক ব্যবহার করবেন না, কারণ সেগুলি পিক্সেলের মধ্যে সীমানা। পিক্সেল কেন্দ্র বরাবর পায়ের ছাপ আঁকলে অনিচ্ছাকৃত পিক্সেল সহ বাধা দেয়, যা উদ্দেশ্যযুক্ত পিক্সেলগুলি যখন অ্যান্টিমেরিডিয়ান বা একটি খুঁটির মতো একটি মানচিত্রের সীমারেখা অবলুপ্ত করে তখন ত্রুটি হতে পারে।

উদাহরণস্বরূপ, চারটি বৈধ পিক্সেল সহ একটি 2x2 চিত্রের জন্য, নিম্নলিখিতটি একটি সম্ভাব্য রিং:

[
  {
    "x": 0.5,
    "y": 0.5
  },
  {
    "x": 0.5,
    "y": 1.5
  },
  {
    "x": 1.5,
    "y": 1.5
  },
  {
    "x": 1.5,
    "y": 0.5
  },
  {
    "x": 0.5,
    "y": 0.5
  }
]

footprint.bandId

string

ব্যান্ডের ID যার CRS পদচিহ্নের স্থানাঙ্কগুলিকে সংজ্ঞায়িত করে৷ খালি হলে, প্রথম ব্যান্ড ব্যবহার করা হয়।

missingData.values

list

মানগুলির একটি তালিকা (দ্বৈত প্রকার) যা চিত্রের সমস্ত ব্যান্ডে কোনও ডেটা উপস্থাপন করে না। সমস্ত ব্যান্ডের ক্ষেত্রে প্রযোজ্য যা তাদের নিজস্ব missingData নির্দিষ্ট করে না।

পিরামিডিং নীতি

string

পিরামিডিং নীতি। অনির্দিষ্ট থাকলে, নীতি "MEAN" ডিফল্টরূপে প্রয়োগ করা হয়। সমস্ত ব্যান্ডের ক্ষেত্রে প্রযোজ্য যা তাদের নিজস্ব নির্দিষ্ট করে না। আরো তথ্যের জন্য এই লিঙ্ক দেখুন. বিকল্প অন্তর্ভুক্ত:

  • "MEAN" (ডিফল্ট)
  • "মোড"
  • "নমুনা"

uriPrefix

string

একটি ঐচ্ছিক উপসর্গ ম্যানিফেস্টে সংজ্ঞায়িত সমস্ত uris পূর্বে যুক্ত।

শুরুর সময়

integer

সম্পদের সাথে যুক্ত টাইমস্ট্যাম্প, যদি থাকে। এটি সাধারণত স্যাটেলাইট ছবি তোলার সময়ের সাথে মিলে যায়। সময়ের ব্যবধানের সাথে সঙ্গতিপূর্ণ সম্পদের জন্য, যেমন এক মাস বা বছরের গড় মান, এই টাইমস্ট্যাম্প সেই ব্যবধানের শুরুর সাথে মিলে যায়। যুগ (1970-01-01) থেকে সেকেন্ড এবং (ঐচ্ছিকভাবে) ন্যানোসেকেন্ড হিসাবে নির্দিষ্ট করা হয়েছে। UTC টাইম জোনে বলে ধরে নেওয়া হচ্ছে।

শেষ সময়

integer

সময়ের ব্যবধানের সাথে সামঞ্জস্যপূর্ণ সম্পদের জন্য, যেমন এক মাস বা বছরের গড় মান, এই টাইমস্ট্যাম্পটি সেই ব্যবধানের (একচেটিয়া) শেষের সাথে মিলে যায়। যুগ (1970-01-01) থেকে সেকেন্ড এবং (ঐচ্ছিকভাবে) ন্যানোসেকেন্ড হিসাবে নির্দিষ্ট করা হয়েছে। UTC টাইম জোনে বলে ধরে নেওয়া হচ্ছে।

বৈশিষ্ট্য

dictionary

কী-মান জোড়ার একটি নির্বিচারে সমতল অভিধান। কীগুলি অবশ্যই স্ট্রিং হতে হবে এবং মানগুলি সংখ্যা বা স্ট্রিং হতে পারে৷ ব্যবহারকারীর আপলোড করা সম্পদের জন্য তালিকা মান এখনও সমর্থিত নয়।

সীমাবদ্ধতা

JSON ম্যানিফেস্ট আকার

JSON ম্যানিফেস্ট ফাইলের আকার সীমা হল 10 MB৷ আপনার কাছে আপলোড করার জন্য অনেক ফাইল থাকলে, ডেটাসেট বর্ণনা করার জন্য প্রয়োজনীয় অক্ষরের সংখ্যা কমানোর উপায় বিবেচনা করুন। উদাহরণস্বরূপ, uris তালিকায় প্রতিটি ইউআরআই-এর জন্য Google ক্লাউড বাকেট পাথ প্রদানের প্রয়োজনীয়তা দূর করতে uriPrefix ক্ষেত্রটি ব্যবহার করুন। যদি আরও আকার কমানোর প্রয়োজন হয়, ফাইলের নাম ছোট করার চেষ্টা করুন।

ইমেজ ফাইল ফরম্যাট

প্রতিটি ইমেজ ফাইল একটি TIFF ইমেজ হতে হবে. যদি ম্যানিফেস্টে CRS নির্দিষ্ট করা না থাকে, তাহলে ফাইলটি অবশ্যই একটি এম্বেডেড CRS সহ একটি জিওটিআইএফএফ হতে হবে।

TIFF ফাইলগুলি DEFLATE, JPEG-XL/JXL, LERC, LERC_DEFLATE, LERC_ZSTD, LZMA, LZW, WEBP, বা ZSTD দিয়ে সংকুচিত করা যেতে পারে।

বড় ফাইলের জন্য সেরা আপলোড অভিজ্ঞতার জন্য সুপারিশ:

  • সেরা পছন্দ: ZSTD গতি এবং সংকোচনের একটি ভাল ভারসাম্য অফার করে।
  • এড়িয়ে চলুন: ভাল সংকোচন সত্ত্বেও LZMA খুব ধীর হতে পারে।
  • আনকম্প্রেসড ফাইল: বড় ফাইল এবং আপলোডের সময় বেশি হবে।
  • ক্ষতিকর কম্প্রেশন (যেমন, JPEG): পিক্সেল মান পরিবর্তন করতে পারে। লসলেস কম্প্রেশন ব্যবহার করুন (যেমন, DEFLATE, LZMA, LZW, ZSTD) যদি না আপনি আপনার ডেটার উপর সম্ভাব্য প্রভাব বুঝতে পারেন।