সরাসরি প্রধান সামগ্রীতে চলে যান

Principal Component Analysis (PCA) এর সহজ পাঠ: ডাটা ছোট করার ম্যাজিক

Introduction

সবাইকে স্বাগতম! আজকের এই আলোচনায় আমরা মেশিন লার্নিংয়ের খুব গুরুত্বপূর্ণ একটি টপিক Principal Component Analysis বা সংক্ষেপে PCA নিয়ে কথা বলব। সহজ ভাষায় বলতে গেলে, আমাদের কাছে যখন অনেক বেশি তথ্য বা 'ফিচার' (যেমন- দৈর্ঘ্য, প্রস্থ, ওজন, বয়স ইত্যাদি) থাকে, তখন সবগুলোকে একসাথে সামলানো কঠিন হয়ে পড়ে। PCA আমাদের সাহায্য করে এই অনেকগুলো তথ্য থেকে সবচেয়ে গুরুত্বপূর্ণ অংশগুলো ছেঁকে বের করতে, যাতে ডাটা ছোট হয়ে যায় কিন্তু এর ভেতরের আসল অর্থ বা 'ইনফরমেশন' হারিয়ে না যায়। এটি একটি Unsupervised Learning পদ্ধতি, যার মানে হলো এটি ডাটার লেবেল ছাড়াই কাজ করতে পারে।


১. PCA আসলে কী এবং কেন প্রয়োজন?

ভিডিও রেফারেন্স: ০৩:৩১:০৭

সহজ ব্যাখ্যা: কল্পনা করুন আপনার কাছে একটি টেবিল আছে যেখানে কোনো জিনিসের ১০টি আলাদা বৈশিষ্ট্য দেওয়া আছে। এখন ১০টি মাত্রা বা 'Dimension' নিয়ে কাজ করা এবং সেগুলো গ্রাফে দেখানো অসম্ভব। PCA যা করে তা হলো, এই ১০টি বৈশিষ্ট্যকে মিলিয়ে মাত্র ২-৩টি নতুন বৈশিষ্ট্য তৈরি করে। এই নতুন বৈশিষ্ট্যগুলোকে বলা হয় Principal Components। এতে করে আমরা সহজেই ডাটা ভিজ্যুয়ালাইজ করতে পারি এবং কম্পিউটারও দ্রুত প্রসেস করতে পারে।

কঠিন শব্দের ব্যাখ্যা:

  • Dimensionality Reduction: এর মানে হলো ডাটার মাত্রা কমানো। ধরুন, ৩ডি মুভিকে ২ডি স্ক্রিনে দেখা।

  • Feature (ফিচার): ডাটাবেজের কলামগুলোকে ফিচার বলে। যেমন- মানুষের উচ্চতা একটি ফিচার।


২. PCA এর কাজ করার ধরন (Theory)

ভিডিও রেফারেন্স: ০৩:৩৮:০০

PCA ডাটার ভেতরে এমন কিছু দিক বা 'অক্ষ' (Axis) খুঁজে বের করে যেখানে ডাটা সবচেয়ে বেশি ছড়িয়ে আছে (যাকে টেকনিক্যাল ভাষায় Variance বলে)।

  • প্রথম যে অক্ষ বরাবর ডাটা সবচেয়ে বেশি বিস্তৃত থাকে, তাকে বলা হয় Principal Component 1 (PC1)

  • দ্বিতীয় অক্ষটি এমনভাবে নেওয়া হয় যা প্রথমটির সাথে লম্ব (Orthogonal) থাকে এবং বাকি থাকা তথ্যের সবচেয়ে বেশি অংশ ধারণ করে। একে বলে PC2

এভাবে আমরা অনেকগুলো ফিচার থেকে কমিয়ে মাত্র কয়েকটি কম্পোনেন্টে ডাটাকে নিয়ে আসি।


৩. কোডিংয়ের মাধ্যমে PCA প্রয়োগ

ভিডিও রেফারেন্স: ০৩:৪৮:০০

মেশিন লার্নিংয়ে পাইথন ব্যবহার করে খুব সহজেই PCA করা যায়। নিচে একটি উদাহরণ দেওয়া হলো যেখানে ৭টি ফিচারকে কমিয়ে ২টিতে আনা হয়েছে:

Python

from sklearn.decomposition import PCA
import pandas as pd

# মনে করি x আমাদের মূল ডাটা যাতে ৭টি কলাম আছে
# PCA মডেল তৈরি, আমরা ২টি কম্পোনেন্ট চাই
pca = PCA(n_components=2)

# ডাটাকে ট্রান্সফর্ম করা
transformed_x = pca.fit_transform(x)

# এখন transformed_x এর আকার হবে (samples, 2)
# অর্থাৎ ৭টি কলাম এখন মাত্র ২টি কলামে চলে এসেছে!
print(transformed_x.shape) 

কোড ব্যাখ্যা:

  • PCA(n_components=2): এখানে আমরা কম্পিউটারকে বলছি যে আমার অনেক কলাম দরকার নেই, তুমি শুধু সেরা ২টিকে রাখো।

  • fit_transform: এই ফাংশনটি ডাটা থেকে প্যাটার্ন শিখে এবং সাথে সাথে ডাটাকে ছোট করে ফেলে।


আমার বিশ্লেষণ ও চিন্তাভাবনা

PCA হলো ডাটা সায়েন্সের একটি শক্তিশালী হাতিয়ার। তবে আমাদের মনে রাখতে হবে: ১. সব তথ্য পাওয়া যায় না: PCA করলে কিছু না কিছু তথ্য হারিয়ে যায়। কিন্তু লক্ষ্য থাকে যাতে গুরুত্বপূর্ণ তথ্যগুলো থেকে যায়। ২. স্কেলিং জরুরি: PCA করার আগে ডাটাকে স্কেল করে নেওয়া খুব দরকার, না হলে বড় মানের ডাটা (যেমন- বেতন) ছোট মানের ডাটাকে (যেমন- বয়স) ডমিনেট করবে।

বিকল্প চিন্তা: PCA ছাড়াও ডাটা কমানোর জন্য t-SNE বা UMAP এর মতো আরও আধুনিক পদ্ধতি আছে, যা বিশেষ করে ডাটা গ্রাফে দেখানোর জন্য (Visualization) খুব ভালো কাজ করে। তবে থিওরি বোঝার জন্য এবং গাণিতিক শুদ্ধতার জন্য PCA এখনও অপ্রতিদ্বন্দ্বী।

পরামর্শ: আপনি যদি নতুন হন, তবে প্রথমে ছোট কোনো ডাটা সেট (যেমন- Iris dataset) নিয়ে PCA প্র্যাকটিস করুন। এতে আপনি সরাসরি দেখতে পারবেন কীভাবে ৩-৪টি কলাম কমে ২টি হয়ে যাচ্ছে এবং গ্রাফে সেগুলো সুন্দরভাবে আলাদা করা যাচ্ছে।

[

Machine Learning for Everybody – Full Course

freeCodeCamp.org · 9.4M views

](http://www.youtube.com/watch?v=i_LwzRVP7bg)

মন্তব্যসমূহ

এই ব্লগটি থেকে জনপ্রিয় পোস্টগুলি

সিজ্জিন (Sijjin) vs ইল্লিয়িন (Illiyin) পার্থক্য Difference

Sijjin (سِجِّين) এবং Illiyin (عِلِّيِّين) —এ দুটি শব্দ কুরআনে এসেছে এবং দুটোই মানুষের আমলনামা সংরক্ষণ সম্পর্কিত স্থানকে নির্দেশ করে। ১. সিজ্জিন (Sijjin) সিজ্জিন হলো পাপীদের (কাফের, মুনাফিক ও দুরাচারীদের) আমলনামা সংরক্ষণের স্থান। এটি সাত তলদেশের নীচে এক কারাগার বা অন্ধকার জগতে অবস্থিত বলে উল্লেখ রয়েছে। সূরা আল-মুতাফফিফীন (৮৩:৭-৯) তে বলা হয়েছে: "كَلَّا إِنَّ كِتَابَ الْفُجَّارِ لَفِي سِجِّينٍ ۝ وَمَا أَدْرَاكَ مَا سِجِّينٌ ۝ كِتَابٌ مَرْقُومٌ" অর্থ: "না, পাপীদের আমলনামা সিজ্জিনে সংরক্ষিত। তুমি কি জানো, সিজ্জিন কী? এটি এক লিখিত দলিল।" সিজ্জিনকে একটি কারাগার, সংকীর্ণ স্থান, বা নিচের স্তরে অবস্থিত এক অন্ধকার দুনিয়া হিসেবে ব্যাখ্যা করা হয়। ২. ইল্লিয়িন (Illiyin) ইল্লিয়িন হলো সৎকর্মশীলদের (মুমিন ও নেককারদের) আমলনামা সংরক্ষণের স্থান । এটি সপ্তম আসমানের ওপরে সংরক্ষিত এক সম্মানিত স্থান। সূরা আল-মুতাফফিফীন (৮৩:১৮-২১) তে বলা হয়েছে: "كَلَّا إِنَّ كِتَابَ الْأَبْرَارِ لَفِي عِلِّيِّينَ ۝ وَمَا أَدْرَاكَ مَا عِلِّيُّونَ ۝ كِتَابٌ مَرْقُومٌ ۝ يَش...

তারাবিহ সমগ্র - প্রথম আলো

রামাদান ২০২৪ উপলক্ষে প্রথম আলোর নিয়মিত আয়োজন - খতমে তারাবিহ'র সূরা গুলো নিয়ে সংক্ষিপ্ত আলোচনা'র লিংক  নিচে দেওয়া হলো।  লিংকে ক্লিক করলেই আপনাকে আলোচনা তে নিয়ে যাবে। তারাবিহ: ১ | একটি খুন ও গাভি নিয়ে বনি ইসরাইলের বাড়াবাড়ি তারাবিহ: ২ | নারীর মর্যাদা ও অধিকার এবং অলৌকিক তিন ঘটনা তারাবিহ: ৩ | যে ১৪ নারীকে বিয়ে করা হারাম তারাবিতে: ১২ | মহানবী (সা.)–এর আকাশভ্রমণ এবং আসহাবে কাহাফের কাহিনি

রেডমি নোট ৯ এর বিস্তারিত | Redmi Note 9 in Bangla

৩০ এপ্রিল, ২০২০ এ শাওমির ঘোষনা আসে এই ফোনটি নিয়ে। কিন্তু ফোনটি মার্কেটে আসে মে মাসের শেষের দিকে৷ করোনার কারনে ফোনটি বাংলাদেশে আসতে আরো সময় নেয়। বর্তমানে বাংলাদেশে আন অফিশিয়াল ভাবে ফোনটি পাওয়া যাচ্ছে৷ বাংলাদেশে অফিশিয়াল ভাবে এখনো ফোনটি আসার তথ্য নেয়৷ চলুন ফোনটি নিয়ে বিস্তারিত আলোচনা করা যাক। শাওমি নোট সিরিজের ফোন বের করে এদের রেডমি নামে সাব ব্যান্ড৷ এদের কাজ হল এই নোট সিরিজ নিয়ে কাজ করা৷ প্রতিবছর নোট সিরিজের ১/২ টা ফোন বাজারে আসে। সাথে সেই ফোন গুলার বিভিন্ন ভার্সন (যেমন - র‍্যাম ও রমের ভিত্তিতে) বাজারে আসে। এই বছরও তারা রেডমি সিরিজের নোট ৯ বাজারে আনে। এই বছর হয়তো এই সিরিজের আরো ফোন বাজারে আসবে। ডিস্পলেঃ ফোনটির ডিসপ্লে সাইজ ৬.৫৩ ইঞ্চি। এতে আইপিএস এলসিডি ডিসপ্লে ব্যবহার করা হয়েছে। এই ফোনের ডিসপ্লে প্রটেকশন হিসেবে আছে গরিলা গ্লাস ফাইভ। স্ক্রিন আর ফোনের বডির অনুপাত প্রায় ৮৩.৫%। এই ফোনের ডিসপ্লে ফুলএইচডি মানে ১০৮০পি। এই ডিস্পলের দৈর্ঘ্য ১৯.৫ একক এবং প্রস্থ হল ৯ একক। এত বড় ফোনের কারনে এই ফোনের পিপি আই ডেনসিটি ৩৯৫। যা একটু কম। প্লাটফর্মঃ এই ফোনের অপারেটিং সিস্টেম এন্ড্রয়েড ১০ এবং এর...