ഒപ്റ്റിമൈസിംഗ് കംപൈലർ
പ്രോഗ്രാം എക്സിക്യൂഷൻ |
---|
പൊതുവായ ആശയങ്ങൾ |
|
ടൈപ്പ്സ് ഓഫ് കോഡ് |
കംപലേഷൻ സ്ട്രാറ്റെജീസ് |
|
ശ്രദ്ധേയമായ റൺടൈമുകൾ |
|
ശ്രദ്ധേയമായ കംപൈലറുകളും ടൂൾചെയിനുകളും |
|
ഒപ്റ്റിമൈസിംഗ് കംപൈലർ എന്നത് പ്രോഗ്രാമിന്റെ പ്രവർത്തനവും കാര്യക്ഷമതയും മെച്ചപ്പെടുത്താൻ രൂപകൽപ്പന ചെയ്ത ഒരു പ്രത്യേകതയുള്ള കംപൈലറാണ്. പ്രോഗ്രാമിന്റെ പ്രവർത്തന സമയം കുറയ്ക്കുക, മെമ്മറി ഉപയോഗം കുറയ്ക്കുക, സ്റ്റോറേജ് വലുപ്പം ചുരുക്കുക, പവർ ഉപഭോഗം കുറയ്ക്കുക മുതലായ ലക്ഷ്യങ്ങൾക്കായാണ് അനുയോജ്യമായ കോഡ് നിർമ്മിക്കുന്നതിന് രൂപകൽപ്പന ചെയ്തിരിക്കുന്നത്[1]. ഒപ്റ്റിമൈസേഷൻ എന്നത് കോഡിന്റെ അടിസ്ഥാന അർത്ഥത്തിൽ ഒരു മാറ്റവും വരുത്താതെ, അത് കൂടുതൽ വേഗത്തിൽ പ്രവർത്തിക്കാൻ, മെമ്മറി കുറച്ച് ഉപയോഗിക്കാൻ, കുറഞ്ഞ സ്ഥലം വേണ്ടതായി മാറ്റാൻ, അല്ലെങ്കിൽ മറ്റ് കാര്യക്ഷമത ലക്ഷ്യങ്ങൾ പൂർത്തിയാക്കാൻ സഹായിക്കുന്ന പ്രക്രിയയാണ്. ഇത് സാങ്കേതികമായി ഒപ്റ്റിമൈസിംഗ് ട്രാൻസ്ഫോർമേഷനുകൾ പടിപടിയായി നടപ്പാക്കപ്പെടുന്നു. ഓരോ ട്രാൻസ്ഫോർമേഷനും കോഡ് മാറ്റി അതിന്റെ പ്രവർത്തനം മെച്ചപ്പെടുത്തുമ്പോഴും, അർത്ഥപരമായ സമാനത (semantic equivalence) നിലനിർത്തുകയാണ് പ്രധാനമായ ലക്ഷ്യം. ഉദാഹരണത്തിന്, ഒരു പണി ചെയ്യാൻ കൂടുതൽ വേഗത്തിലും എളുപ്പത്തിലും എത്തിച്ചേരാൻ മികച്ച പാത കണ്ടെത്തുന്നതുപോലെയാണ് കോഡ് ഒപ്റ്റിമൈസ് ചെയ്യുന്നത്. ഇതോടെ കോഡിംഗിന് ചെലവാകുന്ന സമയം കുറയും, പക്ഷേ ഫലത്തിൽ മാറ്റമൊന്നും ഉണ്ടാവില്ല.
പ്രായോഗികമായി, ലഭ്യമായ മെമ്മറി എത്രയാണ്, പ്രോഗ്രാമർ കോഡ് മാറ്റാൻ എത്ര സമയം കാത്തിരിക്കുമെന്നതുപോലുള്ള കാര്യങ്ങൾ ഉൾപ്പെടെ, കംപൈലർ നൽകുന്ന മെച്ചപ്പെടുത്തലുകൾക്ക് ഒരു പരിധി വെക്കുന്നു. കംപൈലറിന് ചില ഒപ്റ്റിമൈസേഷൻ പ്രശ്നങ്ങളുണ്ടെന്ന് ഗവേഷണങ്ങൾ സൂചിപ്പിക്കുന്നു, ഉദാഹരണത്തിന് എൻപി-കമ്പ്ലീറ്റ്(NP-complete) എന്നത് ഒപ്റ്റിമൈസേഷൻ പ്രശ്നങ്ങൾ അത്ര എളുപ്പത്തിൽ പരിഹരിക്കാനാവാത്തതാണ്. നിർണയിക്കാൻ കഴിയാത്തത് (Undecidable) എന്നാൽ, ഒരു പ്രശ്നത്തിന് ഒരു നിശ്ചിത പരിഹാരമില്ലെന്ന് അർത്ഥം. ആ പ്രശ്നം എത്ര ശ്രമം നടത്തി നോക്കിയാലും, അതിന്റെ ഉത്തരം കണ്ടെത്താൻ സാധിക്കില്ല.[2]. ഒപ്റ്റിമൈസേഷൻ സാധാരണയായി ഒരു പ്രശ്നത്തിന് മികച്ച പരിഹാരം കണ്ടെത്താനായി ശ്രമിക്കുമ്പോഴും, എല്ലാ കാര്യങ്ങളും ഒരുമിച്ച് പരിഹരിക്കാൻ സാധിക്കില്ല. ഉദാഹരണത്തിന്, ഒരു പ്രോഗ്രാമിന്റെ വേഗത വർധിപ്പിക്കാൻ ശ്രമിക്കുമ്പോൾ, ഇത് കൂടുതൽ മെമ്മറി ഉപയോഗിക്കേണ്ടി വരാം. അതിനാൽ, ഓപ്റ്റിമൈസേഷൻ എന്നത് ഒരു പ്രശ്നത്തിൽ സാധ്യമായത്ര മികച്ച ഫലം കണ്ടെത്താൻ ശ്രമിക്കുന്ന രീതി മാത്രമാണ്. എന്നാൽ ഇത് എല്ലാ വിഷയങ്ങളിലും ഒരേ സമയം പരമാവധി ഫലപ്രാപ്തി നേടുമെന്ന് പ്രതീക്ഷിക്കരുത്. ഒരു കാര്യം മെച്ചപ്പെടുത്തുമ്പോൾ, മറ്റൊരു കാര്യം കുറയാനുള്ള സാധ്യത ഉണ്ടാവാം, എന്നാൽ ഇത് എല്ലായ്പ്പോഴും ഏറ്റവും മികച്ച ഫലമാകണമെന്നില്ല. എന്തായാലും, സാധാരണ ഉപയോഗത്തിലുള്ള പ്രോഗ്രാമുകൾക്കായി വേഗതയോ മെമ്മറിയോ കുറക്കുന്നതുപോലുള്ള കാര്യങ്ങളിൽ മെച്ചപ്പെടുത്തൽ നേടാൻ ഇത് സഹായിക്കും[3].
വർഗ്ഗീകരണം
[തിരുത്തുക]ലോക്കൽ vs. ഗ്ലോബൽ സ്കോപ്പ്
[തിരുത്തുക]ഒപ്റ്റിമൈസേഷൻ ചെയ്യുമ്പോൾ കോഡിന്റെ എത്ര ഭാഗം പരിഗണിക്കണമെന്നത് സ്കോപ്പ്(scope) ആണ് വ്യക്തമാക്കുന്നത്. ചിലപ്പോൾ ഒരു ചെറിയ ഭാഗം മാത്രം (ഉദാ. ഒരു ഫങ്ഷൻ), അല്ലെങ്കിൽ പ്രോഗ്രാമിന്റെ മുഴുവൻ ഭാഗം വരെ ഉൾപ്പെടാം. ലോക്കൽ സ്കോപ്പ് ഒപ്റ്റിമൈസേഷൻസ്, ബേസിക് ബ്ലോക്കിനുള്ളിലെ വിവരങ്ങൾ ഉപയോഗിച്ച് അനാവശ്യമായ ഓപ്പറേഷനുകൾ നീക്കം ചെയ്യുകയും, കാൽക്കുലേഷനുകൾ കംപൈൽ-ടൈമിൽ തന്നെ നടത്തുകയും ചെയ്യുന്നു. ഇതിന്റെ ഉദാഹരണങ്ങൾ ഡെഡ് കോഡ് എലിമിനേഷൻ, കൺസ്റ്റന്റ് ഫോൾഡിംഗ്, കോമൺ സബ്എക്സ്പ്രഷൻ എലിമിനേഷൻ എന്നിവയാണ്[4].
ബേസിക് ബ്ലോക്കുകളിൽ കൺട്രോൾ ഫ്ലോ(Control flow-പ്രോഗ്രാമിലെ കോഡ് എങ്ങനെ പ്രവർത്തിക്കണമെന്ന് നിർണ്ണയിക്കുന്ന പ്രക്രിയയാണ്. ഇത് if, for, while പോലുള്ള ഉപയോഗിച്ച് ഡിസിഷൻസ്, ലൂപ്പുകൾ, അല്ലെങ്കിൽ ഫംഗ്ഷൻ കോളുകൾ വഴി നിയന്ത്രിക്കപ്പെടുന്നു. കോഡിന്റെ എക്സിക്യൂഷൻ ഓർഡറിംഗ്, കണ്ടീഷണൽസ്(conditionals), ജമ്പുകൾ എന്നിവ കൺട്രോൾ ഫ്ലോയുടെ ഭാഗമാണ്.) ഇല്ലാത്തതിനാൽ, ഒപ്റ്റിമൈസേഷൻ ചെയ്യാൻ സാധിക്കുന്നത് എളുപ്പമാണ്, കാരണം കുറച്ചുകൂടി മികച്ച വിശകലനം ആവശ്യമാണ്. ഇതുകൊണ്ട് പ്രോഗ്രാമിന്റെ സമയം, സ്റ്റോറേജ് (Storage) മുതലയാവ കുറയുന്നു. എങ്കിലും, ജമ്പുകൾ (jumps) ഉള്ളിടത്ത്, ഒരു ബ്ലോക്കിൽ നിന്ന് മറ്റൊന്നിലേക്ക് ഡാറ്റ മാറ്റാൻ കഴിയില്ല, കാരണം ഓരോ ബ്ലോക്കും സ്വതന്ത്രമായി പ്രവർത്തിക്കുന്നു.
ഗ്ലോബൽ സ്കോപ്പ് ഓപ്റ്റിമൈസേഷനുകൾ (ഇൻട്രാ പ്രോസീജ്യുറൽ ഓപ്റ്റിമൈസേഷൻസ് എന്നും അറിയപ്പെടുന്നു) ഓരോ ഫംഗ്ഷനിലും പ്രവർത്തിക്കുന്നു. ഇത് കോഡ് കൂടുതൽ വേഗത്തിൽ പ്രവർത്തിക്കാൻ സഹായിക്കുന്നു. ഓരോ ഫംഗ്ഷനിലെയും അനാവശ്യ ഭാഗങ്ങൾ നീക്കം ചെയ്ത് കാര്യങ്ങൾ എളുപ്പമാക്കുന്നു. സിസ്റ്റം, പ്രോഗ്രാം, അല്ലെങ്കിൽ ആപ്ലിക്കേഷന്റെ പ്രവർത്തനക്ഷമത വർദ്ധിപ്പിക്കാൻ കൂടുതൽ വിവരങ്ങൾ ഉപയോഗപ്പെടുത്തുന്നു, എന്നാൽ പലപ്പോഴും വലിയ കണക്കുകൾ നടത്തേണ്ടതുണ്ടാകാം. ഫംഗ്ഷൻ കോൾ ചെയ്യുമ്പോൾ അല്ലെങ്കിൽ ഗ്ലോബൽ വേരിയബിളുകൾ ആക്സസ് ചെയ്യുമ്പോൾ, അവയെക്കുറിച്ചുള്ള കൂടുതൽ വിവരങ്ങൾ ഇല്ലാത്തതിനാൽ ഏറ്റവും മോശമായ സാഹചര്യങ്ങളെ അടിസ്ഥാനമാക്കി തീരുമാനങ്ങൾ എടുക്കേണ്ടി വരും.
പീപ്ഹോൾ ഒപ്റ്റിമൈസേഷൻ
[തിരുത്തുക]പീപ്ഹോൾ ഓപ്റ്റിമൈസേഷൻ വഴി ഒരു കോഡിന്റെ ചെറിയ ഭാഗങ്ങൾ (വാതിലുകളിലുള്ള ചെറിയ ദ്വാരത്തിലൂടെ നോക്കുന്നതുപോലെ) പരിശോധിച്ച് കുറച്ച് ഇൻസ്ട്രക്ഷനുകൾ എളുപ്പത്തിൽ മാറ്റാനാകും. ഇത് സാധാരണ മെഷീൻ കോഡ് തയ്യാറാക്കിയതിന് ശേഷം സാധാരണയായി ചെയ്യപ്പെടുന്നു. ഇതിലൂടെ കോഡിന്റെ ദൈർഘ്യം കുറയ്ക്കാനും കാര്യക്ഷമത വർധിപ്പിക്കാനും കഴിയും. ഒരു സംഖ്യയെ രണ്ട് കൊണ്ട് ഗുണിക്കുന്നതിന് പല എളുപ്പവഴികൾ ഉണ്ട്. ഉദാഹരണത്തിന്, സാധാരണ ഗുണനക്രിയ ചെയ്യുന്നതിന് പകരം, സംഖ്യയുടെ ബൈനറിയിൽ ഒരു സ്ഥാനം മാറ്റി ഇടത്തോട്ട് ഷിഫ്റ്റ് ചെയ്യാം, ഇത് രണ്ട് കൊണ്ട് ഗുണിക്കുന്നതിന് തുല്ല്യമാണ്[3](p554). ഉദാഹരണത്തിന്, 5 എന്ന സംഖ്യയെ 2 കൊണ്ട് ഗുണിക്കാൻ, നമ്മൾ സാധാരണ ഗുണനക്രിയ ഇങ്ങനെ നടത്തും: 5 × 2 = 10 പക്ഷേ, 5-ന്റെ ബൈനറി രൂപം 101 ആണ്. ഇത് ഇടത്തോട്ട് ഒരു സ്ഥാനമെങ്കിലും മാറ്റിയാൽ, അത് 1010 ആകും, ഇതിന്റെ ദശാംശം 10 ആണ് ഇത് 5 × 2 എന്ന സാധാരണ ഗുണനക്രിയയ്ക്കുപകരമായ ഒരു പ്രക്രിയയാണ്, എന്നാൽ ഇടത്തോട്ട് ഷിഫ്റ്റ് ചെയ്യുന്നത് സാധാരണ ഗുണനത്തേക്കാൾ വേഗത്തിൽ ഈ പ്രക്രിയ പൂർത്തിയാക്കുന്നു.
ഇൻ്റർ പ്രൊസീജറൽ ഒപ്റ്റിമൈസേഷൻ
[തിരുത്തുക]ഇൻ്റർ പ്രൊസീജറൽ ഒപ്റ്റിമൈസേഷൻ ഒരു പ്രോഗ്രാമിന്റെ എല്ലാ സോഴ്സ് കോഡും വിശകലനം ചെയ്യുന്നു. കൂടുതൽ വിവരങ്ങൾ ലഭ്യമാകുന്നുവെങ്കിൽ, ഒപ്റ്റിമൈസേഷന്റെ കാര്യക്ഷമത വർധിപ്പിക്കാൻ സാധിക്കും. ഈ വിവരങ്ങൾ വിവിധ ഒപ്റ്റിമൈസേഷനുകൾക്ക് ഉപയോഗിക്കാം, ഉദാഹരണത്തിന് ഫംഗ്ഷൻ ഇൻലൈനിംഗ് ഒരു പ്രക്രിയയാണ്, അതിൽ ഫംഗ്ഷൻ കോൾ കൂടാതെ, ഫംഗ്ഷന്റെ കോഡ് നേരിട്ട് പ്രോഗ്രാമിൽ ചേർക്കപ്പെടുന്നു. ഇതിലൂടെ ഫംഗ്ഷൻ കോൾ ഒഴിവാക്കുകയും, പ്രോഗ്രാമിന്റെ പ്രവർത്തനം കൂടുതൽ വേഗം നടക്കുകയും ചെയ്യുന്നു.
ലിങ്ക്-ടൈം ഒപ്റ്റിമൈസേഷൻ
[തിരുത്തുക]ലിങ്ക്-ടൈം ഒപ്റ്റിമൈസേഷൻ (LTO) പ്രോഗ്രാമുകൾ എങ്ങനെ കാര്യക്ഷമമായി പ്രവർത്തിക്കാമെന്നത് ഉറപ്പാക്കാനുള്ള ഒരു ടെക്നിക്കാണ്. സാധാരണയായി, ഒരു പ്രോഗ്രാം പല ഭാഗങ്ങളായി വേർതിരിച്ചെഴുതുന്നു(translation units). എൽടിഒ ഉപയോഗിച്ച് കമ്പൈലർ അവയെ ഒരുമിച്ച് പരിശോധിക്കാം, ഒരുപാട് കാര്യങ്ങൾ കൂട്ടിച്ചേർത്ത് (inlining), അനാവശ്യ ഭാഗങ്ങൾ ഒഴിവാക്കി, പ്രോഗ്രാം കൂടുതൽ ഫാസ്റ്റ് ആക്കാം. ഇതിലൂടെ പ്രോഗ്രാം ശരിയായി പ്രവർത്തിക്കുമ്പോഴും, അതിന്റെ പ്രകടനം മെച്ചപ്പെടുന്നു.
മെഷീൻ ഒബ്ജക്റ്റ് കോഡ് ഒപ്റ്റിമൈസേഷൻ
[തിരുത്തുക]മെഷീൻ കോഡ് ഒപ്റ്റിമൈസേഷൻ എന്നത് പ്രോഗ്രാമിന്റെ അവസാന ഘട്ടത്തിൽ, അതിന്റെ പ്രവർത്തനം കൂടുതൽ കാര്യക്ഷമമാക്കാനുള്ള ഒരു നടപടിയാണ്. പ്രോഗ്രാം ലിങ്ക് ചെയ്ത ശേഷം, ഒബ്ജക്റ്റ് കോഡ് ഒപ്റ്റിമൈസർ ഉപയോഗിച്ച് പ്രോഗ്രാമിന്റെ മുഴുവൻ കോഡ് പരിശോധിക്കാം. അനാവശ്യ ഭാഗങ്ങൾ നീക്കംചെയ്യുക, ആവർത്തിക്കുന്ന കോഡുകൾ ഒന്നാക്കി ചുരുക്കുക എന്നിവ ചെയ്യുന്നതിലൂടെ പ്രോഗ്രാം കുറച്ച് സ്ഥലം (memory) മാത്രം ഉപയോഗിച്ച്, കോഡിനെ വേഗത്തിലാക്കാൻ സാധിക്കുന്നു. ഇതു കൊണ്ട് പ്രോഗ്രാമുകൾ മെച്ചപ്പെട്ട രീതിയിൽ പ്രവർത്തിക്കും[5].
അവലംബം
[തിരുത്തുക]- ↑ Godbolt, Matt (November 12, 2019). "Optimizations in C++ Compilers". ACM Queue. Vol. 17, no. 5.
- ↑ "Lecture 15: NP-completeness, Optimization and Separation" (PDF). IE 511: Integer Programming, Spring 2021.
- ↑ 3.0 3.1 Aho, Alfred V.; Sethi, Ravi; Ullman, Jeffrey D. (1986). Compilers: Principles, Techniques, and Tools. Reading, Massachusetts: Addison-Wesley. ISBN 0-201-10088-6.
- ↑ Cooper, Keith D.; Torczon, Linda (2003) [2002-01-01]. Engineering a Compiler. Morgan Kaufmann. pp. 404, 407. ISBN 978-1-55860-698-2.
- ↑ Goss, Clinton F. (August 2013) [First published June 1986]. Machine Code Optimization – Improving Executable Object Code (PDF) (Ph.D. dissertation). Vol. Computer Science Department Technical Report #246. Courant Institute, New York University. arXiv:1308.4815. Bibcode:2013arXiv1308.4815G. Archived (PDF) from the original on 2022-10-09. Retrieved 22 Aug 2013.
- Clinton F. Goss (2013) [1986]. Machine Code Optimization - Improving Executable Object Code (PhD thesis). Courant Institute, New York University.