Complex.Equals Yöntem
Tanım
Önemli
Bazı bilgiler ürünün ön sürümüyle ilgilidir ve sürüm öncesinde önemli değişiklikler yapılmış olabilir. Burada verilen bilgilerle ilgili olarak Microsoft açık veya zımni hiçbir garanti vermez.
İki karmaşık sayının eşit olup olmadığını gösteren bir değer döndürür.
Aşırı Yüklemeler
Equals(Object) |
Geçerli örnekle belirtilen nesnenin aynı değere sahip olup olmadığını gösteren bir değer döndürür. |
Equals(Complex) |
Geçerli örneğin ve belirtilen karmaşık sayının aynı değere sahip olup olmadığını gösteren bir değer döndürür. |
Equals(Object)
- Kaynak:
- Complex.cs
- Kaynak:
- Complex.cs
- Kaynak:
- Complex.cs
Geçerli örnekle belirtilen nesnenin aynı değere sahip olup olmadığını gösteren bir değer döndürür.
public:
override bool Equals(System::Object ^ obj);
public override bool Equals (object obj);
public override bool Equals (object? obj);
override this.Equals : obj -> bool
Public Overrides Function Equals (obj As Object) As Boolean
Parametreler
- obj
- Object
Karşılaştırma yapılacak nesne.
Döndürülenler
true
obj
parametre bir nesneye örtük dönüştürme Complex yapabilen bir Complex nesne veya türse ve değeri geçerli Complex nesneye eşitse; aksi takdirde, false
.
Açıklamalar
Gerçek parçaları eşitse ve hayali parçaları eşitse iki karmaşık sayı eşittir. Equals(Object) yöntemi aşağıdaki ifadeye eşdeğerdir:
return this.Real.Equals(((Complex) value).Real) &&
this.Imaginary.Equals(((Complex) value).Imaginary);
this.Real.Equals((value :?> Complex).Real)
&& this.Imaginary.Equals((value :?> Complex).Imaginary)
Return Me.Real.Equals(CType(value, Complex).Real) AndAlso
Me.Imaginary.Equals(CType(value, Complex).Imaginary)
obj
Parametre bir Complex nesne değilse, ancak örtük dönüştürmenin tanımlandığı bir veri türüyse, yöntem karşılaştırmayı Equals(Object) gerçekleştirmeden önce gerçek bölümü değerine obj
eşit olan ve sanal bölümü sıfıra eşit olan bir Complex nesneye dönüştürürobj
. Aşağıdaki örnek, karmaşık bir sayı ile çift duyarlıklı kayan nokta değerinin eşit olduğunu bularak bunu gösterir.
double n1 = 16.33;
System.Numerics.Complex c1 =
new System.Numerics.Complex(16.33, 0);
Console.WriteLine(c1.Equals(n1)); // Returns true.
let n1 = 16.33;
let c1 = System.Numerics.Complex(16.33, 0)
printfn $"{c1.Equals n1}" // Returns true.
Dim n1 As Double = 16.33
Dim c1 As New System.Numerics.Complex(16.33, 0)
Console.WriteLine(c1.Equals(n1)) ' Returns True.
Arayanlara Notlar
Equals(Complex) Yöntemi dikkatli kullanın, çünkü görünüşte eşdeğer olan iki değer, gerçek ve hayali bileşenlerinin farklı duyarlığı nedeniyle eşit kabul edilemez. Karşılaştırma gerçekleştirilmeden önce bir'e Double dönüştürülmesi gerekiyorsa sorun vurgulanabilirobj
. Aşağıdaki örnek, gerçek bileşeni bu değere sahip Single bir değere eşit gibi görünen karmaşık bir Single sayıyı karşılaştırır. Çıktıda gösterildiği gibi, eşitlik karşılaştırması döndürür False
.
using System;
using System.Numerics;
public class Example
{
public static void Main()
{
float n1 = 1.430718e-12f;
Complex c1 = new Complex(1.430718e-12, 0);
Console.WriteLine("{0} = {1}: {2}", c1, n1, c1.Equals(n1));
}
}
// The example displays the following output:
// (1.430718E-12, 0) = 1.430718E-12: False
open System.Numerics
let n1 = 1.430718e-12f
let c1 = Complex(1.430718e-12, 0);
printfn $"{c1} = {n1}: {c1.Equals n1}"
// The example displays the following output:
// (1.430718E-12, 0) = 1.430718E-12: False
Imports System.Numerics
Module Example
Public Sub Main()
Dim n1 As Single = 1.430718e-12
Dim c1 As New Complex(1.430718e-12, 0)
Console.WriteLine("{0} = {1}: {2}", c1, n1, c1.Equals(n1))
End Sub
End Module
' The example displays the following output:
' (1.430718E-12, 0) = 1.430718E-12: False
Önerilen tekniklerden biri, değerleri eşitlik için karşılaştırmak yerine iki değer (değerlerin gerçek ve sanal bileşenlerinden birinin %.01'i gibi) arasında kabul edilebilir bir fark marjı tanımlamaktır. İki değer arasındaki farkın mutlak değeri bu kenar boşluğundan küçük veya buna eşitse, fark büyük olasılıkla duyarlık farkından kaynaklanır ve bu nedenle değerler eşit olabilir. Aşağıdaki örnek, önceki kod örneğinin eşit olmadığını bulduğu iki değeri karşılaştırmak için bu tekniği kullanır. Şimdi onları eşit olarak bulur.
using System.Numerics;
public class Example
{
public static void Main()
{
float n1 = 1.430718e-12f;
Complex c1 = new Complex(1.430718e-12, 0);
double difference = .0001;
// Compare the values
bool result = (Math.Abs(c1.Real - n1) <= c1.Real * difference) &
c1.Imaginary == 0;
Console.WriteLine("{0} = {1}: {2}", c1, n1, result);
}
}
// The example displays the following output:
// (1.430718E-12, 0) = 1.430718E-12: True
open System.Numerics
let n1 = 1.430718e-12f
let c1 = Complex(1.430718e-12, 0);
let difference = 0.0001f;
// Compare the values
let result = (abs (c1.Real - float n1) <= c1.Real * float difference) && c1.Imaginary = 0;
printfn $"{c1} = {n1}: {result}"
// The example displays the following output:
// (1.430718E-12, 0) = 1.430718E-12: True
Imports System.Numerics
Module Example
Public Sub Main()
Dim n1 As Single = 1.430718e-12
Dim c1 As New Complex(1.430718e-12, 0)
Dim difference As Double = .0001
' Compare the values
Dim result As Boolean = (Math.Abs(c1.Real - n1) <= c1.Real * difference) And
c1.Imaginary = 0
Console.WriteLine("{0} = {1}: {2}", c1, n1, result)
End Sub
End Module
' The example displays the following output:
' (1.430718E-12, 0) = 1.430718E-12: True
Şunlara uygulanır
Equals(Complex)
- Kaynak:
- Complex.cs
- Kaynak:
- Complex.cs
- Kaynak:
- Complex.cs
Geçerli örneğin ve belirtilen karmaşık sayının aynı değere sahip olup olmadığını gösteren bir değer döndürür.
public:
virtual bool Equals(System::Numerics::Complex value);
public bool Equals (System.Numerics.Complex value);
override this.Equals : System.Numerics.Complex -> bool
Public Function Equals (value As Complex) As Boolean
Parametreler
- value
- Complex
Karşılaştıracak karmaşık sayı.
Döndürülenler
true
bu karmaşık sayıysa ve value
aynı değere sahipse; değilse, false
.
Uygulamalar
Açıklamalar
yöntemi, Equals(Complex) yapı için Complex uygulamayı sağlarIEquatable<T>. Parametresini karmaşık bir sayıya dönüştürmesi gerekmediğinden yöntemden biraz daha Equals(Object) iyi performans gösterir.
Gerçek parçaları eşitse ve hayali parçaları eşitse iki karmaşık sayı eşittir. Equals(Complex) yöntemi aşağıdaki ifadeye eşdeğerdir:
return this.Real.Equals(value) && this.Imaginary.Equals(value);
this.Real.Equals value && this.Imaginary.Equals value
Return Me.Real.Equals(value.Real) AndAlso Me.Imaginary.Equals(value.Imaginary)
Arayanlara Notlar
Equals(Complex) Yöntemi dikkatli kullanın, çünkü görünüşte eşdeğer olan iki değer, gerçek ve hayali bileşenlerinin farklı duyarlığı nedeniyle eşit kabul edilemez. Aşağıdaki örnek, ve'nin (3.33333, 0.142857)
(10/3, 1/7)
eşit olmadığını bildirir.
System.Numerics.Complex c1 = new System.Numerics.Complex(3.33333, .142857);
System.Numerics.Complex c2 = new System.Numerics.Complex(10/3.0, 1.0/7);
Console.WriteLine("{0} = {1}: {2}", c1, c2, c1.Equals(c2));
// The example displays the following output:
// (3.33333, 0.142857) = (3.33333333333333, 0.142857142857143): False
let c1 = System.Numerics.Complex(3.33333, 0.142857)
let c2 = System.Numerics.Complex(10. / 3., 1. / 7.)
printfn $"{c1} = {c2}: {c1.Equals c2}"
// The example displays the following output:
// (3.33333, 0.142857) = (3.33333333333333, 0.142857142857143): False
Dim c1 As New System.Numerics.Complex(3.33333, .142857)
Dim c2 As New System.Numerics.Complex(10/3, 1/7)
Console.WriteLine("{0} = {1}: {2}", c1, c2, c1.Equals(c2))
' The example displays the following output:
' (3.33333, 0.142857) = (3.33333333333333, 0.142857142857143): False
Önerilen tekniklerden biri, değerleri eşitlik için karşılaştırmak yerine iki değer (değerlerin gerçek ve sanal bileşenlerinden birinin %.01'i gibi) arasında kabul edilebilir bir fark marjı tanımlamaktır. İki değer arasındaki farkın mutlak değeri bu kenar boşluğundan küçük veya buna eşitse, fark büyük olasılıkla duyarlık farkından kaynaklanır ve bu nedenle değerlerin eşit olma olasılığı yüksektir. Aşağıdaki örnek, önceki kod örneğinin eşit olmadığını bulduğu iki karmaşık değeri karşılaştırmak için bu tekniği kullanır. İki karmaşık sayının eşit olduğunu bulur.
System.Numerics.Complex c1 = new System.Numerics.Complex(3.33333, .142857);
System.Numerics.Complex c2 = new System.Numerics.Complex(10/3.0, 1.0/7);
double difference = .0001;
// Compare the values
bool result = (Math.Abs(c1.Real - c2.Real) <= c1.Real * difference) &
(Math.Abs(c1.Imaginary - c2.Imaginary) <= c1.Imaginary * difference);
Console.WriteLine("{0} = {1}: {2}", c1, c2, result);
// The example displays the following output:
// (3.33333, 0.142857) = (3.33333333333333, 0.142857142857143): True
let c1 = System.Numerics.Complex(3.33333, 0.142857)
let c2 = System.Numerics.Complex(10. / 3., 1. / 7.)
let difference = 0.0001
// Compare the values
let result =
(Math.Abs(c1.Real - c2.Real) <= c1.Real * difference)
&& (Math.Abs(c1.Imaginary - c2.Imaginary) <= c1.Imaginary * difference)
printfn $"{c1} = {c2}: {result}"
// The example displays the following output:
// (3.33333, 0.142857) = (3.33333333333333, 0.142857142857143): True
Dim c1 As New System.Numerics.Complex(3.33333, .142857)
Dim c2 As New System.Numerics.Complex(10/3.0, 1.0/7)
Dim difference As Double = .0001
' Compare the values
Dim result As Boolean = (Math.Abs(c1.Real - c2.Real) <= c1.Real * difference) And
(Math.Abs(c1.Imaginary - c2.Imaginary) <= c1.Imaginary * difference)
Console.WriteLine("{0} = {1}: {2}", c1, c2, result)
' The example displays the following output:
' (3.33333, 0.142857) = (3.33333333333333, 0.142857142857143): True