You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
68 lines
1.8 KiB
68 lines
1.8 KiB
8 months ago
|
#if !BESTHTTP_DISABLE_ALTERNATE_SSL && (!UNITY_WEBGL || UNITY_EDITOR)
|
||
|
#pragma warning disable
|
||
|
using System;
|
||
|
|
||
|
using BestHTTP.SecureProtocol.Org.BouncyCastle.Utilities;
|
||
|
|
||
|
namespace BestHTTP.SecureProtocol.Org.BouncyCastle.Math.Field
|
||
|
{
|
||
|
internal class GenericPolynomialExtensionField
|
||
|
: IPolynomialExtensionField
|
||
|
{
|
||
|
protected readonly IFiniteField subfield;
|
||
|
protected readonly IPolynomial minimalPolynomial;
|
||
|
|
||
|
internal GenericPolynomialExtensionField(IFiniteField subfield, IPolynomial polynomial)
|
||
|
{
|
||
|
this.subfield = subfield;
|
||
|
this.minimalPolynomial = polynomial;
|
||
|
}
|
||
|
|
||
|
public virtual BigInteger Characteristic
|
||
|
{
|
||
|
get { return subfield.Characteristic; }
|
||
|
}
|
||
|
|
||
|
public virtual int Dimension
|
||
|
{
|
||
|
get { return subfield.Dimension * minimalPolynomial.Degree; }
|
||
|
}
|
||
|
|
||
|
public virtual IFiniteField Subfield
|
||
|
{
|
||
|
get { return subfield; }
|
||
|
}
|
||
|
|
||
|
public virtual int Degree
|
||
|
{
|
||
|
get { return minimalPolynomial.Degree; }
|
||
|
}
|
||
|
|
||
|
public virtual IPolynomial MinimalPolynomial
|
||
|
{
|
||
|
get { return minimalPolynomial; }
|
||
|
}
|
||
|
|
||
|
public override bool Equals(object obj)
|
||
|
{
|
||
|
if (this == obj)
|
||
|
{
|
||
|
return true;
|
||
|
}
|
||
|
GenericPolynomialExtensionField other = obj as GenericPolynomialExtensionField;
|
||
|
if (null == other)
|
||
|
{
|
||
|
return false;
|
||
|
}
|
||
|
return subfield.Equals(other.subfield) && minimalPolynomial.Equals(other.minimalPolynomial);
|
||
|
}
|
||
|
|
||
|
public override int GetHashCode()
|
||
|
{
|
||
|
return subfield.GetHashCode() ^ Integers.RotateLeft(minimalPolynomial.GetHashCode(), 16);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
#pragma warning restore
|
||
|
#endif
|