Complex.Equals Complex.Equals Complex.Equals Complex.Equals Method

定義

2 つの複素数が等しいかどうかを示す値を返します。Returns a value that indicates whether two complex numbers are equal.

オーバーロード

Equals(Complex) Equals(Complex) Equals(Complex) Equals(Complex)

現在のインスタンスの値と指定した複素数の値が等しいかどうかを示す値を返します。Returns a value that indicates whether the current instance and a specified complex number have the same value.

Equals(Object) Equals(Object) Equals(Object) Equals(Object)

現在のインスタンスの値と指定されたオブジェクトの値が等しいかどうかを示す値を返します。Returns a value that indicates whether the current instance and a specified object have the same value.

Equals(Complex) Equals(Complex) Equals(Complex) Equals(Complex)

現在のインスタンスの値と指定した複素数の値が等しいかどうかを示す値を返します。Returns a value that indicates whether the current instance and a specified complex number have the same value.

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

パラメーター

value
Complex Complex Complex Complex

比較対象の複素数。The complex number to compare.

戻り値

この複素数の値と value の値が等しい場合は true。それ以外の場合は falsetrue if this complex number and value have the same value; otherwise, false.

実装

注釈

Equals(Complex)メソッドを提供、IEquatable<T>の実装、Complex構造体。The Equals(Complex) method provides the IEquatable<T> implementation for the Complex structure. 少し実行よりも優れていますEquals(Object)メソッド値から複素数へのパラメーターを変換することはありませんので。It performs slightly better than Equals(Object) method because it does not have to convert its parameter to a complex number.

2 つの複素数は、その実数部が等しくないと、その虚数が等しい場合は等しくなります。Two complex numbers are equal if their real parts are equal and their imaginary parts are equal. Equals(Complex)メソッドは、次の式と同じです。The Equals(Complex) method is equivalent to the following expression:

return this.Real.Equals(value) && this.Imaginary.Equals(value);      
Return Me.Real.Equals(value.Real) AndAlso Me.Imaginary.Equals(value.Imaginary)

注意 (呼び出し元)

使用して、Equals(Complex)メソッド、注意を 2 つの値が等しいために見なすことができます、実数部と虚数コンポーネントの有効桁数が異なるために等しくないです。Use the Equals(Complex) method with caution, because two values that are apparently equivalent can be considered unequal due to the differing precision of their real and imaginary components. 次の例では、レポートを(3.33333, 0.142857)(10/3, 1/7)が等しくないです。The following example reports that (3.33333, 0.142857) and (10/3, 1/7) are not equal.

[!code-csharpSystem.Numerics.Complex.Equals#4] [!code-vbSystem.Numerics.Complex.Equals#4][!code-csharpSystem.Numerics.Complex.Equals#4] [!code-vbSystem.Numerics.Complex.Equals#4] 手法は、2 つの値の差の許容の余白を定義する 1 つお勧めします (など。 値の実数部と虚数コンポーネントの 1 つの 01%) 値の等価性を比較する代わりにします。One recommended technique is to define an acceptable margin of difference between the two values (such as .01% of one of the values' real and imaginary components) instead of comparing the values for equality. 違いは、有効桁数の違いが原因である可能性を 2 つの値の差の絶対値の余白に等しいまたはそれよりも小さい場合は、そのため、値が等しいと考えられます。If the absolute value of the difference between the two values is less than or equal to that margin, the difference is likely to be due to a difference in precision, and, therefore, the values are likely to be equal. 次の例では、この手法を使用して、等しくない場合に上記のコード例にある 2 つの複雑な値の比較します。The following example uses this technique to compare the two complex values that the previous code example found to be unequal. 等しい 2 つの複素数を検索します。It finds the two complex numbers to be equal.

[!code-csharpSystem.Numerics.Complex.Equals#5] [!code-vbSystem.Numerics.Complex.Equals#5][!code-csharpSystem.Numerics.Complex.Equals#5] [!code-vbSystem.Numerics.Complex.Equals#5]

こちらもご覧ください

Equals(Object) Equals(Object) Equals(Object) Equals(Object)

現在のインスタンスの値と指定されたオブジェクトの値が等しいかどうかを示す値を返します。Returns a value that indicates whether the current instance and a specified object have the same value.

public:
 override bool Equals(System::Object ^ obj);
public override bool Equals (object obj);
override this.Equals : obj -> bool
Public Overrides Function Equals (obj As Object) As Boolean

パラメーター

obj
Object Object Object Object

比較対象のオブジェクト。The object to compare.

戻り値

obj パラメーターが Complex オブジェクトであるか Complex オブジェクトに暗黙的に変換できる型であり、その値が現在の Complex オブジェクトの値と等しい場合は true。それ以外の場合は falsetrue if the obj parameter is a Complex object or a type capable of implicit conversion to a Complex object, and its value is equal to the current Complex object; otherwise, false.

注釈

2 つの複素数は、その実数部が等しくないと、その虚数が等しい場合は等しくなります。Two complex numbers are equal if their real parts are equal and their imaginary parts are equal. Equals(Object)メソッドは、次の式と同じです。The Equals(Object) method is equivalent to the following expression:

return this.Real.Equals(((Complex) value).Real) && 
       this.Imaginary.Equals(((Complex) value).Imaginary);
Return Me.Real.Equals(CType(value, Complex).Real) AndAlso 
       Me.Imaginary.Equals(CType(value, Complex).Imaginary)

場合、objパラメーターではありません、Complexオブジェクトでは、暗黙的な変換が定義されているデータ型、Equals(Object)メソッドに変換しますobjComplex実数部がの値と等しいオブジェクトobj、比較を実行する前に、虚数部は 0 に等しいとします。If the obj parameter is not a Complex object, but it is a data type for which an implicit conversion is defined, the Equals(Object) method converts obj to a Complex object whose real part is equal to the value of obj and whose imaginary part is equal to zero before it performs the comparison. 次の例は、複素数と倍精度浮動小数点値が等しいことを見つけることによって、これを示しています。The following example illustrates this by finding that a complex number and a double-precision floating-point value are equal.

double n1 = 16.33;
System.Numerics.Complex c1 = 
       new System.Numerics.Complex(16.33, 0);
Console.WriteLine(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.

注意 (呼び出し元)

使用して、Equals(Complex)メソッド、注意を 2 つの値が等しいために見なすことができます、実数部と虚数コンポーネントの有効桁数が異なるために等しくないです。Use the Equals(Complex) method with caution, because two values that are apparently equivalent can be considered unequal due to the differing precision of their real and imaginary components. 問題が顕著になる場合objに変換する必要があります、Double比較を実行する前にします。The problem can be accentuated if obj must be converted to a Double before performing the comparison. 次の例では、複素数の実数部に等しいことが表示されます、SingleSingle値。The following example compares a complex number whose real component appears to be equal to a Single value with that Single value. 等しいかどうか比較が返される出力をFalseします。As the output shows, the comparison for equality returns False.

[!code-csharpSystem.Numerics.Complex.Equals#8] [!code-vbSystem.Numerics.Complex.Equals#8][!code-csharpSystem.Numerics.Complex.Equals#8] [!code-vbSystem.Numerics.Complex.Equals#8] 手法は、2 つの値の差の許容の余白を定義する 1 つお勧めします (など。 値の実数部と虚数コンポーネントの 1 つの 01%) 値の等価性を比較する代わりにします。One recommended technique is to define an acceptable margin of difference between the two values (such as .01% of one of the values' real and imaginary components) instead of comparing the values for equality. 違いは、有効桁数の違いが原因である可能性を 2 つの値の差の絶対値の余白に等しいまたはそれよりも小さい場合は、そのため、値が等しいと考えられます。If the absolute value of the difference between the two values is less than or equal to that margin, the difference is likely to be due to a difference in precision and, therefore, the values are likely to be equal. 次の例では、この手法を使用して、等しくない場合に上記のコード例にある 2 つの値の比較します。The following example uses this technique to compare the two values that the previous code example found to be unequal. これで、それらを同じ検索します。It now finds them to be equal.

[!code-csharpSystem.Numerics.Complex.Equals#7] [!code-vbSystem.Numerics.Complex.Equals#7][!code-csharpSystem.Numerics.Complex.Equals#7] [!code-vbSystem.Numerics.Complex.Equals#7]

適用対象