شبه‌کد

روشی سریع، فشرده و غیررسمی برای توضیح یک الگوریتم کامپیوتری

شبه‌کد (به انگلیسی: pseudocode) روشی سریع، فشرده و غیررسمی برای توضیح یک الگوریتم کامپیوتری است که از ساختارهای معمول بعضی از زبان‌های برنامه‌نویسی استفاده می‌کند که برای خوانده‌شدن توسط انسان و نه ماشین طراحی شده‌است. شبه کد معمولاً فاقد جزئیاتی است که کامپیوتر بتواند بدون آن‌ها الگوریتم را بفهمد، مثل تعریف متغیرها، کدهای وابسته به سیستم (سیستم‌عاملهای مختلف یا غیره) و زیرروالها. در شبه‌کدها معمولاً برای راحتی از زبان محاوره معمولی یا علامت‌های ریاضی نیز استفاده می‌کنند. هدف از استفاده از شبه‌کد این است که فهم آن ساده‌تر از زبان‌های برنامه‌نویسی است.

نمونه یک شبه‌کد، برای اعمال فیلتر میانه

کاربرد

ویرایش

کتاب‌های درسی و منتشرات علمی مربوط به کامپیوتر و محاسبات عددی غالباً از شبه‌کد برای بیان الگوریتم‌ها استفاده می‌کنند، تا برنامه‌نویسان آن‌ها را بفهمند، حتی اگر آن‌ها تمام آن زبان برنامه‌نویسی را بلد نباشند. در کتاب‌های درسی، معمولاً بخشی برای معرفی قراردادها و توضیح ویژگی کدها و سبک کدنویسی وجود دارد تا خواننده بتواند منظور نویسنده را به سادگی متوجه شود و در طول مطالعه کتاب مشکلی با کدهای نوشته شده در کتاب نداشته باشد. میزان جزئیات این زبان‌ها ممکن است در برخی موارد به زبان‌های همه منظوره رسمی نزدیک باشد –برای مثال، کتاب مرجع کنوت " هنر برنامه‌نویسی کامپیوتر" الگوریتم‌ها را در زبان اسمبلی کاملاً صریح که برای ریزپردازنده ناموجود است نوشته شده‌است.
برنامه‌نویسی که می‌خواهد الگوریتم مشخصی را پیاده کند، مخصوصاً الگوریتمی که با آن آشنایی ندارد، غالباً با توضیح شبه‌کد آن شروع خواهد کرد، و سپس آن شرح را به سادگی به زبان برنامه‌نویسی هدف ترجمه خواهد کرد و سپس آن را تغییر خواهد داد، تا به‌درستی با سایر قسمت‌های برنامه هماهنگی داشته باشد. برنامه‌نویسان ممکن است همچنین یک پروژه را با بیان کلیات آن به صورت شبه‌کد و بر روی کاغذ شروع کنند و سپس آن را به زبان واقعی بنویسند، به‌عنوان یک روش حل ساختاری بالا به پایین.

گرامر

ویرایش

همان‌گونه که از اسم آن مشخص است، شبه کد معمولاً از گرامر هیچ زبان مشخصی پیروی نمی‌کند، و هیچ فرم سیستماتیک استاندارد یا ساخت‌یافته‌ای وجود ندارد، هرچند هر نویسنده‌ای ممکن است به‌طور کلی سبک و گرامر زبان خاصی را استفاده کند برای مثال ممکن است برای بیان کدهای درون یک بلوک مانند زبان‌های برنامه‌نویسی C و جاوا از گیومه استفاده کند یا اینکه صرفاً مانند زبان برنامه‌نویسی پایتون از فاصله‌ها استفاده کند. انتخاب روش نوشتن شبه کد قراردادی است که نویسنده دارد و می‌تواند مستقل از یک زبان برنامه‌نویسی خاص باشد. اما نویسندگان معمولاً از گرامر و سبک زبان‌های محبوب و معروفی مثل پاسکال، بیسیک، C,C++، جاوا، لیسپ و ALGOL استفاده می‌کنند. تعریف متغیرها در یک شبه‌کد ذکر نمی‌شود. صدا کردن توابع و بلوک‌ها برای مثال کدهای درون حلقه غالباً با کد یک خطی طبیعی جایگزین می‌شوند. در نتیجه وابسته به نویسنده، شبه کد ممکن است در سبک و سیاق گستردگی زیادی داشته باشد، از پیاده‌سازی تقریباً دقیق یک زبان مشخص در یک سو تا توصیف توضیحی کد به زبان انسانی در سوی دیگر.

مثال‌ها

ویرایش

<variable> = <expression>

if <condition>
    do stuff
else
    do other stuff

while <condition>
    do stuff

for <variable> from <first value> to <last value> by <step>
    do stuff with variable

function <function name>(<arguments>)
    do stuff with arguments
    return something

<function name>(<arguments>)    // Function call

برای دیدن مثال‌های بیشتر می‌توانی به مقالات با مثال‌های شبه‌کد مراجعه کنید.

شبه‌کد ریاضی‌گونه

ویرایش

در محاسبات عددی، شبه‌کد غالباً شامل نمادگذاری ریاضی است، نوعاً از مجموعه و تئوری ماتریس، ترکیب شده با یک زبان قراردادی، و شاید توضیحات زبان طبیعی. این یک نمادگذاری فشرده و غالباً غیررسمی است، که تعداد زیادی از ریاضی‌آموختگان می‌توانند آن را متوجه شوند، و یک روش بسیار متداول است برای بیان آلگوریتم‌های ریاضی.
معمولاً حروف چینی غیر اسکی برای معادلات ریاضی مورد استفاده قرار می‌گیرد، برای مثال به وسیله Tex یا MathML یا ویرایشگران فرمول اختصاصی.
شبه‌کدهای ریاضی گاهی کد دست و پا شکسته(pidgin) نامیده می‌شوند، برای مثال pidgin ALGOL، pidgin fortran، pidgin basic، pidgin pascal، pidgin C، pidgin Ada.

کامپایل ماشین یا تفسیر

ویرایش

غالباً پیشنهاد می‌شود که زبان‌های برنامه‌نویسی آینده بیشتر از زبان‌های متداول امروز به زبان طبیعی و زبان انسان نزدیک باشند؛ نکته این‌جاست که با رو به افزایش بودن سرعت کامپیوترها و پیشرفت‌های حاصل در زمینه کامپایل کردن به کامپیوترها این اجازه را خواهد داد که از توضیح الگوریتم‌ها برنامه را ایجاد کنند، به‌جای این‌که نیاز داشته باشند تا انسان تمام جزئیات را پیاده کند.
دستور زبان طبیعی در زبان‌های برنامه‌نویسی
تلاش‌های گسترده برای وارد کردن دستور زبان طبیعی به زبان‌های برنامه‌نویسی منجر به ایجاد زبان‌های برنامه‌نویسی از قبیل HyperTalk، Lingo، AppleScript, SQL و Inform شده‌است. در این زبان‌ها، پرانتزها و کاراکترهای خاص با حروف اضافه جایگزین شده‌اند، تا کد به زبان طبیعی نزدیک‌تر باشد. این کار باعث می‌شود که انسانی که با زبان آشنایی ندارد متوجه کد شود و حتی یک زبان را نیز بیاموزد. در هر حال، شباهت به زبان طبیعی بیشتر جنبه زیبایی دارد تا اصالت. قواعد گرامری دقیقاً مانند زبان‌های برنامه‌نویسی قراردادی محض و رسمی هستند، و لزوماً نوشتن برنامه‌ها را آسان‌تر نمی‌کنند.

زبان‌های برنامه‌نویسی ریاضی

ویرایش

یک جایگزین برای استفاده شبه‌کد ریاضی (شامل نظریه مجموعه‌ها و عملیات ماتریسی) برای مستندسازی الگوریتم‌ها استفاده از یک زبان برنامه‌نویسی ریاضی‌وار است که از ترکیبی از نمادگذاری ریاضی غیر اسکی و ساختارهای کنترل برنامه باشد. سپس کد می‌تواند توسط ماشین تجزیه و تفسیر شود.
چند زبان‌های خصوصیات رسمی نمادگذاری نظریه مجموعه‌ها را با کمک کاراکترهای ویژه شامل می‌شوند. برای مثال:
نماد گذاری Z
 

منابع

ویرایش

مشارکت‌کنندگان ویکی‌پدیا. «Pseudocode». در دانشنامهٔ ویکی‌پدیای انگلیسی.