الرئيسيةعريقبحث

هاسكل (لغة برمجة)


☰ جدول المحتويات


لمعانٍ أخرى، انظر هاسكل (توضيح).

هاسكل [5][6] هي لغة برمجة مطابقة للمعايير، للأغراض العامة، وهي لغة وظيفية إلى حد كبير، دون دلالات ألفاظ ملزمة وبكتابة ثابتة وقوية.[7] وقد سُميت بـ هاسكل علي اسم عالم المنطق " هاسكل كوري ". وفي اللغة هاسكل، "تمثل الوظيفة مواطن من الدرجة الأولى" من لغة البرمجة.[8] ولكونها لغة برمجة وظيفية فإن بنية التحكم الرئيسية هي الوظيفة. وترجع أصول اللغة إلى ملاحظات هاسكل كوري وأتباعه من المفكرين، بأن " الإثبات هو برنامج؛ والمعادلة التي يثبتها هي نوع للبرنامج".[9][10][11][12]

هاسكل
Haskell
شعار هاسكل


التصنيف وظيفيَّة، كسولة/غير صارمة، تركيبيَّة
التنميط سكونيّ، قويّ، استدلاليّ
ظهرت في 1990
صممها سيمون بيتن جونز، لينرت أوغستسن، ديف بارتون، برايان بوتل، وارين بورتون، جوسيف فاسل، كيفين هاموند، رالف هينز، بول هوداك، جون هيوز، توماس جونسن، مارك جونز، جون لانشبري، إريك ميجر، جون بيترسون، ألستر ريد، كولين رنسيمان، فيليب وادلر
نظام التشغيل متعدد المنصات
المطور سيمون بيتن جونز[1]
إريك ماير[1] 
رقم اخر اصدار Haskell 2010[2] (يوليو 2010
أثرت في Agda, Bluespec, كلوجر, C#, CAL, Cat, Cayenne, Clean, Curry, Epigram, Escher, F#, فاكتور (لغة برمجة) , Isabelle, Java Generics, Kaya, الاستعلام التكميلي اللغوي (لينك), ميرسي (لغة برمجة) , Omega, Perl 6, بايثون, Qi, سكالا (لغة برمجة), Timber, فيجوال بيزك دوت نت
متفرقات
امتدادات الملفات .hs وَ .lhs
موقع ويب haskell.org

تاريخ اللغة

عقب إصدار لغة البرمجة ميريندا في عام 1985 بواسطة شركة برمجيات البحوث المحدودة (Research Software Ltd، زاد الاهتمام بلغات البرمجة الوظيفية الكسولة: بحلول عام 1987 زاد عدد لغات البرمجة الوظيفية الصرفة بشكل كبير. من بين هذه اللغات كانت ميراندا الأكثر استخداماً ولكنها لم تكن خاضعة للملكية العامة. لذلك في مؤتمر اللغات البرمجية الوظيفية وعمارة الحاسوب (FPCA 87) والذي تم عقده في بورتلاند اوريجون، تم عقد اجتماع أعرب فيه المشاركون بالإجماع على ضرورة تشكيل لجنة لتعمل على تحديد معايير مفتوحة لهذه اللغات. وكانت اللجنة تهدف إلى دمج اللغات الوظيفية الموجودة في ذلك الوقت في لغة واحدة عامة لتكون أساس للأبحاث المستقبلية في تصميمات اللغات الوظيفية.[13]

هاسكل 1.0

ظهر الإصدار الأول من هاسكل ("هاسكل 1.0") في عام 1990.[14] ونتج عن مجهودات اللجنة مجموعة من التعريفات اللغوية.

هاسكل 98

في أواخر عام 1997، توجت سلسلة هاسكل بـ هاسكل98، وكان يهدف الي تحديد إصدار ثابت، وبسيط، ومحمول ومزود بمكتبة قياسية للتدريس، وليكون قاعدة للتوسعات المستقبلية. وقد رحبت اللجنة بإنشاء الإضافات والبدائل لهاسكل 98 عن طريق إضافة ودمج الخصائص التجريبية.[13]

في فبراير من عام 1999 أعلنت النسخة القياسية من لغة هاسكل 98 في أول الأمر تحت اسم " تقرير هاسكل 98 "[13]"The Haskell 98 Report. وفي يناير من عام 2003 تم إصدار نسخة مُعدلة تحت اسم " هاسكل98 لغة ومكتبات: التقرير المُعدَل""Haskell 98 Language and Libraries: The Revised Report.[15] وواصلت لغة هاسكل تطورها بشكل سريع، وذلك مع تنفيذ المترجم غلاسكو هاسكل (GHC) الذي يعتبر القياسي حاليا.

هاسكل برايم

في مطلع عام 2006 بدأت عملية إنشاء نسخة تخلُف الإصدار "هاسكل98 الأساسي" الدارج باسم "هاسكل" وأطلق على هذه النسخة اسم ("هاسكل برايم").[16] وهي تعتبر عملية متطورة ومستمرة لتعديل تعريفات اللغة وذلك لإنتاج نسخة معدلة جديدة سنوياً. وتم الإعلان عن أول نسخة مُعدلة في نوفمبر من عام 2009 وسميت بـ "هاسكل 2010".[2]

هاسكل 2010

تضيف هاسكل 2010 الواجهة البينية الوظيفية الخارجية (FFI) إلى لغة هاسكل، مما يسمح بربطها بلغات برمجة أخرى، وتثبيت بعض القواعد اللغوية (تغييرات في القواعد الشكلية)، وحظر ما يسمى بنماذج " n-plus-k"، أي تعريفات للصيغة " fak (n+1) = (n+1) * fak n " لم تعد مسموحة. ويقدم هذا الإصدار إمكانية تمديد الجمل في اللغة والتي تسمح بتعيين مصدر لهاسكل مثل هاسكل2010 أو تتطلب امتدادات محددة للغة هاسكل. وأسماء الامتدادات المقدمة في هاسكل2010 هي:[2] DoAndIfThenElse، HierarchicalModules، EmptyDataDeclarations، FixityResolution، ForeignFunctionInterface، LineCommentSyntax، PatternGuards، RelaxDependencyAnalysis، LanguagePragma، NoNPlusKPatterns

الخصائص

خصائص لغة الهاسكل هي التقييم الكسول، تطابق النماذج، قائمة الإدراك، فئات الكتابة وتعدد أشكالها. وهي لغة وظيفية صرف، والتي تعني بشكل عام، أن الوظائف في هاسكل ليس لها آثار جانبية. وهناك نوع مميز يمثل الآثار الجانبية وهو متعامد مع نوع الوظائف. حيث يمكن أن تنتج وظيفة صِرفة ما أثر جانبي يمكن أن ينفذ لاحقا، ويعد نماذج لوظائف غير صرفية للغات الأخرى.

تتمتع هاسكل بنظام كتابة ثابت وقوي يقوم على واجهة كتابة هيندلي-ميلنر. والابتكار الرئيسي للغة هاسكل في هذا النطاق هو إضافة فئات الكتابة، والتي كانت معروفة في الأساس كطريقة رئيسية لإضافة حِمل زائدة إلى اللغة،[17] ولكن وُجد لها استخدامات أخرى كثيرة فيما بعد.[18]

وتعتبر موناد مثالاً للكتابات التي لها آثار جانبية، كما تمثل كتابات موناد إطار عام يمكنه صياغة عمليات حسابية متنوعة، بما في ذلك معالجة الأخطاء، تنوع المُدخلات، التحليل اللغوي، وذاكرة عمليات البرمجيات. وتعرف كتابات موناد بأنها أنواع عادية من البيانات، بينما تقدم هاسكل بعض التبسيطات اللغوية لتسهيل استخدامها.

كما أنها لغة ذات خصائص معلنة مفتوحة[15] وتطبيقات متعددة.

ويحيط بهذه اللغة مجتمع فاعل، وأكثر من 3000 مكتبة مفتوحة المصدر وأدوات متاحة في مستودع حزمة الانترنت هاكاج Hackage.[19]

ويعتبر مترجم جلاسجو GHC هو التطبيق الرئيسي للغة هاسكل، وهو مترجم ومفسر للشفرة الأم ويعمل علي معظم المنصات. كما يتسم بأداء عالية في تنفيذ التطبيقات المتزامنة والمتوازية,[20] ويتميز كذلك بوجود نظام كتابة غني يضم الابتكارات الحديثة مثل كتابات البيانات الجبرية العامة وعائلات الكتابة Type Families.

أمثلة للأكواد

البرنامج التالي هو " هاللو ورلد " وهو مكتوب بلغة هاسكل (لاحظ أنه يمكن حذف جميع الخطوط ماعدا الخط الأخير).

module Main where main :: IO () main = putStrLn "Hello, World!"

هاهو العاملي الرياضي مشروحا بستة طرق مختلفة:

-- type factorial :: Integer -> Integer -- using recursion factorial 0 = 1 factorial n = n * factorial (n - 1) -- using lists factorial n = product [1..n] -- using recursion but written without pattern matching factorial n = if n> 0 then n * factorial (n-1) else 1 -- using fold factorial n = foldl (*) 1 [1..n] -- using only prefix notation and n+k-patterns (no longer allowed in Haskell 2010) factorial 0 = 1 factorial (n+1) = (*) (n+1) (factorial n) -- Point-free style factorial = foldr (*) 1. enumFromTo 1

وهذا تطبيق فعال لأرقام فيبوتاتشي، كقائمة لا نهائية:

-- Point-free style fib :: Int -> Integer fib = (fibs !!) where fibs = 0 : scanl (+) 1 fibs -- Explicit fib :: Int -> Integer fib n = fibs !! n where fibs = 0 : scanl (+) 1 fibs -- with a similar idea, using zipWith fib :: Int -> Integer fib n = fibs !! n where fibs = 0 : 1 : zipWith (+) fibs (tail fibs) -- Using an extra parameter fib :: Int -> Integer fib n = (fibs 0 1) !! n where fibs a b = a : fibs b (a+b)

تشير الكتابة "Int" إلى عدد صحيح (machine-sized) (تستخدم كقائمة رموز سفلية مع المُعامل !!)، بينما "عدد صحيح" هو عدد صحيح ذو دقة تامة. وعلى سبيل المثال، فالكود الموجود بالأعلي يحسب سريعا "fib10000" كعدد من 2090-رقم.

التطبيقات

تلتزم كافة التطبيقات التالية أو " معظمها تقريبا" لمعايير هاسكل 98، ويتم توزيعها برخص مصدر مفتوح. وحاليا لاتوجد ملكية لتطبيقات هاسكل.

  • المترجم جلاسجو هاسكل (GHC) يترجم الأكواد الأصلية إلى عدد ذو بنيات مختلفة – وكذلك مع لغة C وفقا للمعهد الأمريكي للمعايير الوطنية ANSI C -- مستخدما سي - - كلغة متوسطة. ويعتبر مترجم جلاسجو هاسكل هو الأكثر شيوعا في مترجمات هاسكل، وهناك قليل للغاية من المكتبات المفيدة التي تعمل فقط مع مترجم جلاسجو (مثل أوبن جي إل). ويوزع مترجم جلاسجو جنبا الي جنب مع نظام هاسكل.
  • جوفر كان عبارة عن لهجة تعليمية لهاسكل، بخاصية تسمى " فئات المشيد" والتي قام مارك جونز بتطويرها. وحل محلها هوجز (Hugs) (انظر أدناه).
  • اتش بي سي HBC هو عبارة عن مترجم آخر للكود الأصلي لهاسكل. لم يتم تطويره بفعالية لبعض الوقت ولكنه ما زال مستخدماً.
  • هيليوم هي لهجة جديدة من لهجات هاسكل. وتهدف إلى جعلها سهلة التعلم عن طريق توفير رسائل أوضح للأخطاء. وهي حالياً تفتقر إلى الدعم الكامل لأنواع الكتابة، مما يجعلها غير متوافقة مع أنواع عديدة من برامج هاسكل.
  • مترجم أوتريخت هاسكل (UHC) هو عبارة عن تطبيق لهاسكل من جامعة أوتريخت. ويدعم المترجم اوتريخت هاسكل جميع خصائص هاسكل 98 تقريباُ بالإضافة إلى دعمه للعديد من الامتدادات التجريبية. ويتم تطبيقه باستخدام قواعد خصائصية وحالياً يستخدم بصورة رئيسية للبحث في أنظمة الكتابة المُحدثة وكذلك في امتدادات اللغة.
  • مستخدم نظام جوفر بهاسكل (Hugs) هو عبارة عن مُفسر تشفير ثتائي. ويقدم هوجز ترجمة سريعة للبرامج وسرعة تنفيذ معقولة. كما يأتي هوجز مع مكتبة رسومات بسيطة. ويعتبر هوجز مناسب لمن يتعلمون أساسيات هاسكل، ولكنه ليس تطبيق "صغير" علي الإطلاق. وهو أكثر تطبيقات هاسكل محمولاً وأخفها.
  • جي اتش سي JHC هو عبارة عن مترجم هاسكل تم كتابته بواسطة جون ميتشان، ويتميز بالسرعة والكفاءة في توليد البرامج بالإضافة الي استكشاف تحويلات البرامج الجديدة. ويعد LHC تشعُب مستحدث من Jhc.
  • إن إتش سي 98 nhc عبارة عن مترجم تشفير ثنائي آخر، ولكن ثنائية التشفير تعمل بصورة أسرع بكثير من عملها مع تطبيق هوجزHugs. ويركزNhc98 علي تقليل استخدام الذاكرة، وهو اختيار جيد خاصة للأجهزة القديمة والبطيئة.
  • المترجم يورك هاسكل Yhc كان عبارة عن تشعُب من nhc98، ويهدف إلى أن يصبح أبسط، وأكثر كفاءة ومحمولاً، وتقديم دعم للتطبيق هاتHat، (مُتتبع هاسكل). كما يدعم أيضا خلفية جافاسكريبت التي تسمح للمستخدمين بتشغيل برامج هاسكل في متصفح الويب.

تطبيقات

يتزايد استخدام هاسكل في الاستخدامات التجارية.[21] قامت المُبرمجة أودري تانج بعمل تطبيق من أجل بيرل 6 المنتظر طويلا يسمى Pugsوهو عبارة عن مترجم ومفسر أثبت أهميته بعد أشهر قليلة فقط من كتابته؛ وبالمثل المترجم جلاسجو الذي دائما ما يستخدم كمُختبِر لخصائص وتحسينات البرمجة الوظيفية المتقدمة. داركس Darcs هو نظام مراجعة وتحكم تمت كتابته بلغة هاسكل، ويتميز بخصائص مبتكرة عديدة. كما اختارت لينسبير جنو/ لينكس Linspire GNU/Linux هاسكل لتطوير أدوات النظام.[22] وكذلك اكس موناد Xmonad وهو نظام مدير النوافذ لنظام النوافذ إكس، مكتوبة بلغة هاسكل بالكامل.

نظام بلوسبك فيرلوج عبارة عن لغة لتصميم شبه موصل وهي امتداد للغة هاسكل. كما ان أداوت شركة بلوسبك تم تطبيقها في لغة هاسكل. كريبتول Cryptol هي عبارة عن لغة وسلسلة من الأدوات المستخدمة لتطوير وتدقيق الأكواد الحسابية، ويتم تطبيقه في لغة هاسكل. والنوية (microkernel) أول موثق رسميا وسيل4 الذي تم تدقيقه باستخدام هاسكل.

اللغات المتعلقة بهاسكل

لغة التنظيف المتزامن "Concurrent Clean" وهي مرتبطة للغاية بلغة هاسكل. ومن أكبر انحرافاتها عن لغة هاسكل نجده في استخدامها للكتابات المتفردة بدلا من كتابات موناد من أجل I/O وكذلك الآثار الجانبية.

هناك مجموعة من اللغات التي استوحت من اللغة هاسكل، ولكن بنظم كتابة مختلفة، والتي تم تطوريها ومنها:

  • ايبجرام: هي لغة وظيفية بأنظمة كتابية مستقلة تناسب لاختبار خصائص البرامج.
  • أجدا: لغة وظيفية بأنظمة كتابية مستقلة.

كما توجد لغات اخري متعلقة بهاسكل :

  • كوري: هي لغة مبنية علي هاسكل.
  • جاسكل: هي لغة برمجة كتابة وظيفية، تعمل في جافا في إم.

واستخدمت هاسكل كاختبار للعديد من الأفكار الجديدة في تصميمات اللغة. وهناك عدد كبير من المنتجات المتنوعة لهاسكل والتي تستكشف الأفكار الجديدة للغة وتشمل:

  • هاسكل المتوازية:
    • من جامعة جلاسجو وتدعُم مجموعة من الأجهزة كما تدعم جهاز واحد بمعالجات متعددة.[23][24] كما تدعم هاسكل عمليات التشغيل المتزامنة متعددة المعالجات والمتناسقة.[25]
    • من إم أي تي MIT[26]
  • هاسكل الموزعة (جوفن سابقاً) وإدين.
  • هاسكل الطموحة، تقوم على التقييم التأمُلي.
  • العديد من الإصدارات الشيئية الموجهة مثل : هاسكل++ وموندريان.
  • هاسكل العام، إصدار من هاسكل يتميز بنظام كتابي يدعم البرامج الشاملة.
  • أو-هاسكل، امتداد لهاسكل يضيف توجيه شيئي ويدعم البرمجة المتزامنة.
  • التابع، عبارة عن قيمة فرضية دقيقة (تُتيح التكاسل من خلال التعليق) وهي من لهجات هاسكل والتي تدعم التحديث التدميري، وكذلك التأثيرات الحسابية كما تدعم كتابة عروض الحقول الموجهة والجودة الوظيفية المصاحبة.
  • سكوتش، وهو عبارة عن هجين بين هاسكل وبايسون[27]

النقد

في عامي 2002 و2003 ناقش كلاً من جان ويليام مايسن وسيمون بيتون جونز المشكلات المرتبطة بالتقييم الكسول مع إقرار الدافع النظري له،[28][29] بالإضافة إلى اعتبارات الممارسة الصرفية مثل الأداء المُحسن.[30] كما لاحظوا انه عند إضافة بعض التحسينات لرفع الأداء، فإن الكسل يزيد الأمر صعوبة علي المبرمجين لتقييم أداء أكوادهم (وخاصة استخدام مساحاتها).

في عام 2003 لاحظ كل من: باستيات هيران ودان ليين وأريان فان إيزيندورن وجود بعض العوائق أمام دارسي لغة هاسكل، فقد لوحظ أن نظام الكتابة المعقد والقواعد اللغوية الدقيقة لهاسكل هي سلاح ذو حدين، فهو محل تقدير كبير من قِبل المبرمجين ذوي الخبرة بينما هو مصدر إحباط للمبتدئين، نظرا لأن عمومية تطبيقات هاسكل تؤدي إلى رسائل خطأ مُبهمة.[31] ولمعالجة تلك المسائل، قام باحثون من جامعة اُوتريخت بتطوير مترجم متقدم يسمي هيليوم والذي يقوم بتحسين استقبال المستخدمين لرسائل الخطأ عن طريق الحد من عمومية بعض خصائص هاسكل، وبالتحديد إزالة دعمها لفئات الكتابة.

قام بِن ليبميير بتصميم التابع[32] كقيمة فرضية دقيقة (تطبيق كسول من خلال ملحقات واضحة) وهو من لهجات هاسكل التي تدعم نظام الكتابة والتأثير، وقد صُمم لمعالجة صعوبات هاسكل في التفكير بشأن التقييم الكسول وفي استخدام بنيات البيانات التقليدية مثل المصفوفات المتغيرة[33]. لقد حاول ليبميير (ص: 20) أن يبرهن علي أن "التحديث المُدمر يُزود المبرمجين بإثنتين من الأدوات الهامة والقوية... الأولى هي مجموعة بنيات البيانات الفعالة مثل المصفوفات من أجل إدارة مجموعة من الكائنات... والثانية هي إمكانية بث قيمة جديدة لجميع أجزاء برنامج ما مع أدني عبء علي المبرمج."

المؤتمرات وورش العمل

يتقابل مجتمع هاسكل بصورة منتظمة وذلك لأنشطة البحث والتطوير. والأحداث الرئيسية هي:

ومنذ عام 2006 أصبح هناك سلسلة من الإجراءات المنظمة، سلسلة Hac، والتي تهدف إلى تحسين أدوات ومكتبات لغات البرمجة وذلك مثل:

ومنذ عام 2005، تشكلت أعداد متزايدة من مجموعات مستخدمي هاسكل، في كل من الولايات المتحدة وكندا وأستراليا وأمريكا الجنوبية وأوروبا وآسيا.

المراجع

  1. A history of Haskell:being lazy with class — تاريخ الاطلاع: 3 أكتوبر 2016 — الناشر: SIGPLAN — تاريخ النشر: 2007
  2. Marlow, Simon (November 24, 2009). "Announcing Haskell 2010". Haskell (Mailing list). مؤرشف من الأصل في 13 فبراير 201512 مارس 2011.
  3. Lynagh, Ian (1 May 2013). "Haskell 2014". Haskell-prime (Mailing list). مؤرشف من الأصل في 21 مارس 201409 أكتوبر 2013.
  4. Haskell 98 Report, p. xi
  5. Chevalier, Tim (January 28, 2008). "anybody can tell me the pronuncation of "haskell"?". Haskell-cafe (Mailing list). مؤرشف من الأصل في 25 أكتوبر 201412 مارس 2011.
  6. Chevalier, Tim (January 28, 2008). "anybody can tell me the pronuncation of "haskell"?". Haskell-cafe (Mailing list). مؤرشف من الأصل في 26 يناير 201312 مارس 2011.
  7. Haskell Report
  8. Burstall, Rod (2000), "Christopher Strachey—Understanding Programming Languages", Higher-Order and Symbolic Computation, 13
  9. Curry, Haskell (1934), "Functionality in Combinatory Logic", Proceedings of the National Academy of Sciences, 20, صفحات 584–590
  10. Curry, Haskell B.; Feys, Robert (1958), Combinatory Logic Vol. I, Amsterdam: North-Holland , with 2 sections by William Craig, see paragraph 9E
  11. De Bruijn, Nicolaas (1968), "Automath, a language for mathematics", TH-report 68-WSK-05, Department of Mathematics, جامعة آيندهوفن للتكنولوجيا Reprinted in revised form, with two pages commentary, in: "Classical papers on computational logic 1967-1970", Automation and Reasoning, 2, Springer Verlag, 1983, صفحات 159–200
  12. Howard, William A. (1980) [original paper manuscript from 1969], "The formulae-as-types notion of construction", in Seldin, Jonathan P.; Hindley, J. Roger (المحررون), To H.B. Curry: Essays on Combinatory Logic, Lambda Calculus and Formalism, Boston, MA: Academic Press, صفحات 479–490,   .
  13. "Preface". Haskell 98 Language and Libraries: The Revised Report. 2002. مؤرشف من الأصل في 02 فبراير 2019.
  14. Hudak, Paul; Hughes, John; Peyton Jones, Simon; Wadler, Philip (2007). "A history of Haskell: being lazy with class". Proceedings of the third ACM SIGPLAN conference on History of programming languages (HOPL III). doi:10.1145/1238844.1238856.
  15. Simon Peyton Jones (editor) (2002). "Haskell 98 Language and Libraries: The Revised Report". مؤرشف من الأصل في 05 أبريل 2019.
  16. "Welcome to Haskell". The Haskell' Wiki. مؤرشف من الأصل في 09 أكتوبر 2012.
  17. Wadler, P.; Blott, S. (1989). "How to make ad-hoc polymorphism less ad hoc". Proceedings of the 16th ACM SIGPLAN-SIGACT Symposium on Principles of Programming Languages. رابطة مكائن الحوسبة: 60–76. doi:10.1145/75277.75283.
  18. Hallgren, T. (January 2001). "Fun with Functional Dependencies, or Types as Values in Static Computations in Haskell". Proceedings of the Joint CS/CE Winter Meeting. Varberg, Sweden. مؤرشف من الأصل في 29 مارس 2010.
  19. "HackageDB statistics". مؤرشف من الأصل في 3 مايو 2013.
  20. Computer Language Benchmarks Game - تصفح: نسخة محفوظة 01 ديسمبر 2012 على موقع واي باك مشين.
  21. See Industrial Haskell Group for collaborative development, Commercial Users of Functional Programming for specific projects and Haskell in industry for a list of companies using Haskell commercially نسخة محفوظة 08 أبريل 2017 على موقع واي باك مشين.
  22. "Linspire/Freespire Core OS Team and Haskell". Debian Haskell mailing list. 2006. مؤرشف من الأصل في 27 ديسمبر 2017.
  23. Glasgow Parallel Haskell - تصفح: نسخة محفوظة 04 يونيو 2017 على موقع واي باك مشين.
  24. GHC Language Features: Parallel Haskell - تصفح: نسخة محفوظة 07 أكتوبر 2014 على موقع واي باك مشين.
  25. Using GHC: Using SML parallelism - تصفح: نسخة محفوظة 07 أكتوبر 2014 على موقع واي باك مشين.
  26. MIT Parallel Haskell - تصفح: نسخة محفوظة 24 يونيو 2017 على موقع واي باك مشين.
  27. Scotch - تصفح: نسخة محفوظة 25 مارس 2016 على موقع واي باك مشين.
  28. Jan-Willem Maessen. Eager Haskell: Resource-bounded execution yields efficient iteration. Proceedings of the 2002 رابطة مكائن الحوسبة SIGPLAN workshop on Haskell.
  29. Simon Peyton Jones. Wearing the hair shirt: a retrospective on Haskell. Invited talk at POPL 2003. نسخة محفوظة 27 أكتوبر 2008 على موقع واي باك مشين.
  30. Lazy evaluation can lead to excellent performance, such as in The Computer Language Benchmarks Game [1] - تصفح: نسخة محفوظة 13 فبراير 2015 على موقع واي باك مشين.
  31. Heeren, Bastiaan; Leijen, Daan; van IJzendoorn, Arjan (2003). "Helium, for learning Haskell" ( كتاب إلكتروني PDF ). Proceedings of the 2003 رابطة مكائن الحوسبة SIGPLAN workshop on Haskell. مؤرشف من الأصل ( كتاب إلكتروني PDF ) في 4 فبراير 2007.
  32. DDC - HaskellWiki - تصفح: نسخة محفوظة 02 يناير 2015 على موقع واي باك مشين.
  33. Ben Lippmeier, Type Inference and Optimisation for an Impure World, الجامعة الوطنية الأسترالية (2010) PhD thesis, chapter 1 نسخة محفوظة 25 مايو 2013 على موقع واي باك مشين.

لمزيد من القراءة

وصلات خارجية

Tutorials

موسوعات ذات صلة :