ക്വാണ്ടം അൽഗോരിതം
സാധാരണ കമ്പ്യൂട്ടർ വെച്ചു നിർധാരണം ചെയ്യാനാകാത്ത പ്രശ്നങ്ങൾ (Undecidable Problems) ക്വാണ്ടം കമ്പ്യൂട്ടർ വെച്ചും നിർധാരണം ചെയ്യാനാകില്ല.[4]:127 എന്നാൽ സാധാരണ കമ്പ്യൂട്ടറിൽ പതിയെ മാത്രം നിർധാരണം ചെയ്യാൻ കഴിയുന്ന ചില പ്രശ്നങ്ങൾ (സമയ സങ്കീർണ്ണത (time complexity) കൂടിയ പ്രശ്നങ്ങൾ ആണ് ഇവിടെ ഉദ്ദേശിയ്ക്കുന്നത്, കൂടുതൽ ശേഷി കൂടിയ പ്രൊസസ്സറുകൾ അല്ല ക്വാണ്ടം കംപ്യൂട്ടറുകൾ) ക്വാണ്ടം അൽഗോരിതങ്ങൾ ഉപയോഗിച്ച് വേഗത്തിൽ നിർധാരണം ചെയാൻ സാധിയ്ക്കും. ഭാജ്യസംഖ്യകളെ ഘടകക്രിയ ചെയ്യാനുള്ള ഷോറിന്റെ അൽഗോരിതം, അനുക്രമമല്ലാത്ത ഒരു ലിസ്റ്റിലോ ഡാറ്റാബേസിലോ ഡാറ്റാ തിരയാനുള്ള ഗ്രോവർ'സ് അൽഗോരിതം തുടങ്ങിയവയാണ് പ്രശസ്തമായ ക്വാണ്ടം അൽഗോരിതങ്ങൾ. ഘടകക്രിയ ചെയ്യാൻ സാധാരണ കമ്പ്യൂട്ടറിൽ ലഭ്യമായ ഏറ്റവും വേഗതയേറിയ ജനറൽ നമ്പർ ഫീൽഡ് സീവ് എന്ന അൽഗോരിതത്തെക്കാൾ അനേകമടങ്ങ് (exponential increase) ഭേദമാണ് ഷോറിന്റെ അൽഗോരിതത്തിന്റെ സമയ സങ്കീർണ്ണത. അതുപോലെ ഏറ്റവും മികച്ച തിരച്ചിൽ അൽഗോരിതത്തെന്റെ സമയ സങ്കീർണ്ണതയുടെ (അനുക്രമമല്ലാത്ത ലിസ്റ്റിലെ തിരച്ചിൽ) ഒരു വർഗമൂലം മാത്രമാണ് ഗ്രോവർ'സ് അൽഗോരിതത്തിന്റെ സമയ സങ്കീർണ്ണത. അവലോകനംസാധാരണയായി ക്വാണ്ടം കമ്പ്യൂട്ടിങ്ങിന്റെ സർക്യൂട്ട് മാതൃകയിലാണ് ക്വാണ്ടം അൽഗോരിതങ്ങൾ വിവരിയ്ക്കപ്പെടുന്നത്. ഈ മാതൃകയിൽ ഒരു ക്വാണ്ടം സർക്യൂട്ട് ഒരു കൂട്ടം ക്യൂബിറ്റുകളിൽ പ്രവർത്തിയ്ക്കുകയും അവയുടെ വിലകൾ മാറ്റിക്കൊണ്ടിരിയ്ക്കുകയും ചെയ്യുന്നു. ഇതിന്റ അവസാനം ഒരു ക്വാണ്ടം അളക്കൽ നടത്തുകയും ഒരു സാധാരണ സംഖ്യ ഉത്തരമായി പുറത്തെടുക്കുകയും ചെയ്യുന്നു. ക്വാണ്ടം സർക്യൂട്ട് എന്നത് ഒരു കൂട്ടം ക്വാണ്ടം ഗേറ്റുകളുടെ സമാഹാരമാണ്. ഒരു അൽഗോരിതത്തിൽ ഉപയോഗിയ്ക്കുന്ന പ്രധാന ക്വാണ്ടം കമ്പ്യൂട്ടിങ് സങ്കേതത്തെ അടിസ്ഥാനപ്പെടുത്തിയാണ് ഇവയെ തരം തിരിയ്ക്കുന്നത്. ഫേസ് കിക്ക് ബാക്, ക്വാണ്ടം ഫ്യൂറിയേ ട്രാൻസ്ഫോം, ക്വാണ്ടം വോക്സ്, ആംപ്ലിറ്റ്യൂട് ആംപ്ലിഫിക്കേഷൻ തുടങ്ങിയവയാണ് ഇത്തരം സങ്കേതങ്ങൾ. ക്വാണ്ടം ഫ്യൂറിയേ ട്രാൻസ്ഫോമിനെ അടിസ്ഥാനപെടുത്തിയ അൽഗോരിതങ്ങൾഡിസ്ക്രീറ്റ് ഫ്യൂറിയേ ട്രാൻസ്ഫോമിന്റെ ക്വാണ്ടം പതിപ്പാണ് ക്വാണ്ടം ഫ്യൂറിയേ ട്രാൻസ്ഫോം. പല ക്വാണ്ടം അൽഗോരിതങ്ങളിലും ഇത് ഉപയോഗിയ്ക്കുന്നുണ്ട്. നിർധാരണം ചെയ്യേണ്ട പ്രശ്നത്തിന്റെ ഇന്പുട് വിലകളുടെ എണ്ണം ആണെങ്കിൽ പരമാവധി ക്വാണ്ടം ഗേറ്റുകൾ മാത്രം ഉപയോഗിച്ച് ക്വാണ്ടം ഫ്യൂറിയേ ട്രാൻസ്ഫോം നടത്താനുള്ള ഒരു ക്വാണ്ടം സർക്യൂട്ട് ഉണ്ടാക്കിയെടുക്കാവുന്നതാണ്. പൊതുവെ ഇത്തരം അൽഗോരിതങ്ങളിൽ തന്നിരിയ്ക്കുന്ന പ്രശ്നത്തിന്റെ സെറ്റ് അപ്പിനെ ആദ്യം ഒരു തരംഗമായി മോഡൽ ചെയ്യുന്നു. അതിനുശേഷം തന്നിരിയ്ക്കുന്ന പ്രശ്നത്തെ ഈ തരംഗത്തിന്റെ തരംഗദൈർഘ്യം കണ്ടെത്തുന്ന ഒരു പ്രശ്നമായി രൂപാന്തരണം നടത്തുന്നു. അതിനു ശേഷം ക്വാണ്ടം ഫ്യൂറിയേ ട്രാൻസ്ഫോം ഉപയോഗിച്ച് തരംഗദൈർഘ്യം കണ്ടുപിടിയ്ക്കുന്നു.[5] ഡോയ്ഷ്-ജോസ അൽഗോരിതം (Deutsch–Jozsa algorithm)ഇത് പ്രത്യേകിച്ച് ഉപകാരം ഒന്നും ഇല്ലാത്ത, എന്നാൽ ക്വാണ്ടം കമ്പ്യൂട്ടിങ്ങിന്റെ പ്രത്യേകതകൾ എടുത്തു കാണിയ്ക്കാനായി ഡേവിഡ് ഡോയ്ഷും റിച്ചാർഡ് ജോസയും 1992 ൽ മുന്നോട്ടു വെച്ച ഒരു അൽഗോരിതം ആണ്. ഇവിടെ ഒരു പ്രത്യേക ഫങ്ക്ഷൻ ഉണ്ട്. ഇത് ഒന്നുകിൽ അതിലേയ്ക്ക് പാസ് ചെയ്യുന്ന ഏതു ബിറ്റ് കോമ്പിനേഷനും ഒരേ ഔട്ട്പുട്ട് (ഒന്നുകിൽ എല്ലാ കോമ്പിനേഷനും ഔട്ട്പുട്ട് ആയി 0; അല്ലെങ്കിൽ എല്ലാ കോമ്പിനേഷനും 1) തരും അല്ലെങ്കിൽ പകുതി ഇൻപുട്ടുകൾക്ക് ഉത്തരം 0 വും ബാക്കി പകുതി ഇൻപുട്ടുകൾക്ക് ഉത്തരം 1 ഉം തരും. നമുക്ക് കണ്ടു പിടിയ്ക്കേണ്ടത് ഈ ഫങ്ക്ഷൻ ആദ്യത്തേത് പോലെ ആണോ അതോ രണ്ടാമത്തേത് പോലെ ആണോ പ്രവർത്തിയ്ക്കുന്നത് എന്നാണ്. സാധാരണ ഒരു കമ്പ്യൂട്ടറിൽ ഇത് തീരുമാനിയ്ക്കാനായി പകുതി എണ്ണം ഇന്പുട് എങ്കിലും കൊടുത്തു നോക്കണമല്ലോ. അതായത് ബിറ്റുകൾ ഉള്ള ഒരു കോമ്പിനേഷൻ ആണ് ഇന്പുട് എങ്കിൽ ആണ് ഇതിന്റ സമയ സങ്കീർണ്ണത. എന്നാൽ ഒറ്റ ഇന്പുട് മാത്രം കൊടുത്തു ഉത്തരം കണ്ടു പിടിയ്ക്കാവുന്ന ഒരു ക്വാണ്ടം അൽഗോരിതം ഇതിനു വേണ്ടി ഡിസൈൻ ചെയ്യാൻ സാധിയ്ക്കും. സൈമണിന്റെ അൽഗോരിതം(Simon's algorithm)ഇതും മുകളിൽ പറഞ്ഞ അൽഗോരിതം പോലെ തന്നെ പ്രായോഗിക ഉപകാരങ്ങൾ ഒന്നുമില്ലാത്ത, എന്നാൽ ക്വാണ്ടം കമ്പ്യൂട്ടിങ്ങിന്റെ ശക്തി എടുത്തു കാണിയ്ക്കാനുള്ള മറ്റൊരു ക്വാണ്ടം അൽഗോരിതം ആണ്. ഷോറിന്റെ അൽഗോരിതത്തിന് ഒരു പ്രേരണ ഈ അൽഗോരിതമാണ്. ഷോറിന്റെ അൽഗോരിതം(Shor's algorithm)ഇത് വളരെ പ്രായോഗിക ഉപകാരങ്ങളുള്ള വളരെ പ്രധാനപ്പെട്ട ഒരു ക്വാണ്ടം അൽഗോരിതം ആണ്. ഭാജ്യസംഖ്യകളെ ഘടകക്രിയ ചെയ്യുക എന്നുള്ളതാണ് ഇതിന്റെ കർത്തവ്യം. പോളിനോമിയൽ സമയ സങ്കീർണ്ണതയിൽ ഘടകക്രിയ ചെയ്യാം എന്നുള്ളതാണ് ഇതിന്റെ നേട്ടം. ഏറ്റവും മികച്ച സമയ സങ്കീർണ്ണതയുള്ള സാധാരണ കംപ്യൂട്ടറിലെ അൽഗോരിതം പോലും ഇതിനു വേണ്ടി എക്സ്പോണെൻഷ്യൽ സമയം എടുക്കും.[6] ഹിഡൻ സബ്ഗ്രൂപ് പ്രോബ്ലം (Hidden Subgroup Problem), ബോസോൺ സാംപ്ലിങ് പ്രോബ്ലം (Boson Sampling Problem), ഗൗസ് സം എസ്റ്റിമേഷൻസ് (Gauss Sum Estimations), ഫ്യൂറിയേ ഫിഷിങ്, ഫ്യൂറിയേ ചെക്കിങ് തുടങ്ങിയവയും ക്വാണ്ടം ഫ്യൂറിയേ ട്രാൻസ്ഫോമിനെ അടിസ്ഥാനപെടുത്തിയ മറ്റു അൽഗോരിതങ്ങൾ ആണ്.[7] ആംപ്ലിറ്റ്യൂട് ആംപ്ലിഫിക്കേഷൻ അടിസ്ഥാനമായുള്ള അൽഗോരിതങ്ങൾഒരു ക്വാണ്ടം അവസ്ഥയുടെ ഹിൽബെർട് സ്പേസ് ഡിസൈൻ ചെയ്ത ശേഷം അതിന്റെ ഒരു 'നല്ല' ഉപ സ്പേസ് (subspace) കണ്ടെത്തിയ ശേഷം അതിന്റെ ആംപ്ലിറ്റ്യൂട് വർധിപ്പിച്ചാണ് ഇത്തരം അൽഗോരിതങ്ങൾ പ്രവർത്തിയ്ക്കുന്നത്. സാദാ അൽഗോരിതങ്ങളുടെ ഒരു വർഗമൂലം അധ്വാനം മാത്രമാണ് ഇത്തരം അൽഗോരിതങ്ങൾ എടുക്കുക. ഗ്രോവേഴ്സ് അൽഗോരിതം (Grover's Algorithm) ആണ് ഇത്തരം അൽഗോരിതങ്ങളിൽ ഏറ്റവും പ്രശസ്തം. അനുക്രമമല്ലാത്ത ഒരു ലിസ്റ്റിലെയോ ഡാറ്റാബേസിലെയോ ഒരു അംഗത്തെ തെരയാനുള്ള അൽഗോരിതമാണ് ഇത്. അംഗങ്ങളുള്ള ഇത്തരം ഒരു ലിസ്റ്റിൽ തിരയാൻ സാദാ അൽഗോരിതങ്ങൾ വെച്ച് സ്റ്റെപ്പുകൾ (വരികൾ) വേണം. എന്നാൽ ഗ്രോവേഴ്സ് അൽഗോരിതം ഉപയോഗിച്ച് സ്റ്റെപ്പുകളിൽ ഇത് തെരഞ്ഞു കണ്ടു പിടിയ്ക്കാം.[8] ക്വാണ്ടം വോക്കുകളെ അടിസ്ഥാനപ്പെടുത്തിയ അൽഗോരിതങ്ങൾസാധാരണ കമ്പ്യൂട്ടറിൽ ചെയ്യുന്ന റാൻഡം വോക് എന്ന ടൈപ്പ് അൽഗോരിതങ്ങളുടെ ക്വാണ്ടം പതിപ്പാണ് ഇവ. ഒരു സെറ്റ് അവസ്ഥകളിൽ ഒരു പ്രത്യേക സംഭാവ്യതാ വിതരണത്തെ (probability distribution) അടിസ്ഥാനപ്പെടുത്തി ഒന്നിൽ നിന്നും മറ്റൊന്നിലേക്ക് നീങ്ങുന്ന പ്രക്രിയയെ സിമുലേറ്റ് ചെയ്യുന്നതാണ് റാൻഡം വോക് അൽഗോരിതങ്ങൾ ചെയ്യുന്നത്. ക്വാണ്ടം വോക് അൽഗോരിതങ്ങൾ ഇത്തരം അവസ്ഥകളുടെ വിശിഷ്ടസ്ഥിതിയെ ചൂഷണം ചെയ്താണ് കൂടുതൽ വേഗത കൈവരിയ്ക്കുന്നത്.[9][10] എലമെന്റ് ഡിസ്റ്റിംക്ട്നെസ്സ് (Element Distinctness), ട്രയാങ്കിൾ ഫൈൻഡിങ് പ്രോബ്ലം (Triangle-finding Problem), ഫോർമുല ഇവാലുവേഷൻ (Formula Evaluation), ഗ്രൂപ്പ് കമ്മ്യൂറ്റേറ്റിവിറ്റി (group commutativity) തുടങ്ങിയവ ഈ ഗണത്തിൽ പെടുന്ന അൽഗോരിതങ്ങളാണ്. ഇവ കൂടി കാണുക
അവലംബം
|
Portal di Ensiklopedia Dunia