ലിസ്പ്

പ്രോഗ്രാമിങ് ഭാഷ From Wikipedia, the free encyclopedia

ലിസ്പ്
Remove ads

നീണ്ട ചരിത്രമുള്ളതും മറ്റു പ്രോഗ്രാമിങ് ഭാഷകളിൽ നിന്ന് വ്യത്യസ്തമായ ലേഖനവ്യവസ്ഥയോടുകൂടിയതുമായ പ്രോഗ്രാമിങ് ഭാഷാവിഭാഗമാണ്‌ ലിസ്പ് (LISP).പൂർണ്ണമായും പരാൻതൈസ് ചെയ്ത പ്രിഫിക്‌സ് നൊട്ടേഷനാനുള്ളത്.[1] 1958-ലാണ്‌ ഇത് പുറത്തിറങ്ങിയത്. 'ലിസ്റ്റ് പ്രൊസസ്സിങ് ലാംഗ്വേജ്' (LISt Processing language) എന്നതിൽ നിന്നാണ്‌ പേരിന്റെ ഉൽഭവം. ഇന്ന് വ്യാപകമായ ഉപയോഗത്തിലുള്ള രണ്ടാമത്തെ ഏറ്റവും പഴയ ഹൈ-ലെവൽ പ്രോഗ്രാമിംഗ് ഭാഷയാണ് ലിസ്പ്. ഫോർട്രാൻ മാത്രമേ ഇതിലും പഴക്കമുള്ളത്, ഒരു വർഷം മാത്രം.[2][3] ഫോർട്രാനെ പോലെ തന്നെ ലിസ്പിനും തുടക്കത്തിൽ നിന്ന് ഒരുപാട് മാറ്റങ്ങൾ സംഭവിച്ചിട്ടുണ്ട്. ഇന്ന് നിലവിലുള്ള ലിസ്പിന്റെ പ്രചാരത്തിലുള്ള വകഭേദങ്ങളിൽ പ്രധാനപ്പെട്ടവ റാക്കറ്റ്(Racket), കോമൺ ലിസ്പും (Common Lisp) സ്കീം (Scheme) ക്ലോജുറും(Clojure) ആണ്‌.

വസ്തുതകൾ ശൈലി:, പുറത്തുവന്ന വർഷം: ...

അലോൺസോ ചർച്ചിന്റെ ലാംഡ കാൽകുലസിനെ അടിസ്ഥാനമാക്കി കമ്പ്യൂട്ടർ പ്രോഗ്രാമുകളിൽ ഗണിതസമവാക്യങ്ങൾ രേഖപ്പെടുത്തുന്നതിനുള്ള മാർഗ്ഗമായിട്ടായിരുന്നു ആദ്യം ലിസ്പ് രൂപംകൊണ്ടത്. പിന്നീട് പെട്ടെന്ന് തന്നെ കമ്പ്യൂട്ടറുകളിൽ കൃത്രിമബുദ്ധി പ്രായോഗികമാക്കാനുള്ള ഗവേഷണങ്ങൾക്കുള്ള പ്രോഗ്രാമിങ് ഭാഷ എന്ന നിലയിൽ പ്രചാരത്തിലാവുകയും ചെയ്തു. കമ്പ്യൂട്ടർ ശാസ്ത്രത്തിൽ പല തത്ത്വങ്ങളും ലിസ്പ് സംഭാവന ചെയ്തിട്ടുണ്ട്. ട്രീ ഡാറ്റാ സ്ട്രക്ച്ചർ, ഓട്ടോമാറ്റിക്ക് സ്റ്റോറേജ് മാനേജ്മെന്റ്, ഡൈനാമിക്ക് ടൈപ്പിങ്,കണ്ടീഷണൽസ്,ഹൈ ഓർഡർ ഫംഗ്ഷനുകൾ,റിക്കർഷൻസ്, സെൽഫ് ഹോസ്റ്റിങ് കം‌പൈലർ,റീഡ്-ഇവാൾ-പ്രിന്റ് ലൂപ്പ് എന്നിവ അവയിൽ ചിലതാണ്‌.[4]

"ലിസ്പ് പ്രോസസ്സർ" എന്നതിൽ നിന്നാണ് ലിസ്പ് എന്ന പേര് ഉരുത്തിരിഞ്ഞത്. [5] ലിസ്പിന്റെ പ്രധാന ഡാറ്റാ ഘടനകളിലൊന്നാണ് ലിങ്ക്ഡ് ലിസ്റ്റുകൾ, കൂടാതെ ലിസ്പ് സോഴ്സ് കോഡ് ലിസ്റ്റുകൾ കൊണ്ട് നിർമ്മിച്ചതാണ്. അതിനാൽ, ലിസ്പ് പ്രോഗ്രാമുകൾക്ക് സോഴ്സ് കോഡിനെ ഒരു ഡാറ്റാ സ്ട്രക്ചറായി കൈകാര്യം ചെയ്യാൻ കഴിയും, ഇത് പുതിയ സിന്റാക്സ് അല്ലെങ്കിൽ ലിസ്പിൽ ഉൾച്ചേർത്ത(embedded)പുതിയ ഡൊമെയ്ൻ നിർദ്ദിഷ്ട ഭാഷകൾ സൃഷ്ടിക്കാൻ പ്രോഗ്രാമർമാരെ അനുവദിക്കുന്ന മാക്രോ സിസ്റ്റങ്ങൾ ഉണ്ടാകുന്നു.

കോഡിന്റെയും ഡാറ്റയുടെയും പരസ്പര കൈമാറ്റം ലിസ്പിന് തൽക്ഷണം തിരിച്ചറിയാൻ കഴിയുന്ന വാക്യഘടന നൽകുന്നു. എല്ലാ പ്രോഗ്രാം കോഡുകളും എസ്-എക്സ്പ്രഷനുകൾ അല്ലെങ്കിൽ പരാൻതൈസ്ഡ് ലിസ്റ്റുകളായി എഴുതിയിരിക്കുന്നു. ഒരു ഫംഗ്ഷൻ കോൾ അല്ലെങ്കിൽ വാക്യഘടന ഫോം ആദ്യം ഫംഗ്ഷന്റെയോ ഓപ്പറേറ്ററുടെയോ പേരോടുകൂടിയ ഒരു ലിസ്റ്റായി എഴുതുന്നു, കൂടാതെ ഇനിപ്പറയുന്ന ആർഗ്യുമെന്റുകൾ; ഉദാഹരണത്തിന്, മൂന്ന് ആർഗ്യുമെന്റുകൾ എടുക്കുന്ന ഒരു ഫംഗ്ഷനെ (f arg1 arg2 arg3)എന്ന് വിളിക്കും.

Remove ads

ചരിത്രം

Thumb
Thumb
ജോൺ മക്കാർത്തിയും (മുകളിൽ), സ്റ്റീവ് റസ്സലും

ജോൺ മക്കാർത്തി 1958 ൽ മസാച്ചുസെറ്റ്സ് ഇൻസ്റ്റിറ്റ്യൂട്ട് ഓഫ് ടെക്നോളജിയിൽ (എംഐടി) പഠിക്കുമ്പോൾ ലിസ്പ് വികസിപ്പിച്ചു. 1960 ൽ കമ്മ്യൂണിക്കേഷൻസ് ഓഫ് എസി‌എമ്മിൽ ഒരു പ്രബന്ധത്തിൽ മക്കാർത്തി അതിന്റെ പേപ്പർ പ്രസിദ്ധീകരിച്ചു, "സിംബോളിക് എക്സ്പ്രഷനുകളുടെ ആവർത്തന പ്രവർത്തനങ്ങൾ, മെഷീൻ, ഭാഗം I ഉം അവയുടെ കണക്കുകൂട്ടലും"[6]കുറച്ച് ലളിതമായ ഓപ്പറേറ്റഴസും ചർച്ചിൽ(Church) നിന്ന് കടമെടുത്ത അനോണിമസ് ഫങ്ഷനായിട്ടുള്ള ഒരു നൊട്ടേഷനും ഉപയോഗിച്ച് ഒരാൾക്ക് അൽഗോരിതംസിനായി ട്യൂറിംഗ്-കംപ്ലീറ്റ് ഭാഷ നിർമ്മിക്കാൻ കഴിയുമെന്ന് അദ്ദേഹം കാണിച്ചു.

ഇൻഫർമേഷൻ പ്രോസസ്സിംഗ് ലാംഗ്വേജ് 1955 മുതൽ 1956 വരെയുള്ള ആദ്യത്തെ എഐ ഭാഷയായിരുന്നു, കൂടാതെ ലിസ്റ്റ്-പ്രോസസ്സിംഗ്, റിക്കർഷൻ എന്നിവ പോലുള്ള നിരവധി ആശയങ്ങൾ ഇതിനകം ഉൾപ്പെടുത്തിയിട്ടുണ്ട്, അവ ലിസ്പിൽ ഉപയോഗിച്ചു.

മക്കാർത്തിയുടെ യഥാർത്ഥ നൊട്ടേഷൻ ബ്രാക്കറ്റുചെയ്‌ത "എം-എക്‌സ്‌പ്രഷനുകൾ" ഉപയോഗിച്ചു, അത് എസ്-എക്‌സ്‌പ്രഷനുകളിലേക്ക് വിവർത്തനം ചെയ്യും. ഒരു ഉദാഹരണമായി, എം-എക്സ്പ്രഷൻ car[cons[A,B]]എസ്-എക്സ്പ്രഷന് തുല്യമാണ്(car (cons A B))ലിസ്പ് നടപ്പിലാക്കാൻ വേണ്ടി പ്രോഗ്രാമർമാർ അതിവേഗം എസ്-എക്സ്പ്രഷനുകൾ ഉപയോഗിക്കുകയും, എം-എക്സ്പ്രഷനുകൾ ഉപേക്ഷിക്കുകയും ചെയ്തു. എം-എക്സ്പ്രഷനുകൾ വീണ്ടും പ്രത്യക്ഷപ്പെട്ടു, ഹോറസ് എനിയ സി‌ജി‌ഒ‌എല്ലിനു(CGOL)വേണ്ടിയും വോൺ‌ പ്രാറ്റ് എം‌ലിസ്പിന്(MLisp)വേണ്ടിയും ഹ്രസ്വകാല ശ്രമങ്ങൾ നടത്തി [7]

പഞ്ച് കാർഡുകൾ ഉപയോഗിച്ച് ഐബിഎം 704 കമ്പ്യൂട്ടറിൽ സ്റ്റീവ് റസ്സൽ ആണ് ലിസ്പ് ആദ്യമായി നടപ്പിലാക്കിയത്. [8] റസ്സൽ മക്കാർത്തിയുടെ പ്രബന്ധം വായിക്കുകയും (മക്കാർത്തിയുടെ സർപ്രൈസ്) ലിസ്പ് ഇവാൾ ഫംഗ്ഷൻ മെഷീൻ കോഡിൽ നടപ്പിലാക്കാമെന്ന് മനസ്സിലാക്കി. [9] ലിസ്പ് പ്രോഗ്രാമുകൾ പ്രവർത്തിപ്പിക്കുന്നതിനോ അല്ലെങ്കിൽ കൂടുതൽ ശരിയായി "ലിസ്പ് എക്സ്പ്രഷനുകൾ വിലയിരുത്തുന്നതിനോ" ഉപയോഗിക്കാവുന്ന ഒരു വർക്കിംഗ് ലിസ്പ് ഇന്റർപ്രെറ്ററായിരുന്നു അതിന്റെ റിസൾട്ട്.

Remove ads

അവലംബം

Loading related searches...

Wikiwand - on

Seamless Wikipedia browsing. On steroids.

Remove ads