അറേ പ്രോഗ്രാമിംഗ്കമ്പ്യൂട്ടർ സയൻസിൽ, അറേ പ്രോഗ്രാമിംഗ് എന്നത് ഒരു സമയത്ത് ഒരു മൂല്യത്തിന് പകരം മുഴുവൻ മൂല്യങ്ങളിലേക്കും ഒരേസമയം പ്രവർത്തനങ്ങൾ പ്രയോഗിക്കുന്ന ഒരു രീതിയാണ്. വലിയ അളവിലുള്ള ഡാറ്റ കാര്യക്ഷമമായി പ്രോസസ്സ് ചെയ്യേണ്ട സയൻസ്, എഞ്ചിനീയറിംഗ് തുടങ്ങിയ മേഖലകളിൽ ഈ സമീപനം പ്രത്യേകിച്ചും ഉപയോഗപ്രദമാണ്[1]. അറേ പ്രോഗ്രാമിംഗിനെ പിന്തുണയ്ക്കുന്ന ആധുനിക പ്രോഗ്രാമിംഗ് ഭാഷകൾ രൂപകൽപ്പന ചെയ്തിരിക്കുന്നത് ഒരേ ഓപ്പറേഷൻ ഒന്നിലധികം ഡാറ്റ പോയിൻ്റുകളിലേക്ക് ഒരേസമയം പ്രയോഗിക്കുന്നത് എളുപ്പമാക്കുന്നതിനാണ്. വ്യക്തിഗത സംഖ്യകൾ (സ്കെയിലറുകൾ) കൈകാര്യം ചെയ്യുന്നതിനുപകരം, ലിസ്റ്റുകൾ (വെക്ടറുകൾ), ടേബിളുകൾ (മാട്രിക്സ്) അല്ലെങ്കിൽ കൂടുതൽ സങ്കീർണ്ണമായ ഘടനകൾ പോലുള്ള വലിയ സെറ്റുകളിൽ തടസ്സമില്ലാത്ത രീതിയിൽ പ്രവർത്തിക്കാൻ അവയ്ക്ക് കഴിയും. ഇത് വലിയ ഡാറ്റാസെറ്റുകളിൽ കണക്കുകൂട്ടലുകൾ നടത്തുന്നത് കൂടുതൽ കാര്യക്ഷമമാക്കുന്നു. എപിഎൽ, ജെ(J), ഫോർട്രാൻ, മാറ്റ് ലാബ്, അനലിറ്റിക്ക(Analytica), ഒക്ടേവ്, ആർ (R), സിൽക്ക് പ്ലസ്(Cilk Plus), ജൂലിയ, പേൾ ഡാറ്റ ലാംഗ്വേജ് (PDL) എന്നിവ അറേ പ്രോഗ്രാമിംഗിനെ പിന്തുണയ്ക്കുന്ന ഭാഷകളിൽ ഉൾപ്പെടുന്നു. ഈ ഭാഷകൾ രൂപകൽപ്പന ചെയ്തിരിക്കുന്നത് വലിയ കൂട്ടം ഡാറ്റകളിൽ ഒരേസമയം പ്രവർത്തനങ്ങൾ കാര്യക്ഷമമായി കൈകാര്യം ചെയ്യുന്നതിനാണ്. വെക്ടറൈസ്ഡ് ഓപ്പറേഷനുകൾ, ഗണിതശാസ്ത്രം, താരതമ്യപ്പെടുത്തൽ, ലോജിക്കൽ ഓപ്പറേഷനുകൾ, ഗണിതശാസ്ത്ര പ്രവർത്തനങ്ങൾ എന്നിവ പോലുള്ള ജോലികൾക്കായി നംപൈ(NumPy), പാൻഡാസ്(Pandas), മാറ്റ് ലാബ്, ആർ, ജൂലിയ തുടങ്ങിയ ഭാഷകളിൽ ലഭ്യമായ മാനുവൽ ലൂപ്പിംഗ് ഇല്ലാതാക്കുകയും സങ്കീർണ്ണമായ ഡാറ്റ മാനിപ്പുലേഷൻ ലളിതമാക്കുകയും ചെയ്യുന്ന കാര്യക്ഷമമായ പ്രക്രിയകളാണ്[2]. സ്പ്രെഡ്ഷീറ്റുകൾക്കായി ഒരു മാജിക് ബട്ടൺ ഉള്ളത് പോലെയാണ് അറേ പ്രോഗ്രാമിംഗ്, എല്ലാ നമ്പറുകളിലേക്കും 10 ചേർക്കുക, ഉയർന്ന മൂല്യം കണ്ടെത്തുക അല്ലെങ്കിൽ ഡാറ്റ അടുക്കുക എന്നിങ്ങനെയുള്ള സങ്കീർണ്ണമായ ജോലികൾ തൽക്ഷണം ചെയ്യാൻ അനുവദിക്കുന്നു. ഇത് ഡാറ്റാ ജോലി ലളിതമാക്കുകയും കോഡിംഗ് സമയം കുറയ്ക്കുകയും ചെയ്യുന്നു. അറേ എന്ന ആശയംഅറേ പ്രോഗ്രാമിംഗിൽ, ഓരോ ഡാറ്റയും ഓരോന്നായി കൈകാര്യം ചെയ്യാൻ നീണ്ട കോഡ് എഴുതുന്നതിനുപകരം, ഒരു കമാൻഡ് ഉപയോഗിച്ച് നിങ്ങൾക്ക് മുഴുവൻ ഡാറ്റാ ഗ്രൂപ്പുകളിലും (അറേകൾ പോലെ) പ്രവർത്തനങ്ങൾ നടത്താൻ കഴിയും. ഇത് മൂലം കോഡ് ചെറുതാക്കാൻ സാധിക്കുന്നു, മനസ്സിലാക്കാൻ എളുപ്പമാക്കുന്നു, കോഡ് എഴുതുന്നത് വേഗത്തിലാക്കുന്നു. കെന്നത്ത് ഇ. ഐവർസൺ അറേ പ്രോഗ്രാമിംഗിനെക്കുറിച്ച് (എപിഎല്ലിലെ പോലെ) വിവരിച്ചത് മുഴുവൻ ഡാറ്റാ ഗ്രൂപ്പുകളിലും ഒരേസമയം പ്രവർത്തനങ്ങൾ നടത്തുന്നതിനുള്ള ഒരു മാർഗമായിത്തീർന്നു. ഇനിപ്പറയുന്ന രീതിയിൽ അദ്ദേഹം അതേക്കുറിച്ച് അദ്ദേഹത്തിന്റെ വാക്കുകളിലൂടെ മനസ്സിലാക്കാം:[3].
ഡാറ്റാ ഘടകങ്ങൾ ഒരുപോലെയോ പരസ്പരം അടുത്തോ ഉള്ള പാറ്റേണുകൾ തിരിച്ചറിയുകയും കാര്യക്ഷമമായ പ്രോസസ്സിംഗിനായി ആ പ്രോപ്പർട്ടികൾ ഉപയോഗിക്കുകയും ചെയ്യുന്നതാണ് അറേ പ്രോഗ്രാമിംഗ്. ഒബ്ജക്റ്റ് ഓറിയൻ്റഡ് പ്രോഗ്രാമിംഗിൽ നിന്ന് വ്യത്യസ്തമായി, ഡാറ്റയെ ചെറിയ കഷണങ്ങളായി വിഭജിക്കുന്നു, അറേ പ്രോഗ്രാമിംഗ് ഡാറ്റയെ ഒരുമിച്ച് ഗ്രൂപ്പുചെയ്യുകയും ഒരേ പ്രവർത്തനം എല്ലാ ഘടകങ്ങളിലും ഒരേസമയം പ്രയോഗിക്കുകയും ഡാറ്റ മാനിപ്പുലേഷൻ ലളിതമാക്കുകയും ചെയ്യുന്നു. ഫംഗ്ഷൻ റാങ്ക് ഒരു ഫംഗ്ഷൻ എത്ര അളവുകൾ ഉപയോഗിച്ച് പ്രവർത്തിക്കുന്നു എന്ന് വിവരിക്കുന്നു. രണ്ട് ഒറ്റ സംഖ്യകളെ ഗുണിച്ചാൽ, അത് റാങ്ക് 0 ആണ്, കാരണം ഒരു അളവും ഉൾപ്പെട്ടിട്ടില്ല. വെക്ടറുകൾ (സംഖ്യകളുടെ വരികൾ) ഉപയോഗിച്ച് ഒരു ക്രോസ് പ്രൊഡക്റ്റ് ചെയ്താൽ, നിങ്ങൾ 1ഡി ഒബ്ജക്റ്റുകൾക്കൊപ്പം പ്രവർത്തിക്കുന്നതിനാൽ അത് റാങ്ക് 1 ആണ്. മെട്രിക്സ് ഗുണനത്തിന് റാങ്ക് 2 ആണ്, കാരണം ഇത് സംഖ്യകളുടെ പട്ടികകൾ പോലെയുള്ള 2ഡി ഒബ്ജക്റ്റുകളിൽ പ്രവർത്തിക്കുന്നു. ഒരു ടേബിളിൽ എല്ലാം ചേർക്കുന്നത് പോലെയുള്ള ചില ഫംഗ്ഷനുകൾ, അതിൻ്റെ വലുപ്പം ഒരു ഡൈമെൻഷൻ കൊണ്ട് കുറയ്ക്കുന്നു-2ഡി ഒറ്റ സംഖ്യയാക്കി മാറ്റുന്നു. ഫംഗ്ഷൻ റാങ്കിൻ്റെ യഥാർത്ഥ ഉദാഹരണം ഇമേജ് പ്രോസസ്സിംഗിൽ കാണാൻ കഴിയും. ഒരു ഗ്രേസ്കെയിൽ ഇമേജ് പിക്സൽ മൂല്യങ്ങളുടെ 2ഡി മെട്രിക്സാണ് (അതിനെ ഒരു അക്കങ്ങളുടെ പട്ടിക പോലെ കരുതുക). ഇമേജ് റൊട്ടേറ്റ് ചെയ്യുന്നതുപോലുള്ള റാങ്ക് 2 ഫംഗ്ഷൻ പ്രയോഗിക്കാൻ നിങ്ങൾ ആഗ്രഹിക്കുന്നുവെങ്കിൽ, പ്രവർത്തനം മുഴുവൻ 2ഡി അറേയിലും ഒരേസമയം പ്രവർത്തിക്കും. ഇപ്പോൾ, നിങ്ങൾക്ക് ചിത്രത്തിൻ്റെ ശരാശരി തെളിച്ചം ലഭിക്കണമെങ്കിൽ, എല്ലാ പിക്സൽ മൂല്യങ്ങളും സംഗ്രഹിച്ച് അവയുടെ ശരാശരി കണക്കാക്കി ഒരൊറ്റ മൂല്യത്തിലേക്ക് കൊളാപ്സ് ചെയ്യും, ഇത് ഒരു റാങ്ക് 1 പ്രവർത്തനമാണ്. ഉപയോഗങ്ങൾമുഴുവൻ ഡാറ്റാ സെറ്റുകളിലും ഒരേസമയം പ്രവർത്തനങ്ങൾ അനുവദിക്കുന്ന അറേ പ്രോഗ്രാമിംഗ്, ഇമ്പ്ലിസിറ്റ് പാരലൈസേഷന് അനുയോജ്യമാണ്. ഇതിനർത്ഥം, പല കണക്കുകൂട്ടലുകളും സമാന്തരമായി നടത്താം, പ്രോസസ്സിംഗ് വേഗത്തിലാക്കുന്നു, ഇന്ന് വ്യാപകമായി ഗവേഷണം നടക്കുന്ന ഒരു വിഷയം ഇതാണ്. കൂടാതെ, 1997 മുതൽ ഇൻ്റലും മറ്റ് സിപിയുകളും(ഉദാ:എഎംഡി പ്രോസസ്സറുകൾ, വിഐഎ പ്രോസസ്സറുകൾ, ട്രാൻസ്മെറ്റ പ്രോസസ്സറുകൾ) എംഎംഎക്സ്(MMX), ട്രിപ്പിൾഎസ്ഇ3(SSSE3), ത്രിഡിനൗ(3DNow) തുടങ്ങിയ ഇൻസ്ട്രക്ഷൻ സെറ്റുകൾ അവതരിപ്പിച്ചു! അത് സിമ്ഡി(SIMD-സിംഗിൾ ഇൻസ്ട്രക്ഷൻ മൾട്ടിപ്പിൾ ഡാറ്റ) പ്രവർത്തനങ്ങളെ പിന്തുണയ്ക്കുന്നു. ഈ നിർദ്ദേശങ്ങൾ സിപിയുവിനുള്ളിൽ നേരിട്ട് അടിസ്ഥാന അറേ പ്രോസസ്സിംഗ് പ്രാപ്തമാക്കുന്നു, ഒന്നിലധികം ഡാറ്റ പോയിൻ്റുകൾ സമാന്തരമായി പ്രോസസ്സ് ചെയ്തുകൊണ്ട് പ്രകടനം മെച്ചപ്പെടുത്തുന്നു, ഇത് ഗ്രാഫിക്സ്, സയൻ്റിഫിക് കംപ്യൂട്ടേഷനുകൾ പോലുള്ള ജോലികളിൽ പ്രത്യേകിച്ചും ഉപയോഗപ്രദമാണ്. ആധുനിക സിപിയു-കൾ (സെൻട്രൽ പ്രോസസ്സിംഗ് യൂണിറ്റ്സ്) എവിഎക്സ്-512 പോലെയുള്ള പ്രത്യേക നിർദ്ദേശങ്ങൾ ഉപയോഗിച്ച് കൂടുതൽ വികസിച്ചുകൊണ്ടിരിക്കുന്നു, അത് അവയെ ഒന്നിലധികം ഡാറ്റ പോയിൻ്റുകൾ ഒരേസമയം കൈകാര്യം ചെയ്യാൻ സഹായിക്കുന്നു (അറേ പ്രോസസ്സിംഗ്). ഇതിനർത്ഥം സിപിയുവിന് ഒറ്റയടിക്ക് ഒരു കൂട്ടം ഇനങ്ങളിൽ ഒരുമിച്ച് പ്രവർത്തിക്കാൻ കഴിയും എന്നാണ്, ഇത് ചില ജോലികൾ വേഗത്തിലാക്കുന്നു. അറേ പ്രോസസ്സിംഗ് പാരലൽ പ്രോസസ്സിംഗിൽ നിന്ന് വ്യത്യസ്തമാണ്, ഒരു പ്രോസസ്സർ ഒരേസമയം നിരവധി കാര്യങ്ങൾ ചെയ്യുന്നതിനുപകരം, ഒന്നിലധികം പ്രോസസ്സറുകൾ ഓരോന്നും പ്രശ്നത്തിൻ്റെ ഒരു ചെറിയ ഭാഗം(MIMD) കൈകാര്യം ചെയ്യുകയും അത് പരിഹരിക്കാൻ ഒരുമിച്ച് പ്രവർത്തിക്കുകയും ചെയ്യുന്നു. അവലംബം
|
Portal di Ensiklopedia Dunia