உள்ளடக்கத்துக்குச் செல்

விரவல் கணினி செய்முறை: திருத்தங்களுக்கு இடையிலான வேறுபாடு

கட்டற்ற கலைக்களஞ்சியமான விக்கிப்பீடியாவில் இருந்து.
உள்ளடக்கம் நீக்கப்பட்டது உள்ளடக்கம் சேர்க்கப்பட்டது
சி r2.6.2) (தானியங்கி இணைப்பு: ur:منقسم شمارندکاری
Rescuing 1 sources and tagging 0 as dead.) #IABot (v2.0.9.2
 
(8 பயனர்களால் செய்யப்பட்ட 27 இடைப்பட்ட திருத்தங்கள் காட்டப்படவில்லை.)
வரிசை 1: வரிசை 1:
{{கூகுள் தமிழாக்கக் கட்டுரை}}
{{கூகுள் தமிழாக்கக் கட்டுரைகள்}}
'''விரவல் கணினி செய்முறை''' அல்லது '''பரவிய கணித்தலியல் (Distributed computing)''' என்பது கணிப்பொறி அறிவியலின் ஒரு பிரிவாகும். இதில் பல செய்நிரல்கள் (programs), கணிப்பொறி வலையமைப்பு (computer network) மூலம் ஒன்றுக்கொன்று தொடர்பு கொண்டு தரவுகளையும் (data), ஏனைய செய்திகளையும் (message) பகிர்ந்து தம் பணிகளைச் செய்து முடிக்கின்றன. '''பரவிய கணித்தலியலில்''' பயன்படுத்தப் படும் செய்நிரல்கள் '''பரவிய''' '''செய்நிரல்கள் (distributed programs)''' என்று அழைக்கப் படுகின்றன'''.''' <ref>{{harvtxt|Andrews|2000}}. {{harvtxt|Dolev|2000}}. {{harvtxt|Ghosh|2007}}, ப. 10.</ref> ஆனால், செய்முறையில் ஒரு சில நேரங்களில், பல கணினிகளைப் பயன்படுத்துவதற்குப் பதிலாக''',''' ஒரே ஒரு கணினியைப் பயன் படுத்துவதும் உண்டு.<ref>{{harvtxt|Godfrey|2002}}.</ref>
'''விரவல் கணிப்பு செய்முறை''' என்பது விரவல் அமைப்புகளை பற்றி படிக்கும் கணிப்பொறி அறிவியலின் ஒரு பிரிவாகும். '''விரவல் கணிப்பு செய்முறை''' பல தானியங்கு [[கணிப்பொறி]]களைக் கொண்டு கணிப்பொறி வலையமைப்பு மூலம் தொடர்பு கொள்கிறது. கணிப்பொறிகள் ஒன்றுடன் ஒன்று தொடர்பு கொண்டு பொதுவான இலக்கை எட்டுகின்றன. '''விரவல் கணிப்பு செய்முறையில்''' உபயோகமாகும் கணினிச் செய்நிரல் '''விரவல் செய்நிரலாகும்''' மேலும் விரவல் செய்நிரல் என்பது செய்நிரல்களை இவ்வாறு எழுதுவதாகும் prefix="" gtc:mediawiki-xid="3" gtc:temp><ref>{{harvtxt|Andrews|2000}}. {{harvtxt|Dolev|2000}}. {{harvtxt|Ghosh|2007}}, ப. 10.</ref>

விரவல் கணிப்பு செய்முறையானது விரவல் அமைப்பு மூலம் கணக்கீட்டு பிரச்சனைகளைத் தீர்க்க உதவுவதாகவும் குறிப்பிடப்படுகிறது. விரவல் கணிப்பு செய்முறையில் பிரச்சனைகள் பல கொள்பணிகளாக மாற்றப்பட்டு ஒரே ஒரு கணினி மூலம் தீர்க்கப்படுகிறது.<ref>{{harvtxt|Godfrey|2002}}.</ref>


== முகவுரை ==
== முகவுரை ==


''பரவிய'' என்ற சொல் முதலில் ''நிலத்தில் பரவி உள்ள'' (geographically distributed) என்ற பொருளில் வந்தது. எடுத்துக் காட்டாக, ''பரவிய அமைப்பு'' (distributed system) என்றால் பல இடங்களில் பரவி அமைந்துள்ள ஓர் அமைப்பு என்று பொருள் பட்டது. . அது போலவே, ''பரவிய செய்நிரல்கள்'' (distributed programs) என்பது பல இடங்களில் அமைந்து உள்ள கணினிகளில் இயங்கும் செய்நிரல்களையும், ''பரவிய படிமுறை'' (distributed algorithm) என்பது அச் ''செய்நிரல்களில்'' அமைந்துள்ள ''படிமுறைகளையும்'' குறித்தன.<ref>{{harvtxt|Lynch|1996}}, ப. 1.</ref> இப்போது ''பரவிய'' என்ற சொல் மேலும் பொதுப்படையான பொருளில் பயன்படுத்தப் படுகின்றது. எடுத்துக் காட்டாக, பல தனித்தியங்கும் செய்முறைகள் (autonomous processes), ஒரே கணிப்பொறியில் இயங்கி, தங்களுக்குள் தரவுகளையும் செய்திகளையும் பகிர்ந்துகொண்டு இருக்கையில், அவை ''பரவிய'' செய்முறைகள் என்று அழைக்கப் படுகின்றன.<ref>{{harvtxt|Andrews|2000}}, ப. 291–292. {{harvtxt|Dolev|2000}}, ப. 5.</ref>
''விரவல்'' என்ற வார்த்தையானது "விரவல் அமைப்பு", "விரவல் செய்நிரல்" மற்றும் "விரவல் நெறிமுறை" என்று கணிப்பொறி வலையமைப்பு மூலம் குறிக்கப்பட்டு தனி கணிப்பொறிகள் புவியியலுக்குரிய பகுதி அமைப்பில் விரவலாகும்.<ref>{{harvtxt|Lynch|1996}}, ப. 1.</ref> இந்த வார்த்தை தற்போது பரவலான முறையில் உபயோகிக்கப்படுகிறது. தானியங்கு நெறிமுறைகளைக் குறிக்கும் போது ஒரே கணிப்பொறியில் அமைந்து இடைவிளைவு செய்து தகவல்களை பரிமாற்றம் செய்கிறது.<ref>{{harvtxt|Andrews|2000}}, ப. 291–292. {{harvtxt|Dolev|2000}}, ப. 5.</ref>


விரவல் அமைப்புகளை விவரிக்க எந்த வரையறையும் இல்லை<ref name="harvtxt|Ghosh|2007">{{harvtxt|Ghosh|2007}}, ப. 10.</ref>. பின்வரும் வரையறு பண்புகள் பொதுவாக உபயோகப்படுகின்றன.
பரவிய அமைப்புகளை விவரிக்க பல வகையான வரையறைகள் இருக்கும் நேரத்தில்,<ref name="harvtxt|Ghosh|2007">{{harvtxt|Ghosh|2007}}, ப. 10.</ref>. பின்வரும் வரையறு பண்புகள் பொதுவாக பயன்படுத்தப்படுகின்றன:
* பல தன்னாட்சி கணக்கீட்டு உள்பொருள்கள் இருந்தாலும் ஒவ்வொன்றும் அதன் தனி நினைவகத்தைக் கொண்டுள்ளன.<ref>{{harvtxt|Andrews|2000}}, ப. 8–9, 291. {{harvtxt|Dolev|2000}}, ப. 5. {{harvtxt|Ghosh|2007}}, ப. 3. {{harvtxt|Lynch|1996}}, ப. xix, 1. {{harvtxt|Peleg|2000}}, ப. xv.</ref>
* உள்பொருள்கள் தகவல் பரிமாற்றம் மூலம் ஒன்றை ஒன்று தொடர்பு கொள்கின்றன.<ref>{{harvtxt|Andrews|2000}}, ப. 291. {{harvtxt|Ghosh|2007}}, ப. 3. {{harvtxt|Peleg|2000}}, ப. 4.</ref>
இந்தக் கட்டுரையில், கணக்கீட்டு உள்பொருள்கள் ''கணிப்பொறிகள்'' அல்லது ''[[முனையம்]]'' என்று அழைக்கப்படுகிறது.


* ஒரு பரவிய அமைப்பில், பல கணிப்பொறிகள் இருக்கும். ஒவ்வொன்றும் மற்றவற்றின் துணையின்றி தனித்தியங்கும் தன்மை படைத்தனவாக இருக்கும். ஒவ்வொன்றுக்கும் சொந்தமான நினைவகங்கள் இருக்கும்.<ref>{{harvtxt|Andrews|2000}}, ப. 8–9, 291. {{harvtxt|Dolev|2000}}, ப. 5. {{harvtxt|Ghosh|2007}}, ப. 3. {{harvtxt|Lynch|1996}}, ப. xix, 1. {{harvtxt|Peleg|2000}}, ப. xv.</ref>
விரவல் அமைப்புகளுக்கு பெரிய கணக்கீட்டு பிரச்சனைகளைத் தீர்ப்பது போன்ற பொதுவான குறிக்கோள்கள் உள்ளன.<ref>{{harvtxt|Ghosh|2007}}, ப. 3–4. {{harvtxt|Peleg|2000}}, ப. 1.</ref> மாறாக ஒவ்வொரு கணிப்பொறியும் தனிப்பட்ட தேவைகளுக்கான சொந்த பயனரை கொண்டுள்ளது. விரவல் அமைப்புகளின் நோக்கம் பகிர்வு வளங்கள் அல்லது பயனருக்குத் தொடர்பு சேவைகளை வழங்குவதாகும்.<ref>{{harvtxt|Ghosh|2007}}, ப. 4. {{harvtxt|Peleg|2000}}, ப. 2</ref>
* தேவை படும் பொது, ஒரு கணிப்பொறி மற்ற கணிப்பொறிகளுடன் தொடர்பு கொண்டு தேவையான தரவுகளைப் (data) பரிமாறிக் கொள்கின்றது.<ref>{{harvtxt|Andrews|2000}}, ப. 291. {{harvtxt|Ghosh|2007}}, ப. 3. {{harvtxt|Peleg|2000}}, ப. 4.</ref>


இந்தக் கட்டுரையில், இந்தக் கணிப்பொறிகள் '''கணுக்கள்''' (nodes) என்றும் அழைக்கப் படும்.
விரவல் அமைப்புகளின் மற்ற குறிப்பிடத்தக்க பண்புகள் பின்வருமாறு:
* தனி கணினிகளில் ஏற்படும் தோல்விகளைப் பொறுத்துக் கொள்பவைகளாக இருக்க வேண்டும்.<ref>{{harvtxt|Ghosh|2007}}, ப. 4, 8. {{harvtxt|Lynch|1996}}, ப. 2–3. {{harvtxt|Peleg|2000}}, ப. 4.</ref>
* இந்த அமைப்பின் கட்டமைப்பு (வலையமைப்பு இடவியல், வலையமைப்பு உள்மறை, கணிப்பொறிகளின் எண்ணிக்கை) முன்கூட்டியே தெரியாது. இந்த அமைப்பானது பலதரப்பட்ட கணினிகள் மற்றும் வலையமைப்பு இணைப்புகளையும் கொண்டுள்ளது. விரவல் செய்நிரல்களை நிறைவேற்றும் போது அமைப்பு மாறக்கூடியதாக இருக்கிறது.<ref>{{harvtxt|Lynch|1996}}, ப. 2. {{harvtxt|Peleg|2000}}, ப. 1.</ref>
* ஒவ்வொரு கணினியும் வரம்புக்குட்பட்ட, முழுமையற்ற பார்வை அமைப்பைப் பெற்றிருக்கும். ஒவ்வொரு கணினியும் ஒரு பகுதி உள்ளீட்டை மட்டும் அறிந்திருக்கும்.<ref>{{harvtxt|Ghosh|2007}}, ப. 7. {{harvtxt|Lynch|1996}}, ப. xix, 2. {{harvtxt|Peleg|2000}}, ப. 4.</ref>


இப்படிப்பட்ட பரவிய அமைப்பில், அனைத்துக் கணிப்பொறிகளும் ஒன்றாகக் கூட்டு சேர்ந்து ஒரு பணியைச் செய்யும் வல்லமை படைத்தவையாக இருக்கும். மேலும் ஒவ்வொன்றும் தனித்து இயங்கும் திறன் கொண்டவையாகவும் இருக்கும். <ref>{{harvtxt|Ghosh|2007}}, ப. 3–4. {{harvtxt|Peleg|2000}}, ப. 1.</ref> பரவிய அமைப்பின் நோக்கம் என்னவென்றால், கணிப்பொறிகள் ஒவ்வொன்றும் தம்மிடம் உள்ள வளங்களை (resources) மற்றவற்றிடம் பகிர்ந்து கொண்டு, தங்களால் தனித்து செய்ய இயலாத பணிகளைக் கூட்டாகச் சேர்ந்து செய்யும் வலிமை உள்ளவையாக ஆக வேண்டும் என்பதே ஆகும்.<ref>{{harvtxt|Ghosh|2007}}, ப. 4. {{harvtxt|Peleg|2000}}, ப. 2</ref> அதாவது, தங்களுக்குக் கொடுக்கப்பட்ட தரவுகளை (data input) ஒவ்வொரு கணினியும் தங்களுக்குள் பிரித்து, அதை வைத்து தங்கள் வெளியீடுகளை (output) கணித்து வெளியிட வேண்டும்.
[[படிமம்:Distributed-parallel.svg|thumb|right|260px|(a)–(b)&nbsp;விரவல் அமைப்பு. (c)இணையான அமைப்பு.]]


பரவிய அமைப்புகளின் மற்ற குறிப்பிடத்தக்க பண்புகள் பின்வருமாறு:
=== இணையான அல்லது விரவல் கணினி செய்முறை? ===


* ஏதேனும் ஒரு கணினியில் தவறுகள் நடந்தால், அந்தத் தவறினால் மற்ற கணினிகள் பாதிப்பு அடையக் கூடாது. குறிப்பாக, அந்த முழு ''பரவிய அமைப்பு''ம் கூடிய வரை தம்மால் ஆன அளவு சரியாகவே இயங்க முயல வேண்டும்.<ref>{{harvtxt|Ghosh|2007}}, ப. 4, 8. {{harvtxt|Lynch|1996}}, ப. 2–3. {{harvtxt|Peleg|2000}}, ப. 4.</ref>
"உடன்நிகழ்வு கணினிப்படுத்துகை", {/0{0}}"இணையான கணினிப்படுத்துகை" மற்றும் "விரவல் கணினிச் செய்முறை" என்ற வார்த்தைகள் அதிகப்படியான மேற்காவு கொண்டவை மற்றும் இவைகளுக்குள் தெளிவான தனிச் சிறப்பு இல்லை.<ref>{{harvtxt|Ghosh|2007}}, ப. 10. {{harvtxt|Keidar|2008}}.</ref> இதே அமைப்பு "இணையான" அல்லது "விரவல்" என்று பகுக்கப்பட்டால் பங்கிடப்பட்ட கணினி செய்முறையில் உள்ள செயற்படுத்திகளில் இணையாக உடன்நிகழ்வு நிகழும்.<ref>{{harvtxt|Lynch|1996}}, ப. xix, 1–2. {{harvtxt|Peleg|2000}}, ப. 1.</ref> இணையான கணினிப்படுத்துகை என்பது விரவல் கணினி செய்முறையின் நெருக்க-இணைவு வடிவம் என்றும்<ref>{{harvtxt|Peleg|2000}}, ப. 1.</ref> மற்றும் விரவல் கணினி செய்முறை என்பது இணையான கணினிப்படுத்துகையின் தளர்ந்த-இணைவு வடிவம் என்றும் பார்க்கபடுகிறது.<ref name="harvtxt|Ghosh|2007"/> இருந்தபோதிலும் உடன்நிகழ்வு அமைப்புகளை "இணையான" அல்லது "விரவல்" என்று பின்வரும் காரணங்களினால் பிரிக்க முடியும்:
* பொதுவாக, இந்த பரவிய அமைப்பின் கட்டமைப்பு (structure) (அதாவது, எத்தனைக் கணிப்பொறிகள் உள்ளன, எவ்வாறு அவை ஒன்றோடு ஒன்றாய் இணைக்கப் பட்டுள்ளன, எவ்வளவு விரைவாக அவை இயங்குகின்றன என்பன போன்றவை ) முன்கூட்டியே தெரிவதில்லை. மேலும், இந்த பரவிய அமைப்பு இயங்கிக் கொண்டிருக்கும் போதே, அதன் கட்டமைப்பு மாற்றி அமைக்கப் படலாம்.<ref>{{harvtxt|Lynch|1996}}, ப. 2. {{harvtxt|Peleg|2000}}, ப. 1.</ref>
* இணையான கணினிப்படுத்துகையில், அனைத்து செயற்படுத்திகளும் பகிர்வு நினைவகத்தைஅணுகமுடியும். பகிர்வு நினைவகமானது தகவல்களைச் செயற்படுத்திகளுக்கு இடையே மாற்றிக் கொள்ள உபயோகப்படுகிறது.<ref>{{harvtxt|Papadimitriou|1994}}, அத்தியாயம் 15. 50</ref>
* ஒவ்வொரு கணினியும் இந்த அமைப்பைப் பற்றிய முழு அறிவும் பெற்று இருப்பதில்லை. மாறாக, ஒரு பகுதியை பற்றி மட்டுமே அறிந்து இருக்கும். மேலும், ஒவ்வொரு கணினியும் தனக்கு கொடுக்கப்பட்ட தரவை மட்டுமே பயன் படுத்தி தன் வெளியீடுகளைக் கணிக்க வேண்டும்.<ref>{{harvtxt|Ghosh|2007}}, ப. 7. {{harvtxt|Lynch|1996}}, ப. xix, 2. {{harvtxt|Peleg|2000}}, ப. 4.</ref>
* விரவல் கணினி செய்முறையில் ஒவ்வொரு செயற்படுத்தியும் தனது தனி நினைவகமான விரவல் நினைவகத்தைக் கொண்டுள்ளது. செயற்படுத்திகளுக்கிடையே தகவல்கள் பரிமாறுவதன் மூலம் தகவலானது பரிமாற்றப்படுகிறது.<ref>மேற்குறிப்புகளை [[முன்னுரை]]யில் பார்க்க</ref>
வலதுபுறம் உள்ள படம் விரவல் மற்றும் இணையான கணினி செய்முறை வித்தியாசங்களை விளக்குகிறது. படம் (a) விரவல் கணினி செய்முறையின் தோற்றத்தைக் காட்டுகிறது. இதன் அமைப்பானது வரைபட வடிவில் விளக்கபட்டுள்ளது. இதில் ஒவ்வொரு முனையமும் (வெர்டெக்ஸ்) கணினியாகவும் மற்றும் ஒவ்வொரு விளிம்பும் (முனையங்களை இணைக்கும் கம்பி) தொடர்பாடல் கம்பியாகவும் உள்ளது. படம் (b) அதே கணினி செய்முறையின் தோற்றத்தை விரிவாக காட்டுகிறது: ஒவ்வொரு கணினியும் தனது தனி நினைவகத்துடனும் மற்றும் தகவலானது ஒரு முனையத்திலிருந்து மற்றொரு முனையத்திற்கு தொடர்பாடல் கம்பியின் வழியாக தகவல் பரிமாற்றம் மூலம் பரிமாற்றப்படுகிறது. படம் (c) இணையான கணினி செய்முறையில் ஒவ்வொரு செயற்படுத்திகள் எவ்வாறு விரவல் நினைவகத்தை நேரடியாக பெறுகிறது என்பதை விளக்குகிறது.


[[படிமம்:Distributed-parallel.svg|thumb|right|260px|(a)–(b)&nbsp;பரவிய கணிப்பு (c)இணை கணிப்பு ]]
இந்த சூழ்நிலையானது இணை மற்றும் விரவல் ''நெறிமுறை'' களின் மரபுவழி உபயோகத்தை குழப்பமாக்குகிறது. இவை மேலே கூறப்பட்ட இணை மற்றும் விரவல் ''அமைப்பு'' களின் விளக்கங்களுடன் ஒத்து போவதில்லை. இருந்த போதிலும் விதிகளின் படி அதிக-செயல்திறன் இணை கணிப்பானது இணை நெறிமுறைகளின் மூலம் பகிர்வு-நினைவக பன்மை செயற்படுத்திகளையும் பேரளவு விரவல் அமைப்பானது பங்கிடப்பட்ட நெறிமுறைகளையும் உபயோகப்படுத்துகிறது.

=== இணை கணித்தல், பரவிய கணித்தல் ===

இணை கணித்தல் (Parallel Computing) என்பது பல கணிப்பொறிகள் ஒரே நேரத்தில் செயலாற்றி, தம் பணிகளைச் செவ்வனே முடிப்பதைக் குறிக்கும். பரவிய கணித்தல் என்பது பல கணினிகள் பல இடங்களில் வைக்கப் பட்டு, இணைக்கப் பட்டு உருவாக்கப் பட்ட அமைப்பு எனலாம். எனவே, பரவிய கணித்தல் என சொல்லும் போது, அதில் இணை கணித்தல் என்ற செயலும் நடக்கின்றது எனலாம்.<ref>{{harvtxt|Ghosh|2007}}, ப. 10. {{harvtxt|Keidar|2008}}.</ref> <ref>Lynch, Nancy A. (1996), ''Distributed Algorithms'', Morgan Kaufmann, {{ISBN|978-1-55860-348-6}}</ref> எனினும், பொதுவாக இரண்டுக்கும் ஒரு சிறு வேற்றுமை உள்ளது. ஒரு கணினி என்பது ஒரு கணிப்பான் (processor)-உம், ஒரு நினைவகம் (memory)-உம் கொண்டது.

* பரவிய கணித்தலில் (படத்தில் காட்டியவாறு), ஒவ்வொரு கணினியும் தனித்தனியாக வைக்கப் பட்டு, அவை பின் இணைக்கப் பட்டுள்ளன.<ref>See references in Introduction</ref> அவை இயங்கும் போது, ஒன்றுக்கொன்று சேதிகளை (messages) அனுப்பி, வேண்டிய தரவுகளைப் பகிர்ந்து கொள்கின்றன.
* இணை கணித்தலில், கணினிகள் அனைத்திற்கும் ஒரே ஒரு நினைவகம் தான் இருக்கிறது. அதாவது, இந்த நினைவகத்தை அனைத்து கணிப்பிகளும் பகிர்ந்து கொள்கின்றன. அதனால் இந்த நினைவகம் '''பகிர்ந்த நினைவகம்''' (shared memory) என்று அழைக்கப் படுகின்றது.<ref>Papadimitriou (1994), Chapter 15. Keidar (2008).</ref> இந்த முறையில் கணினிகள் வேண்டிய தரவுகளைப் பகிர்ந்த நினைவகத்தில் வழியாக ஒன்றுக்கொன்று பரிமாறிக்கி கொள்கின்றன. அதாவது, ஒன்றுக்கொன்று சேதிகளை (messages) அனுப்பி, வேண்டிய தரவுகளைப் பகிர்ந்து கொள்வதில்லை.
* பரவிய கணித்தலில், பரவிய படிமுறைகள் (distributed algorithms) நடைமுறை படுத்தப் பட்டிருக்கும். இணை கணித்தலில், இணை படிமுறைகள் (parallel algorithms) நடைமுறை படுத்தப் பட்டிருக்கும்.<ref>Bentaleb, A.; Yifan, L.; Xin, J.; et al. (2016). "Parallel and Distributed Algorithms" (PDF). National University of Singapore. Retrieved 20 July2018.</ref>


== வரலாறு ==
== வரலாறு ==


தகவல்-பரிமாற்றத்தின் தொடர்பு கொள்ளும் உடன்நிகழ்வு செயற்படுத்தலின் பயன் 1960களில் படிக்கப்பட்ட இயக்க அமைப்பு கட்டமைப்புகளை அடிப்படையாக கொண்டது.<ref>{{harvtxt|Andrews|2000}}, ப. 348.</ref> முதன் முதல் பரவலாக தொடங்கப்பட்ட விரவல் அமைப்பானது 1970களில் கண்டுபிடிக்கப்பட்ட [[ஈதர்நெட்]] மூலம் உருவாக்கப்பட்ட இடத்துரி வலையமைப்பாகும்.<ref>{{harvtxt|Andrews|2000}}, ப. 32.</ref>
"கணினிகள் பல ஒரே நேரத்தில் இயங்கும் போது அவை செய்திகளை தங்களுக்குள் அனுப்பி தரவுகளை பகிர்ந்து கொள்ள இயலும்" என்ற கோட்பாடு, 1960-களில் [[இயக்கு தளம்|'''இயங்கு தளம்''']] ( operating system) என்ற மென்பொருளை உருவாக்கும் போது முதன் முறையாகப் பயன்படுத்தப் பட்டது.<ref>{{harvtxt|Andrews|2000}}, ப. 348.</ref> முதன் முதல் பரவலாக தொடங்கப்பட்ட பரவிய அமைப்பானது 1970களில் கண்டுபிடிக்கப்பட்ட [[ஈதர்நெட்]] மூலம் உருவாக்கப்பட்ட இடத்துரி வலையமைப்பாகும்.<ref>{{harvtxt|Andrews|2000}}, ப. 32.</ref>


1960 ஆம் ஆண்டின் இறுதியில் அறிமுகம் செய்யப்பட்ட ARPANET, இணையத்திற்கு முன்னோடியாக இருந்தது மற்றும் 1970 ஆம் ஆண்டு ஆரம்பத்தில் ARPANET [[மின்னஞ்சல்]] உருவாக்கபட்டது. ARPANET இன் மிகப் பெரிய வெற்றி செய்நிரலாக மின்னஞ்சல் இருந்தது. மேலும் பேரளவு விரவல் அமைப்புக்கு எடுத்துக்காட்டாகவும் இது இருந்தது.<ref>{{harvtxt|Peter|2004}}, [http://www.nethistory.info/History%20of%20the%20Internet/email.html மின்னஞ்சலின் வரலாறு].</ref> ARPANET மற்றும் அதன் பின்னோடியான இணையதளம் 1980களில் உலகளாவிய கணினி வலையமைப்புகளாக இருந்த யூஸ்நெட் மற்றும் ஃபிடோநெட், இவைகள் இரண்டும் விரவல் விவாத அமைப்புகளுக்கு உறுதுணையாக இருந்தன.
1960 ஆம் ஆண்டின் இறுதியில் அறிமுகம் செய்யப்பட்ட ARPANET, இணையத்திற்கு முன்னோடியாக இருந்தது மற்றும் 1970 ஆம் ஆண்டு ஆரம்பத்தில் ARPANET [[மின்னஞ்சல்]] உருவாக்கபட்டது. ARPANET இன் மிகப் பெரிய வெற்றி செய்நிரலாக மின்னஞ்சல் இருந்தது. மேலும் பேரளவு பரவிய அமைப்புக்கு எடுத்துக்காட்டாகவும் இது இருந்தது.<ref>{{harvtxt|Peter|2004}}, [http://www.nethistory.info/History%20of%20the%20Internet/email.html மின்னஞ்சலின் வரலாறு].</ref> ARPANET மற்றும் அதன் பின்னோடியான இணையதளம் 1980களில் உலகளாவிய கணினி வலையமைப்புகளாக இருந்த யூஸ்நெட் மற்றும் ஃபிடோநெட், இவைகள் இரண்டும் பரவிய விவாத அமைப்புகளுக்கு உறுதுணையாக இருந்தன.


விரவல் கணினி செய்முறைகளை பற்றிய படிப்பு கணிப்பொறி அறிவியலின் பகுதியாக 1970 இறுதி மற்றும் 1980 ஆரம்பங்களில் மாறியது. இந்த துறையின் முதல் கருத்தரங்கம், சிம்போசியம் ஆன் பிரின்ஸிபல்ஸ் ஆப் டிஸ்ட்ரிபியூடேட் கம்ப்யூடிங் (PODC) என்று 1982 ஆம் ஆண்டிலும் இதன் ஐரோப்பிய பகுதி இண்டர்நேசனல் சிம்போசியம் ஆன் டிஸ்ட்ரிபியூடேட் கம்ப்யூடிங் (DISC) என்று 1985 ஆம் ஆண்டிலும் முதன் முதலில் நடைப்பெற்றது.
பரவியகணினி செய்முறைகளை பற்றிய படிப்பு கணிப்பொறி அறிவியலின் பகுதியாக 1970 இறுதி மற்றும் 1980 ஆரம்பங்களில் மாறியது. இந்த துறையின் முதல் கருத்தரங்கம், சிம்போசியம் ஆன் பிரின்ஸிபல்ஸ் ஆப் டிஸ்ட்ரிபியூடேட் கம்ப்யூடிங் (PODC) என்று 1982 ஆம் ஆண்டிலும் இதன் ஐரோப்பிய பகுதி இண்டர்நேசனல் சிம்போசியம் ஆன் டிஸ்ட்ரிபியூடேட் கம்ப்யூடிங் (DISC) என்று 1985 ஆம் ஆண்டிலும் முதன் முதலில் நடைபெற்றது.


== பயன்பாடுகள் ==
== பயன்பாடுகள் ==


இரண்டு முக்கிய காரணங்களுக்காக விரவல் கணினி செய்முறை மற்றும் பங்கிடப்பட்ட கணிப்புகளை உபயோகப்படுத்துகிறோம். முதலில் இந்த முறையின் இயற்கை பிரயோகங்கங்களுக்கு தொடர்பாடல் வலையமைப்பின் மூலம் பல கணினிகளை இணைக்க ''தேவைப்படலாம்''. எடுத்துகாட்டாக ஒரு இடத்தில் உருவாக்கப்பட்ட தகவலானது மற்றொரு இடத்திலும் தேவைப்படுகிறது.
இரண்டு முக்கிய காரணங்களுக்காகபரவிய கணினி செய்முறை மற்றும் பங்கிடப்பட்ட கணிப்புகளை உபயோகப்படுத்துகிறோம். முதலில் இந்த முறையின் இயற்கை பிரயோகங்கங்களுக்கு தொடர்பாடல் வலையமைப்பின் மூலம் பல கணினிகளை இணைக்க ''தேவைப்படலாம்''. எடுத்துகாட்டாக ஒரு இடத்தில் உருவாக்கப்பட்ட தகவலானது மற்றொரு இடத்திலும் தேவைப்படுகிறது.


இரண்டாவதாக சில சமயங்களில் ஒரு கணினியை உபயோகிப்பது சாத்தியமாக இருக்கலாம். ஆனால் நடைமுறை காரணங்களுக்காக விரவல் அமைப்புகளை உபயோகிப்பது ''பயனுள்ளதாகும்''. உதாரணமாக ஒரு அதிக-திறனுடைய கணினிகளை கொண்டு பெறமுடியாத விளைவுகளை சில குறைந்த-திறனுடைய கணினி கொத்துகள் மூலம் பெற முடியும். பங்கிடப்படாத அமைப்புகளை விட விரவல் அமைப்புகள் மிகவும் நம்பிக்கையானவை. சிறிதளவு தோல்வியும் அதில் ஏற்படுவதில்லை. இவற்றை விட ஒற்றைசார் செயற்படுத்திகளை விட விரவல் அமைப்பானது எளிதாக விரிவாக்கவும் சமாளிக்கவும் வல்லது.<ref>{{harvtxt|Elmasri|Navathe|2000}}, பிரிவு 24.1.2.</ref>
இரண்டாவதாக சில சமயங்களில் ஒரு கணினியை உபயோகிப்பது சாத்தியமாக இருக்கலாம். ஆனால் நடைமுறை காரணங்களுக்காக பரவிய அமைப்புகளை உபயோகிப்பது ''பயனுள்ளதாகும்''. உதாரணமாக ஒரு அதிக-திறனுடைய கணினிகளை கொண்டு பெறமுடியாத விளைவுகளை சில குறைந்த-திறனுடைய கணினி கொத்துகள் மூலம் பெற முடியும். பங்கிடப்படாத அமைப்புகளை விட பரவிய அமைப்புகள் மிகவும் நம்பிக்கையானவை. சிறிதளவு தோல்வியும் அதில் ஏற்படுவதில்லை. இவற்றை விட ஒற்றைசார் செயற்படுத்திகளை விட பரவிய அமைப்பானது எளிதாக விரிவாக்கவும் சமாளிக்கவும் வல்லது.<ref>{{harvtxt|Elmasri|Navathe|2000}}, பிரிவு 24.1.2.</ref>


பின்வருவன விரவல் அமைப்புகள் மற்றும் பங்கிடப்பட்ட கணிப்புகளின் உதாரணங்களாகும்.<ref>{{harvtxt|Andrews|2000}}, ப. 10–11. {{harvtxt|Ghosh|2007}}, ப. 4–6. {{harvtxt|Lynch|1996}}, ப. xix, 1. {{harvtxt|Peleg|2000}}, ப. xv. {{harvtxt|Elmasri|Navathe|2000}}{{harvtxt|Elmasri|Navathe|2000}}, பிரிவு 24.</ref>
பின்வருவன பரவிய அமைப்புகள் மற்றும் பங்கிடப்பட்ட கணிப்புகளின் உதாரணங்களாகும்.<ref>{{harvtxt|Andrews|2000}}, ப. 10–11. {{harvtxt|Ghosh|2007}}, ப. 4–6. {{harvtxt|Lynch|1996}}, ப. xix, 1. {{harvtxt|Peleg|2000}}, ப. xv. {{harvtxt|Elmasri|Navathe|2000}}{{harvtxt|Elmasri|Navathe|2000}}, பிரிவு 24.</ref>
* [[தொலைத்தொடர்பு]] வலையமைப்புகள்:
* [[தொலைத்தொடர்பு]] வலையமைப்புகள்:
** தொலைப்பேசி வலையமைப்புகள் மற்றும் கலமுறை வலையமைப்புகள்
** தொலைபேசி வலையமைப்புகள் மற்றும் கலமுறை வலையமைப்புகள்
** இணையத்தை போன்ற [[கணினி வலையமைப்பு]]
** இணையத்தை போன்ற [[கணினி வலையமைப்பு]]
** கம்பியில்லா உணரி வலையமைப்புகள்
** கம்பியில்லா உணரி வலையமைப்புகள்
** வழிபடுத்தும் நெறிமுறைகள்.
** வழிபடுத்தும் நெறிமுறைகள்.
* வலையமைப்பு பயன்பாடுகள்:
* வலையமைப்பு பயன்பாடுகள்:
** [[உலகளாவிய வலை]] மற்றும் சமமான வலையமைப்புகள்
**[[உலகளாவிய வலை]] மற்றும் சமமான வலையமைப்புகள்
** பெருமளவு மல்டிப்ளேயர் ஆன்லைன் விளையாட்டு மற்றும் மாயமான உண்மை குழுமம்.
** பெருமளவு மல்டிப்ளேயர் ஆன்லைன் விளையாட்டு மற்றும் மாயமான உண்மை குழுமம்.
** விரவல் தரவுதளங்கள் மற்றும் விரவல் தரவுதள முகாமை அமைப்புகள்
** பரவிய தரவுதளங்கள் மற்றும் பரவிய தரவுதள முகாமை அமைப்புகள்
** வலையமைப்பு கோப்பு அமைப்புகள்.
** வலையமைப்பு கோப்பு அமைப்புகள்.
** வங்கி மற்றும் விமான முன்பதிவு அமைப்புகளை போன்ற விரவல் தகவல் செயல்படுத்தும் அமைப்புகள்
** வங்கி மற்றும் விமான முன்பதிவு அமைப்புகளை போன்ற பரவிய தகவல் செயல்படுத்தும் அமைப்புகள்
* நிகழ் நேர முறை வழியாக்க கட்டுபாடுகள்:
* நிகழ் நேர முறை வழியாக்க கட்டுபாடுகள்:
** [[வானூர்தி]] கட்டுபாட்டு அமைப்புகள்
** [[வானூர்தி]] கட்டுபாட்டு அமைப்புகள்
** தொழிலக கட்டுபாட்டு அமைப்புகள்.
** தொழிலக கட்டுபாட்டு அமைப்புகள்.
* இணையான கணிப்பு:
* இணையான கணிப்பு:
** அறிவியல் கணிப்பு, கொத்து கணிப்பு மற்றும் கட்ட கணிப்புமற்றும் பல தன்னார்வ கணிப்பு திட்டபணிகள், விரவல் கணிப்பு திட்டபணிகளில் பட்டியலைப் பார்க்கவும்.
** அறிவியல் கணிப்பு, கொத்து கணிப்பு மற்றும் கட்ட கணிப்புமற்றும் பல தன்னார்வ கணிப்பு திட்டபணிகள், பரவிய கணிப்பு திட்டபணிகளில் பட்டியலைப் பார்க்கவும்.
** கணினி வரைவியலில் விரவல் அளிப்பு.
** கணினி வரைவியலில் பரவிய அளிப்பு.


== கோட்பாட்டு அடித்தளம் ==
== கோட்பாட்டு அடித்தளம் ==
வரிசை 71: வரிசை 71:
கோட்பாட்டுக் கணிப்பொறி அறிவியலானது எந்த விதமான கணக்கீட்டு புதிர்களை, கணினியின் கணக்கீட்டு கோட்பாடுகள் தீர்க்கிறது மற்றும் கணக்கீட்டு சிக்கல் கோட்பாட்டின் திறன் என்ன என்பதை புரிந்து கொள்ள ஆர்வமாக இருக்கும். பொதுவாக ஒரு பிரச்சனையானது கணினியில் நாம் உருவாக்கிய [[நெறிமுறை]] திட்டம் எவ்வாறு சரியான தீர்வை சான்றுக்கு அளிக்கிறது என்றும் சொல்லப்படுகிறது. இவ்வாறு உருவாக்கப்பட்ட நெறிமுறைகள் பொதுவான கணினிகளில் உபயோகப்படும் கணினி செய்நிரல்என்று செயற்படுத்தபடுகிறது: இந்த செய்நிரலானது பிரச்சனை சான்றை உள்ளீடாக பெற்று, சில கணக்கீடுகளைச் செய்து தீர்வை வெளியீடாகத் தருகிறது. பொதுவாக தற்போக்கு அணுகல் எந்திரம் அல்லது உலகளாவிய தூரிங் எந்திரம் ஆகியவற்றை தொடர்ச்சியான பொது-நோக்க கணினியின் சுருக்க மாதிரியாக வைத்து இந்த மாதிரியான செய்நிரல்களை செயல்படுத்த வேண்டும்.
கோட்பாட்டுக் கணிப்பொறி அறிவியலானது எந்த விதமான கணக்கீட்டு புதிர்களை, கணினியின் கணக்கீட்டு கோட்பாடுகள் தீர்க்கிறது மற்றும் கணக்கீட்டு சிக்கல் கோட்பாட்டின் திறன் என்ன என்பதை புரிந்து கொள்ள ஆர்வமாக இருக்கும். பொதுவாக ஒரு பிரச்சனையானது கணினியில் நாம் உருவாக்கிய [[நெறிமுறை]] திட்டம் எவ்வாறு சரியான தீர்வை சான்றுக்கு அளிக்கிறது என்றும் சொல்லப்படுகிறது. இவ்வாறு உருவாக்கப்பட்ட நெறிமுறைகள் பொதுவான கணினிகளில் உபயோகப்படும் கணினி செய்நிரல்என்று செயற்படுத்தபடுகிறது: இந்த செய்நிரலானது பிரச்சனை சான்றை உள்ளீடாக பெற்று, சில கணக்கீடுகளைச் செய்து தீர்வை வெளியீடாகத் தருகிறது. பொதுவாக தற்போக்கு அணுகல் எந்திரம் அல்லது உலகளாவிய தூரிங் எந்திரம் ஆகியவற்றை தொடர்ச்சியான பொது-நோக்க கணினியின் சுருக்க மாதிரியாக வைத்து இந்த மாதிரியான செய்நிரல்களை செயல்படுத்த வேண்டும்.


உடன்நிகழ்வு மற்றும் விரவல் கணக்கீட்டு துறைகளின் படிப்புகளில் ஒரே மாதிரியான கேள்விகள் இந்த நிகழ்ச்சியில் பன்மடங்கு கணினி அல்லது வலையமைப்பில் இடையீட்டு நடைமுறையில் உள்ள கணினியில் எந்த கணகீட்டுத் தீர்வுகளில் இப்படிப் பட்ட வலையமைப்பில் தீர்க்கப்படும் தீர்வு எவ்வாறு திறமையாக இருக்கும்? எப்படி இருந்தாலும், "புதிரை தீர்ப்பது" என்பதன் அர்த்தம் உடன்நிகழ்வு அல்லது விரவல் அமைப்புகளில் வெளிப்படையாக இல்லை: எடுத்துக்காட்டாக நெறிமுறை உருவாக்குபவரின் வேலை என்ன, மேலும் தொடர்ச்சியான பொது-நோக்க கணினியில் உடன்நிகழ்வு அல்லது விரவல்வைக்கு நிகரானது எவை.
உடன்நிகழ்வு மற்றும் பரவிய கணக்கீட்டு துறைகளின் படிப்புகளில் ஒரே மாதிரியான கேள்விகள் இந்த நிகழ்ச்சியில் பன்மடங்கு கணினி அல்லது வலையமைப்பில் இடையீட்டு நடைமுறையில் உள்ள கணினியில் எந்த கணகீட்டுத் தீர்வுகளில் இப்படிப் பட்ட வலையமைப்பில் தீர்க்கப்படும் தீர்வு எவ்வாறு திறமையாக இருக்கும்? எப்படி இருந்தாலும், "புதிரை தீர்ப்பது" என்பதன் அர்த்தம் உடன்நிகழ்வு அல்லது பரவிய அமைப்புகளில் வெளிப்படையாக இல்லை: எடுத்துக்காட்டாக நெறிமுறை உருவாக்குபவரின் வேலை என்ன, மேலும் தொடர்ச்சியான பொது-நோக்க கணினியில் உடன்நிகழ்வு அல்லது பரவியவைக்கு நிகரானது எவை.


கீழே உள்ள கலந்தாய்வு பல்வகை கணினிகளை மையப்படுத்துகிறது. ஒரு கணினியில் செய்யப்படும் உடன்நிகழ்வு செய்முறை வெளியீடு ஒரே மாதிரியாக இருக்கிறது.
கீழே உள்ள கலந்தாய்வு பல்வகை கணினிகளை மையப்படுத்துகிறது. ஒரு கணினியில் செய்யப்படும் உடன்நிகழ்வு செய்முறை வெளியீடு ஒரே மாதிரியாக இருக்கிறது.


மூன்று பார்வைப்புள்ளிகள் பொதுவாக உபயோகப்படுத்தப்படுகிறது:
மூன்று பார்வைப்புள்ளிகள் பொதுவாக உபயோகப்படுத்தப்படுகிறது:
;விரவல் நினைவக மாதிரியில் உள்ள இணை நெறிமுறைகள்
;பரவிய நினைவக மாதிரியில் உள்ள இணை நெறிமுறைகள்
* அனைத்து கணினிகளும் விரவல் நினைவகத்தை உபயோகிக்கின்றன. நெறிமுறை உருவாக்குபவர் ஒவ்வொரு கணினி செயல்படுத்தும் செய்நிரலை தேர்ந்தெடுப்பார்.
* அனைத்து கணினிகளும் பரவிய நினைவகத்தை உபயோகிக்கின்றன. நெறிமுறை உருவாக்குபவர் ஒவ்வொரு கணினி செயல்படுத்தும் செய்நிரலை தேர்ந்தெடுப்பார்.
* இணை தற்போக்குப் பெறுவழி அமைப்பு(PRAM) ஒரு கோட்பாட்டு மாதிரியாக உபயோகப்படுகிறது.<ref>{{harvtxt|Cormen|Leiserson|Rivest|1990}}, பிரிவு 30.</ref> எப்படி இருந்தாலும், PRAM மாதிரியானது விரவல் நினைவகத்தை ஒத்தியக்க செயல்படுத்து முறையில் அனுமானிக்கிறது.
* இணை தற்போக்குப் பெறுவழி அமைப்பு(PRAM) ஒரு கோட்பாட்டு மாதிரியாக உபயோகப்படுகிறது.<ref>{{harvtxt|Cormen|Leiserson|Rivest|1990}}, பிரிவு 30.</ref> எப்படி இருந்தாலும், PRAM மாதிரியானது பரவிய நினைவகத்தை ஒத்தியக்க செயல்படுத்து முறையில் அனுமானிக்கிறது.
* நிழல்-உலக பன்மைமுறைவழியாக்க அமைப்புகளின் நடத்தைகளுக்கு ஒரு மாதிரி நெருக்கமாக இருந்து எந்திர அறிவுறுத்தல்களை ஒப்பிடல்-மற்றும்-இடமாற்றம் (CAS) செய்கிறது என்றால் அது ''ஒத்தியங்கா விரவல் நினைவகம் '' முறையில் ஆகும். அதிகப்படியான வேலை இந்த மாதிரியில் உள்ளது. இவற்றின் தொகுப்புகளை இலக்கியத்தில் காண முடியும்.<ref>{{harvtxt|Herlihy|Shavit|2008}}, அத்தியாயம் 2-6.</ref><ref>{{harvtxt|Lynch|1996}}</ref>
* நிழல்-உலக பன்மைமுறைவழியாக்க அமைப்புகளின் நடத்தைகளுக்கு ஒரு மாதிரி நெருக்கமாக இருந்து எந்திர அறிவுறுத்தல்களை ஒப்பிடல்-மற்றும்-இடமாற்றம் (CAS) செய்கிறது என்றால் அது ''ஒத்தியங்கா பரவிய நினைவகம் '' முறையில் ஆகும். அதிகப்படியான வேலை இந்த மாதிரியில் உள்ளது. இவற்றின் தொகுப்புகளை இலக்கியத்தில் காண முடியும்.<ref>{{harvtxt|Herlihy|Shavit|2008}}, அத்தியாயம் 2-6.</ref><ref>{{harvtxt|Lynch|1996}}</ref>


;தகவல்-செலுத்து மாதிரியில் இணை நெறிமுறைகள்
;தகவல்-செலுத்து மாதிரியில் இணை நெறிமுறைகள்
* நெறிமுறை உருவாக்குபவர் வலையமைப்பின் கட்டமைப்பு மற்றும் ஒவ்வொரு கணினி இயக்கும் செய்நிரலையும் தேர்வு செய்கிறார்.
* நெறிமுறை உருவாக்குபவர் வலையமைப்பின் கட்டமைப்பு மற்றும் ஒவ்வொரு கணினி இயக்கும் செய்நிரலையும் தேர்வு செய்கிறார்.
* பூலியன் சுற்றுகள் மற்றும் வரிசையாக்கு வலையமைப்புமாதிரிகள் உபயோகப்படுத்தப்படுகின்றன.<ref>{{harvtxt|Cormen|Leiserson|Rivest|1990}}, பிரிவுகள் 28 மற்றும் 29.</ref> பூலியன் சுற்றுகள் கணினி வலையமைப்பாக பார்க்கபடுகிறது: ஒவ்வொரு வாயிலும் கணினியாக இருந்து சாதாரண கணினி செய்நிரலை இயக்குகிறது. அதே போல வரிசையாக்கு வலையமைப்பும் கணினி வலையமைப்பாக பார்க்கபடுகிறது: ஒவ்வொரு ஒப்பீட்டுமானியும் கணினி.
* பூலியன் சுற்றுகள் மற்றும் வரிசையாக்கு வலையமைப்புமாதிரிகள் உபயோகப்படுத்தப்படுகின்றன.<ref>{{harvtxt|Cormen|Leiserson|Rivest|1990}}, பிரிவுகள் 28 மற்றும் 29.</ref> பூலியன் சுற்றுகள் கணினி வலையமைப்பாக பார்க்கபடுகிறது: ஒவ்வொரு வாயிலும் கணினியாக இருந்து சாதாரண கணினி செய்நிரலை இயக்குகிறது. அதே போல வரிசையாக்கு வலையமைப்பும் கணினி வலையமைப்பாக பார்க்கபடுகிறது: ஒவ்வொரு ஒப்பீட்டுமானியும் கணினி.
;தகவல்-செலுத்து மாதிரியில் விரவல் நெறிமுறைகள்
;தகவல்-செலுத்து மாதிரியில் பரவிய நெறிமுறைகள்
* நெறிமுறை உருவாக்குபவர் கணினி செய்நிரல் மட்டும் தேர்ந்தெடுக்கிறார். அனைத்து கணினிகளும் இதே செய்நிரலை இயக்குகிறது. வலையமைப்பின் கட்டமைப்பை பொருட்படுத்தாமல் அமைப்பானது சரியாக இயங்க வேண்டும்.
* நெறிமுறை உருவாக்குபவர் கணினி செய்நிரல் மட்டும் தேர்ந்தெடுக்கிறார். அனைத்து கணினிகளும் இதே செய்நிரலை இயக்குகிறது. வலையமைப்பின் கட்டமைப்பை பொருட்படுத்தாமல் அமைப்பானது சரியாக இயங்க வேண்டும்.
* பொதுவாக உபயோகப்படுத்தபடும் மாதிரியாக ஒவ்வொரு முனையத்திற்கு வரம்பிற்குட்பட்ட எந்திர வரைபடத்துடன் உள்ளது.
* பொதுவாக உபயோகப்படுத்தபடும் மாதிரியாக ஒவ்வொரு முனையத்திற்கு வரம்பிற்குட்பட்ட எந்திர வரைபடத்துடன் உள்ளது.


விரவல் நெறிமுறைகளில், கணக்கியல் பிரச்சனைகள் வரைப்படத்துடன் தொடர்பு கொண்டுள்ளன. கணினி வலையமைப்பின் கட்டமைப்பை விவரிக்கும் வரைபடமானது பிரச்சனை சான்றில் ''இருக்கிறது'' . பின்வரும் எடுத்துக்காட்டில் இது விவரிக்கப்பட்டுள்ளது.
பரவிய நெறிமுறைகளில், கணக்கியல் பிரச்சனைகள் வரைப்படத்துடன் தொடர்பு கொண்டுள்ளன. கணினி வலையமைப்பின் கட்டமைப்பை விவரிக்கும் வரைபடமானது பிரச்சனை சான்றில் ''இருக்கிறது'' . பின்வரும் எடுத்துக்காட்டில் இது விவரிக்கப்பட்டுள்ளது.


=== ஒரு உதாரணம்: ===
=== ஒரு உதாரணம்: ===
வரிசை 98: வரிசை 98:
* மீண்டும் வரைப்படம் ''G '' சரமாக மாற்றப்படுகிறது. எனினும் பன்முனை கணினிகள் இந்தச் சரத்தை இணையாக இயக்க முடியும். ஒவ்வொரு கணினியும் வரைப்படத்தின் ஒரு பகுதியை மட்டும் மையப்படுத்தி அந்தப் பகுதியின் நிறத்தை உண்டாக்கும்.
* மீண்டும் வரைப்படம் ''G '' சரமாக மாற்றப்படுகிறது. எனினும் பன்முனை கணினிகள் இந்தச் சரத்தை இணையாக இயக்க முடியும். ஒவ்வொரு கணினியும் வரைப்படத்தின் ஒரு பகுதியை மட்டும் மையப்படுத்தி அந்தப் பகுதியின் நிறத்தை உண்டாக்கும்.
* பன்முனைக் கணினிகளை இணையாக இயக்கும் திறன் தனிமைப்படுத்தி கணக்கியலில் அதிக செயல்திறனை மையப்படுத்துவது முதன்மையாகும்.
* பன்முனைக் கணினிகளை இணையாக இயக்கும் திறன் தனிமைப்படுத்தி கணக்கியலில் அதிக செயல்திறனை மையப்படுத்துவது முதன்மையாகும்.
;விரவல் நெறிமுறைகள்
;பரவிய நெறிமுறைகள்
* வரைப்படம் ''G'' கணினி வலையமைப்பின் கட்டமைப்பாகும். ''G '' யின் ஒவ்வொரு முனையத்திற்கும் ஒரு கணினி மற்றும் ''G'' யின் விளிம்பிற்கும் ஒரு தொடர்பு வரிசை இருக்கும். வரைப்படம் ''G '' யின் அடுத்த நெருக்கமானவரை ஒவ்வொரு கணினியும் அறியும்; ''G'' யின் கட்டமைப்பை தெரிந்து கொள்ள ஒவ்வொரு கணினியும் தகவல்களை பரிமாற்றம் செய்து கொள்ளும். ஒவ்வொரு கணினியும் தனித்தனியாகத் தனது வெளியீட்டை வெளிவிடும்.
* வரைப்படம் ''G'' கணினி வலையமைப்பின் கட்டமைப்பாகும். ''G '' யின் ஒவ்வொரு முனையத்திற்கும் ஒரு கணினி மற்றும் ''G'' யின் விளிம்பிற்கும் ஒரு தொடர்பு வரிசை இருக்கும். வரைப்படம் ''G '' யின் அடுத்த நெருக்கமானவரை ஒவ்வொரு கணினியும் அறியும்; ''G'' யின் கட்டமைப்பை தெரிந்து கொள்ள ஒவ்வொரு கணினியும் தகவல்களை பரிமாற்றம் செய்து கொள்ளும். ஒவ்வொரு கணினியும் தனித்தனியாகத் தனது வெளியீட்டை வெளிவிடும்.
* தன்னிச்சையாக இயங்கும் விரவல் அமைப்புகளின் நடவடிக்கைகளை ஒன்றினைப்பது முக்கிய மையமாகும்.
* தன்னிச்சையாக இயங்கும் பரவிய அமைப்புகளின் நடவடிக்கைகளை ஒன்றினைப்பது முக்கிய மையமாகும்.


விரவல் நெறிமுறைகளின் பகுதிகளிலிருந்து இணையான நெறிமுறை பகுதிகள் வேறுபட்ட மையங்கள் கொண்டுள்ளன. இரண்டு பகுதிகளுக்கும் நிறைய இடையீட்டு விளைவுகள் உண்டு. உதாரணமாக வரைப்பட நிறத்திற்கான<ref>{{harvtxt|Cole|Vishkin|1986}}. {{harvtxt|Cormen|Leiserson|Rivest|1990}}, பிரிவு 30.5.</ref> கோல்-விஸ்கின் நெறிமுறைஇணையான நெறிமுறையாக முதலில் வழங்கப்பட்டாலும் விரவல் நெறிமுறையில் நேரடியாக இதன் உத்திகள் உபயோகப்படுத்தப்படுகின்றன.
பரவிய நெறிமுறைகளின் பகுதிகளிலிருந்து இணையான நெறிமுறை பகுதிகள் வேறுபட்ட மையங்கள் கொண்டுள்ளன. இரண்டு பகுதிகளுக்கும் நிறைய இடையீட்டு விளைவுகள் உண்டு. உதாரணமாக வரைப்பட நிறத்திற்கான<ref>{{harvtxt|Cole|Vishkin|1986}}. {{harvtxt|Cormen|Leiserson|Rivest|1990}}, பிரிவு 30.5.</ref> கோல்-விஸ்கின் நெறிமுறைஇணையான நெறிமுறையாக முதலில் வழங்கப்பட்டாலும் பரவிய நெறிமுறையில் நேரடியாக இதன் உத்திகள் உபயோகப்படுத்தப்படுகின்றன.


இவற்றுக்கு மேலாக இணையான நெறிமுறையானது இணை அமைப்பிலும் (விரவல் நினைவகம் மூலம்) அல்லது பங்கிடப்பட்ட அமைப்பில் (தகவல் செலுத்து மூலம்) நிறைவேற்றப்படுகிறது.<ref>{{harvtxt|Andrews|2000}}, ப. ix.</ref> இணையான மற்றும் விரவல் நெறிமுறைகளுக்கு இடையான எல்லையானது (வலையமைப்பை தேர்வு செய்வது vs. வலையமைப்பில் இயங்குவது) இணையான மற்றும் விரவல் அமைப்புகளின் (பங்கிடப்பட்ட நினைவகம் vs. தகவல் செலுத்துதல்) எல்லையின் ஒரே இடத்தில் இருக்காது.
இவற்றுக்கு மேலாக இணையான நெறிமுறையானது இணை அமைப்பிலும் (பரவிய நினைவகம் மூலம்) அல்லது பங்கிடப்பட்ட அமைப்பில் (தகவல் செலுத்து மூலம்) நிறைவேற்றப்படுகிறது.<ref>{{harvtxt|Andrews|2000}}, ப. ix.</ref> இணையான மற்றும் பரவிய நெறிமுறைகளுக்கு இடையான எல்லையானது (வலையமைப்பை தேர்வு செய்வது vs. வலையமைப்பில் இயங்குவது) இணையான மற்றும் பரவிய அமைப்புகளின் (பங்கிடப்பட்ட நினைவகம் vs. தகவல் செலுத்துதல்) எல்லையின் ஒரே இடத்தில் இருக்காது.


=== சிக்கலான அளவீடுகள் ===
=== சிக்கலான அளவீடுகள் ===
வரிசை 112: வரிசை 112:
இணையான நெறிமுறைகளில் நேரம் மற்றும் இடத்துடன் மற்றொரு ஆதாரமான கணினிகளின் வகைகளும் கூடுதலாக இருக்கும். கணினிகளின் எண்ணிக்கை மற்றும் இயங்கும் நேரங்கள் இடையே ஒரு தொடர்பு இருக்கும்: அதிகப்படியான கணினிகள் இணையாக இயங்கும் போது பிரச்சனையானது சுலபமாக தீர்க்கப்படும் (வேகக்கூடுதலை பார்க்கவும்) செயற்படுத்திகளின் கோர்வை எண்ணிக்கை மூலம் பலகோண நேரத்தில் முடிக்கப்பட்ட தீர்வு பிரச்சனையானது NC என்ற பகுப்பின் கீழ் சொல்லப்படும்.<ref>{{harvtxt|Arora|Barak|2009}}, பிரிவு 6.7. {{harvtxt|Papadimitriou|1994}}, பிரிவு 15.3.</ref> NC பகுப்பானது PRAM நடைமுறை அல்லது பூலியன் சுற்றுகள் மூலம் சமமாக விவரிக்கப்படும். PRAM அமைப்புகளானது பூலியன் சுற்றுகளை எளிதாக ஒன்றுபடுத்தும் மற்றும் நிலை எதிர்மாறாகவும் செயல்படும்.<ref>{{harvtxt|Papadimitriou|1994}}, பிரிவு 15.2.</ref>
இணையான நெறிமுறைகளில் நேரம் மற்றும் இடத்துடன் மற்றொரு ஆதாரமான கணினிகளின் வகைகளும் கூடுதலாக இருக்கும். கணினிகளின் எண்ணிக்கை மற்றும் இயங்கும் நேரங்கள் இடையே ஒரு தொடர்பு இருக்கும்: அதிகப்படியான கணினிகள் இணையாக இயங்கும் போது பிரச்சனையானது சுலபமாக தீர்க்கப்படும் (வேகக்கூடுதலை பார்க்கவும்) செயற்படுத்திகளின் கோர்வை எண்ணிக்கை மூலம் பலகோண நேரத்தில் முடிக்கப்பட்ட தீர்வு பிரச்சனையானது NC என்ற பகுப்பின் கீழ் சொல்லப்படும்.<ref>{{harvtxt|Arora|Barak|2009}}, பிரிவு 6.7. {{harvtxt|Papadimitriou|1994}}, பிரிவு 15.3.</ref> NC பகுப்பானது PRAM நடைமுறை அல்லது பூலியன் சுற்றுகள் மூலம் சமமாக விவரிக்கப்படும். PRAM அமைப்புகளானது பூலியன் சுற்றுகளை எளிதாக ஒன்றுபடுத்தும் மற்றும் நிலை எதிர்மாறாகவும் செயல்படும்.<ref>{{harvtxt|Papadimitriou|1994}}, பிரிவு 15.2.</ref>


விரவல் நெறிமுறைகளின் பகுப்பாய்வில் கணக்கீட்டு முறைகளை விட தொடர்பு நடவடிக்கைகளில் அதிகம் கவனம் செலுத்தப்படும். விரவல் கணினிச் செய்முறையின் சிறந்த மாதிரி ஒத்தியக்க அமைப்பாகும் இதில் அனைத்து முனையங்களும் மூடிய படிவத்தில் இயக்கப்படும். ''தொடர்பு வட்டத்தின்'' போது அனைத்து முனையங்களும் இணையாக மாறி அயலகத்திலிருந்து அண்மை தகவலை பெற்று, தன்னிச்சையான கணக்கீடுகளை செய்து, புதிய தகவல்களைத் தன்னுடைய அயலகத்திற்கு அனுப்புகிறது. இந்த அமைப்புகளில் மைய சிக்கல் அளவீடுகளுக்கு செயலை முடிக்க குறிப்பிட்ட எண்ணிக்கை கொண்ட ஒத்தியக்க தொடர்பு வட்டங்கள் தேவைப்படுகின்றன.<ref>{{harvtxt|Lynch|1996}}, ப. 17–23.</ref>
பரவிய நெறிமுறைகளின் பகுப்பாய்வில் கணக்கீட்டு முறைகளை விட தொடர்பு நடவடிக்கைகளில் அதிகம் கவனம் செலுத்தப்படும். பரவிய கணினிச் செய்முறையின் சிறந்த மாதிரி ஒத்தியக்க அமைப்பாகும் இதில் அனைத்து முனையங்களும் மூடிய படிவத்தில் இயக்கப்படும். ''தொடர்பு வட்டத்தின்'' போது அனைத்து முனையங்களும் இணையாக மாறி அயலகத்திலிருந்து அண்மை தகவலை பெற்று, தன்னிச்சையான கணக்கீடுகளை செய்து, புதிய தகவல்களைத் தன்னுடைய அயலகத்திற்கு அனுப்புகிறது. இந்த அமைப்புகளில் மைய சிக்கல் அளவீடுகளுக்கு செயலை முடிக்க குறிப்பிட்ட எண்ணிக்கை கொண்ட ஒத்தியக்க தொடர்பு வட்டங்கள் தேவைப்படுகின்றன.<ref>{{harvtxt|Lynch|1996}}, ப. 17–23.</ref>


இந்தச் சிக்கலான அளவீடுகள் வலையமைப்பின் விட்டத்துடன் அருகில் தொடர்புடையது. ''D '' என்பது வலையமைப்பின் விட்டம் எனில் மற்றொரு பக்கத்தில், எளிதாக ஒத்தியக்க விரவல் அமைப்புகள் மூலம் கணக்கிடப்பட்ட தீர்வுகள் தோரயமாக 2''D'' தொடர்பு வட்டங்கள்: ஒரு பக்கத்திலிருந்து பெறப்பட்ட அனைத்து தகவல்கள் ''D '' வட்டங்கள்), தீர்வு கண்டு ஒவ்வொரு முனையத்திற்கும் ''D'' வட்டங்களில் தீர்வு கொடுக்கிறது.
இந்தச் சிக்கலான அளவீடுகள் வலையமைப்பின் விட்டத்துடன் அருகில் தொடர்புடையது. ''D '' என்பது வலையமைப்பின் விட்டம் எனில் மற்றொரு பக்கத்தில், எளிதாக ஒத்தியக்க பரவிய அமைப்புகள் மூலம் கணக்கிடப்பட்ட தீர்வுகள் தோரயமாக 2''D'' தொடர்பு வட்டங்கள்: ஒரு பக்கத்திலிருந்து பெறப்பட்ட அனைத்து தகவல்கள் ''D '' வட்டங்கள்), தீர்வு கண்டு ஒவ்வொரு முனையத்திற்கும் ''D'' வட்டங்களில் தீர்வு கொடுக்கிறது.


மற்றொரு விதத்தில் நெறிமுறைகளின் இயக்கு நேரமானது ''D '' தொடர்பு வட்டங்களை விட குறைவானதாக இருக்கும், வலையமைப்பில் இணைக்கப்பட்டுள்ள முனையங்கள் அவைகளின் வெளியீடுகளை நெருக்கமில்லாத வலையமைப்பு பகுதிகளிலிருந்து தகவல்களை பெறாமல் வெளிவிடுகின்றன. மற்ற வார்த்தைகளில், தகவல்களைப் பொறுத்த இசைவான முடிவுகளை தனது ''உள்பகுதி அக்கம் பக்கத்திலிருந்து'' உருவாக்குகின்றன. பல விரவல் நெறிமுறைகளின் இயக்க நேரங்கள் ''D'' வட்டத்தை விட குறைவாக உள்ளது, எந்த நெறிமுறைகள் எந்த பிரச்சனைகளைத் தீர்த்தது என்பதை புரிந்து கொள்வது இந்தப் பகுதியின் மைய ஆய்வு கேள்வியாக உள்ளது.<ref>{{harvtxt|Peleg|2000}}, பிரிவுகள் 2.3 மற்றும் 7. {{harvtxt|Linial|1992}}. {{harvtxt|Naor|Stockmeyer|1995}}.</ref>
மற்றொரு விதத்தில் நெறிமுறைகளின் இயக்கு நேரமானது ''D '' தொடர்பு வட்டங்களை விட குறைவானதாக இருக்கும், வலையமைப்பில் இணைக்கப்பட்டுள்ள முனையங்கள் அவைகளின் வெளியீடுகளை நெருக்கமில்லாத வலையமைப்பு பகுதிகளிலிருந்து தகவல்களை பெறாமல் வெளிவிடுகின்றன. மற்ற வார்த்தைகளில், தகவல்களைப் பொறுத்த இசைவான முடிவுகளை தனது ''உள்பகுதி அக்கம் பக்கத்திலிருந்து'' உருவாக்குகின்றன. பல பரவிய நெறிமுறைகளின் இயக்க நேரங்கள் ''D'' வட்டத்தை விட குறைவாக உள்ளது, எந்த நெறிமுறைகள் எந்த பிரச்சனைகளைத் தீர்த்தது என்பதை புரிந்து கொள்வது இந்தப் பகுதியின் மைய ஆய்வு கேள்வியாக உள்ளது.<ref>{{harvtxt|Peleg|2000}}, பிரிவுகள் 2.3 மற்றும் 7. {{harvtxt|Linial|1992}}. {{harvtxt|Naor|Stockmeyer|1995}}.</ref>


மற்ற பொதுவான உபயோகப்படும் அளவுகள் வலையமைப்பில் அனுப்பப்பட்ட துணுக்குகளின் மொத்த எண்ணிக்கையைப் பொறுத்தது (cf. தொடர்பு சிக்கல்)
மற்ற பொதுவான உபயோகப்படும் அளவுகள் வலையமைப்பில் அனுப்பப்பட்ட துணுக்குகளின் மொத்த எண்ணிக்கையைப் பொறுத்தது (cf. தொடர்பு சிக்கல்)
வரிசை 122: வரிசை 122:
=== மற்ற பிரச்சனைகள் ===
=== மற்ற பிரச்சனைகள் ===


பொதுவான கணக்கீட்டு சிக்கல்களைக் கண்ணோட்டத்திற்கு எடுத்துக் கொண்டால் ஒரு கேள்வி எழுகிறது, ஒரு கணினி (அல்லது விரவல் அமைப்பு) அந்த கேள்வியை ஒரு குறிப்பிட்ட நேரத்துக்கு இயக்கி, முடிவை வெளியிட்டு விட்டு நின்று விடுகிறது. எப்படி இருந்தாலும், இயந்திரம் எப்போதும் நிறுத்தாமல் வேலை செய்ய வேண்டிய கணக்குகளும் உள்ளன. இந்தச் சிக்கல்களுக்கு எடுத்துக்காட்டாக டைனிங் பிலோஸபர்ஸ் மற்றும் மியூட்சுவல் எக்ஸ்லுசன்சிக்கல்களைக் கூறலாம். இந்தச் சிக்கல்களில் விரவல் அமைப்பானது தொடர்ச்சியாக பங்கிடப்பட்ட மூலங்களுடன் ஒருங்கிணைந்து இருக்க வேண்டும் அப்போது தான் முரண்பாடுகளும் அல்லது முடக்கம் ஏற்படாமல் இருக்கும்.
பொதுவான கணக்கீட்டு சிக்கல்களைக் கண்ணோட்டத்திற்கு எடுத்துக் கொண்டால் ஒரு கேள்வி எழுகிறது, ஒரு கணினி (அல்லது பரவிய அமைப்பு) அந்த கேள்வியை ஒரு குறிப்பிட்ட நேரத்துக்கு இயக்கி, முடிவை வெளியிட்டு விட்டு நின்று விடுகிறது. எப்படி இருந்தாலும், இயந்திரம் எப்போதும் நிறுத்தாமல் வேலை செய்ய வேண்டிய கணக்குகளும் உள்ளன. இந்தச் சிக்கல்களுக்கு எடுத்துக்காட்டாக டைனிங் பிலோஸபர்ஸ் மற்றும் மியூட்சுவல் எக்ஸ்லுசன்சிக்கல்களைக் கூறலாம். இந்தச் சிக்கல்களில் பரவிய அமைப்பானது தொடர்ச்சியாக பங்கிடப்பட்ட மூலங்களுடன் ஒருங்கிணைந்து இருக்க வேண்டும் அப்போது தான் முரண்பாடுகளும் அல்லது முடக்கம் ஏற்படாமல் இருக்கும்.

பரவிய கணினி செய்முறைக்கான தனித்துவம் வாய்ந்த சில அடிப்படைச் சவால்கள் உள்ளன. ''பழுது பொறுத்தி''களுடன் தொடர்புடைய சவால்கள் முதல் எடுத்துக்காட்டு தொடர்புடைய சிக்கல்களுக்கு கருத்தொற்றுமை சிக்கல்கள்<ref>{{harvtxt|Lynch|1996}}, பிரிவுகள் 5–7. {{harvtxt|Ghosh|2007}}, அத்தியாயம் 13.</ref>, பைஜாண்டைன் பழுது பொறுதி<ref>{{harvtxt|Lynch|1996}}, ப. 99–102. {{harvtxt|Ghosh|2007}}, ப. 192–193.</ref> மற்றும் சுய-உறுதியாக்கல்<ref>{{harvtxt|Dolev|2000}}. {{harvtxt|Ghosh|2007}}, அத்தியாயம் 17.</ref> உதாரணங்களாகும்.


பல வகையான ஆய்வுகள் பரவிய அமைப்புகளின் ''ஒத்தியங்கா'' நிலையை புரிந்து கொள்ள மையப்படுத்தபட்டுள்ளது.
விரவல் கணினி செய்முறைக்கான தனித்துவம் வாய்ந்த சில அடிப்படைச் சவால்கள் உள்ளன. ''பழுது பொறுத்தி''களுடன் தொடர்புடைய சவால்கள் முதல் எடுத்துக்காட்டு தொடர்புடைய சிக்கல்களுக்கு கருத்தொற்றுமை சிக்கல்கள்<ref>{{harvtxt|Lynch|1996}}, பிரிவுகள் 5–7. {{harvtxt|Ghosh|2007}}, அத்தியாயம் 13.</ref>, பைஜாண்டைன் பழுது பொறுதி<ref>{{harvtxt|Lynch|1996}}, ப. 99–102. {{harvtxt|Ghosh|2007}}, ப. 192–193.</ref> மற்றும் சுய-உறுதியாக்கல்<ref>{{harvtxt|Dolev|2000}}. {{harvtxt|Ghosh|2007}}, அத்தியாயம் 17.</ref> உதாரணங்களாகும்.


பல வகையான ஆய்வுகள் விரவல் அமைப்புகளின் ''ஒத்தியங்கா'' நிலையை புரிந்து கொள்ள மையப்படுத்தபட்டுள்ளது.
* ஒத்தியக்க நெறிமுறைகளை ஒத்தியங்கா அமைப்புகளில் இயக்க சிங்ரோனைசர்ஸ் உபயோகிக்கலாம்.<ref>{{harvtxt|Lynch|1996}}, பிரிவு 16. {{harvtxt|Peleg|2000}}, பிரிவு 6.</ref>
* ஒத்தியக்க நெறிமுறைகளை ஒத்தியங்கா அமைப்புகளில் இயக்க சிங்ரோனைசர்ஸ் உபயோகிக்கலாம்.<ref>{{harvtxt|Lynch|1996}}, பிரிவு 16. {{harvtxt|Peleg|2000}}, பிரிவு 6.</ref>
* தர்க்கபூர்வ கடிகாரம் நிகழ்வுகளை வரிசைப்படுத்தும் முன்பு நடந்த காரணங்களை வழங்குகிறது.<ref>{{harvtxt|Lynch|1996}}, பிரிவு 18. {{harvtxt|Ghosh|2007}}, பிரிவுகள் 6.2–6.3.</ref>
* தர்க்கபூர்வ கடிகாரம் நிகழ்வுகளை வரிசைப்படுத்தும் முன்பு நடந்த காரணங்களை வழங்குகிறது.<ref>{{harvtxt|Lynch|1996}}, பிரிவு 18. {{harvtxt|Ghosh|2007}}, பிரிவுகள் 6.2–6.3.</ref>
* <ref>{{harvtxt|Ghosh|2007}}, பிரிவு 6.4.</ref> கடிகார சிங்ரோனைசேசன் நெறிமுறைகள் உளகலாவிய முரணற்ற நேரங்களை வழங்குகின்றன.
* <ref>{{harvtxt|Ghosh|2007}}, பிரிவு 6.4.</ref> கடிகார சிங்ரோனைசேசன் நெறிமுறைகள் உளகலாவிய முரணற்ற நேரங்களை வழங்குகின்றன.


=== விரவல் அமைப்புகளின் பண்புகள் ===
=== பரவிய அமைப்புகளின் பண்புகள் ===


கொடுக்கப்பட்ட சிக்கலைத் தீர்ப்பதற்கான விரவல் அமைப்பை ''வடிவமைப்பது'' மையமாக இருந்தது. நிறைவு உண்டாக்கும் ஆராய்ச்சி சிக்கல் என்பது விரவல் அமைப்புகளை பற்றி ''படிப்பதாகும்'' .
கொடுக்கப்பட்ட சிக்கலைத் தீர்ப்பதற்கான பரவிய அமைப்பை ''வடிவமைப்பது'' மையமாக இருந்தது. நிறைவு உண்டாக்கும் ஆராய்ச்சி சிக்கல் என்பது பரவிய அமைப்புகளை பற்றி ''படிப்பதாகும்'' .


இடைத்தடங்கள் சிக்கல் என்பது மையமாக்கப்பட்ட கணக்கீட்டுடன் தொடர்புடைய ஒற்றுமையான உதாரணமாகும்: நாம் கணினிக்கு ஒரு செய்முறை மற்றும் பணியைக் கொடுத்து அவை இடைத்தடங்களில் இருக்க வேண்டுமா அல்லது எப்போதும் இயங்க வேண்டுமா என்று தீர்மானிக்கிறோம். பொதுவான நடத்தைகளில் இடைத்தடங்கள் சிக்கல் கணிக்க முடியாதது. கணினி வலையமைப்பின் நடத்தை புரிந்து கொள்வதை விட ஒரு கணினியின் நடத்தையை புரிந்து கொள்வது கடினமாகும்.
இடைத்தடங்கள் சிக்கல் என்பது மையமாக்கப்பட்ட கணக்கீட்டுடன் தொடர்புடைய ஒற்றுமையான உதாரணமாகும்: நாம் கணினிக்கு ஒரு செய்முறை மற்றும் பணியைக் கொடுத்து அவை இடைத்தடங்களில் இருக்க வேண்டுமா அல்லது எப்போதும் இயங்க வேண்டுமா என்று தீர்மானிக்கிறோம். பொதுவான நடத்தைகளில் இடைத்தடங்கள் சிக்கல் கணிக்க முடியாதது. கணினி வலையமைப்பின் நடத்தை புரிந்து கொள்வதை விட ஒரு கணினியின் நடத்தையை புரிந்து கொள்வது கடினமாகும்.


எனினும் சில நேர்த்தியான சிறப்பு நடத்தைகள் கணிக்ககூடியவை. வரம்புக்குட்பட்ட அமைப்பு இயந்திரங்களின் வலையமைப்பு நடத்தையை அறிந்து கொள்வதற்கான காரணங்களும் குறிப்பாக உள்ளன. ஒரு உதாரணமாக கொடுக்கப்பட்ட வலையமைப்பில் வரம்புக்குட்பட்ட அமைப்பு (ஒத்தியங்கா மற்றும் உறுதிசெய்யாத) இயந்திரங்களின் இடையீடு முடக்கம் அடையும். இந்தச் சிக்கலானது PSPACE-நிறைவடைந்தது<ref>{{harvtxt|Papadimitriou|1994}}, பிரிவு 19.3.</ref>, அதாவது இது கணிக்ககூடியவை, பெரிய வலையமைப்புகளின் பகுதிகளில் உள்ள சிக்கல்களைத் தீர்க்கப் பயன்படும் (மையமாக்கபட்ட, இணையான அல்லது விரவல்) நெறிமுறைகளைப் போல திறமையாக இருக்காது.
எனினும் சில நேர்த்தியான சிறப்பு நடத்தைகள் கணிக்ககூடியவை. வரம்புக்குட்பட்ட அமைப்பு இயந்திரங்களின் வலையமைப்பு நடத்தையை அறிந்து கொள்வதற்கான காரணங்களும் குறிப்பாக உள்ளன. ஒரு உதாரணமாக கொடுக்கப்பட்ட வலையமைப்பில் வரம்புக்குட்பட்ட அமைப்பு (ஒத்தியங்கா மற்றும் உறுதிசெய்யாத) இயந்திரங்களின் இடையீடு முடக்கம் அடையும். இந்தச் சிக்கலானது PSPACE-நிறைவடைந்தது<ref>{{harvtxt|Papadimitriou|1994}}, பிரிவு 19.3.</ref>, அதாவது இது கணிக்ககூடியவை, பெரிய வலையமைப்புகளின் பகுதிகளில் உள்ள சிக்கல்களைத் தீர்க்கப் பயன்படும் (மையமாக்கபட்ட, இணையான அல்லது பரவிய) நெறிமுறைகளைப் போல திறமையாக இருக்காது.


== கட்டமைப்பு ==
== கட்டமைப்பு ==


பல மென்பொருள் மற்றும் வன்பொருள் கட்டமைப்புகள் விரவல் கணினிச் செய்முறையில் உபயோகப்படுத்தப்படுகின்றன. குறைந்த நிலைகளில் பன்மடங்கு CPU களை ஒரு குறுகிய வலையமைப்பில் இணைப்பது தேவையானதாகும். வலையமைப்பானது சுற்று பலகையில் பதிக்கபட்டு இருந்தாலோ அல்லது நெடுமை-இணைவு கருவிகள் மற்றும் கம்பிகளுடன் உருவாக்கப்பட்டு இருந்தாலோ பொருட்படுத்தாது. ஆனால் அதிகமான நிலைகளில் அந்த CPU களில் இயங்கும் செய்முறைகளை சில தொடர்பு அமைப்புகள்மூலம் இணைப்பது தேவையானதாகும்.
பல மென்பொருள் மற்றும் வன்பொருள் கட்டமைப்புகள் பரவிய கணினிச் செய்முறையில் உபயோகப்படுத்தப்படுகின்றன. குறைந்த நிலைகளில் பன்மடங்கு CPU களை ஒரு குறுகிய வலையமைப்பில் இணைப்பது தேவையானதாகும். வலையமைப்பானது சுற்று பலகையில் பதிக்கபட்டு இருந்தாலோ அல்லது நெடுமை-இணைவு கருவிகள் மற்றும் கம்பிகளுடன் உருவாக்கப்பட்டு இருந்தாலோ பொருட்படுத்தாது. ஆனால் அதிகமான நிலைகளில் அந்த CPU களில் இயங்கும் செய்முறைகளை சில தொடர்பு அமைப்புகள்மூலம் இணைப்பது தேவையானதாகும்.


விரவல் செய்முறையானது சேவைபயனர் வழங்கி, 3-அடுக்கு கட்டமைப்பு, N-அடுக்கு கட்டமைப்பு, விரவல் பொருள்கள், நெடுமை இணைவு அல்லது நெருக்க இணைவுபோன்ற அடிப்படை கட்டமைப்புகள் அல்லது பகுப்புகளில் பொதுவாக வருகின்றன.
பரவிய செய்முறையானது சேவைபயனர் வழங்கி, 3-அடுக்கு கட்டமைப்பு, N-அடுக்கு கட்டமைப்பு, பரவிய பொருள்கள், நெடுமை இணைவு அல்லது நெருக்க இணைவுபோன்ற அடிப்படை கட்டமைப்புகள் அல்லது பகுப்புகளில் பொதுவாக வருகின்றன.


* சேவைப் பயனர் வழங்கி- சிறிய சேவைப் பயனர் தகவல்களைப் பெற வழங்கியுடன் இணைக்கபட்டு, பயனருக்கு தேவையான விதத்தில் தகவலை வழங்கும். சேவைப் பயனரில் உள்ளீடாக வழங்கபட்ட தகவலில் தொடர்ச்சியான மாற்றம் இருந்தால் அது வழங்கிக்கு திருப்பி அனுப்பும்.
* சேவைப் பயனர் வழங்கி- சிறிய சேவைப் பயனர் தகவல்களைப் பெற வழங்கியுடன் இணைக்கபட்டு, பயனருக்கு தேவையான விதத்தில் தகவலை வழங்கும். சேவைப் பயனரில் உள்ளீடாக வழங்கபட்ட தகவலில் தொடர்ச்சியான மாற்றம் இருந்தால் அது வழங்கிக்கு திருப்பி அனுப்பும்.
* 3-அடுக்கு கட்டமைப்பு- மூன்று அடுக்கு அமைப்பில் சேவைப் பயனரானது நடு அடுக்காக மாறி நிலையற்ற சேவைப் பயனரும் உபயோகிக்கும் விதத்தில் அமையும். பயனுறுத்ததை எளிமையாக்குகிறது இணைய பயனுறுத்தங்கள் பெரும்பாலும் 3-அடுக்கு கட்டமைப்பு கொண்டவை
* 3-அடுக்கு கட்டமைப்பு- மூன்று அடுக்கு அமைப்பில் சேவைப் பயனரானது நடு அடுக்காக மாறி நிலையற்ற சேவைப் பயனரும் உபயோகிக்கும் விதத்தில் அமையும். பயனுறுத்ததை எளிமையாக்குகிறது இணைய பயனுறுத்தங்கள் பெரும்பாலும் 3-அடுக்கு கட்டமைப்பு கொண்டவை
* N-அடுக்கு கட்டமைப்பு- N-அடுக்கு பெரும்பாலும் இணைய பயனுறுத்தங்களில் தனது தேவைகளை முயற்சி சேவைகளுக்காக அனுப்புகிறது. இந்த வகையான பயனுறுத்தங்கள் பயனுறுத்த வழங்கிகளின் வெற்றிக்கு பெரிய காரணமாக உள்ளது.
* N-அடுக்கு கட்டமைப்பு- N-அடுக்கு பெரும்பாலும் இணைய பயனுறுத்தங்களில் தனது தேவைகளை முயற்சி சேவைகளுக்காக அனுப்புகிறது. இந்த வகையான பயனுறுத்தங்கள் பயனுறுத்த வழங்கிகளின் வெற்றிக்கு பெரிய காரணமாக உள்ளது.
* நெருக்க இணைவு (கொத்துக்கள்)- எந்திரங்களின் கொத்துக்கள் இணைவாக அமைக்கப்பட்டு விரவல் முறை வழிப்படுத்தலில் இயக்கப்படுவதை குறிக்கிறது. இந்த முறையானது பிரிவுகளாக பிரிக்கப்பட்டு தனித்தனியாக்கப்பட்டு மீண்டும் ஒன்றிணைக்கப்பட்டு இறுதி முடிவு எட்டப்படுகிறது.
* நெருக்க இணைவு (கொத்துக்கள்)- எந்திரங்களின் கொத்துக்கள் இணைவாக அமைக்கப்பட்டு பரவிய முறை வழிப்படுத்தலில் இயக்கப்படுவதை குறிக்கிறது. இந்த முறையானது பிரிவுகளாக பிரிக்கப்பட்டு தனித்தனியாக்கப்பட்டு மீண்டும் ஒன்றிணைக்கப்பட்டு இறுதி முடிவு எட்டப்படுகிறது.
* சமமானவர் தொடர்பு- இந்த கட்டமைப்பில் சிறப்பு இயந்திரமோ அல்லது இயந்திரங்களோ வலையமைப்பு சாதனங்களை சமாளிக்க அல்லது சேவை வழங்க தேவையில்லை. சுமைகள் அனைத்து எந்திரங்களுக்கும் சமமாக பிரிக்கப்பட்டு சமமானவர் என்று அறியப்படுகிறது. சேவைப் பயனாளர் மற்றும் வழங்கிகளாக பியர்ஸ் இருக்கும்.
* சமமானவர் தொடர்பு- இந்த கட்டமைப்பில் சிறப்பு இயந்திரமோ அல்லது இயந்திரங்களோ வலையமைப்பு சாதனங்களை சமாளிக்க அல்லது சேவை வழங்க தேவையில்லை. சுமைகள் அனைத்து எந்திரங்களுக்கும் சமமாக பிரிக்கப்பட்டு சமமானவர் என்று அறியப்படுகிறது. சேவைப் பயனாளர் மற்றும் வழங்கிகளாக பியர்ஸ் இருக்கும்.
* இடைவெளி அடிப்படை- இந்த கட்டமைப்பானது ஒற்றை முகவரி-இடைவெளியில் ஒரு தோற்ற மாயயை உருவாக்கிறது. பயனுறுத்த தேவைகளுக்காக தகவல் தெளிவாக பிரதிபலிக்கப்படுகிறது. நேரம், இடம் மற்றும் குறிப்புதவி ஆகியவற்றில் இணை பிரிப்பு அடையப்படுகிறது.
* இடைவெளி அடிப்படை- இந்த கட்டமைப்பானது ஒற்றை முகவரி-இடைவெளியில் ஒரு தோற்ற மாயயை உருவாக்கிறது. பயனுறுத்த தேவைகளுக்காக தகவல் தெளிவாக பிரதிபலிக்கப்படுகிறது. நேரம், இடம் மற்றும் குறிப்புதவி ஆகியவற்றில் இணை பிரிப்பு அடையப்படுகிறது.


விரவல் கணினி செய்முறைகளின் மற்றொரு அடிப்படை அம்சம் என்னவென்றால் உடன்நிகழ்வு முறைவழிப்படுத்துதலில் உள்ள தொடர்பு மற்றும் ஒருங்கிணைப்பு வகைகளாகும். பலதரப்பட்ட தகவல் பரவல் நடப்பொழுங்குகள் மூலம், முறைவழிப்படுவது ஒன்றை ஒன்று நேரடியாக எஜமான்/அடிமை தொடர்பில் தொடர்பு கொள்கிறது. மைய தரவுதள கட்டமைப்பு எந்த வித நேரடி உள்-முறைவழிப்படுத்து தொடர்பு இல்லாமல் பகிர்வு தரவுதளத்தின் மூலம் விரவல் கணினி செயல்முறை பதிலீடாக செய்யப்படுகிறது.<ref>[http://www.ncbi.nlm.nih.gov/sites/entrez?db=pubmed&amp;list_uids=16711722&amp;cmd=Retrieve எ டேட்டாபேஸ்-செண்ட்ரிக் விரிட்சுவல் ஹெமிஸ்ட்ரி சிஸ்டம், ஜெ செம் இன்ஃப் மாடல் ][http://www.ncbi.nlm.nih.gov/sites/entrez?db=pubmed&amp;list_uids=16711722&amp;cmd=Retrieve 2006 மே-ஜூன்;46(3):1034-9]</ref>
பரவிய கணினி செய்முறைகளின் மற்றொரு அடிப்படை அம்சம் என்னவென்றால் உடன்நிகழ்வு முறைவழிப்படுத்துதலில் உள்ள தொடர்பு மற்றும் ஒருங்கிணைப்பு வகைகளாகும். பலதரப்பட்ட தகவல் பரவல் நடப்பொழுங்குகள் மூலம், முறைவழிப்படுவது ஒன்றை ஒன்று நேரடியாக எஜமான்/அடிமை தொடர்பில் தொடர்பு கொள்கிறது. மைய தரவுதள கட்டமைப்பு எந்த வித நேரடி உள்-முறைவழிப்படுத்து தொடர்பு இல்லாமல் பகிர்வு தரவுதளத்தின் மூலம் பரவிய கணினி செயல்முறை பதிலீடாக செய்யப்படுகிறது.<ref>[http://www.ncbi.nlm.nih.gov/sites/entrez?db=pubmed&amp;list_uids=16711722&amp;cmd=Retrieve எ டேட்டாபேஸ்-செண்ட்ரிக் விரிட்சுவல் ஹெமிஸ்ட்ரி சிஸ்டம், ஜெ செம் இன்ஃப் மாடல் ][http://www.ncbi.nlm.nih.gov/sites/entrez?db=pubmed&amp;list_uids=16711722&amp;cmd=Retrieve 2006 மே-ஜூன்;46(3):1034-9]</ref>


== குறிப்புகள் ==
== குறிப்புகள் ==
வரிசை 171: வரிசை 172:
| last2=Barak | first2=Boaz
| last2=Barak | first2=Boaz
| title=Computational Complexity – A Modern Approach
| title=Computational Complexity – A Modern Approach
| publisher=[[Cambridge University Press|Cambridge]]
| publisher=[[கேம்பிறிட்ஜ் பல்கலைக்கழகப் பதிப்பகம்|Cambridge]]
| year=2009
| year=2009
| isbn=978-0-521-42426-4
| isbn=978-0-521-42426-4
வரிசை 231: வரிசை 232:
}}.
}}.
* {{citation
* {{citation
| last=Peleg | first=David | authorlink=David Peleg (scientist)
| last=Peleg
| first=David
| authorlink=David Peleg (scientist)
| title=Distributed Computing: A Locality-Sensitive Approach
| title=Distributed Computing: A Locality-Sensitive Approach
| publisher=[[Society for Industrial and Applied Mathematics|SIAM]]
| publisher=[[Society for Industrial and Applied Mathematics|SIAM]]
வரிசை 237: வரிசை 240:
| isbn=0-89871-464-8
| isbn=0-89871-464-8
| url=http://www.ec-securehost.com/SIAM/DT05.html
| url=http://www.ec-securehost.com/SIAM/DT05.html
| accessdate=2010-03-23
| archive-date=2009-08-06
| archive-url=https://web.archive.org/web/20090806070332/http://www.ec-securehost.com/SIAM/DT05.html
| url-status=dead
}}.
}}.
;கட்டுரைகள்
;கட்டுரைகள்
வரிசை 251: வரிசை 258:
}}.
}}.
* {{citation
* {{citation
| last1=Keidar | first1=Idit
| last1=Keidar
| first1=Idit
| title=Distributed computing column 32 – The year in review
| title=Distributed computing column 32 – The year in review
| journal=ACM SIGACT News
| journal=ACM SIGACT News
வரிசை 259: வரிசை 267:
| pages=53–54
| pages=53–54
| url=http://webee.technion.ac.il/~idish/sigactNews/#column%2032
| url=http://webee.technion.ac.il/~idish/sigactNews/#column%2032
| accessdate=2010-03-23
| archive-date=2014-01-16
| archive-url=https://web.archive.org/web/20140116123634/http://webee.technion.ac.il/~idish/sigactNews/#column%2032
| url-status=dead
}}.
}}.
* {{citation
* {{citation
வரிசை 283: வரிசை 295:
;இணையத்தளங்கள்
;இணையத்தளங்கள்
* {{cite web
* {{cite web
| last=Godfrey | first=Bill
| last=Godfrey
| first=Bill
| url=http://www.bacchae.co.uk/docs/dist.html
| url=http://www.bacchae.co.uk/docs/dist.html
| title=A primer on distributed computing
| title=A primer on distributed computing
| year=2002
| year=2002
| access-date=2010-03-23
| archive-date=2010-02-25
| archive-url=https://web.archive.org/web/20100225154106/http://www.bacchae.co.uk/docs/dist.html
| url-status=
}}
}}
* {{cite web
* {{cite web
வரிசை 299: வரிசை 316:


;புத்தகங்கள்
;புத்தகங்கள்
* {{cite book|first=Gerard|last=Tel |title=Introduction to Distributed Algorithms| publisher=Cambridge University Press| year=1994}}
* {{cite book|first=Gerard|last=Tel |title=Introduction to Distributed Algorithms|url=https://archive.org/details/introductiontodi0000telg| publisher=Cambridge University Press| year=1994}}
* {{cite book|author=Attiya, Hagit and Welch, Jennifer|title=Distributed Computing: Fundamentals, Simulations, and Advanced Topics| publisher=Wiley-Interscience| year=2004}} ISBN 0-471-45324-2.
* {{cite book|author=Attiya, Hagit and Welch, Jennifer|title=Distributed Computing: Fundamentals, Simulations, and Advanced Topics| publisher=Wiley-Interscience| year=2004}} {{ISBN|0-471-45324-2}}.
* {{cite book|author=Garg, Vijay K.|title=Elements of Distributed Computing| publisher=Wiley-IEEE Press| year=2002}} ISBN 0-471-03600-5.
* {{cite book|author=Garg, Vijay K.|title=Elements of Distributed Computing| publisher=Wiley-IEEE Press| year=2002}} {{ISBN|0-471-03600-5}}.


;கட்டுரைகள்
;கட்டுரைகள்
* {{citation
* {{citation
| editor1-last=Keidar | editor1-first=Idit
| editor1-last=Keidar
| editor1-first=Idit
| editor2-last=Rajsbaum | editor2-first=Sergio
| editor2-last=Rajsbaum
| editor2-first=Sergio
| url=http://webee.technion.ac.il/~idish/sigactNews/
| url=http://webee.technion.ac.il/~idish/sigactNews/
| contribution=Distributed computing column
| contribution=Distributed computing column
| title=ACM SIGACT News
| title=ACM SIGACT News
| year=2000–2009
| year=2000–2009
| accessdate=2010-03-23
| archive-date=2014-01-16
| archive-url=https://web.archive.org/web/20140116123634/http://webee.technion.ac.il/~idish/sigactNews/
| url-status=dead
}}.
}}.


வரிசை 317: வரிசை 340:
* {{dmoz|Computers/Computer_Science/Distributed_Computing/Publications/|Distributed computing journals}}
* {{dmoz|Computers/Computer_Science/Distributed_Computing/Publications/|Distributed computing journals}}


[[ta:பரவிய_கணிப்பு]
[[ta:விரவல்_கணிப்பு]


[[பகுப்பு:கூகுள் தமிழாக்கம்-கணினியியல்]]
[[ar:حوسبة موزعة]]
[[be:Размеркаваныя вылічэнні]]
[[be-x-old:Разьмеркаваныя вылічэньні]]
[[bg:Разпределени изчислителни системи]]
[[bs:Distribuirano računarstvo]]
[[ca:Aplicació distribuïda]]
[[cs:Distribuovaný výpočet]]
[[da:Distribuerede beregninger]]
[[de:Verteiltes Rechnen]]
[[el:Παράλληλα και κατανεμημένα συστήματα]]
[[en:Distributed computing]]
[[eo:Disa komputado]]
[[es:Computación distribuida]]
[[et:Hajusarvutus]]
[[fa:رایانش توزیع‌شده]]
[[fi:Hajautetut järjestelmät]]
[[fr:Calcul distribué]]
[[he:חישוב מבוזר]]
[[hu:Elosztott számítások]]
[[id:Komputasi terdistribusi]]
[[io:Sistemi descentraligita]]
[[it:Calcolo distribuito]]
[[ja:分散コンピューティング]]
[[kk:Мәліметтерді үлестіре өңдеу]]
[[ko:분산 컴퓨팅]]
[[lt:Paskirstytasis skaičiavimas]]
[[mk:Дистрибуиран компјутерски систем]]
[[ms:Pengkomputeran teragih]]
[[nl:Distributed computing]]
[[nn:Distribuert datahandsaming]]
[[pl:Obliczenia rozproszone]]
[[pt:Computação distribuída]]
[[ro:Calcul distribuit]]
[[ru:Распределённые вычисления]]
[[simple:Distributed computing]]
[[sk:Distribuovaný výpočet]]
[[sv:Distributed computing]]
[[tr:Dağıtık hesaplama]]
[[uk:Розподілені обчислення]]
[[ur:منقسم شمارندکاری]]
[[vi:Điện toán phân tán]]
[[zh:分布式计算]]

16:14, 12 திசம்பர் 2022 இல் கடைசித் திருத்தம்

விரவல் கணினி செய்முறை அல்லது பரவிய கணித்தலியல் (Distributed computing) என்பது கணிப்பொறி அறிவியலின் ஒரு பிரிவாகும். இதில் பல செய்நிரல்கள் (programs), கணிப்பொறி வலையமைப்பு (computer network) மூலம் ஒன்றுக்கொன்று தொடர்பு கொண்டு தரவுகளையும் (data), ஏனைய செய்திகளையும் (message) பகிர்ந்து தம் பணிகளைச் செய்து முடிக்கின்றன. பரவிய கணித்தலியலில் பயன்படுத்தப் படும் செய்நிரல்கள் பரவிய செய்நிரல்கள் (distributed programs) என்று அழைக்கப் படுகின்றன. [1] ஆனால், செய்முறையில் ஒரு சில நேரங்களில், பல கணினிகளைப் பயன்படுத்துவதற்குப் பதிலாக, ஒரே ஒரு கணினியைப் பயன் படுத்துவதும் உண்டு.[2]

முகவுரை

[தொகு]

பரவிய என்ற சொல் முதலில் நிலத்தில் பரவி உள்ள (geographically distributed) என்ற பொருளில் வந்தது. எடுத்துக் காட்டாக, பரவிய அமைப்பு (distributed system) என்றால் பல இடங்களில் பரவி அமைந்துள்ள ஓர் அமைப்பு என்று பொருள் பட்டது. . அது போலவே, பரவிய செய்நிரல்கள் (distributed programs) என்பது பல இடங்களில் அமைந்து உள்ள கணினிகளில் இயங்கும் செய்நிரல்களையும், பரவிய படிமுறை (distributed algorithm) என்பது அச் செய்நிரல்களில் அமைந்துள்ள படிமுறைகளையும் குறித்தன.[3] இப்போது பரவிய என்ற சொல் மேலும் பொதுப்படையான பொருளில் பயன்படுத்தப் படுகின்றது. எடுத்துக் காட்டாக, பல தனித்தியங்கும் செய்முறைகள் (autonomous processes), ஒரே கணிப்பொறியில் இயங்கி, தங்களுக்குள் தரவுகளையும் செய்திகளையும் பகிர்ந்துகொண்டு இருக்கையில், அவை பரவிய செய்முறைகள் என்று அழைக்கப் படுகின்றன.[4]

பரவிய அமைப்புகளை விவரிக்க பல வகையான வரையறைகள் இருக்கும் நேரத்தில்,[5]. பின்வரும் வரையறு பண்புகள் பொதுவாக பயன்படுத்தப்படுகின்றன:

  • ஒரு பரவிய அமைப்பில், பல கணிப்பொறிகள் இருக்கும். ஒவ்வொன்றும் மற்றவற்றின் துணையின்றி தனித்தியங்கும் தன்மை படைத்தனவாக இருக்கும். ஒவ்வொன்றுக்கும் சொந்தமான நினைவகங்கள் இருக்கும்.[6]
  • தேவை படும் பொது, ஒரு கணிப்பொறி மற்ற கணிப்பொறிகளுடன் தொடர்பு கொண்டு தேவையான தரவுகளைப் (data) பரிமாறிக் கொள்கின்றது.[7]

இந்தக் கட்டுரையில், இந்தக் கணிப்பொறிகள் கணுக்கள் (nodes) என்றும் அழைக்கப் படும்.

இப்படிப்பட்ட பரவிய அமைப்பில், அனைத்துக் கணிப்பொறிகளும் ஒன்றாகக் கூட்டு சேர்ந்து ஒரு பணியைச் செய்யும் வல்லமை படைத்தவையாக இருக்கும். மேலும் ஒவ்வொன்றும் தனித்து இயங்கும் திறன் கொண்டவையாகவும் இருக்கும். [8] பரவிய அமைப்பின் நோக்கம் என்னவென்றால், கணிப்பொறிகள் ஒவ்வொன்றும் தம்மிடம் உள்ள வளங்களை (resources) மற்றவற்றிடம் பகிர்ந்து கொண்டு, தங்களால் தனித்து செய்ய இயலாத பணிகளைக் கூட்டாகச் சேர்ந்து செய்யும் வலிமை உள்ளவையாக ஆக வேண்டும் என்பதே ஆகும்.[9] அதாவது, தங்களுக்குக் கொடுக்கப்பட்ட தரவுகளை (data input) ஒவ்வொரு கணினியும் தங்களுக்குள் பிரித்து, அதை வைத்து தங்கள் வெளியீடுகளை (output) கணித்து வெளியிட வேண்டும்.

பரவிய அமைப்புகளின் மற்ற குறிப்பிடத்தக்க பண்புகள் பின்வருமாறு:

  • ஏதேனும் ஒரு கணினியில் தவறுகள் நடந்தால், அந்தத் தவறினால் மற்ற கணினிகள் பாதிப்பு அடையக் கூடாது. குறிப்பாக, அந்த முழு பரவிய அமைப்பும் கூடிய வரை தம்மால் ஆன அளவு சரியாகவே இயங்க முயல வேண்டும்.[10]
  • பொதுவாக, இந்த பரவிய அமைப்பின் கட்டமைப்பு (structure) (அதாவது, எத்தனைக் கணிப்பொறிகள் உள்ளன, எவ்வாறு அவை ஒன்றோடு ஒன்றாய் இணைக்கப் பட்டுள்ளன, எவ்வளவு விரைவாக அவை இயங்குகின்றன என்பன போன்றவை ) முன்கூட்டியே தெரிவதில்லை. மேலும், இந்த பரவிய அமைப்பு இயங்கிக் கொண்டிருக்கும் போதே, அதன் கட்டமைப்பு மாற்றி அமைக்கப் படலாம்.[11]
  • ஒவ்வொரு கணினியும் இந்த அமைப்பைப் பற்றிய முழு அறிவும் பெற்று இருப்பதில்லை. மாறாக, ஒரு பகுதியை பற்றி மட்டுமே அறிந்து இருக்கும். மேலும், ஒவ்வொரு கணினியும் தனக்கு கொடுக்கப்பட்ட தரவை மட்டுமே பயன் படுத்தி தன் வெளியீடுகளைக் கணிக்க வேண்டும்.[12]
(a)–(b) பரவிய கணிப்பு (c)இணை கணிப்பு

இணை கணித்தல், பரவிய கணித்தல்

[தொகு]

இணை கணித்தல் (Parallel Computing) என்பது பல கணிப்பொறிகள் ஒரே நேரத்தில் செயலாற்றி, தம் பணிகளைச் செவ்வனே முடிப்பதைக் குறிக்கும். பரவிய கணித்தல் என்பது பல கணினிகள் பல இடங்களில் வைக்கப் பட்டு, இணைக்கப் பட்டு உருவாக்கப் பட்ட அமைப்பு எனலாம். எனவே, பரவிய கணித்தல் என சொல்லும் போது, அதில் இணை கணித்தல் என்ற செயலும் நடக்கின்றது எனலாம்.[13] [14] எனினும், பொதுவாக இரண்டுக்கும் ஒரு சிறு வேற்றுமை உள்ளது. ஒரு கணினி என்பது ஒரு கணிப்பான் (processor)-உம், ஒரு நினைவகம் (memory)-உம் கொண்டது.

  • பரவிய கணித்தலில் (படத்தில் காட்டியவாறு), ஒவ்வொரு கணினியும் தனித்தனியாக வைக்கப் பட்டு, அவை பின் இணைக்கப் பட்டுள்ளன.[15] அவை இயங்கும் போது, ஒன்றுக்கொன்று சேதிகளை (messages) அனுப்பி, வேண்டிய தரவுகளைப் பகிர்ந்து கொள்கின்றன.
  • இணை கணித்தலில், கணினிகள் அனைத்திற்கும் ஒரே ஒரு நினைவகம் தான் இருக்கிறது. அதாவது, இந்த நினைவகத்தை அனைத்து கணிப்பிகளும் பகிர்ந்து கொள்கின்றன. அதனால் இந்த நினைவகம் பகிர்ந்த நினைவகம் (shared memory) என்று அழைக்கப் படுகின்றது.[16] இந்த முறையில் கணினிகள் வேண்டிய தரவுகளைப் பகிர்ந்த நினைவகத்தில் வழியாக ஒன்றுக்கொன்று பரிமாறிக்கி கொள்கின்றன. அதாவது, ஒன்றுக்கொன்று சேதிகளை (messages) அனுப்பி, வேண்டிய தரவுகளைப் பகிர்ந்து கொள்வதில்லை.
  • பரவிய கணித்தலில், பரவிய படிமுறைகள் (distributed algorithms) நடைமுறை படுத்தப் பட்டிருக்கும். இணை கணித்தலில், இணை படிமுறைகள் (parallel algorithms) நடைமுறை படுத்தப் பட்டிருக்கும்.[17]

வரலாறு

[தொகு]

"கணினிகள் பல ஒரே நேரத்தில் இயங்கும் போது அவை செய்திகளை தங்களுக்குள் அனுப்பி தரவுகளை பகிர்ந்து கொள்ள இயலும்" என்ற கோட்பாடு, 1960-களில் இயங்கு தளம் ( operating system) என்ற மென்பொருளை உருவாக்கும் போது முதன் முறையாகப் பயன்படுத்தப் பட்டது.[18] முதன் முதல் பரவலாக தொடங்கப்பட்ட பரவிய அமைப்பானது 1970களில் கண்டுபிடிக்கப்பட்ட ஈதர்நெட் மூலம் உருவாக்கப்பட்ட இடத்துரி வலையமைப்பாகும்.[19]

1960 ஆம் ஆண்டின் இறுதியில் அறிமுகம் செய்யப்பட்ட ARPANET, இணையத்திற்கு முன்னோடியாக இருந்தது மற்றும் 1970 ஆம் ஆண்டு ஆரம்பத்தில் ARPANET மின்னஞ்சல் உருவாக்கபட்டது. ARPANET இன் மிகப் பெரிய வெற்றி செய்நிரலாக மின்னஞ்சல் இருந்தது. மேலும் பேரளவு பரவிய அமைப்புக்கு எடுத்துக்காட்டாகவும் இது இருந்தது.[20] ARPANET மற்றும் அதன் பின்னோடியான இணையதளம் 1980களில் உலகளாவிய கணினி வலையமைப்புகளாக இருந்த யூஸ்நெட் மற்றும் ஃபிடோநெட், இவைகள் இரண்டும் பரவிய விவாத அமைப்புகளுக்கு உறுதுணையாக இருந்தன.

பரவியகணினி செய்முறைகளை பற்றிய படிப்பு கணிப்பொறி அறிவியலின் பகுதியாக 1970 இறுதி மற்றும் 1980 ஆரம்பங்களில் மாறியது. இந்த துறையின் முதல் கருத்தரங்கம், சிம்போசியம் ஆன் பிரின்ஸிபல்ஸ் ஆப் டிஸ்ட்ரிபியூடேட் கம்ப்யூடிங் (PODC) என்று 1982 ஆம் ஆண்டிலும் இதன் ஐரோப்பிய பகுதி இண்டர்நேசனல் சிம்போசியம் ஆன் டிஸ்ட்ரிபியூடேட் கம்ப்யூடிங் (DISC) என்று 1985 ஆம் ஆண்டிலும் முதன் முதலில் நடைபெற்றது.

பயன்பாடுகள்

[தொகு]

இரண்டு முக்கிய காரணங்களுக்காகபரவிய கணினி செய்முறை மற்றும் பங்கிடப்பட்ட கணிப்புகளை உபயோகப்படுத்துகிறோம். முதலில் இந்த முறையின் இயற்கை பிரயோகங்கங்களுக்கு தொடர்பாடல் வலையமைப்பின் மூலம் பல கணினிகளை இணைக்க தேவைப்படலாம். எடுத்துகாட்டாக ஒரு இடத்தில் உருவாக்கப்பட்ட தகவலானது மற்றொரு இடத்திலும் தேவைப்படுகிறது.

இரண்டாவதாக சில சமயங்களில் ஒரு கணினியை உபயோகிப்பது சாத்தியமாக இருக்கலாம். ஆனால் நடைமுறை காரணங்களுக்காக பரவிய அமைப்புகளை உபயோகிப்பது பயனுள்ளதாகும். உதாரணமாக ஒரு அதிக-திறனுடைய கணினிகளை கொண்டு பெறமுடியாத விளைவுகளை சில குறைந்த-திறனுடைய கணினி கொத்துகள் மூலம் பெற முடியும். பங்கிடப்படாத அமைப்புகளை விட பரவிய அமைப்புகள் மிகவும் நம்பிக்கையானவை. சிறிதளவு தோல்வியும் அதில் ஏற்படுவதில்லை. இவற்றை விட ஒற்றைசார் செயற்படுத்திகளை விட பரவிய அமைப்பானது எளிதாக விரிவாக்கவும் சமாளிக்கவும் வல்லது.[21]

பின்வருவன பரவிய அமைப்புகள் மற்றும் பங்கிடப்பட்ட கணிப்புகளின் உதாரணங்களாகும்.[22]

  • தொலைத்தொடர்பு வலையமைப்புகள்:
    • தொலைபேசி வலையமைப்புகள் மற்றும் கலமுறை வலையமைப்புகள்
    • இணையத்தை போன்ற கணினி வலையமைப்பு
    • கம்பியில்லா உணரி வலையமைப்புகள்
    • வழிபடுத்தும் நெறிமுறைகள்.
  • வலையமைப்பு பயன்பாடுகள்:
    • உலகளாவிய வலை மற்றும் சமமான வலையமைப்புகள்
    • பெருமளவு மல்டிப்ளேயர் ஆன்லைன் விளையாட்டு மற்றும் மாயமான உண்மை குழுமம்.
    • பரவிய தரவுதளங்கள் மற்றும் பரவிய தரவுதள முகாமை அமைப்புகள்
    • வலையமைப்பு கோப்பு அமைப்புகள்.
    • வங்கி மற்றும் விமான முன்பதிவு அமைப்புகளை போன்ற பரவிய தகவல் செயல்படுத்தும் அமைப்புகள்
  • நிகழ் நேர முறை வழியாக்க கட்டுபாடுகள்:
    • வானூர்தி கட்டுபாட்டு அமைப்புகள்
    • தொழிலக கட்டுபாட்டு அமைப்புகள்.
  • இணையான கணிப்பு:
    • அறிவியல் கணிப்பு, கொத்து கணிப்பு மற்றும் கட்ட கணிப்புமற்றும் பல தன்னார்வ கணிப்பு திட்டபணிகள், பரவிய கணிப்பு திட்டபணிகளில் பட்டியலைப் பார்க்கவும்.
    • கணினி வரைவியலில் பரவிய அளிப்பு.

கோட்பாட்டு அடித்தளம்

[தொகு]

மாடல்கள்

[தொகு]

நிறையப் பணிகளைக் கணினியின் கேள்வி-பதில் முறையில் தானியக்கமாக மாற்ற விரும்புவோம்: நாம் ஒரு கேள்வி கேட்க விரும்புவோம் கணினி அதற்கான பதிலை தர வேண்டும். கோட்பாட்டுக் கணிப்பொறி அறிவியலில், இந்த மாதிரியான பணிகள் கணக்கீட்டுப் புதிர்கள் எனப்படும். பொதுவாக கணக்கீட்டுப் புதிர்கள் சான்றுகளையும் ஒவ்வொரு சான்றுகளுக்கான தீர்வுகளையும்" கொண்டிருக்கும். சான்றுகள் என்பது நாம் கேட்கும் கேள்விகளாகவும், தீர்வுகள் அந்த கேள்விகளுக்கு பதில்களாகவும் இருக்கும்.

கோட்பாட்டுக் கணிப்பொறி அறிவியலானது எந்த விதமான கணக்கீட்டு புதிர்களை, கணினியின் கணக்கீட்டு கோட்பாடுகள் தீர்க்கிறது மற்றும் கணக்கீட்டு சிக்கல் கோட்பாட்டின் திறன் என்ன என்பதை புரிந்து கொள்ள ஆர்வமாக இருக்கும். பொதுவாக ஒரு பிரச்சனையானது கணினியில் நாம் உருவாக்கிய நெறிமுறை திட்டம் எவ்வாறு சரியான தீர்வை சான்றுக்கு அளிக்கிறது என்றும் சொல்லப்படுகிறது. இவ்வாறு உருவாக்கப்பட்ட நெறிமுறைகள் பொதுவான கணினிகளில் உபயோகப்படும் கணினி செய்நிரல்என்று செயற்படுத்தபடுகிறது: இந்த செய்நிரலானது பிரச்சனை சான்றை உள்ளீடாக பெற்று, சில கணக்கீடுகளைச் செய்து தீர்வை வெளியீடாகத் தருகிறது. பொதுவாக தற்போக்கு அணுகல் எந்திரம் அல்லது உலகளாவிய தூரிங் எந்திரம் ஆகியவற்றை தொடர்ச்சியான பொது-நோக்க கணினியின் சுருக்க மாதிரியாக வைத்து இந்த மாதிரியான செய்நிரல்களை செயல்படுத்த வேண்டும்.

உடன்நிகழ்வு மற்றும் பரவிய கணக்கீட்டு துறைகளின் படிப்புகளில் ஒரே மாதிரியான கேள்விகள் இந்த நிகழ்ச்சியில் பன்மடங்கு கணினி அல்லது வலையமைப்பில் இடையீட்டு நடைமுறையில் உள்ள கணினியில் எந்த கணகீட்டுத் தீர்வுகளில் இப்படிப் பட்ட வலையமைப்பில் தீர்க்கப்படும் தீர்வு எவ்வாறு திறமையாக இருக்கும்? எப்படி இருந்தாலும், "புதிரை தீர்ப்பது" என்பதன் அர்த்தம் உடன்நிகழ்வு அல்லது பரவிய அமைப்புகளில் வெளிப்படையாக இல்லை: எடுத்துக்காட்டாக நெறிமுறை உருவாக்குபவரின் வேலை என்ன, மேலும் தொடர்ச்சியான பொது-நோக்க கணினியில் உடன்நிகழ்வு அல்லது பரவியவைக்கு நிகரானது எவை.

கீழே உள்ள கலந்தாய்வு பல்வகை கணினிகளை மையப்படுத்துகிறது. ஒரு கணினியில் செய்யப்படும் உடன்நிகழ்வு செய்முறை வெளியீடு ஒரே மாதிரியாக இருக்கிறது.

மூன்று பார்வைப்புள்ளிகள் பொதுவாக உபயோகப்படுத்தப்படுகிறது:

பரவிய நினைவக மாதிரியில் உள்ள இணை நெறிமுறைகள்
  • அனைத்து கணினிகளும் பரவிய நினைவகத்தை உபயோகிக்கின்றன. நெறிமுறை உருவாக்குபவர் ஒவ்வொரு கணினி செயல்படுத்தும் செய்நிரலை தேர்ந்தெடுப்பார்.
  • இணை தற்போக்குப் பெறுவழி அமைப்பு(PRAM) ஒரு கோட்பாட்டு மாதிரியாக உபயோகப்படுகிறது.[23] எப்படி இருந்தாலும், PRAM மாதிரியானது பரவிய நினைவகத்தை ஒத்தியக்க செயல்படுத்து முறையில் அனுமானிக்கிறது.
  • நிழல்-உலக பன்மைமுறைவழியாக்க அமைப்புகளின் நடத்தைகளுக்கு ஒரு மாதிரி நெருக்கமாக இருந்து எந்திர அறிவுறுத்தல்களை ஒப்பிடல்-மற்றும்-இடமாற்றம் (CAS) செய்கிறது என்றால் அது ஒத்தியங்கா பரவிய நினைவகம் முறையில் ஆகும். அதிகப்படியான வேலை இந்த மாதிரியில் உள்ளது. இவற்றின் தொகுப்புகளை இலக்கியத்தில் காண முடியும்.[24][25]
தகவல்-செலுத்து மாதிரியில் இணை நெறிமுறைகள்
  • நெறிமுறை உருவாக்குபவர் வலையமைப்பின் கட்டமைப்பு மற்றும் ஒவ்வொரு கணினி இயக்கும் செய்நிரலையும் தேர்வு செய்கிறார்.
  • பூலியன் சுற்றுகள் மற்றும் வரிசையாக்கு வலையமைப்புமாதிரிகள் உபயோகப்படுத்தப்படுகின்றன.[26] பூலியன் சுற்றுகள் கணினி வலையமைப்பாக பார்க்கபடுகிறது: ஒவ்வொரு வாயிலும் கணினியாக இருந்து சாதாரண கணினி செய்நிரலை இயக்குகிறது. அதே போல வரிசையாக்கு வலையமைப்பும் கணினி வலையமைப்பாக பார்க்கபடுகிறது: ஒவ்வொரு ஒப்பீட்டுமானியும் கணினி.
தகவல்-செலுத்து மாதிரியில் பரவிய நெறிமுறைகள்
  • நெறிமுறை உருவாக்குபவர் கணினி செய்நிரல் மட்டும் தேர்ந்தெடுக்கிறார். அனைத்து கணினிகளும் இதே செய்நிரலை இயக்குகிறது. வலையமைப்பின் கட்டமைப்பை பொருட்படுத்தாமல் அமைப்பானது சரியாக இயங்க வேண்டும்.
  • பொதுவாக உபயோகப்படுத்தபடும் மாதிரியாக ஒவ்வொரு முனையத்திற்கு வரம்பிற்குட்பட்ட எந்திர வரைபடத்துடன் உள்ளது.

பரவிய நெறிமுறைகளில், கணக்கியல் பிரச்சனைகள் வரைப்படத்துடன் தொடர்பு கொண்டுள்ளன. கணினி வலையமைப்பின் கட்டமைப்பை விவரிக்கும் வரைபடமானது பிரச்சனை சான்றில் இருக்கிறது . பின்வரும் எடுத்துக்காட்டில் இது விவரிக்கப்பட்டுள்ளது.

ஒரு உதாரணம்:

[தொகு]

ஒரு வரைபடம் G யின் நிறங்களை கண்டறியும் கணக்கியல் சிக்கல்களை எடுத்துக் கொள்வோம். பலதரப்பட்ட புலங்கள் பின்வரும் அணுகுமுறைகளை எடுத்துக் கொள்ளலாம்.

ஒருமுகப்படுத்தப்பட்ட நெறிமுறைகள்
  • வரைப்படம் G யானது சரமாக மாற்றப்பட்டு கணினிக்கு உள்ளீடாக தரப்படுகிறது. கணினி செயல்நிரையானது வரைப்படத்தின் நிறங்களை கண்டறிந்து அவற்றை சரமாக மாற்றி வெளியீடாக தருகிறது.
இணையான நெறிமுறைகள்
  • மீண்டும் வரைப்படம் G சரமாக மாற்றப்படுகிறது. எனினும் பன்முனை கணினிகள் இந்தச் சரத்தை இணையாக இயக்க முடியும். ஒவ்வொரு கணினியும் வரைப்படத்தின் ஒரு பகுதியை மட்டும் மையப்படுத்தி அந்தப் பகுதியின் நிறத்தை உண்டாக்கும்.
  • பன்முனைக் கணினிகளை இணையாக இயக்கும் திறன் தனிமைப்படுத்தி கணக்கியலில் அதிக செயல்திறனை மையப்படுத்துவது முதன்மையாகும்.
பரவிய நெறிமுறைகள்
  • வரைப்படம் G கணினி வலையமைப்பின் கட்டமைப்பாகும். G யின் ஒவ்வொரு முனையத்திற்கும் ஒரு கணினி மற்றும் G யின் விளிம்பிற்கும் ஒரு தொடர்பு வரிசை இருக்கும். வரைப்படம் G யின் அடுத்த நெருக்கமானவரை ஒவ்வொரு கணினியும் அறியும்; G யின் கட்டமைப்பை தெரிந்து கொள்ள ஒவ்வொரு கணினியும் தகவல்களை பரிமாற்றம் செய்து கொள்ளும். ஒவ்வொரு கணினியும் தனித்தனியாகத் தனது வெளியீட்டை வெளிவிடும்.
  • தன்னிச்சையாக இயங்கும் பரவிய அமைப்புகளின் நடவடிக்கைகளை ஒன்றினைப்பது முக்கிய மையமாகும்.

பரவிய நெறிமுறைகளின் பகுதிகளிலிருந்து இணையான நெறிமுறை பகுதிகள் வேறுபட்ட மையங்கள் கொண்டுள்ளன. இரண்டு பகுதிகளுக்கும் நிறைய இடையீட்டு விளைவுகள் உண்டு. உதாரணமாக வரைப்பட நிறத்திற்கான[27] கோல்-விஸ்கின் நெறிமுறைஇணையான நெறிமுறையாக முதலில் வழங்கப்பட்டாலும் பரவிய நெறிமுறையில் நேரடியாக இதன் உத்திகள் உபயோகப்படுத்தப்படுகின்றன.

இவற்றுக்கு மேலாக இணையான நெறிமுறையானது இணை அமைப்பிலும் (பரவிய நினைவகம் மூலம்) அல்லது பங்கிடப்பட்ட அமைப்பில் (தகவல் செலுத்து மூலம்) நிறைவேற்றப்படுகிறது.[28] இணையான மற்றும் பரவிய நெறிமுறைகளுக்கு இடையான எல்லையானது (வலையமைப்பை தேர்வு செய்வது vs. வலையமைப்பில் இயங்குவது) இணையான மற்றும் பரவிய அமைப்புகளின் (பங்கிடப்பட்ட நினைவகம் vs. தகவல் செலுத்துதல்) எல்லையின் ஒரே இடத்தில் இருக்காது.

சிக்கலான அளவீடுகள்

[தொகு]

மையப்படுத்தப்பட்ட நெறிமுறையானது சிறப்பாக இருக்கலாம் அதிகமான நேரமோ (கணக்கியல் முறைகளின் எண்ணிக்கை) அல்லது இடமோ (நினைவகத்தின் அளவு) தேவைப்படாத போது. சிக்கலான அளவீடுகள் P (நேரங்களின் கோர்வையில் தீர்க்கப்பட்ட பிரச்சனைகளைப்போல) மற்றும் PSPACE (இடங்களின் கோர்வையில் தீர்க்கப்பட்ட பிரச்சனைகளைப் போல) சிக்கலான பிரிவுகளை உருவாக்கும்.

இணையான நெறிமுறைகளில் நேரம் மற்றும் இடத்துடன் மற்றொரு ஆதாரமான கணினிகளின் வகைகளும் கூடுதலாக இருக்கும். கணினிகளின் எண்ணிக்கை மற்றும் இயங்கும் நேரங்கள் இடையே ஒரு தொடர்பு இருக்கும்: அதிகப்படியான கணினிகள் இணையாக இயங்கும் போது பிரச்சனையானது சுலபமாக தீர்க்கப்படும் (வேகக்கூடுதலை பார்க்கவும்) செயற்படுத்திகளின் கோர்வை எண்ணிக்கை மூலம் பலகோண நேரத்தில் முடிக்கப்பட்ட தீர்வு பிரச்சனையானது NC என்ற பகுப்பின் கீழ் சொல்லப்படும்.[29] NC பகுப்பானது PRAM நடைமுறை அல்லது பூலியன் சுற்றுகள் மூலம் சமமாக விவரிக்கப்படும். PRAM அமைப்புகளானது பூலியன் சுற்றுகளை எளிதாக ஒன்றுபடுத்தும் மற்றும் நிலை எதிர்மாறாகவும் செயல்படும்.[30]

பரவிய நெறிமுறைகளின் பகுப்பாய்வில் கணக்கீட்டு முறைகளை விட தொடர்பு நடவடிக்கைகளில் அதிகம் கவனம் செலுத்தப்படும். பரவிய கணினிச் செய்முறையின் சிறந்த மாதிரி ஒத்தியக்க அமைப்பாகும் இதில் அனைத்து முனையங்களும் மூடிய படிவத்தில் இயக்கப்படும். தொடர்பு வட்டத்தின் போது அனைத்து முனையங்களும் இணையாக மாறி அயலகத்திலிருந்து அண்மை தகவலை பெற்று, தன்னிச்சையான கணக்கீடுகளை செய்து, புதிய தகவல்களைத் தன்னுடைய அயலகத்திற்கு அனுப்புகிறது. இந்த அமைப்புகளில் மைய சிக்கல் அளவீடுகளுக்கு செயலை முடிக்க குறிப்பிட்ட எண்ணிக்கை கொண்ட ஒத்தியக்க தொடர்பு வட்டங்கள் தேவைப்படுகின்றன.[31]

இந்தச் சிக்கலான அளவீடுகள் வலையமைப்பின் விட்டத்துடன் அருகில் தொடர்புடையது. D என்பது வலையமைப்பின் விட்டம் எனில் மற்றொரு பக்கத்தில், எளிதாக ஒத்தியக்க பரவிய அமைப்புகள் மூலம் கணக்கிடப்பட்ட தீர்வுகள் தோரயமாக 2D தொடர்பு வட்டங்கள்: ஒரு பக்கத்திலிருந்து பெறப்பட்ட அனைத்து தகவல்கள் D வட்டங்கள்), தீர்வு கண்டு ஒவ்வொரு முனையத்திற்கும் D வட்டங்களில் தீர்வு கொடுக்கிறது.

மற்றொரு விதத்தில் நெறிமுறைகளின் இயக்கு நேரமானது D தொடர்பு வட்டங்களை விட குறைவானதாக இருக்கும், வலையமைப்பில் இணைக்கப்பட்டுள்ள முனையங்கள் அவைகளின் வெளியீடுகளை நெருக்கமில்லாத வலையமைப்பு பகுதிகளிலிருந்து தகவல்களை பெறாமல் வெளிவிடுகின்றன. மற்ற வார்த்தைகளில், தகவல்களைப் பொறுத்த இசைவான முடிவுகளை தனது உள்பகுதி அக்கம் பக்கத்திலிருந்து உருவாக்குகின்றன. பல பரவிய நெறிமுறைகளின் இயக்க நேரங்கள் D வட்டத்தை விட குறைவாக உள்ளது, எந்த நெறிமுறைகள் எந்த பிரச்சனைகளைத் தீர்த்தது என்பதை புரிந்து கொள்வது இந்தப் பகுதியின் மைய ஆய்வு கேள்வியாக உள்ளது.[32]

மற்ற பொதுவான உபயோகப்படும் அளவுகள் வலையமைப்பில் அனுப்பப்பட்ட துணுக்குகளின் மொத்த எண்ணிக்கையைப் பொறுத்தது (cf. தொடர்பு சிக்கல்)

மற்ற பிரச்சனைகள்

[தொகு]

பொதுவான கணக்கீட்டு சிக்கல்களைக் கண்ணோட்டத்திற்கு எடுத்துக் கொண்டால் ஒரு கேள்வி எழுகிறது, ஒரு கணினி (அல்லது பரவிய அமைப்பு) அந்த கேள்வியை ஒரு குறிப்பிட்ட நேரத்துக்கு இயக்கி, முடிவை வெளியிட்டு விட்டு நின்று விடுகிறது. எப்படி இருந்தாலும், இயந்திரம் எப்போதும் நிறுத்தாமல் வேலை செய்ய வேண்டிய கணக்குகளும் உள்ளன. இந்தச் சிக்கல்களுக்கு எடுத்துக்காட்டாக டைனிங் பிலோஸபர்ஸ் மற்றும் மியூட்சுவல் எக்ஸ்லுசன்சிக்கல்களைக் கூறலாம். இந்தச் சிக்கல்களில் பரவிய அமைப்பானது தொடர்ச்சியாக பங்கிடப்பட்ட மூலங்களுடன் ஒருங்கிணைந்து இருக்க வேண்டும் அப்போது தான் முரண்பாடுகளும் அல்லது முடக்கம் ஏற்படாமல் இருக்கும்.

பரவிய கணினி செய்முறைக்கான தனித்துவம் வாய்ந்த சில அடிப்படைச் சவால்கள் உள்ளன. பழுது பொறுத்திகளுடன் தொடர்புடைய சவால்கள் முதல் எடுத்துக்காட்டு தொடர்புடைய சிக்கல்களுக்கு கருத்தொற்றுமை சிக்கல்கள்[33], பைஜாண்டைன் பழுது பொறுதி[34] மற்றும் சுய-உறுதியாக்கல்[35] உதாரணங்களாகும்.

பல வகையான ஆய்வுகள் பரவிய அமைப்புகளின் ஒத்தியங்கா நிலையை புரிந்து கொள்ள மையப்படுத்தபட்டுள்ளது.

  • ஒத்தியக்க நெறிமுறைகளை ஒத்தியங்கா அமைப்புகளில் இயக்க சிங்ரோனைசர்ஸ் உபயோகிக்கலாம்.[36]
  • தர்க்கபூர்வ கடிகாரம் நிகழ்வுகளை வரிசைப்படுத்தும் முன்பு நடந்த காரணங்களை வழங்குகிறது.[37]
  • [38] கடிகார சிங்ரோனைசேசன் நெறிமுறைகள் உளகலாவிய முரணற்ற நேரங்களை வழங்குகின்றன.

பரவிய அமைப்புகளின் பண்புகள்

[தொகு]

கொடுக்கப்பட்ட சிக்கலைத் தீர்ப்பதற்கான பரவிய அமைப்பை வடிவமைப்பது மையமாக இருந்தது. நிறைவு உண்டாக்கும் ஆராய்ச்சி சிக்கல் என்பது பரவிய அமைப்புகளை பற்றி படிப்பதாகும் .

இடைத்தடங்கள் சிக்கல் என்பது மையமாக்கப்பட்ட கணக்கீட்டுடன் தொடர்புடைய ஒற்றுமையான உதாரணமாகும்: நாம் கணினிக்கு ஒரு செய்முறை மற்றும் பணியைக் கொடுத்து அவை இடைத்தடங்களில் இருக்க வேண்டுமா அல்லது எப்போதும் இயங்க வேண்டுமா என்று தீர்மானிக்கிறோம். பொதுவான நடத்தைகளில் இடைத்தடங்கள் சிக்கல் கணிக்க முடியாதது. கணினி வலையமைப்பின் நடத்தை புரிந்து கொள்வதை விட ஒரு கணினியின் நடத்தையை புரிந்து கொள்வது கடினமாகும்.

எனினும் சில நேர்த்தியான சிறப்பு நடத்தைகள் கணிக்ககூடியவை. வரம்புக்குட்பட்ட அமைப்பு இயந்திரங்களின் வலையமைப்பு நடத்தையை அறிந்து கொள்வதற்கான காரணங்களும் குறிப்பாக உள்ளன. ஒரு உதாரணமாக கொடுக்கப்பட்ட வலையமைப்பில் வரம்புக்குட்பட்ட அமைப்பு (ஒத்தியங்கா மற்றும் உறுதிசெய்யாத) இயந்திரங்களின் இடையீடு முடக்கம் அடையும். இந்தச் சிக்கலானது PSPACE-நிறைவடைந்தது[39], அதாவது இது கணிக்ககூடியவை, பெரிய வலையமைப்புகளின் பகுதிகளில் உள்ள சிக்கல்களைத் தீர்க்கப் பயன்படும் (மையமாக்கபட்ட, இணையான அல்லது பரவிய) நெறிமுறைகளைப் போல திறமையாக இருக்காது.

கட்டமைப்பு

[தொகு]

பல மென்பொருள் மற்றும் வன்பொருள் கட்டமைப்புகள் பரவிய கணினிச் செய்முறையில் உபயோகப்படுத்தப்படுகின்றன. குறைந்த நிலைகளில் பன்மடங்கு CPU களை ஒரு குறுகிய வலையமைப்பில் இணைப்பது தேவையானதாகும். வலையமைப்பானது சுற்று பலகையில் பதிக்கபட்டு இருந்தாலோ அல்லது நெடுமை-இணைவு கருவிகள் மற்றும் கம்பிகளுடன் உருவாக்கப்பட்டு இருந்தாலோ பொருட்படுத்தாது. ஆனால் அதிகமான நிலைகளில் அந்த CPU களில் இயங்கும் செய்முறைகளை சில தொடர்பு அமைப்புகள்மூலம் இணைப்பது தேவையானதாகும்.

பரவிய செய்முறையானது சேவைபயனர் வழங்கி, 3-அடுக்கு கட்டமைப்பு, N-அடுக்கு கட்டமைப்பு, பரவிய பொருள்கள், நெடுமை இணைவு அல்லது நெருக்க இணைவுபோன்ற அடிப்படை கட்டமைப்புகள் அல்லது பகுப்புகளில் பொதுவாக வருகின்றன.

  • சேவைப் பயனர் வழங்கி- சிறிய சேவைப் பயனர் தகவல்களைப் பெற வழங்கியுடன் இணைக்கபட்டு, பயனருக்கு தேவையான விதத்தில் தகவலை வழங்கும். சேவைப் பயனரில் உள்ளீடாக வழங்கபட்ட தகவலில் தொடர்ச்சியான மாற்றம் இருந்தால் அது வழங்கிக்கு திருப்பி அனுப்பும்.
  • 3-அடுக்கு கட்டமைப்பு- மூன்று அடுக்கு அமைப்பில் சேவைப் பயனரானது நடு அடுக்காக மாறி நிலையற்ற சேவைப் பயனரும் உபயோகிக்கும் விதத்தில் அமையும். பயனுறுத்ததை எளிமையாக்குகிறது இணைய பயனுறுத்தங்கள் பெரும்பாலும் 3-அடுக்கு கட்டமைப்பு கொண்டவை
  • N-அடுக்கு கட்டமைப்பு- N-அடுக்கு பெரும்பாலும் இணைய பயனுறுத்தங்களில் தனது தேவைகளை முயற்சி சேவைகளுக்காக அனுப்புகிறது. இந்த வகையான பயனுறுத்தங்கள் பயனுறுத்த வழங்கிகளின் வெற்றிக்கு பெரிய காரணமாக உள்ளது.
  • நெருக்க இணைவு (கொத்துக்கள்)- எந்திரங்களின் கொத்துக்கள் இணைவாக அமைக்கப்பட்டு பரவிய முறை வழிப்படுத்தலில் இயக்கப்படுவதை குறிக்கிறது. இந்த முறையானது பிரிவுகளாக பிரிக்கப்பட்டு தனித்தனியாக்கப்பட்டு மீண்டும் ஒன்றிணைக்கப்பட்டு இறுதி முடிவு எட்டப்படுகிறது.
  • சமமானவர் தொடர்பு- இந்த கட்டமைப்பில் சிறப்பு இயந்திரமோ அல்லது இயந்திரங்களோ வலையமைப்பு சாதனங்களை சமாளிக்க அல்லது சேவை வழங்க தேவையில்லை. சுமைகள் அனைத்து எந்திரங்களுக்கும் சமமாக பிரிக்கப்பட்டு சமமானவர் என்று அறியப்படுகிறது. சேவைப் பயனாளர் மற்றும் வழங்கிகளாக பியர்ஸ் இருக்கும்.
  • இடைவெளி அடிப்படை- இந்த கட்டமைப்பானது ஒற்றை முகவரி-இடைவெளியில் ஒரு தோற்ற மாயயை உருவாக்கிறது. பயனுறுத்த தேவைகளுக்காக தகவல் தெளிவாக பிரதிபலிக்கப்படுகிறது. நேரம், இடம் மற்றும் குறிப்புதவி ஆகியவற்றில் இணை பிரிப்பு அடையப்படுகிறது.

பரவிய கணினி செய்முறைகளின் மற்றொரு அடிப்படை அம்சம் என்னவென்றால் உடன்நிகழ்வு முறைவழிப்படுத்துதலில் உள்ள தொடர்பு மற்றும் ஒருங்கிணைப்பு வகைகளாகும். பலதரப்பட்ட தகவல் பரவல் நடப்பொழுங்குகள் மூலம், முறைவழிப்படுவது ஒன்றை ஒன்று நேரடியாக எஜமான்/அடிமை தொடர்பில் தொடர்பு கொள்கிறது. மைய தரவுதள கட்டமைப்பு எந்த வித நேரடி உள்-முறைவழிப்படுத்து தொடர்பு இல்லாமல் பகிர்வு தரவுதளத்தின் மூலம் பரவிய கணினி செயல்முறை பதிலீடாக செய்யப்படுகிறது.[40]

குறிப்புகள்

[தொகு]
  1. (Andrews 2000). (Dolev 2000). (Ghosh 2007), ப. 10.
  2. (Godfrey 2002).
  3. (Lynch 1996), ப. 1.
  4. (Andrews 2000), ப. 291–292. (Dolev 2000), ப. 5.
  5. (Ghosh 2007), ப. 10.
  6. (Andrews 2000), ப. 8–9, 291. (Dolev 2000), ப. 5. (Ghosh 2007), ப. 3. (Lynch 1996), ப. xix, 1. (Peleg 2000), ப. xv.
  7. (Andrews 2000), ப. 291. (Ghosh 2007), ப. 3. (Peleg 2000), ப. 4.
  8. (Ghosh 2007), ப. 3–4. (Peleg 2000), ப. 1.
  9. (Ghosh 2007), ப. 4. (Peleg 2000), ப. 2
  10. (Ghosh 2007), ப. 4, 8. (Lynch 1996), ப. 2–3. (Peleg 2000), ப. 4.
  11. (Lynch 1996), ப. 2. (Peleg 2000), ப. 1.
  12. (Ghosh 2007), ப. 7. (Lynch 1996), ப. xix, 2. (Peleg 2000), ப. 4.
  13. (Ghosh 2007), ப. 10. (Keidar 2008).
  14. Lynch, Nancy A. (1996), Distributed Algorithms, Morgan Kaufmann, பன்னாட்டுத் தரப்புத்தக எண் 978-1-55860-348-6
  15. See references in Introduction
  16. Papadimitriou (1994), Chapter 15. Keidar (2008).
  17. Bentaleb, A.; Yifan, L.; Xin, J.; et al. (2016). "Parallel and Distributed Algorithms" (PDF). National University of Singapore. Retrieved 20 July2018.
  18. (Andrews 2000), ப. 348.
  19. (Andrews 2000), ப. 32.
  20. (Peter 2004), மின்னஞ்சலின் வரலாறு.
  21. (Elmasri & Navathe 2000), பிரிவு 24.1.2.
  22. (Andrews 2000), ப. 10–11. (Ghosh 2007), ப. 4–6. (Lynch 1996), ப. xix, 1. (Peleg 2000), ப. xv. (Elmasri & Navathe 2000)(Elmasri & Navathe 2000), பிரிவு 24.
  23. (Cormen, Leiserson & Rivest 1990), பிரிவு 30.
  24. (Herlihy & Shavit 2008), அத்தியாயம் 2-6.
  25. (Lynch 1996)
  26. (Cormen, Leiserson & Rivest 1990), பிரிவுகள் 28 மற்றும் 29.
  27. (Cole & Vishkin 1986). (Cormen, Leiserson & Rivest 1990), பிரிவு 30.5.
  28. (Andrews 2000), ப. ix.
  29. (Arora & Barak 2009), பிரிவு 6.7. (Papadimitriou 1994), பிரிவு 15.3.
  30. (Papadimitriou 1994), பிரிவு 15.2.
  31. (Lynch 1996), ப. 17–23.
  32. (Peleg 2000), பிரிவுகள் 2.3 மற்றும் 7. (Linial 1992). (Naor & Stockmeyer 1995).
  33. (Lynch 1996), பிரிவுகள் 5–7. (Ghosh 2007), அத்தியாயம் 13.
  34. (Lynch 1996), ப. 99–102. (Ghosh 2007), ப. 192–193.
  35. (Dolev 2000). (Ghosh 2007), அத்தியாயம் 17.
  36. (Lynch 1996), பிரிவு 16. (Peleg 2000), பிரிவு 6.
  37. (Lynch 1996), பிரிவு 18. (Ghosh 2007), பிரிவுகள் 6.2–6.3.
  38. (Ghosh 2007), பிரிவு 6.4.
  39. (Papadimitriou 1994), பிரிவு 19.3.
  40. எ டேட்டாபேஸ்-செண்ட்ரிக் விரிட்சுவல் ஹெமிஸ்ட்ரி சிஸ்டம், ஜெ செம் இன்ஃப் மாடல் 2006 மே-ஜூன்;46(3):1034-9

குறிப்புதவிகள்

[தொகு]
புத்தகங்கள்
கட்டுரைகள்
இணையத்தளங்கள்

கூடுதல் வாசிப்பு

[தொகு]
புத்தகங்கள்
கட்டுரைகள்
  • Keidar, Idit; Rajsbaum, Sergio, eds. (2000–2009), "Distributed computing column", ACM SIGACT News, archived from the original on 2014-01-16, பார்க்கப்பட்ட நாள் 2010-03-23.

புற இணைப்புகள்

[தொகு]

[[ta:பரவிய_கணிப்பு]