You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
ML-For-Beginners/translations/bn/AGENTS.md

345 lines
22 KiB

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

<!--
CO_OP_TRANSLATOR_METADATA:
{
"original_hash": "93fdaa0fd38836e50c4793e2f2f25e8b",
"translation_date": "2025-10-03T11:03:29+00:00",
"source_file": "AGENTS.md",
"language_code": "bn"
}
-->
# AGENTS.md
## প্রকল্পের সংক্ষিপ্ত বিবরণ
এটি **Machine Learning for Beginners**, একটি ১২-সপ্তাহের, ২৬-লেসনের পাঠক্রম যা Python (মূলত Scikit-learn) এবং R ব্যবহার করে ক্লাসিক মেশিন লার্নিং ধারণাগুলি কভার করে। এই রিপোজিটরি একটি স্ব-গতি সম্পন্ন শিক্ষার উৎস হিসেবে ডিজাইন করা হয়েছে, যেখানে হাতে-কলমে প্রকল্প, কুইজ এবং অ্যাসাইনমেন্ট অন্তর্ভুক্ত রয়েছে। প্রতিটি পাঠ বাস্তব-জীবনের ডেটা ব্যবহার করে বিভিন্ন সংস্কৃতি এবং অঞ্চলের মাধ্যমে মেশিন লার্নিং ধারণাগুলি অন্বেষণ করে।
মূল উপাদানসমূহ:
- **শিক্ষামূলক বিষয়বস্তু**: ২৬টি পাঠ যা মেশিন লার্নিং-এর পরিচিতি, রিগ্রেশন, ক্লাসিফিকেশন, ক্লাস্টারিং, NLP, টাইম সিরিজ এবং রিইনফোর্সমেন্ট লার্নিং কভার করে
- **কুইজ অ্যাপ্লিকেশন**: Vue.js ভিত্তিক কুইজ অ্যাপ যা প্রি- এবং পোস্ট-লেসন মূল্যায়ন প্রদান করে
- **বহুভাষা সমর্থন**: GitHub Actions এর মাধ্যমে + ভাষায় স্বয়ংক্রিয় অনুবাদ
- **দ্বৈত ভাষা সমর্থন**: পাঠগুলি Python (Jupyter notebooks) এবং R (R Markdown files) উভয় ভাষায় উপলব্ধ
- **প্রকল্প ভিত্তিক শিক্ষা**: প্রতিটি বিষয়ের সাথে ব্যবহারিক প্রকল্প এবং অ্যাসাইনমেন্ট অন্তর্ভুক্ত
## রিপোজিটরি কাঠামো
```
ML-For-Beginners/
├── 1-Introduction/ # ML basics, history, fairness, techniques
├── 2-Regression/ # Regression models with Python/R
├── 3-Web-App/ # Flask web app for ML model deployment
├── 4-Classification/ # Classification algorithms
├── 5-Clustering/ # Clustering techniques
├── 6-NLP/ # Natural Language Processing
├── 7-TimeSeries/ # Time series forecasting
├── 8-Reinforcement/ # Reinforcement learning
├── 9-Real-World/ # Real-world ML applications
├── quiz-app/ # Vue.js quiz application
├── translations/ # Auto-generated translations
└── sketchnotes/ # Visual learning aids
```
প্রতিটি পাঠের ফোল্ডারে সাধারণত থাকে:
- `README.md` - প্রধান পাঠের বিষয়বস্তু
- `notebook.ipynb` - Python Jupyter notebook
- `solution/` - সমাধানের কোড (Python এবং R সংস্করণ)
- `assignment.md` - অনুশীলনের জন্য কাজ
- `images/` - ভিজ্যুয়াল রিসোর্স
## সেটআপ কমান্ড
### Python পাঠের জন্য
অধিকাংশ পাঠ Jupyter notebooks ব্যবহার করে। প্রয়োজনীয় ডিপেনডেন্সি ইনস্টল করুন:
```bash
# Install Python 3.8+ if not already installed
python --version
# Install Jupyter
pip install jupyter
# Install common ML libraries
pip install scikit-learn pandas numpy matplotlib seaborn
# For specific lessons, check lesson-specific requirements
# Example: Web App lesson
pip install flask
```
### R পাঠের জন্য
R পাঠগুলি `solution/R/` ফোল্ডারে `.rmd` বা `.ipynb` ফাইল হিসেবে রয়েছে:
```bash
# Install R and required packages
# In R console:
install.packages(c("tidyverse", "tidymodels", "caret"))
```
### কুইজ অ্যাপ্লিকেশনের জন্য
কুইজ অ্যাপটি `quiz-app/` ডিরেক্টরিতে অবস্থিত একটি Vue.js অ্যাপ্লিকেশন:
```bash
cd quiz-app
npm install
```
### ডকুমেন্টেশন সাইটের জন্য
লোকালভাবে ডকুমেন্টেশন চালানোর জন্য:
```bash
# Install Docsify
npm install -g docsify-cli
# Serve from repository root
docsify serve
# Access at http://localhost:3000
```
## ডেভেলপমেন্ট ওয়ার্কফ্লো
### পাঠের নোটবুক নিয়ে কাজ করা
1. পাঠের ডিরেক্টরিতে যান (যেমন, `2-Regression/1-Tools/`)
2. Jupyter notebook খুলুন:
```bash
jupyter notebook notebook.ipynb
```
3. পাঠের বিষয়বস্তু এবং অনুশীলন সম্পন্ন করুন
4. প্রয়োজন হলে `solution/` ফোল্ডারে সমাধান পরীক্ষা করুন
### Python ডেভেলপমেন্ট
- পাঠগুলি স্ট্যান্ডার্ড Python ডেটা সায়েন্স লাইব্রেরি ব্যবহার করে
- ইন্টারঅ্যাকটিভ শিক্ষার জন্য Jupyter notebooks
- প্রতিটি পাঠের `solution/` ফোল্ডারে সমাধানের কোড উপলব্ধ
### R ডেভেলপমেন্ট
- R পাঠগুলি `.rmd` ফরম্যাটে (R Markdown)
- সমাধান `solution/R/` সাবডিরেক্টরিতে অবস্থিত
- RStudio বা Jupyter এর R kernel ব্যবহার করে R notebooks চালান
### কুইজ অ্যাপ্লিকেশন ডেভেলপমেন্ট
```bash
cd quiz-app
# Start development server
npm run serve
# Access at http://localhost:8080
# Build for production
npm run build
# Lint and fix files
npm run lint
```
## টেস্টিং নির্দেশনা
### কুইজ অ্যাপ্লিকেশন টেস্টিং
```bash
cd quiz-app
# Lint code
npm run lint
# Build to verify no errors
npm run build
```
**নোট**: এটি মূলত একটি শিক্ষামূলক পাঠক্রমের রিপোজিটরি। পাঠের বিষয়বস্তুতে কোনো স্বয়ংক্রিয় টেস্ট নেই। যাচাই করা হয়:
- পাঠের অনুশীলন সম্পন্ন করে
- নোটবুক সেল সফলভাবে চালিয়ে
- সমাধানের সাথে আউটপুট মিলিয়ে
## কোড স্টাইল নির্দেশিকা
### Python কোড
- PEP 8 স্টাইল নির্দেশিকা অনুসরণ করুন
- পরিষ্কার, বর্ণনামূলক ভেরিয়েবল নাম ব্যবহার করুন
- জটিল অপারেশনের জন্য মন্তব্য অন্তর্ভুক্ত করুন
- Jupyter notebooks-এ ধারণাগুলি ব্যাখ্যা করার জন্য markdown সেল থাকা উচিত
### JavaScript/Vue.js (কুইজ অ্যাপ)
- Vue.js স্টাইল গাইড অনুসরণ করে
- `quiz-app/package.json` এ ESLint কনফিগারেশন
- `npm run lint` চালিয়ে সমস্যা পরীক্ষা এবং স্বয়ংক্রিয়ভাবে ঠিক করুন
### ডকুমেন্টেশন
- Markdown ফাইলগুলি পরিষ্কার এবং সুগঠিত হওয়া উচিত
- ফেন্সড কোড ব্লকে কোড উদাহরণ অন্তর্ভুক্ত করুন
- অভ্যন্তরীণ রেফারেন্সের জন্য আপেক্ষিক লিঙ্ক ব্যবহার করুন
- বিদ্যমান ফরম্যাটিং কনভেনশন অনুসরণ করুন
## বিল্ড এবং ডিপ্লয়মেন্ট
### কুইজ অ্যাপ্লিকেশন ডিপ্লয়মেন্ট
কুইজ অ্যাপটি Azure Static Web Apps-এ ডিপ্লয় করা যেতে পারে:
1. **প্রয়োজনীয়তা**:
- Azure অ্যাকাউন্ট
- GitHub রিপোজিটরি (আগে থেকেই fork করা)
2. **Azure-এ ডিপ্লয় করুন**:
- Azure Static Web App রিসোর্স তৈরি করুন
- GitHub রিপোজিটরির সাথে সংযুক্ত করুন
- অ্যাপ লোকেশন সেট করুন: `/quiz-app`
- আউটপুট লোকেশন সেট করুন: `dist`
- Azure স্বয়ংক্রিয়ভাবে GitHub Actions workflow তৈরি করে
3. **GitHub Actions Workflow**:
- Workflow ফাইল `.github/workflows/azure-static-web-apps-*.yml` এ তৈরি হয়
- মূল ব্রাঞ্চে push করলে স্বয়ংক্রিয়ভাবে বিল্ড এবং ডিপ্লয় হয়
### ডকুমেন্টেশন PDF
ডকুমেন্টেশন থেকে PDF তৈরি করুন:
```bash
npm install
npm run convert
```
## অনুবাদ ওয়ার্কফ্লো
**গুরুত্বপূর্ণ**: অনুবাদগুলি GitHub Actions এর মাধ্যমে Co-op Translator ব্যবহার করে স্বয়ংক্রিয়ভাবে সম্পন্ন হয়।
- মূল ব্রাঞ্চে পরিবর্তন push করলে অনুবাদ স্বয়ংক্রিয়ভাবে তৈরি হয়
- **কোনোভাবেই ম্যানুয়ালি অনুবাদ করবেন না** - সিস্টেম এটি পরিচালনা করে
- Workflow `.github/workflows/co-op-translator.yml` এ সংজ্ঞায়িত
- Azure AI/OpenAI পরিষেবাগুলি অনুবাদের জন্য ব্যবহার করে
- + ভাষা সমর্থন করে
## কন্ট্রিবিউটিং নির্দেশিকা
### বিষয়বস্তু কন্ট্রিবিউটরদের জন্য
1. **রিপোজিটরি fork করুন** এবং একটি ফিচার ব্রাঞ্চ তৈরি করুন
2. **পাঠের বিষয়বস্তু পরিবর্তন করুন** যদি নতুন পাঠ যোগ বা আপডেট করেন
3. **অনুবাদ করা ফাইল পরিবর্তন করবেন না** - সেগুলি স্বয়ংক্রিয়ভাবে তৈরি হয়
4. **আপনার কোড পরীক্ষা করুন** - নিশ্চিত করুন যে সমস্ত নোটবুক সেল সফলভাবে চালায়
5. **লিঙ্ক এবং ইমেজ যাচাই করুন** সঠিকভাবে কাজ করছে কিনা
6. **একটি pull request জমা দিন** পরিষ্কার বিবরণ সহ
### Pull Request নির্দেশিকা
- **শিরোনামের ফরম্যাট**: `[Section] পরিবর্তনের সংক্ষিপ্ত বিবরণ`
- উদাহরণ: `[Regression] পাঠ ৫-এ টাইপো সংশোধন`
- উদাহরণ: `[Quiz-App] ডিপেনডেন্সি আপডেট`
- **জমা দেওয়ার আগে**:
- নিশ্চিত করুন যে সমস্ত নোটবুক সেল ত্রুটি ছাড়াই চালায়
- `npm run lint` চালান যদি quiz-app পরিবর্তন করেন
- Markdown ফরম্যাটিং যাচাই করুন
- নতুন কোড উদাহরণ পরীক্ষা করুন
- **PR-এ অন্তর্ভুক্ত থাকতে হবে**:
- পরিবর্তনের বিবরণ
- পরিবর্তনের কারণ
- UI পরিবর্তনের ক্ষেত্রে স্ক্রিনশট
- **আচরণবিধি**: [Microsoft Open Source Code of Conduct](CODE_OF_CONDUCT.md) অনুসরণ করুন
- **CLA**: Contributor License Agreement সাইন করতে হবে
## পাঠের কাঠামো
প্রতিটি পাঠ একটি ধারাবাহিক প্যাটার্ন অনুসরণ করে:
1. **পূর্ব-লেকচার কুইজ** - প্রাথমিক জ্ঞান পরীক্ষা করুন
2. **পাঠের বিষয়বস্তু** - লিখিত নির্দেশনা এবং ব্যাখ্যা
3. **কোড প্রদর্শনী** - নোটবুকে হাতে-কলমে উদাহরণ
4. **জ্ঞান যাচাই** - পাঠের সময় বোঝার যাচাই করুন
5. **চ্যালেঞ্জ** - ধারণাগুলি স্বাধীনভাবে প্রয়োগ করুন
6. **অ্যাসাইনমেন্ট** - দীর্ঘমেয়াদী অনুশীলন
7. **পোস্ট-লেকচার কুইজ** - শিক্ষার ফলাফল মূল্যায়ন করুন
## সাধারণ কমান্ড রেফারেন্স
```bash
# Python/Jupyter
jupyter notebook # Start Jupyter server
jupyter notebook notebook.ipynb # Open specific notebook
pip install -r requirements.txt # Install dependencies (where available)
# Quiz App
cd quiz-app
npm install # Install dependencies
npm run serve # Development server
npm run build # Production build
npm run lint # Lint and fix
# Documentation
docsify serve # Serve documentation locally
npm run convert # Generate PDF
# Git workflow
git checkout -b feature/my-change # Create feature branch
git add . # Stage changes
git commit -m "Description" # Commit changes
git push origin feature/my-change # Push to remote
```
## অতিরিক্ত রিসোর্স
- **Microsoft Learn Collection**: [ML for Beginners মডিউল](https://learn.microsoft.com/en-us/collections/qrqzamz1nn2wx3?WT.mc_id=academic-77952-bethanycheum)
- **কুইজ অ্যাপ**: [অনলাইন কুইজ](https://ff-quizzes.netlify.app/en/ml/)
- **আলোচনা বোর্ড**: [GitHub Discussions](https://github.com/microsoft/ML-For-Beginners/discussions)
- **ভিডিও ওয়াকথ্রু**: [YouTube Playlist](https://aka.ms/ml-beginners-videos)
## মূল প্রযুক্তি
- **Python**: ML পাঠের প্রধান ভাষা (Scikit-learn, Pandas, NumPy, Matplotlib)
- **R**: tidyverse, tidymodels, caret ব্যবহার করে বিকল্প বাস্তবায়ন
- **Jupyter**: Python পাঠের জন্য ইন্টারঅ্যাকটিভ নোটবুক
- **R Markdown**: R পাঠের জন্য ডকুমেন্ট
- **Vue.js 3**: কুইজ অ্যাপ্লিকেশনের ফ্রেমওয়ার্ক
- **Flask**: ML মডেল ডিপ্লয়মেন্টের জন্য ওয়েব অ্যাপ্লিকেশন ফ্রেমওয়ার্ক
- **Docsify**: ডকুমেন্টেশন সাইট জেনারেটর
- **GitHub Actions**: CI/CD এবং স্বয়ংক্রিয় অনুবাদ
## নিরাপত্তা বিবেচনা
- **কোডে কোনো গোপন তথ্য নয়**: API key বা credentials কখনোই কমিট করবেন না
- **ডিপেনডেন্সি**: npm এবং pip প্যাকেজ আপডেট রাখুন
- **ব্যবহারকারীর ইনপুট**: Flask ওয়েব অ্যাপ উদাহরণে মৌলিক ইনপুট যাচাই অন্তর্ভুক্ত
- **সংবেদনশীল ডেটা**: উদাহরণ ডেটাসেটগুলি পাবলিক এবং অ-সংবেদনশীল
## সমস্যা সমাধান
### Jupyter Notebooks
- **কর্নেল সমস্যা**: সেল আটকে গেলে কর্নেল রিস্টার্ট করুন: Kernel → Restart
- **ইমপোর্ট ত্রুটি**: pip দিয়ে প্রয়োজনীয় প্যাকেজ ইনস্টল করুন
- **পাথ সমস্যা**: নোটবুক তাদের কন্টেইনিং ডিরেক্টরি থেকে চালান
### কুইজ অ্যাপ্লিকেশন
- **npm install ব্যর্থ**: npm cache পরিষ্কার করুন: `npm cache clean --force`
- **পোর্ট কনফ্লিক্ট**: পোর্ট পরিবর্তন করুন: `npm run serve -- --port 8081`
- **বিল্ড ত্রুটি**: `node_modules` মুছে পুনরায় ইনস্টল করুন: `rm -rf node_modules && npm install`
### R পাঠ
- **প্যাকেজ পাওয়া যায়নি**: ইনস্টল করুন: `install.packages("package-name")`
- **RMarkdown রেন্ডারিং**: নিশ্চিত করুন rmarkdown প্যাকেজ ইনস্টল করা আছে
- **কর্নেল সমস্যা**: Jupyter এর জন্য IRkernel ইনস্টল করতে হতে পারে
## প্রকল্প-নির্দিষ্ট নোট
- এটি মূলত একটি **শিক্ষামূলক পাঠক্রম**, প্রোডাকশন কোড নয়
- **হাতে-কলমে অনুশীলনের মাধ্যমে মেশিন লার্নিং ধারণা বোঝা**-তে ফোকাস
- কোড উদাহরণগুলি **স্পষ্টতার উপর জোর দেয়, অপ্টিমাইজেশনের উপর নয়**
- অধিকাংশ পাঠ **স্বতন্ত্র** এবং স্বাধীনভাবে সম্পন্ন করা যেতে পারে
- **সমাধান প্রদান করা হয়েছে**, তবে শিক্ষার্থীদের প্রথমে অনুশীলন করা উচিত
- রিপোজিটরি **Docsify** ব্যবহার করে ওয়েব ডকুমেন্টেশন তৈরি করে, কোনো বিল্ড স্টেপ ছাড়াই
- **Sketchnotes** ধারণাগুলির ভিজ্যুয়াল সারাংশ প্রদান করে
- **বহুভাষা সমর্থন** বিষয়বস্তুকে বিশ্বব্যাপী অ্যাক্সেসযোগ্য করে তোলে
---
**অস্বীকৃতি**:
এই নথিটি AI অনুবাদ পরিষেবা [Co-op Translator](https://github.com/Azure/co-op-translator) ব্যবহার করে অনুবাদ করা হয়েছে। আমরা যথাসাধ্য সঠিকতার জন্য চেষ্টা করি, তবে অনুগ্রহ করে মনে রাখবেন যে স্বয়ংক্রিয় অনুবাদে ত্রুটি বা অসঙ্গতি থাকতে পারে। মূল ভাষায় থাকা নথিটিকে প্রামাণিক উৎস হিসেবে বিবেচনা করা উচিত। গুরুত্বপূর্ণ তথ্যের জন্য, পেশাদার মানব অনুবাদ সুপারিশ করা হয়। এই অনুবাদ ব্যবহারের ফলে কোনো ভুল বোঝাবুঝি বা ভুল ব্যাখ্যা হলে আমরা দায়বদ্ধ থাকব না।