Parallel for Loops (parfor) এবং Distributed Arrays

Parallel Computing in MATLAB (প্যারালাল কম্পিউটিং) - ম্যাটল্যাব (MATLAB) - Computer Programming

343

Parallel for Loops (parfor) এবং Distributed Arrays in MATLAB

MATLAB-এ parallel computing ব্যবহারের মাধ্যমে আপনি আপনার কোডের কার্যকারিতা এবং গতি বৃদ্ধি করতে পারেন, বিশেষত যখন আপনি বড় ডেটাসেট বা কম্পিউটেশনালভাবে জটিল কাজ করছেন। MATLAB-এ parfor লুপ এবং Distributed Arrays ব্যবহার করে আপনি আপনার কোডের বিভিন্ন অংশকে একাধিক প্রসেসর কোরে ভাগ করে রান করতে পারেন।

1. Parallel for Loops (parfor)

parfor হল একটি বিশেষ ধরনের লুপ যা MATLAB-এ parallel processing সক্ষম করে। এটি for লুপের মতো কাজ করে, তবে parfor লুপে প্রতিটি ইটারেশন বা চক্র আলাদাভাবে প্রক্রিয়া করা হয় এবং বিভিন্ন কোরে (cores) অথবা প্রসেসরগুলিতে সমান্তরালভাবে চালানো হয়, যার ফলে সমগ্র প্রোগ্রামটি দ্রুত সম্পন্ন হয়।

parfor সিনট্যাক্স:

parfor index = startVal:endVal
    % লুপের মধ্যে কোড
end
  • parfor লুপের মধ্যে প্রতিটি ইটারেশন পৃথকভাবে একটি আলাদা কোরে চলে, যার ফলে অনেক দ্রুত কাজ সম্পন্ন হতে পারে।

parfor উদাহরণ:

% Create a large vector
n = 1000000;
A = zeros(1, n);

% Parallel for loop to compute squares of numbers
parfor i = 1:n
    A(i) = i^2;
end

disp(A(1:10));  % Display the first 10 results

এখানে:

  • parfor লুপটি প্রতিটি i এর জন্য আলাদা আলাদা প্রসেসর কোরে কাজ করবে, যাতে A(i) = i^2 দ্রুত সম্পন্ন হয়।

parfor এর সুবিধা:

  • Speedup: যখন আপনার কোডে আলাদা আলাদা ইটারেশন থাকে, তখন প্রতিটি ইটারেশনকে আলাদা কোরে রান করতে দেয়। এইভাবে আপনি আপনার কোডের এক্সিকিউশন স্পিড উন্নত করতে পারেন।
  • Parallelization of Independent Loops: যদি লুপের মধ্যে কোনো ধরনের ডিপেনডেন্সি না থাকে (যেমন, পূর্ববর্তী ইটারেশনটির ফলাফল পরবর্তীটির উপর নির্ভর না করে), তাহলে সেই লুপটি সহজেই parfor এ রূপান্তরিত করা যেতে পারে।

parfor ব্লকের ভিন্নতা:

  • parfor ব্যবহার করতে গেলে নিশ্চিত করতে হবে যে লুপের প্রতিটি ইটারেশন একে অপরের উপর নির্ভরশীল নয়, অর্থাৎ, কোন ধরনের শেয়ার করা ডেটার সাথে কাজ না করছে।

2. Distributed Arrays (বিতরণকৃত অ্যারে)

Distributed Arrays হল একটি ফিচার যা MATLAB-এ বড় আকারের ডেটা ব্যবস্থাপনার জন্য ব্যবহৃত হয়। যখন আপনি একটি বড় ডেটাসেট নিয়ে কাজ করছেন, তখন Distributed Arrays ব্যবহার করলে সেই ডেটা মেমরির মধ্যে একাধিক প্রসেসরে ভাগ হয়ে যেতে পারে এবং সমান্তরালভাবে প্রসেস করা যায়। এটি মূলত Parallel Computing Toolbox দ্বারা পরিচালিত হয়।

Distributed Arrays এর বৈশিষ্ট্য:

  • Distributed Memory: এই অ্যারের মধ্যে ডেটা বিভিন্ন প্রসেসরে বিভক্ত হয়, এবং প্রতিটি প্রসেসর সেই অংশটি প্রসেস করে। এটি বড় ডেটাসেট পরিচালনার জন্য উপকারী।
  • Automatic Distribution: যখন আপনি একটি ডিস্ট্রিবিউটেড অ্যারে তৈরি করেন, MATLAB স্বয়ংক্রিয়ভাবে ডেটাকে বিভিন্ন প্রসেসরে বিতরণ করে।

Distributed Arrays সিনট্যাক্স:

D = distributed(A);

এখানে A একটি সাধারণ অ্যারে এবং D একটি বিতরণকৃত অ্যারে যা ডেটাকে একাধিক প্রসেসরে বিতরণ করবে।

distributed উদাহরণ:

% Create a large array
A = rand(1000, 1000);  % 1000x1000 matrix

% Convert it to a distributed array
D = distributed(A);

% Perform operations on the distributed array
meanD = mean(D);  % Compute the mean of the distributed array
disp(meanD);

এখানে:

  • A একটি সাধারণ অ্যারে, এবং distributed(A) ব্যবহার করে A কে একটি বিতরণকৃত অ্যারে D তে রূপান্তরিত করা হয়েছে।
  • mean(D) অপারেশনটি D ডেটার উপর একটি সমান্তরাল গণনা করবে এবং গতি বৃদ্ধি পাবে।

Distributed Arrays এর সুবিধা:

  • Memory Management: যখন আপনার কাছে বড় ডেটাসেট থাকে, তখন ডিস্ট্রিবিউটেড অ্যারে ব্যবহার করলে সেই ডেটা স্মৃতিতে স্বয়ংক্রিয়ভাবে বিতরণ হয়ে যায় এবং বিভিন্ন প্রসেসরে সমান্তরালভাবে প্রক্রিয়া করা হয়।
  • Scalability: এটি বড় ডেটাসেটের জন্য কার্যকরী, কারণ এটি ক্লাস্টার বা একাধিক প্রসেসরের মধ্যে ডেটা ভাগ করে, যার ফলে ডেটা ম্যানিপুলেশন দ্রুত হয়ে যায়।

3. Combining parfor and Distributed Arrays

parfor এবং Distributed Arrays একসাথে ব্যবহৃত হলে, আপনি বড় ডেটাসেটের উপর সমান্তরালভাবে কাজ করতে পারেন, যেখানে ডেটা একাধিক প্রসেসরে বিতরণ করা হয় এবং কোডটি একাধিক কোরে সমান্তরালভাবে রান করে।

Example of parfor and distributed together:

% Create a large array and distribute it
n = 1000000;
A = distributed(rand(1, n));  % Distributed array

% Parallel processing using parfor
parfor i = 1:n
    A(i) = A(i) * 2;  % Double each element in parallel
end

disp(A(1:10));  % Display the first 10 elements

এখানে:

  • A একটি বিতরণকৃত অ্যারে যা বিভিন্ন প্রসেসরে ভাগ করা হয়েছে।
  • parfor ব্যবহার করে প্রতিটি ইটারেশন আলাদাভাবে সমান্তরালভাবে চালানো হচ্ছে।

4. Parallel Computing Toolbox Configuration

Parallel Computing Toolbox MATLAB-এ পার্শিয়াল কম্পিউটিং সক্ষম করে। এটি parfor এবং distributed arrays সহ আরও অনেক ফিচার প্রদান করে।

Parallel Pool Configuration:

% Start a parallel pool with 4 workers
parpool(4);

এখানে, parpool(4) কমান্ডটি একটি parallel pool তৈরি করবে এবং ৪টি প্রসেসর কোরে কাজ করবে।

Stopping the Parallel Pool:

delete(gcp);  % Close the parallel pool

এটি parallel pool বন্ধ করবে।


Conclusion

  • parfor: MATLAB-এ parallel loops ব্যবহারের জন্য একটি শক্তিশালী ফিচার, যা একাধিক প্রসেসর কোরে লুপের কাজ ভাগ করে রান করতে সহায়ক।
  • Distributed Arrays: MATLAB-এ বড় আকারের ডেটা সমান্তরালভাবে পরিচালনা করার জন্য ব্যবহৃত হয়, যেখানে ডেটা বিভিন্ন প্রসেসরে ভাগ হয়ে যায় এবং সেই প্রসেসরগুলির মধ্যে কাজ সমান্তরালভাবে করা হয়।
  • Combining parfor and Distributed Arrays: বড় ডেটাসেটের উপর কাজ করার সময় parfor এবং Distributed Arrays একসাথে ব্যবহার করলে আপনির কোড আরও দ্রুত কার্যকর হয়।

এগুলো Parallel Computing Toolbox ব্যবহার করে MATLAB-এ ডেটা প্রসেসিং গতি বাড়ানোর জন্য খুবই কার্যকরী।

Content added By
Promotion

Are you sure to start over?

Loading...