অ্যালগরিদম

উইকিপিডিয়া, মুক্ত বিশ্বকোষ থেকে
"নোট জি" থেকে অ্যাডা লাভলেসের ডায়াগ্রাম, প্রথম প্রকাশিত কম্পিউটার অ্যালগরিদম।
A এবং B নামক স্থানে দুটি সংখ্যার a এবং b-এর সর্বশ্রেষ্ঠ সাধারণ ভাজক(g.c.d) গণনার জন্য একটি অ্যালগরিদমের ফ্লোচার্ট (ইউক্লিডের অ্যালগরিদম )। অ্যালগরিদম দুটি লুপে ধারাবাহিক বিয়োগ দ্বারা এগিয়ে যায়: যদি পরীক্ষা B ≥ A "হ্যাঁ" দেয় বা "সত্য" (আরো সঠিকভাবে, B অবস্থানে থাকা সংখ্যাটি A অবস্থানে থাকা a সংখ্যাটির চেয়ে বড় বা সমান) তারপর, অ্যালগরিদম B ← B − A (অর্থাৎ সংখ্যা ba পুরানো b প্রতিস্থাপন করে) নির্দিষ্ট করে। একইভাবে, IF A > B, তারপর A ← A − B। প্রক্রিয়াটি শেষ হয়ে যায় যখন (এর বিষয়বস্তু) B 0 হয়, g.c.d পাওয়া যায়। এ. (Scott 2009:13 থেকে প্রাপ্ত অ্যালগরিদম; Tausworthe 1977 থেকে চিহ্ন এবং অঙ্কন শৈলী)।

গণিত এবং কম্পিউটার বিজ্ঞানের আলোচনায় কলনবিধি বা ইংরেজি ভাষায় অ্যালগরিদম (Algorithm) বলতে একটি সুনির্দিষ্ট পদ্ধতিকে বোঝায়, যেটি কম্পিউটারে বাস্তবায়নযোগ্য ও সুনির্দিষ্ট ক্রমে বিন্যস্ত নির্দেশের সমষ্টি, যে নির্দেশগুলিকে ধাপগুলো অনুসরণ করে কোনও সুসংজ্ঞায়িত পরিগণনামূলক সমস্যার সমাধান করা হয়।[১][২] অন্যভাবে বললে, কলনবিধি বা অ্যালগোরিদম হচ্ছে ধাপে ধাপে সমস্যা সমাধানের পদ্ধতি বিশেষ। অর্থাৎ একটি সমস্যাকে সীমিত সংখ্যক কয়েকটি ধাপে ভেঙে প্রত্যেকটি ধাপ পরপর সমাধান করে সমগ্র সমস্যা সমাধান করা হয়। পরিগণক যন্ত্র (কম্পিউটার), রোবট, এমনকি মানুষও কলনবিধি বা অ্যালগোরিদমের ধাপগুলি ধারাবাহিকভাবে অনুসরণ করে একটি নির্দিষ্ট কাজ সম্পাদন করতে পারে। পরিগণক বিজ্ঞানের (কম্পিউটার বিজ্ঞান) বিভিন্ন সমস্যা সমাধানের জন্য সঠিক কলনবিধি বা অ্যালগোরিদমের ধারণাটি অত্যন্ত গুরুত্বপূর্ণ। কলনবিধি বা অ্যালগরিদমগুলি পরিগণনা (কম্পিউটেশন), উপাত্ত প্রক্রিয়াজাতকরণ (ডেটা প্রসেসিং), স্বয়ংক্রিয় যুক্তি, স্বয়ংক্রিয় সিদ্ধান্ত গ্রহণ এবং অন্যান্য কার্য সম্পাদনের জন্য বিনির্দেশ (স্পেসিফিকেশন specification) হিসেবে ব্যবহৃত হয়।

একটি কলনবিধি বা অ্যালগোরিদমকে যেকোনও ভাষায় বর্ণনা করা যেতে পারে, সে ভাষাটি হতে পারে বাংলা, ইংরেজির মত মানুষের মৌখিক ভাষা,অথবা সি++ বা জাভার মত প্রোগ্রাম (পূর্বলিখিত নির্দেশক্রম) রচনার ভাষা। এমনকি যন্ত্রাংশসামগ্রী (হার্ডওয়্যার) নকশাকরণের মাধ্যমেও এটি বর্ণনা করা যেতে পারে। তবে যে ভাষাতেই লেখা হোক না, সমস্যা সমাধানের প্রতিটি ধাপের বর্ণনা কলনবিধি বা অ্যালগোরিদমে থাকতে হবে।

পরিগণক বিজ্ঞান তথা কম্পিউটার বিজ্ঞানের সমস্ত ক্ষেত্রে যেমন উপাত্তাধার (ডেটাবেজ), চিত্রলিখন (গ্রাফিক্স), জালিকায়ন (কম্পিউটার নেটওয়ার্কিং), পরিচালক ব্যবস্থা (অপারেটিং সিস্টেম), কম্পিউটার নিরাপত্তা, কৃত্রিম বুদ্ধিমত্তা, ইত্যাদিতে কলনবিধি বা অ্যালগোরিদম নির্মাণ ও বিশ্লেষণ একটি মৌলিক কর্মকাণ্ড। অ্যালগোরিদম নির্মাণ এবং প্রোগ্রাম (পূর্বলিখিত নির্দেশক্রম) রচনার মধ্যে পার্থক্য আছে। কলনবিধি বা অ্যালগোরিদম নির্মাণের সময় কোনও পরিগণনামূলক সমস্যা সমাধানের উদ্দেশ্যে লভ্য সমস্ত বিকল্প ঠিকমতো বোঝা অত্যাবশ্যক। অর্থাৎ কোনও নির্দিষ্ট সমাধানের জন্য কী যন্ত্রাংশসামগ্রী (হার্ডওয়্যার) ব্যবহৃত হবে, নেটওয়ার্ক তথা জালিকাব্যবস্থাটি কী রকম, কোন্‌ ভাষায় প্রোগ্রাম রচিত হবে, কর্মদক্ষতার উপরে কী কী সীমাবদ্ধতা বিদ্যমান, এই সব কিছু বিবেচনায় রাখতে হয়। কোনও অ্যালগোরিদম যদি কোনও সমস্যাকে পূর্ণাঙ্গরূপে এবং দক্ষভাবে সমাধান করতে পারে, তাহলে সেটিকে "সঠিক" বিবেচনা করা হয়। অ্যালগোরিদমগুলি প্রবিষ্ট উপাত্ত (ইনপুট) ও বহির্গত উপাত্তের (আউটপুট) মাধ্যমে কাজ করে। প্রবিষ্ট উপাত্তের উপরে কলনবিধি বা অ্যালগোরিদমের প্রতিটি ধাপ ধারাবাহিকভাবে প্রয়োগ করা হয় এবং সবশেষে বহির্গত উপাত্ত ফলাফল হিসেবে প্রকাশিত হয়। একটি কলনবিধি বা অ্যালগোরিদমকে তখনই "সঠিক" বলা হয় যদি প্রতিটি প্রবিষ্ট উপাত্তের জন্য কলনবিধি বা অ্যালগোরিদমটি সঠিক বহির্গত উপাত্ত উৎপাদন করে। তবে পুরোপুরি নির্ভুল নয় এমন কলনবিধি বা অ্যালগোরিদমও গুরুত্বপূর্ণ হতে পারে, যদি ভুলের মাত্রা নিয়ন্ত্রণের মধ্যে রাখা যায়।

ইংরেজি "অ্যালগরিদম" শব্দটি ৯ম শতাব্দীর মুসলিম গণিতবিদ মুসা আল খোয়ারিজমি-র নাম থেকে এসেছে।[৩][৪][৫]

কলনবিধি বা অ্যালগোরিদমের বিপরীত ধারণাটি হল আবিষ্করণী পদ্ধতি (Heuristic হিউরিস্টিক), যা হল অতীত অভিজ্ঞতার মূল্যায়নের নিরিখে প্রয়াস ও প্রমাদের (trial and error) মধ্য দিয়ে আরোহী যুক্তিবিন্যাসের মাধ্যমে সমস্যা সমাধানের একটি পদ্ধতি; এটি সম্পূর্ণরূপে নির্দিষ্ট না-ও হতে পারে কিংবা সঠিক বা সর্বোত্তম ফলাফলের নিশ্চয়তা না-ও দিতে পারে (বিশেষ করে সেইসব সমস্যাক্ষেত্রে যেখানে কোন সুনির্দিষ্ট সঠিক বা সর্বোত্তম ফলাফল নেই)।[৬]

ইতিহাস[সম্পাদনা]

অ্যালগরিদমের ধারণাটি প্রাচীনকাল থেকেই বিদ্যমান। পাটিগণিত অ্যালগরিদম, যেমন একটি বিভাগ অ্যালগরিদম, প্রাচীন ব্যাবিলনীয় গণিতবিদরা ব্যবহার করতেন c. 2500 BC এবং মিশরীয় গণিতবিদ গ. ১৫৫০ খ্রিস্টপূর্বাব্দ। [৭] গ্রীক গণিতবিদরা পরবর্তীতে ২৪০ খ্রিস্টপূর্বাব্দে মৌলিক সংখ্যা খুঁজে বের করার জন্য ইরাটোস্থেনিসের চালুনিতে অ্যালগরিদম এবং দুটি সংখ্যার সর্বশ্রেষ্ঠ সাধারণ ভাজক খুঁজে বের করার জন্য ইউক্লিডীয় অ্যালগরিদম ব্যবহার করেন। [৮] ৯ম শতাব্দীতে আল-কিন্দির মতো আরবি গণিতবিদরা ফ্রিকোয়েন্সি বিশ্লেষণের ভিত্তিতে কোড-ব্রেকিংয়ের জন্য ক্রিপ্টোগ্রাফিক অ্যালগরিদম ব্যবহার করতেন। [৯]

অ্যালগরিদম শব্দটি ৯ম শতাব্দীর ফার্সি গণিতবিদ মুহম্মদ ইবনে মুসা আল-খোয়ারিজমির নাম থেকে এসেছে, যার নিসবা (তাঁকে খোয়ারজম থেকে চিহ্নিত করা হয়েছে) ল্যাটিন করা হয়েছিল আলগোরিত্মি ( আরবাইজড ফার্সি الخوارزمی c. 780-780)। [১০][১১] মুহাম্মাদ ইবনে মুসা আল-খোয়ারিজমি ছিলেন একজন গণিতবিদ, জ্যোতির্বিদ, ভূগোলবিদ এবং বাগদাদের হাউস অফ উইজডমের পণ্ডিত, যার নামের অর্থ ' খোয়ারজমের স্থানীয়', এমন একটি অঞ্চল যা বৃহত্তর ইরানের অংশ ছিল এবং এখন উজবেকিস্তানে রয়েছে। [১২][১৩] প্রায় ৮২৫, আল-খোয়ারিজমি হিন্দু-আরবি সংখ্যা পদ্ধতির উপর একটি আরবি ভাষার গ্রন্থ লিখেছিলেন, যা ১২ শতকে ল্যাটিন ভাষায় অনুবাদ করা হয়েছিল। পাণ্ডুলিপিটি শুরু হয় দীক্ষিত আলগোরিজমি ('এইভাবে আল-খোয়ারিজমি') বাক্যাংশ দিয়ে, যেখানে "আলগোরিজমি" ছিল অনুবাদকের আল- খোরিজমির নামের ল্যাটিনাইজেশন। [১৪] আল-খোয়ারিজমি ছিলেন মধ্যযুগের শেষের দিকে ইউরোপে সর্বাধিক পঠিত গণিতবিদ, প্রাথমিকভাবে তার অন্য একটি বইয়ের মাধ্যমে, বীজগণিতের মাধ্যমে। মধ্যযুগের শেষের দিকে ল্যাটিন, অ্যালগোরিসমাস, ইংরেজি ' অ্যালগোরিজম ', তার নামের অপভ্রংশ, কেবল "দশমিক সংখ্যা পদ্ধতি" বোঝায়। ১৫ শতকে, গ্রিক শব্দ ἀριθμός ( arithmos ), 'সংখ্যা' ( cf. 'পাটিগণিত') এর প্রভাবে, ল্যাটিন শব্দটি অ্যালগরিদমাসে পরিবর্তিত হয়েছিল, এবং সংশ্লিষ্ট ইংরেজি শব্দ 'অ্যালগরিদম' প্রথম ১৭ তম সালে প্রমাণিত হয় শতাব্দী; আধুনিক অর্থ ১৯ শতকে প্রবর্তিত হয়েছিল। [১৫]

ভারতীয় গণিত প্রধানত অ্যালগরিদমিক ছিল। অ্যালগরিদমগুলি প্রাচীন থেকে ভারতীয় গাণিতিক ঐতিহ্যের প্রতিনিধিত্ব করে শুলবাসূত্র থেকে কেরালা স্কুলের মধ্যযুগীয় পাঠ্য পর্যন্ত।[তথ্যসূত্র প্রয়োজন]

ইংরেজিতে, অ্যালগরিদম শব্দটি প্রথম ব্যবহৃত হয়েছিল প্রায় 1230 সালে এবং তারপর চসার দ্বারা ১৩৯১ সালে। ইংরেজি ফরাসি শব্দটি গ্রহণ করেছিল, কিন্তু ১৯ শতকের শেষের দিকে "অ্যালগরিদম" আধুনিক ইংরেজিতে যে অর্থ রয়েছে তা গ্রহণ করেনি। [১৬]

আলেকজান্দ্রে দে ভিলেদিউ দ্বারা রচিত কারমেন ডি অ্যালগোরিসমো শিরোনামের একটি ম্যানুয়ালটিতে ১২৪০ সাল থেকে শব্দের আরেকটি প্রাথমিক ব্যবহার। এটি দিয়ে শুরু হয়:

এই বর্তমান শিল্প, যেখানে আমরা সেই দ্বিগুণ পাঁচটি ভারতীয় চিত্র ব্যবহার করি, তাকে অ্যালগোরিসমাস বলা হয়।

এই বর্তমান শিল্প, যেখানে আমরা সেই দ্বিগুণ পাঁচটি ভারতীয় চিত্র ব্যবহার করি, তাকে অ্যালগোরিসমাস বলা হয়।

যা অনুবাদ করে: অ্যালগরিদম হল সেই শিল্প যার দ্বারা বর্তমানে আমরা সেই ভারতীয় পরিসংখ্যানগুলি ব্যবহার করি, যা দুই বার পাঁচ নম্বর। কবিতাটি কয়েকশত লাইন দীর্ঘ এবং নতুন শৈলীকৃত ভারতীয় পাশা (টালি ইন্ডোরাম), বা হিন্দু সংখ্যার সাথে গণনার শিল্পকে সংক্ষিপ্ত করে। [১৭]

অ্যালগরিদমের আধুনিক ধারণার একটি আংশিক আনুষ্ঠানিকীকরণ 1928 সালে ডেভিড হিলবার্ট দ্বারা উত্থাপিত Entscheidungsproblem (সিদ্ধান্ত সমস্যা) সমাধানের প্রচেষ্টার মাধ্যমে শুরু হয়েছিল। " কার্যকর গণনাযোগ্যতা " [১৮] বা "কার্যকর পদ্ধতি" সংজ্ঞায়িত করার প্রচেষ্টা হিসাবে তৈরি করা হয়েছিল। [১৯] এই ফর্মালাইজেশনগুলির মধ্যে 1930, 1934 এবং 1935 সালের Gödel – Herbrand – Kleene রিকার্সিভ ফাংশন, 1936 সালের অ্যালোঞ্জো চার্চের ল্যাম্বডা ক্যালকুলাস, 1936 সালের এমিল পোস্টের ফর্মুলেশন 1 এবং অ্যালান টুরিং -এর টুরিং মেশিন 1936–37 এবং 1936-এর অন্তর্ভুক্ত ছিল।

অনানুষ্ঠানিক সংজ্ঞা[সম্পাদনা]

একটি অনানুষ্ঠানিক সংজ্ঞা হতে পারে "নিয়মের একটি সেট যা সঠিকভাবে ক্রিয়াকলাপের একটি ক্রমকে সংজ্ঞায়িত করে",[২০][যাচাই করার জন্য উদ্ধৃতি প্রয়োজন] যার মধ্যে সমস্ত কম্পিউটার প্রোগ্রাম অন্তর্ভুক্ত থাকবে (এমন প্রোগ্রামগুলি যা সাংখ্যিক গণনা করে না) এবং (উদাহরণস্বরূপ) যেকোন নির্ধারিত আমলাতান্ত্রিক পদ্ধতি [২১] বা রান্নার বইয়ের রেসিপি[২২]

সাধারণভাবে, একটি প্রোগ্রাম শুধুমাত্র একটি অ্যালগরিদম হয় যদি এটি শেষ পর্যন্ত থেমে যায় [২৩] — যদিও অসীম লুপ কখনও কখনও পছন্দসই প্রমাণিত হতে পারে।

একটি অ্যালগরিদমের একটি নমুনা উদাহরণ হল ইউক্লিডীয় অ্যালগরিদম, যা দুটি পূর্ণসংখ্যার সর্বাধিক সাধারণ ভাজক নির্ধারণ করতে ব্যবহৃত হয়; একটি উদাহরণ (অন্যও আছে) উপরের ফ্লোচার্ট দ্বারা এবং পরবর্তী বিভাগে একটি উদাহরণ হিসাবে বর্ণনা করা হয়েছে।

বুলোস & জেফরি (1974, 1999) নিম্নলিখিত উদ্ধৃতিতে "অ্যালগরিদম" শব্দের একটি অনানুষ্ঠানিক অর্থ প্রদান করে:

কোন মানুষই যথেষ্ট দ্রুত, বা যথেষ্ট দীর্ঘ, বা যথেষ্ট ছোট লিখতে পারে না † ( †" ছোট এবং ছোট সীমাহীন... আপনি অণুর উপর, পরমাণুর উপর, ইলেকট্রনের উপর লেখার চেষ্টা করবেন") একটি এর সমস্ত সদস্য তালিকাভুক্ত করতে একের পর এক, কিছু স্বরলিপিতে তাদের নাম লিখে অসংখ্য অসীম সেট। কিন্তু মানুষ সমানভাবে কার্যকর কিছু করতে পারে, নির্দিষ্ট সংখ্যক অসীম সেটের ক্ষেত্রে: তারা নির্বিচারে সসীম n-এর জন্য সেটের nম সদস্য নির্ধারণের জন্য সুস্পষ্ট নির্দেশনা দিতে পারে। এই ধরনের নির্দেশগুলি বেশ স্পষ্টভাবে দেওয়া উচিত, এমন একটি ফর্ম যাতে সেগুলি একটি কম্পিউটিং মেশিন দ্বারা অনুসরণ করা যেতে পারে, অথবা এমন একজন মানুষ যিনি প্রতীকগুলিতে শুধুমাত্র খুব প্রাথমিক ক্রিয়াকলাপগুলি চালাতে সক্ষম। [২৪]

একটি "সংখ্যাযোগ্যভাবে অসীম সেট" হল এমন একটি যার উপাদানগুলিকে পূর্ণসংখ্যার সাথে এক থেকে এক চিঠিপত্রে রাখা যেতে পারে। এইভাবে বুলোস এবং জেফরি বলছেন যে একটি অ্যালগরিদম এমন একটি প্রক্রিয়ার নির্দেশনা বোঝায় যা একটি নির্বিচারে "ইনপুট" পূর্ণসংখ্যা বা পূর্ণসংখ্যা থেকে আউটপুট পূর্ণসংখ্যা "তৈরি করে" যা তত্ত্বগতভাবে, ইচ্ছামত বড় হতে পারে। উদাহরণস্বরূপ, একটি অ্যালগরিদম একটি বীজগণিত সমীকরণ হতে পারে যেমন y = m + n (অর্থাৎ, দুটি নির্বিচারে "ইনপুট ভেরিয়েবল" m এবং n যা একটি আউটপুট y তৈরি করে), কিন্তু ধারণাটিকে সংজ্ঞায়িত করার জন্য বিভিন্ন লেখকের প্রচেষ্টা নির্দেশ করে যে শব্দটি বোঝায় এর থেকে অনেক বেশি, কিছুর অর্ডারে (সংযোজন উদাহরণের জন্য):

একটি দ্রুত, দক্ষ, "ভাল" প্রক্রিয়ার জন্য সুনির্দিষ্ট নির্দেশাবলী (একটি ভাষায় যা "কম্পিউটার" দ্বারা বোঝা যায়) [২৫] একটি দ্রুত, দক্ষ, "ভাল" [২৬] প্রক্রিয়ার জন্য যা "কম্পিউটার" (মেশিন বা মানব, অভ্যন্তরীণভাবে প্রয়োজনীয় সজ্জিত) এর "চালগুলি" নির্দিষ্ট করে, তথ্য এবং ক্ষমতা রয়েছে) [২৭] খুঁজে বের করতে, ডিকোড করতে এবং তারপরে নির্বিচারে ইনপুট পূর্ণসংখ্যা/প্রতীক m এবং n, চিহ্ন + এবং = ... এবং "কার্যকরভাবে" [২৮] প্রসেস করতে, একটি "যুক্তিসঙ্গত" সময়ে,[২৯] আউটপুট-পূর্ণসংখ্যা y একটি নির্দিষ্ট জায়গায় এবং একটি নির্দিষ্ট বিন্যাসে।

অ্যালগরিদমের ধারণাটি সিদ্ধান্তযোগ্যতার ধারণাকে সংজ্ঞায়িত করার জন্যও ব্যবহৃত হয় - একটি ধারণা যা একটি স্বতঃসিদ্ধ এবং নিয়মের একটি ছোট সেট থেকে আনুষ্ঠানিক সিস্টেমগুলি কীভাবে তৈরি হয় তা ব্যাখ্যা করার জন্য কেন্দ্রীয়। যুক্তিতে, একটি অ্যালগরিদম সম্পূর্ণ করার জন্য যে সময় প্রয়োজন তা পরিমাপ করা যায় না, কারণ এটি দৃশ্যত প্রথাগত শারীরিক মাত্রার সাথে সম্পর্কিত নয়।এই ধরনের অনিশ্চয়তা থেকে, যা চলমান কাজকে চিহ্নিত করে, অ্যালগরিদমের একটি সংজ্ঞার অনুপলব্ধতা তৈরি করে যা কংক্রিট (কিছু অর্থে) এবং শব্দটির বিমূর্ত ব্যবহার উভয়ের জন্য উপযুক্ত।

বেশিরভাগ অ্যালগরিদম কম্পিউটার প্রোগ্রাম হিসাবে প্রয়োগ করার উদ্দেশ্যে করা হয়। যাইহোক, অ্যালগরিদমগুলি অন্যান্য উপায়ে প্রয়োগ করা হয়, যেমন একটি জৈবিক নিউরাল নেটওয়ার্কে (উদাহরণস্বরূপ, মানব মস্তিষ্ক গাণিতিক প্রয়োগ করে বা খাদ্যের সন্ধানে একটি পোকা), বৈদ্যুতিক সার্কিটে বা একটি যান্ত্রিক যন্ত্রে।

আনুষ্ঠানিকতা[সম্পাদনা]

কম্পিউটার যেভাবে ডেটা প্রসেস করে তার জন্য অ্যালগরিদম অপরিহার্য। অনেক কম্পিউটার প্রোগ্রামে অ্যালগরিদম থাকে যা একটি নির্দিষ্ট কাজ সম্পাদন করার জন্য, যেমন কর্মচারীদের বেতন চেক গণনা করা বা ছাত্রদের রিপোর্ট কার্ড মুদ্রণ করার জন্য - একটি নির্দিষ্ট ক্রমে - একটি কম্পিউটারের যে নির্দিষ্ট নির্দেশাবলী সম্পাদন করা উচিত তার বিশদ বিবরণ। এইভাবে, একটি অ্যালগরিদমকে ক্রিয়াকলাপের যেকোন ক্রম হিসাবে বিবেচনা করা যেতে পারে যা একটি টুরিং-সম্পূর্ণ সিস্টেম দ্বারা অনুকরণ করা যেতে পারে। যে লেখকরা এই থিসিসটি দাবি করেছেন তাদের মধ্যে রয়েছে মিনস্কি (1967), স্যাভেজ (1987) এবং গুরেভিচ (2000):

মিনস্কি: "তবে আমরা টিউরিংয়ের সাথেও বজায় রাখব... যে কোনও পদ্ধতি যাকে "স্বাভাবিকভাবে" কার্যকর বলা যেতে পারে, বাস্তবে একটি (সরল) মেশিন দ্বারা উপলব্ধি করা যেতে পারে। যদিও এটি চরম মনে হতে পারে, যুক্তিগুলি ... এর পক্ষে খণ্ডন করা কঠিন" [৩০] গুরেভিচ: "... তার থিসিসের পক্ষে টুরিংয়ের অনানুষ্ঠানিক যুক্তি একটি শক্তিশালী থিসিসকে ন্যায্যতা দেয়: প্রতিটি অ্যালগরিদম একটি টুরিং মেশিন দ্বারা অনুকরণ করা যেতে পারে … স্যাভেজ [1987] অনুসারে, একটি অ্যালগরিদম হল একটি টুরিং মেশিন দ্বারা সংজ্ঞায়িত একটি গণনামূলক প্রক্রিয়া"। [৩১]

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

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

এই গণনামূলক প্রক্রিয়াগুলির কিছুর জন্য, অ্যালগরিদমকে অবশ্যই কঠোরভাবে সংজ্ঞায়িত করতে হবে: উদ্ভূত সমস্ত সম্ভাব্য পরিস্থিতিতে এটি যেভাবে প্রযোজ্য তা নির্দিষ্ট করে। এর মানে হল যে কোন শর্তসাপেক্ষ পদক্ষেপগুলি অবশ্যই পদ্ধতিগতভাবে মোকাবেলা করতে হবে, কেস-বাই-কেস; প্রতিটি ক্ষেত্রের মানদণ্ড অবশ্যই পরিষ্কার (এবং গণনাযোগ্য) হতে হবে।

যেহেতু একটি অ্যালগরিদম হল সুনির্দিষ্ট পদক্ষেপের একটি সুনির্দিষ্ট তালিকা, তাই অ্যালগরিদমের কার্যকারিতার জন্য গণনার ক্রম সর্বদা গুরুত্বপূর্ণ। নির্দেশাবলী সাধারণত সুস্পষ্টভাবে তালিকাভুক্ত বলে ধরে নেওয়া হয়, এবং "উপর থেকে" শুরু করা এবং "নীচে নীচে" যাওয়া হিসাবে বর্ণনা করা হয় - একটি ধারণা যা নিয়ন্ত্রণের প্রবাহ দ্বারা আরও আনুষ্ঠানিকভাবে বর্ণনা করা হয়।

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

একটি অ্যালগরিদম কী গঠন করে তার কিছু বিকল্প ধারণার জন্য, কার্যকরী প্রোগ্রামিং এবং লজিক প্রোগ্রামিং দেখুন।

অ্যালগরিদম প্রকাশ করা[সম্পাদনা]

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

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

অ্যালগরিদমগুলির উপস্থাপনাগুলিকে টিউরিং মেশিনের বর্ণনার তিনটি স্বীকৃত স্তরে শ্রেণীবদ্ধ করা যেতে পারে, নিম্নরূপ:[৩২]

১ উচ্চ-স্তরের বর্ণনা
"...গদ্য একটি অ্যালগরিদম বর্ণনা করার জন্য, বাস্তবায়নের বিবরণ উপেক্ষা করে। এই স্তরে, মেশিনটি কীভাবে তার টেপ বা মাথা পরিচালনা করে তা আমাদের উল্লেখ করার দরকার নেই।"
২ বাস্তবায়নের বিবরণ
"...গদ্য টিউরিং মেশিন কীভাবে তার মাথা ব্যবহার করে এবং কীভাবে এটি তার টেপে ডেটা সংরক্ষণ করে তা সংজ্ঞায়িত করতে ব্যবহৃত হয়। এই স্তরে, আমরা রাজ্য বা রূপান্তর ফাংশনের বিশদ বিবরণ দিই না।"
৩ আনুষ্ঠানিক বিবরণ
সবচেয়ে বিস্তারিত, "সর্বনিম্ন স্তর", টিউরিং মেশিনের "স্টেট টেবিল" দেয়।

তিনটি স্তরে বর্ণিত সহজ অ্যালগরিদম "অ্যাড m+n" এর উদাহরণের জন্য, উদাহরণ দেখুন।

ডিজাইন[সম্পাদনা]

অ্যালগরিদম ডিজাইন বলতে সমস্যা সমাধান এবং ইঞ্জিনিয়ারিং অ্যালগরিদমের জন্য একটি পদ্ধতি বা গাণিতিক প্রক্রিয়া বোঝায়। অ্যালগরিদমের নকশা অপারেশন গবেষণার অনেক সমাধান তত্ত্বের অংশ, যেমন ডায়নামিক প্রোগ্রামিং এবং ডিভাইড-এন্ড-কনকার । অ্যালগরিদম ডিজাইন ডিজাইন এবং বাস্তবায়নের কৌশলগুলিকে অ্যালগরিদম ডিজাইন প্যাটার্নও বলা হয়, উদাহরণ সহ টেমপ্লেট পদ্ধতি প্যাটার্ন এবং ডেকোরেটর প্যাটার্ন।

অ্যালগরিদম ডিজাইনের সবচেয়ে গুরুত্বপূর্ণ দিকগুলির মধ্যে একটি হল সম্পদ (রান-টাইম, মেমরি ব্যবহার) দক্ষতা; বড় ও স্বরলিপি ব্যবহার করা হয় যেমন একটি অ্যালগরিদমের রান-টাইম বৃদ্ধির বর্ণনা দিতে, কারণ এটির ইনপুটের আকার বৃদ্ধি পায়।

অ্যালগরিদমগুলির বিকাশের সাধারণ পদক্ষেপগুলি:

  1. সমস্যার সংজ্ঞা
  2. একটি মডেলের উন্নয়ন
  3. অ্যালগরিদমের স্পেসিফিকেশন
  4. একটি অ্যালগরিদম ডিজাইন করা
  5. অ্যালগরিদমের সঠিকতা পরীক্ষা করা হচ্ছে
  6. অ্যালগরিদম বিশ্লেষণ
  7. অ্যালগরিদম বাস্তবায়ন
  8. প্রোগ্রাম পরীক্ষা ও
  9. ডকুমেন্টেশন প্রস্তুতি[স্পষ্টকরণ প্রয়োজন]

আরও দেখুন[সম্পাদনা]

কম্পিউটার অ্যালগরিদম[সম্পাদনা]

লজিক্যাল NAND অ্যালগরিদম 7400 চিপে ইলেকট্রনিকভাবে প্রয়োগ করা হয়েছে

তথ্যসূত্র[সম্পাদনা]

  1. "The Definitive Glossary of Higher Mathematical Jargon — Algorithm"Math Vault (ইংরেজি ভাষায়)। ২০১৯-০৮-০১। ফেব্রুয়ারি ২৮, ২০২০ তারিখে মূল থেকে আর্কাইভ করা। সংগ্রহের তারিখ ২০১৯-১১-১৪ 
  2. "Definition of ALGORITHM"Merriam-Webster Online Dictionary (ইংরেজি ভাষায়)। ফেব্রুয়ারি ১৪, ২০২০ তারিখে মূল থেকে আর্কাইভ করা। সংগ্রহের তারিখ ২০১৯-১১-১৪ 
  3. "Al-Khwarizmi biography"www-history.mcs.st-andrews.ac.uk 
  4. "Etymology of algorithm"Chambers Dictionary। সংগ্রহের তারিখ ডিসেম্বর ১৩, ২০১৬ 
  5. Brezina, Corona (২০০৬)। Al-Khwarizmi: The Inventor Of Algebra। The Rosen Publishing Group। আইএসবিএন 978-1-4042-0513-0 
  6. David A. Grossman, Ophir Frieder, Information Retrieval: Algorithms and Heuristics, 2nd edition, 2004, আইএসবিএন ১৪০২০৩০০৪৫
  7. Chabert, Jean-Luc (২০১২)। A History of Algorithms: From the Pebble to the Microchip। Springer Science & Business Media। পৃষ্ঠা 7–8। আইএসবিএন 9783642181924 
  8. Cooke, Roger L. (২০০৫)। The History of Mathematics: A Brief Course। John Wiley & Sons। আইএসবিএন 978-1-118-46029-0 
  9. Dooley, John F. (২০১৩)। A Brief History of Cryptology and Cryptographic Algorithms। Springer Science & Business Media। পৃষ্ঠা 12–3। আইএসবিএন 9783319016283 
  10. "Al-Khwarizmi biography"www-history.mcs.st-andrews.ac.uk। আগস্ট ২, ২০১৯ তারিখে মূল থেকে আর্কাইভ করা। সংগ্রহের তারিখ মে ৩, ২০১৭ 
  11. "Etymology of algorithm"Chambers Dictionary। মার্চ ৩১, ২০১৯ তারিখে মূল থেকে আর্কাইভ করা। সংগ্রহের তারিখ ডিসেম্বর ১৩, ২০১৬ 
  12. Hogendijk, Jan P. (১৯৯৮)। "al-Khwarzimi": 4–5। এপ্রিল ১২, ২০০৯ তারিখে মূল থেকে আর্কাইভ করা। 
  13. Oaks, Jeffrey A.। "Was al-Khwarizmi an applied algebraist?"University of Indianapolis। জুলাই ১৮, ২০১১ তারিখে মূল থেকে আর্কাইভ করা। সংগ্রহের তারিখ মে ৩০, ২০০৮ 
  14. Brezina, Corona (২০০৬)। Al-Khwarizmi: The Inventor Of Algebra। The Rosen Publishing Group। আইএসবিএন 978-1-4042-0513-0 
  15. Oxford English Dictionary, Third Edition, 2012 s.v.
  16. Mehri, Bahman (২০১৭)। "From Al-Khwarizmi to Algorithm": 71–74। ডিওআই:10.15388/ioi.2017.special.11 
  17. "Abu Jafar Muhammad ibn Musa al-Khwarizmi"members.peak.org। আগস্ট ২১, ২০১৯ তারিখে মূল থেকে আর্কাইভ করা। সংগ্রহের তারিখ ২০১৯-১১-১৪ 
  18. Kleene 1943 in Davis 1965:274
  19. Rosser 1939 in Davis 1965:225
  20. Stone 1973:4
  21. Simanowski, Roberto (২০১৮)। The Death Algorithm and Other Digital Dilemmas। Untimely Meditations। MIT Press। পৃষ্ঠা 147। আইএসবিএন 9780262536370। ডিসেম্বর ২২, ২০১৯ তারিখে মূল থেকে আর্কাইভ করা। সংগ্রহের তারিখ ২৭ মে ২০১৯ 
  22. Dietrich, Eric (১৯৯৯)। "Algorithm"। The MIT Encyclopedia of the Cognitive Sciences। MIT Cognet library। MIT Press (প্রকাশিত হয় ২০০১)। পৃষ্ঠা 11। আইএসবিএন 9780262731447। সংগ্রহের তারিখ ২২ জুলাই ২০২০ 
  23. Stone simply requires that "it must terminate in a finite number of steps" (Stone 1973:7–8).
  24. Boolos and Jeffrey 1974,1999:19
  25. cf Stone 1972:5
  26. Knuth 1973:7 states: "In practice we not only want algorithms, we want good algorithms ... one criterion of goodness is the length of time taken to perform the algorithm ... other criteria are the adaptability of the algorithm to computers, its simplicity, and elegance, etc."
  27. cf Stone 1973:6
  28. Stone 1973:7–8 states that there must be, "...a procedure that a robot [i.e., computer] can follow in order to determine precisely how to obey the instruction". Stone adds finiteness of the process, and definiteness (having no ambiguity in the instructions) to this definition.
  29. Knuth, loc. cit
  30. Minsky 1967
  31. Gurevich 2000:1, 3
  32. Sipser 2006:157

বহিঃসংযোগ[সম্পাদনা]

  • কার্লিতে Algorithms (ইংরেজি)
  • ওয়েইস্টেইন, এরিক ডব্লিউ. "অ্যালগরিদম" । ম্যাথওয়ার্ল্ড ।
  • অ্যালগরিদম এবং ডেটা স্ট্রাকচারের অভিধান - ন্যাশনাল ইনস্টিটিউট অফ স্ট্যান্ডার্ডস অ্যান্ড টেকনোলজি
অ্যালগরিদম সংগ্রহস্থল