ওভারভিউ
মেশ এবং পয়েন্ট ক্লাউড হল 3D আকারের প্রতিনিধিত্ব করার জন্য গুরুত্বপূর্ণ এবং শক্তিশালী ধরণের ডেটা এবং কম্পিউটার দৃষ্টি এবং কম্পিউটার গ্রাফিক্সের ক্ষেত্রে ব্যাপকভাবে অধ্যয়ন করা হয়। 3D ডেটা আরও সর্বব্যাপী হয়ে উঠছে এবং গবেষকরা নতুন সমস্যাগুলিকে চ্যালেঞ্জ করছেন যেমন 2D ডেটা থেকে 3D জ্যামিতি পুনর্গঠন, 3D পয়েন্ট ক্লাউড শব্দার্থিক বিভাজন, 3D অবজেক্টগুলিকে সারিবদ্ধ করা বা মরফ করা ইত্যাদি। অতএব, ফলাফলগুলিকে ভিজ্যুয়ালাইজ করা, বিশেষ করে প্রশিক্ষণের পর্যায়ে, মডেলটি কীভাবে কাজ করে তা আরও ভালভাবে বোঝার জন্য গুরুত্বপূর্ণ।
{width="100%"}
এই প্লাগইনটি টেনসরবোর্ডে 3D পয়েন্ট ক্লাউড বা মেশ (ত্রিভুজাকার বিন্দু মেঘ) প্রদর্শন করতে চায়। উপরন্তু, এটি ব্যবহারকারীকে রেন্ডার করা বস্তুর সাথে ইন্টারঅ্যাক্ট করতে দেয়।
সারাংশ API
হয় একটি জাল বা একটি বিন্দু মেঘ টেনসরের একটি সেট দ্বারা প্রতিনিধিত্ব করা যেতে পারে। উদাহরণস্বরূপ, কেউ একটি পয়েন্ট ক্লাউডকে পয়েন্টের 3D স্থানাঙ্ক এবং প্রতিটি বিন্দুর সাথে যুক্ত কিছু রঙের সেট হিসাবে দেখতে পারে।
from tensorboard.plugins.mesh import summary as mesh_summary
...
point_cloud = tf.constant([[[0.19, 0.78, 0.02], ...]], shape=[1, 1064, 3])
point_colors = tf.constant([[[128, 104, 227], ...]], shape=[1, 1064, 3])
summary = mesh_summary.op('point_cloud', vertices=point_cloud, colors=point_colors)
NOTE colors
টেনসর এই ক্ষেত্রে ঐচ্ছিক কিন্তু পয়েন্টের বিভিন্ন শব্দার্থ দেখাতে উপযোগী হতে পারে।
প্লাগইনটি বর্তমানে শুধুমাত্র ত্রিভুজাকার জাল সমর্থন করে যা শুধুমাত্র মুখের উপস্থিতি দ্বারা উপরের বিন্দু মেঘ থেকে আলাদা - জালের উপর ত্রিভুজ প্রতিনিধিত্বকারী শীর্ষবিন্দুর সেট।
mesh = tf.constant([[[0.19, 0.78, 0.02], ...]], shape=[1, 1064, 3])
colors = tf.constant([[[128, 104, 227], ...]], shape=[1, 1064, 3])
faces = tf.constant([[[13, 78, 54], ...]], shape=[1, 752, 3])
summary = mesh_summary.op('mesh', vertices=mesh, colors=colors, faces=faces)
জালের সারাংশের জন্য শুধুমাত্র colors
টেনসর ঐচ্ছিক।
দৃশ্য কনফিগারেশন
বস্তুগুলি কীভাবে প্রদর্শিত হবে তার উপায়ও দৃশ্যের কনফিগারেশনের উপর নির্ভর করে, যেমন আলোর উত্সের তীব্রতা এবং রঙ, বস্তুর উপাদান, ক্যামেরা মডেল ইত্যাদি। এই সমস্ত একটি অতিরিক্ত প্যারামিটার config_dict
এর মাধ্যমে কনফিগার করা যেতে পারে। এই অভিধানে তিনটি উচ্চ-স্তরের কী থাকতে পারে: camera
, lights
এবং material
। প্রতিটি কী অবশ্যই বাধ্যতামূলক কী cls
সহ একটি অভিধান হতে হবে, বৈধ THREE.js শ্রেণীর নাম উপস্থাপন করে।
camera_config = {'cls': 'PerspectiveCamera'}
summary = mesh_summary.op(
"mesh",
vertices=mesh,
colors=colors,
faces=faces,
config_dict={"camera": camera_config},
)
উপরের স্নিপেট থেকে camera_config
THREE.js ডকুমেন্টেশন অনুযায়ী প্রসারিত করা যেতে পারে। camera_config
থেকে সমস্ত কী camera_config.cls
নামের একটি ক্লাসে পাঠানো হবে। উদাহরণস্বরূপ ( PerspectiveCamera
ডকুমেন্টেশনের উপর ভিত্তি করে):
camera_config = {
'cls': 'PerspectiveCamera',
'fov': 75,
'aspect': 0.9,
}
...
মনে রাখবেন যে দৃশ্য কনফিগারেশন একটি প্রশিক্ষিত পরিবর্তনশীল নয় (অর্থাৎ স্ট্যাটিক) এবং শুধুমাত্র সারাংশ তৈরির সময় প্রদান করা উচিত।
কিভাবে ইন্সটল করবেন
বর্তমানে প্লাগইনটি TensorBoard রাতের বিল্ডের অংশ, তাই প্লাগইনটি ব্যবহার করার আগে আপনাকে এটি ইনস্টল করতে হবে।
কোলাব
pip install -q -U tb-nightly
তারপরে টেনসরবোর্ড এক্সটেনশন লোড করুন এবং এটি চালান, যেমন আপনি টার্মিনালে এটি করবেন:
%load_ext tensorboard
%tensorboard --logdir=/path/to/logs
আরও বিশদ বিবরণের জন্য অনুগ্রহ করে Colab নোটবুকের উদাহরণ দেখুন।
টার্মিনাল
আপনি যদি স্থানীয়ভাবে টেনসরবোর্ড রাত্রিকালীন বিল্ড চালাতে চান, প্রথমে আপনাকে এটি ইনস্টল করতে হবে:
pip install tf-nightly
তারপর শুধু এটি চালান:
tensorboard --logdir path/to/logs