अमृत - पुस्तकालय
Elixir Erlang पुस्तकालयों के साथ उत्कृष्ट अंतर प्रदान करता है। आइए संक्षिप्त में कुछ पुस्तकालयों पर चर्चा करते हैं।
बाइनरी मॉड्यूल
बिल्ट-इन एलिक्जिर स्ट्रिंग मॉड्यूल, उन बैटरियों को संभालता है जो UTF-8 एनकोडेड हैं। बाइनरी मॉड्यूल उपयोगी है जब आप द्विआधारी डेटा के साथ काम कर रहे हैं जो जरूरी नहीं है कि यूटीएफ -8 एन्कोडेड हो। आइए हम बाइनरी मॉड्यूल को समझने के लिए एक उदाहरण पर विचार करें -
# UTF-8
IO.puts(String.to_char_list("Ø"))
# binary
IO.puts(:binary.bin_to_list "Ø")
जब उपरोक्त कार्यक्रम चलाया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
[216]
[195, 152]
उपरोक्त उदाहरण अंतर दिखाता है; स्ट्रिंग मॉड्यूल UTF-8 कोडपॉइंट्स लौटाता है, जबकि: कच्चे डेटा बाइट्स के साथ द्विआधारी सौदे।
क्रिप्टो मॉड्यूल
क्रिप्टो मॉड्यूल में हैशिंग फ़ंक्शन, डिजिटल हस्ताक्षर, एन्क्रिप्शन और बहुत कुछ शामिल हैं। यह मॉड्यूल Erlang मानक लाइब्रेरी का हिस्सा नहीं है, लेकिन Erlang वितरण के साथ शामिल है। इसका मतलब है कि आपको अपने प्रोजेक्ट की एप्लिकेशन सूची में क्रिप्टो करना होगा जब भी आप इसका उपयोग करते हैं। क्रिप्टो मॉड्यूल का उपयोग करते हुए एक उदाहरण देखते हैं -
IO.puts(Base.encode16(:crypto.hash(:sha256, "Elixir")))
जब उपरोक्त कार्यक्रम चलाया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
3315715A7A3AD57428298676C5AE465DADA38D951BDFAC9348A8A31E9C7401CB
डिग्राफ मॉड्यूल
डिग्राफ मॉड्यूल में वर्टिकल और किनारों से निर्मित निर्देशित ग्राफ से निपटने के लिए कार्य शामिल हैं। ग्राफ़ का निर्माण करने के बाद, वहाँ के एल्गोरिदम को खोजने में मदद मिलेगी, उदाहरण के लिए, दो कोने के बीच सबसे छोटा रास्ता, या ग्राफ़ में छोरों। ध्यान दें कि फ़ंक्शनin :digraph अतिरिक्त संरचना को साइड इफेक्ट के रूप में बदल देते हैं, जबकि जोड़े गए कोने या किनारों को वापस करते हैं।
digraph = :digraph.new()
coords = [{0.0, 0.0}, {1.0, 0.0}, {1.0, 1.0}]
[v0, v1, v2] = (for c <- coords, do: :digraph.add_vertex(digraph, c))
:digraph.add_edge(digraph, v0, v1)
:digraph.add_edge(digraph, v1, v2)
for point <- :digraph.get_short_path(digraph, v0, v2) do
{x, y} = point
IO.puts("#{x}, #{y}")
end
जब उपरोक्त कार्यक्रम चलाया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
0.0, 0.0
1.0, 0.0
1.0, 1.0
मठ का मॉड्यूल
गणित मॉड्यूल में त्रिकोणमिति, घातीय और लघुगणक कार्यों को कवर करने वाले सामान्य गणितीय कार्य शामिल हैं। गणित मॉड्यूल कैसे काम करता है, इसे समझने के लिए हम निम्नलिखित उदाहरण पर विचार करें -
# Value of pi
IO.puts(:math.pi())
# Logarithm
IO.puts(:math.log(7.694785265142018e23))
# Exponentiation
IO.puts(:math.exp(55.0))
#...
जब उपरोक्त कार्यक्रम चलाया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
3.141592653589793
55.0
7.694785265142018e23
कतार मॉड्यूल
कतार एक डेटा संरचना है जो कुशलतापूर्वक (डबल-एंडेड) फीफो (पहली-पहली पहली-बाहर) कतारों में लागू होती है। निम्न उदाहरण दिखाता है कि एक क्यू मॉड्यूल कैसे काम करता है -
q = :queue.new
q = :queue.in("A", q)
q = :queue.in("B", q)
{{:value, val}, q} = :queue.out(q)
IO.puts(val)
{{:value, val}, q} = :queue.out(q)
IO.puts(val)
जब उपरोक्त कार्यक्रम चलाया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
A
B