الفرق بين المراجعتين لصفحة: «Ruby/Rational»
أنشأ الصفحة ب'<noinclude>{{DISPLAYTITLE: صفحة الصنف <code>Rational</code> في روبي}}</noinclude> تصنيف: Ruby تصنيف: Ruby Rational يمكن تمثيل...' |
لا ملخص تعديل |
||
سطر 2: | سطر 2: | ||
[[تصنيف: Ruby]] | [[تصنيف: Ruby]] | ||
[[تصنيف: Ruby Rational]] | [[تصنيف: Ruby Rational]] | ||
يمكن تمثيل عدد جذري (rational) كزوج من الأعداد الصحيحة: a / | يمكن تمثيل عدد جذري (rational) كزوج من الأعداد الصحيحة: a / b حيث (b> 0). العدد a يمثل البسط، والعدد b يمثل المقام. من الناحية الرياضية، العدد الصحيح a يساوي العدد الجذري a / 1. | ||
في روبي، يمكنك إنشاء الكائنات (الأعداد) الجذرية باستخدام التوابع <code>[[Ruby/Kernel/Rational|Kernel#Rational]]</code> أو <code>[[Ruby/Rational/to_r|to_r]]</code> أو <code>[[Ruby/Rational/rationalize|rationalize]]</code>، أو عن طريق إضافة <code>r</code> إلى رقم. ستكون القيم المعادة كسورًا غير قابلة للاختزال (irreducible fractions). <syntaxhighlight lang="ruby">Rational(1) #=> (1/1) | |||
Rational(2, 3) #=> (2/3) | Rational(2, 3) #=> (2/3) | ||
Rational(4, -6) #=> (-2/3) | Rational(4, -6) #=> (-2/3) | ||
3.to_r #=> (3/1) | 3.to_r #=> (3/1) | ||
2/3r #=> (2/3) | 2/3r #=> (2/3)</syntaxhighlight> يمكنك أيضًا إنشاء الكائنات الجذرية من الأعدد العشرية (floating-point numbers) أو من السلاسل النصية. <syntaxhighlight lang="ruby">Rational(0.3) #=> (5404319552844595/18014398509481984) | ||
Rational('0.3') #=> (3/10) | Rational('0.3') #=> (3/10) | ||
Rational('2/3') #=> (2/3) | Rational('2/3') #=> (2/3) | ||
سطر 13: | سطر 14: | ||
'0.3'.to_r #=> (3/10) | '0.3'.to_r #=> (3/10) | ||
'2/3'.to_r #=> (2/3) | '2/3'.to_r #=> (2/3) | ||
0.3.rationalize #=> (3/10) | 0.3.rationalize #=> (3/10)</syntaxhighlight> الأعداد الجذرية هي أعداد مضبوطة، والتي تساعد على كتابة البرامج بدون أخطاء التقريب. <syntaxhighlight lang="ruby">10.times.inject(0) {|t| t + 0.1 } #=> 0.9999999999999999 | ||
10.times.inject(0) {|t| t + Rational('0.1') } #=> (1/1)</syntaxhighlight> لكن عندما يتضمن التعبير قيمة غير مضبوطة (قيمة عددية أو عملية)، فسينتج نتيجة غير مضبوطة. <syntaxhighlight lang="ruby">Rational(10) / 3 #=> (10/3) | |||
10.times.inject(0) {|t| t + Rational('0.1') } #=> (1/1) | |||
Rational(10) / 3.0 #=> 3.3333333333333335 | Rational(10) / 3.0 #=> 3.3333333333333335 | ||
Rational(-8) ** Rational(1, 3) | Rational(-8) ** Rational(1, 3) | ||
#=> (1.0000000000000002+1.7320508075688772i) | #=> (1.0000000000000002+1.7320508075688772i)</syntaxhighlight> | ||
==توابع الصنف العامة (Public Class Methods)== | ==توابع الصنف العامة (Public Class Methods)== | ||
سطر 32: | سطر 30: | ||
ينفذ عملية الطرح. | ينفذ عملية الطرح. | ||
===[[Ruby/Rational/unary_Minus | التابع -]]=== | ===[[Ruby/Rational/unary_Minus | التابع -]]=== | ||
يعيد نفي | يعيد نفي العدد. | ||
===[[Ruby/Rational/divsion_operator | التابع /]]=== | ===[[Ruby/Rational/divsion_operator | التابع /]]=== | ||
ينفذ عملية القسمة. | ينفذ عملية القسمة. | ||
===[[Ruby/Rational/compar_operator | التابع <=>]]=== | ===[[Ruby/Rational/compar_operator | التابع <=>]]=== | ||
معامل المقارنة. | |||
===[[Ruby/Rational/equality_operator | التابع ==]]=== | ===[[Ruby/Rational/equality_operator | التابع ==]]=== | ||
معامل التساوي. | |||
===[[Ruby/Rational/abs | التابع abs]]=== | ===[[Ruby/Rational/abs | التابع abs]]=== | ||
يعيد القيمة المطلقة | يعيد القيمة المطلقة للعدد. | ||
===[[Ruby/Rational/ceil | التابع ceil]]=== | ===[[Ruby/Rational/ceil | التابع ceil]]=== | ||
يعيد أصغر عدد من الأعداد الأكبر من أو تساوي | يعيد أصغر عدد من الأعداد الأكبر من أو تساوي العدد. | ||
===[[Ruby/Rational/denominator | التابع denominator]]=== | ===[[Ruby/Rational/denominator | التابع denominator]]=== | ||
يعيد المقام (denominator)، ويكون دائمًا موجبًا. | يعيد المقام (denominator)، ويكون دائمًا موجبًا. | ||
سطر 48: | سطر 46: | ||
ينفّذ عملية القسمة، ويعيد القيمة كعدد عشري (<code>[[Ruby/Float|Float]]</code>). | ينفّذ عملية القسمة، ويعيد القيمة كعدد عشري (<code>[[Ruby/Float|Float]]</code>). | ||
===[[Ruby/Rational/floor | التابع floor]]=== | ===[[Ruby/Rational/floor | التابع floor]]=== | ||
يعيد أكبر عدد من الأعداد الأصغر من أو تساوي | يعيد أكبر عدد من الأعداد الأصغر من أو تساوي العدد. | ||
===[[Ruby/Rational/inspect | التابع inspect]]=== | ===[[Ruby/Rational/inspect | التابع inspect]]=== | ||
يُعيد العدد كسلسلة نصية. | يُعيد العدد كسلسلة نصية. | ||
===[[Ruby/Rational/magnitude | التابع magnitude]]=== | ===[[Ruby/Rational/magnitude | التابع magnitude]]=== | ||
يعيد القيمة المطلقة | يعيد القيمة المطلقة للعدد. | ||
===[[Ruby/Rational/negative-3F | التابع negative?]]=== | ===[[Ruby/Rational/negative-3F | التابع negative?]]=== | ||
يعيد <code>true</code> إن كان | يعيد <code>true</code> إن كان العدد أصغر من 0. | ||
===[[Ruby/Rational/numerator | التابع numerator]]=== | ===[[Ruby/Rational/numerator | التابع numerator]]=== | ||
يعيد البسط (numerator). | يعيد البسط (numerator). | ||
===[[Ruby/Rational/positive-3F | التابع positive?]]=== | ===[[Ruby/Rational/positive-3F | التابع positive?]]=== | ||
يعيد القيمة <code>true</code> إن كان | يعيد القيمة <code>true</code> إن كان العدد أكبر من 0. | ||
===[[Ruby/Rational/quo | التابع quo]]=== | ===[[Ruby/Rational/quo | التابع quo]]=== | ||
ينفذ عملية القسمة. | ينفذ عملية القسمة. | ||
===[[Ruby/Rational/rationalize | التابع rationalize]]=== | ===[[Ruby/Rational/rationalize | التابع rationalize]]=== | ||
يُعيد تقريبًا مبسطًا لقيمة العدد | يُعيد تقريبًا مبسطًا لقيمة العدد. | ||
===[[Ruby/Rational/round | التابع round]]=== | ===[[Ruby/Rational/round | التابع round]]=== | ||
يعيد العدد | يعيد العدد مُقرّبًا إلى أقرب قيمة مع دقة <code>ndigits</code> منزلًا عشريًا. | ||
===[[Ruby/Rational/to_f | التابع to_f]]=== | ===[[Ruby/Rational/to_f | التابع to_f]]=== | ||
يُعيد القيمة على هيئة <code>[[Ruby/Float|Float]]</code>. | يُعيد القيمة على هيئة <code>[[Ruby/Float|Float]]</code>. | ||
سطر 70: | سطر 68: | ||
يُعيد القيمة مُقتطعة على هيئة عدد صحيح. | يُعيد القيمة مُقتطعة على هيئة عدد صحيح. | ||
===[[Ruby/Rational/to_r | التابع to_r]]=== | ===[[Ruby/Rational/to_r | التابع to_r]]=== | ||
يعيد | يعيد العدد نفسه. | ||
===[[Ruby/Rational/to_s | التابع to_s]]=== | ===[[Ruby/Rational/to_s | التابع to_s]]=== | ||
يُعيد القيمة على هيئة سلسلة نصية. | يُعيد القيمة على هيئة سلسلة نصية. | ||
===[[Ruby/Rational/truncate | التابع truncate]]=== | ===[[Ruby/Rational/truncate | التابع truncate]]=== | ||
يعيد العدد | يعيد العدد مُقتطعًا (نحو الصفر) بدقة <code>ndigits</code> منزلًا عشريًا. | ||
*[http://ruby-doc.org/core-2.5.1/Rational.html قسم الصنف Rational في توثيق روبي الرسمي.] | *[http://ruby-doc.org/core-2.5.1/Rational.html قسم الصنف Rational في توثيق روبي الرسمي.] |
مراجعة 23:19، 30 أكتوبر 2018
يمكن تمثيل عدد جذري (rational) كزوج من الأعداد الصحيحة: a / b حيث (b> 0). العدد a يمثل البسط، والعدد b يمثل المقام. من الناحية الرياضية، العدد الصحيح a يساوي العدد الجذري a / 1.
في روبي، يمكنك إنشاء الكائنات (الأعداد) الجذرية باستخدام التوابع Kernel#Rational
أو to_r
أو rationalize
، أو عن طريق إضافة r
إلى رقم. ستكون القيم المعادة كسورًا غير قابلة للاختزال (irreducible fractions).
Rational(1) #=> (1/1)
Rational(2, 3) #=> (2/3)
Rational(4, -6) #=> (-2/3)
3.to_r #=> (3/1)
2/3r #=> (2/3)
يمكنك أيضًا إنشاء الكائنات الجذرية من الأعدد العشرية (floating-point numbers) أو من السلاسل النصية.
Rational(0.3) #=> (5404319552844595/18014398509481984)
Rational('0.3') #=> (3/10)
Rational('2/3') #=> (2/3)
0.3.to_r #=> (5404319552844595/18014398509481984)
'0.3'.to_r #=> (3/10)
'2/3'.to_r #=> (2/3)
0.3.rationalize #=> (3/10)
الأعداد الجذرية هي أعداد مضبوطة، والتي تساعد على كتابة البرامج بدون أخطاء التقريب.
10.times.inject(0) {|t| t + 0.1 } #=> 0.9999999999999999
10.times.inject(0) {|t| t + Rational('0.1') } #=> (1/1)
لكن عندما يتضمن التعبير قيمة غير مضبوطة (قيمة عددية أو عملية)، فسينتج نتيجة غير مضبوطة.
Rational(10) / 3 #=> (10/3)
Rational(10) / 3.0 #=> 3.3333333333333335
Rational(-8) ** Rational(1, 3)
#=> (1.0000000000000002+1.7320508075688772i)
توابع الصنف العامة (Public Class Methods)
التابع *
ينفذ عملية الضرب.
التابع **
ينجز عملية الأس.
التابع +
ينفذ عملية الإضافة.
التابع -
ينفذ عملية الطرح.
التابع -
يعيد نفي العدد.
التابع /
ينفذ عملية القسمة.
التابع <=>
معامل المقارنة.
التابع ==
معامل التساوي.
التابع abs
يعيد القيمة المطلقة للعدد.
التابع ceil
يعيد أصغر عدد من الأعداد الأكبر من أو تساوي العدد.
التابع denominator
يعيد المقام (denominator)، ويكون دائمًا موجبًا.
التابع fdiv
ينفّذ عملية القسمة، ويعيد القيمة كعدد عشري (Float
).
التابع floor
يعيد أكبر عدد من الأعداد الأصغر من أو تساوي العدد.
التابع inspect
يُعيد العدد كسلسلة نصية.
التابع magnitude
يعيد القيمة المطلقة للعدد.
التابع negative?
يعيد true
إن كان العدد أصغر من 0.
التابع numerator
يعيد البسط (numerator).
التابع positive?
يعيد القيمة true
إن كان العدد أكبر من 0.
التابع quo
ينفذ عملية القسمة.
التابع rationalize
يُعيد تقريبًا مبسطًا لقيمة العدد.
التابع round
يعيد العدد مُقرّبًا إلى أقرب قيمة مع دقة ndigits
منزلًا عشريًا.
التابع to_f
يُعيد القيمة على هيئة Float
.
التابع to_i
يُعيد القيمة مُقتطعة على هيئة عدد صحيح.
التابع to_r
يعيد العدد نفسه.
التابع to_s
يُعيد القيمة على هيئة سلسلة نصية.
التابع truncate
يعيد العدد مُقتطعًا (نحو الصفر) بدقة ndigits
منزلًا عشريًا.