// <copyright file="Vector.Arithmetic.cs" company="Math.NET">
|
// Math.NET Numerics, part of the Math.NET Project
|
// http://numerics.mathdotnet.com
|
// http://github.com/mathnet/mathnet-numerics
|
//
|
// Copyright (c) 2009-2016 Math.NET
|
//
|
// Permission is hereby granted, free of charge, to any person
|
// obtaining a copy of this software and associated documentation
|
// files (the "Software"), to deal in the Software without
|
// restriction, including without limitation the rights to use,
|
// copy, modify, merge, publish, distribute, sublicense, and/or sell
|
// copies of the Software, and to permit persons to whom the
|
// Software is furnished to do so, subject to the following
|
// conditions:
|
//
|
// The above copyright notice and this permission notice shall be
|
// included in all copies or substantial portions of the Software.
|
//
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
|
// OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
|
// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
// WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
// OTHER DEALINGS IN THE SOFTWARE.
|
// </copyright>
|
|
using System;
|
|
namespace IStation.Numerics.LinearAlgebra
|
{
|
public abstract partial class Vector<T>
|
{
|
/// <summary>
|
/// The zero value for type T.
|
/// </summary>
|
public static readonly T Zero = BuilderInstance<T>.Vector.Zero;
|
|
/// <summary>
|
/// The value of 1.0 for type T.
|
/// </summary>
|
public static readonly T One = BuilderInstance<T>.Vector.One;
|
|
/// <summary>
|
/// Negates vector and save result to <paramref name="result"/>
|
/// </summary>
|
/// <param name="result">Target vector</param>
|
protected abstract void DoNegate(Vector<T> result);
|
|
/// <summary>
|
/// Complex conjugates vector and save result to <paramref name="result"/>
|
/// </summary>
|
/// <param name="result">Target vector</param>
|
protected abstract void DoConjugate(Vector<T> result);
|
|
/// <summary>
|
/// Adds a scalar to each element of the vector and stores the result in the result vector.
|
/// </summary>
|
/// <param name="scalar">The scalar to add.</param>
|
/// <param name="result">The vector to store the result of the addition.</param>
|
protected abstract void DoAdd(T scalar, Vector<T> result);
|
|
/// <summary>
|
/// Adds another vector to this vector and stores the result into the result vector.
|
/// </summary>
|
/// <param name="other">The vector to add to this one.</param>
|
/// <param name="result">The vector to store the result of the addition.</param>
|
protected abstract void DoAdd(Vector<T> other, Vector<T> result);
|
|
/// <summary>
|
/// Subtracts a scalar from each element of the vector and stores the result in the result vector.
|
/// </summary>
|
/// <param name="scalar">The scalar to subtract.</param>
|
/// <param name="result">The vector to store the result of the subtraction.</param>
|
protected abstract void DoSubtract(T scalar, Vector<T> result);
|
|
/// <summary>
|
/// Subtracts each element of the vector from a scalar and stores the result in the result vector.
|
/// </summary>
|
/// <param name="scalar">The scalar to subtract from.</param>
|
/// <param name="result">The vector to store the result of the subtraction.</param>
|
protected void DoSubtractFrom(T scalar, Vector<T> result)
|
{
|
DoNegate(result);
|
result.DoAdd(scalar, result);
|
}
|
|
/// <summary>
|
/// Subtracts another vector to this vector and stores the result into the result vector.
|
/// </summary>
|
/// <param name="other">The vector to subtract from this one.</param>
|
/// <param name="result">The vector to store the result of the subtraction.</param>
|
protected abstract void DoSubtract(Vector<T> other, Vector<T> result);
|
|
/// <summary>
|
/// Multiplies a scalar to each element of the vector and stores the result in the result vector.
|
/// </summary>
|
/// <param name="scalar">The scalar to multiply.</param>
|
/// <param name="result">The vector to store the result of the multiplication.</param>
|
protected abstract void DoMultiply(T scalar, Vector<T> result);
|
|
/// <summary>
|
/// Computes the dot product between this vector and another vector.
|
/// </summary>
|
/// <param name="other">The other vector.</param>
|
/// <returns>The sum of a[i]*b[i] for all i.</returns>
|
protected abstract T DoDotProduct(Vector<T> other);
|
|
/// <summary>
|
/// Computes the dot product between the conjugate of this vector and another vector.
|
/// </summary>
|
/// <param name="other">The other vector.</param>
|
/// <returns>The sum of conj(a[i])*b[i] for all i.</returns>
|
protected abstract T DoConjugateDotProduct(Vector<T> other);
|
|
/// <summary>
|
/// Computes the outer product M[i,j] = u[i]*v[j] of this and another vector and stores the result in the result matrix.
|
/// </summary>
|
/// <param name="other">The other vector</param>
|
/// <param name="result">The matrix to store the result of the product.</param>
|
protected void DoOuterProduct(Vector<T> other, Matrix<T> result)
|
{
|
var work = Build.Dense(Count);
|
for (var i = 0; i < other.Count; i++)
|
{
|
DoMultiply(other.At(i), work);
|
result.SetColumn(i, work);
|
}
|
}
|
|
/// <summary>
|
/// Divides each element of the vector by a scalar and stores the result in the result vector.
|
/// </summary>
|
/// <param name="divisor">The scalar denominator to use.</param>
|
/// <param name="result">The vector to store the result of the division.</param>
|
protected abstract void DoDivide(T divisor, Vector<T> result);
|
|
/// <summary>
|
/// Divides a scalar by each element of the vector and stores the result in the result vector.
|
/// </summary>
|
/// <param name="dividend">The scalar numerator to use.</param>
|
/// <param name="result">The vector to store the result of the division.</param>
|
protected abstract void DoDivideByThis(T dividend, Vector<T> result);
|
|
/// <summary>
|
/// Computes the canonical modulus, where the result has the sign of the divisor,
|
/// for each element of the vector for the given divisor.
|
/// </summary>
|
/// <param name="divisor">The scalar denominator to use.</param>
|
/// <param name="result">A vector to store the results in.</param>
|
protected abstract void DoModulus(T divisor, Vector<T> result);
|
|
/// <summary>
|
/// Computes the canonical modulus, where the result has the sign of the divisor,
|
/// for the given dividend for each element of the vector.
|
/// </summary>
|
/// <param name="dividend">The scalar numerator to use.</param>
|
/// <param name="result">A vector to store the results in.</param>
|
protected abstract void DoModulusByThis(T dividend, Vector<T> result);
|
|
/// <summary>
|
/// Computes the remainder (% operator), where the result has the sign of the dividend,
|
/// for each element of the vector for the given divisor.
|
/// </summary>
|
/// <param name="divisor">The scalar denominator to use.</param>
|
/// <param name="result">A vector to store the results in.</param>
|
protected abstract void DoRemainder(T divisor, Vector<T> result);
|
|
/// <summary>
|
/// Computes the remainder (% operator), where the result has the sign of the dividend,
|
/// for the given dividend for each element of the vector.
|
/// </summary>
|
/// <param name="dividend">The scalar numerator to use.</param>
|
/// <param name="result">A vector to store the results in.</param>
|
protected abstract void DoRemainderByThis(T dividend, Vector<T> result);
|
|
/// <summary>
|
/// Pointwise multiplies this vector with another vector and stores the result into the result vector.
|
/// </summary>
|
/// <param name="other">The vector to pointwise multiply with this one.</param>
|
/// <param name="result">The vector to store the result of the pointwise multiplication.</param>
|
protected abstract void DoPointwiseMultiply(Vector<T> other, Vector<T> result);
|
|
/// <summary>
|
/// Pointwise divide this vector with another vector and stores the result into the result vector.
|
/// </summary>
|
/// <param name="divisor">The pointwise denominator vector to use.</param>
|
/// <param name="result">The result of the division.</param>
|
protected abstract void DoPointwiseDivide(Vector<T> divisor, Vector<T> result);
|
|
/// <summary>
|
/// Pointwise raise this vector to an exponent and store the result into the result vector.
|
/// </summary>
|
/// <param name="exponent">The exponent to raise this vector values to.</param>
|
/// <param name="result">The vector to store the result of the pointwise power.</param>
|
protected abstract void DoPointwisePower(T exponent, Vector<T> result);
|
|
/// <summary>
|
/// Pointwise raise this vector to an exponent vector and store the result into the result vector.
|
/// </summary>
|
/// <param name="exponent">The exponent vector to raise this vector values to.</param>
|
/// <param name="result">The vector to store the result of the pointwise power.</param>
|
protected abstract void DoPointwisePower(Vector<T> exponent, Vector<T> result);
|
|
/// <summary>
|
/// Pointwise canonical modulus, where the result has the sign of the divisor,
|
/// of this vector with another vector and stores the result into the result vector.
|
/// </summary>
|
/// <param name="divisor">The pointwise denominator vector to use.</param>
|
/// <param name="result">The result of the modulus.</param>
|
protected abstract void DoPointwiseModulus(Vector<T> divisor, Vector<T> result);
|
|
/// <summary>
|
/// Pointwise remainder (% operator), where the result has the sign of the dividend,
|
/// of this vector with another vector and stores the result into the result vector.
|
/// </summary>
|
/// <param name="divisor">The pointwise denominator vector to use.</param>
|
/// <param name="result">The result of the modulus.</param>
|
protected abstract void DoPointwiseRemainder(Vector<T> divisor, Vector<T> result);
|
|
/// <summary>
|
/// Pointwise applies the exponential function to each value and stores the result into the result vector.
|
/// </summary>
|
/// <param name="result">The vector to store the result.</param>
|
protected abstract void DoPointwiseExp(Vector<T> result);
|
|
/// <summary>
|
/// Pointwise applies the natural logarithm function to each value and stores the result into the result vector.
|
/// </summary>
|
/// <param name="result">The vector to store the result.</param>
|
protected abstract void DoPointwiseLog(Vector<T> result);
|
|
protected abstract void DoPointwiseAbs(Vector<T> result);
|
protected abstract void DoPointwiseAcos(Vector<T> result);
|
protected abstract void DoPointwiseAsin(Vector<T> result);
|
protected abstract void DoPointwiseAtan(Vector<T> result);
|
protected abstract void DoPointwiseCeiling(Vector<T> result);
|
protected abstract void DoPointwiseCos(Vector<T> result);
|
protected abstract void DoPointwiseCosh(Vector<T> result);
|
protected abstract void DoPointwiseFloor(Vector<T> result);
|
protected abstract void DoPointwiseLog10(Vector<T> result);
|
protected abstract void DoPointwiseRound(Vector<T> result);
|
protected abstract void DoPointwiseSign(Vector<T> result);
|
protected abstract void DoPointwiseSin(Vector<T> result);
|
protected abstract void DoPointwiseSinh(Vector<T> result);
|
protected abstract void DoPointwiseSqrt(Vector<T> result);
|
protected abstract void DoPointwiseTan(Vector<T> result);
|
protected abstract void DoPointwiseTanh(Vector<T> result);
|
protected abstract void DoPointwiseAtan2(Vector<T> other, Vector<T> result);
|
protected abstract void DoPointwiseAtan2(T scalar, Vector<T> result);
|
protected abstract void DoPointwiseMinimum(T scalar, Vector<T> result);
|
protected abstract void DoPointwiseMinimum(Vector<T> other, Vector<T> result);
|
protected abstract void DoPointwiseMaximum(T scalar, Vector<T> result);
|
protected abstract void DoPointwiseMaximum(Vector<T> other, Vector<T> result);
|
protected abstract void DoPointwiseAbsoluteMinimum(T scalar, Vector<T> result);
|
protected abstract void DoPointwiseAbsoluteMinimum(Vector<T> other, Vector<T> result);
|
protected abstract void DoPointwiseAbsoluteMaximum(T scalar, Vector<T> result);
|
protected abstract void DoPointwiseAbsoluteMaximum(Vector<T> other, Vector<T> result);
|
|
/// <summary>
|
/// Adds a scalar to each element of the vector.
|
/// </summary>
|
/// <param name="scalar">The scalar to add.</param>
|
/// <returns>A copy of the vector with the scalar added.</returns>
|
public Vector<T> Add(T scalar)
|
{
|
if (scalar.Equals(Zero))
|
{
|
return Clone();
|
}
|
|
var result = Build.SameAs(this);
|
DoAdd(scalar, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Adds a scalar to each element of the vector and stores the result in the result vector.
|
/// </summary>
|
/// <param name="scalar">The scalar to add.</param>
|
/// <param name="result">The vector to store the result of the addition.</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="result"/> are not the same size.</exception>
|
public void Add(T scalar, Vector<T> result)
|
{
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
if (scalar.Equals(Zero))
|
{
|
CopyTo(result);
|
return;
|
}
|
|
DoAdd(scalar, result);
|
}
|
|
/// <summary>
|
/// Adds another vector to this vector.
|
/// </summary>
|
/// <param name="other">The vector to add to this one.</param>
|
/// <returns>A new vector containing the sum of both vectors.</returns>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="other"/> are not the same size.</exception>
|
public Vector<T> Add(Vector<T> other)
|
{
|
if (Count != other.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(other));
|
}
|
|
var result = Build.SameAs(this, other);
|
DoAdd(other, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Adds another vector to this vector and stores the result into the result vector.
|
/// </summary>
|
/// <param name="other">The vector to add to this one.</param>
|
/// <param name="result">The vector to store the result of the addition.</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="other"/> are not the same size.</exception>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="result"/> are not the same size.</exception>
|
public void Add(Vector<T> other, Vector<T> result)
|
{
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
DoAdd(other, result);
|
}
|
|
/// <summary>
|
/// Subtracts a scalar from each element of the vector.
|
/// </summary>
|
/// <param name="scalar">The scalar to subtract.</param>
|
/// <returns>A new vector containing the subtraction of this vector and the scalar.</returns>
|
public Vector<T> Subtract(T scalar)
|
{
|
if (scalar.Equals(Zero))
|
{
|
return Clone();
|
}
|
|
var result = Build.SameAs(this);
|
DoSubtract(scalar, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Subtracts a scalar from each element of the vector and stores the result in the result vector.
|
/// </summary>
|
/// <param name="scalar">The scalar to subtract.</param>
|
/// <param name="result">The vector to store the result of the subtraction.</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="result"/> are not the same size.</exception>
|
public void Subtract(T scalar, Vector<T> result)
|
{
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
if (scalar.Equals(Zero))
|
{
|
CopyTo(result);
|
return;
|
}
|
|
DoSubtract(scalar, result);
|
}
|
|
/// <summary>
|
/// Subtracts each element of the vector from a scalar.
|
/// </summary>
|
/// <param name="scalar">The scalar to subtract from.</param>
|
/// <returns>A new vector containing the subtraction of the scalar and this vector.</returns>
|
public Vector<T> SubtractFrom(T scalar)
|
{
|
var result = Build.SameAs(this);
|
DoSubtractFrom(scalar, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Subtracts each element of the vector from a scalar and stores the result in the result vector.
|
/// </summary>
|
/// <param name="scalar">The scalar to subtract from.</param>
|
/// <param name="result">The vector to store the result of the subtraction.</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="result"/> are not the same size.</exception>
|
public void SubtractFrom(T scalar, Vector<T> result)
|
{
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
DoSubtractFrom(scalar, result);
|
}
|
|
/// <summary>
|
/// Returns a negated vector.
|
/// </summary>
|
/// <returns>The negated vector.</returns>
|
/// <remarks>Added as an alternative to the unary negation operator.</remarks>
|
public Vector<T> Negate()
|
{
|
var retrunVector = Build.SameAs(this);
|
DoNegate(retrunVector);
|
return retrunVector;
|
}
|
|
/// <summary>
|
/// Negates vector and save result to <paramref name="result"/>
|
/// </summary>
|
/// <param name="result">Target vector</param>
|
public void Negate(Vector<T> result)
|
{
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
DoNegate(result);
|
}
|
|
/// <summary>
|
/// Subtracts another vector from this vector.
|
/// </summary>
|
/// <param name="other">The vector to subtract from this one.</param>
|
/// <returns>A new vector containing the subtraction of the two vectors.</returns>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="other"/> are not the same size.</exception>
|
public Vector<T> Subtract(Vector<T> other)
|
{
|
if (Count != other.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(other));
|
}
|
|
var result = Build.SameAs(this, other);
|
DoSubtract(other, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Subtracts another vector to this vector and stores the result into the result vector.
|
/// </summary>
|
/// <param name="other">The vector to subtract from this one.</param>
|
/// <param name="result">The vector to store the result of the subtraction.</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="other"/> are not the same size.</exception>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="result"/> are not the same size.</exception>
|
public void Subtract(Vector<T> other, Vector<T> result)
|
{
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
DoSubtract(other, result);
|
}
|
|
/// <summary>
|
/// Return vector with complex conjugate values of the source vector
|
/// </summary>
|
/// <returns>Conjugated vector</returns>
|
public Vector<T> Conjugate()
|
{
|
var retrunVector = Build.SameAs(this);
|
DoConjugate(retrunVector);
|
return retrunVector;
|
}
|
|
/// <summary>
|
/// Complex conjugates vector and save result to <paramref name="result"/>
|
/// </summary>
|
/// <param name="result">Target vector</param>
|
public void Conjugate(Vector<T> result)
|
{
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
DoConjugate(result);
|
}
|
|
/// <summary>
|
/// Multiplies a scalar to each element of the vector.
|
/// </summary>
|
/// <param name="scalar">The scalar to multiply.</param>
|
/// <returns>A new vector that is the multiplication of the vector and the scalar.</returns>
|
public Vector<T> Multiply(T scalar)
|
{
|
if (scalar.Equals(One))
|
{
|
return Clone();
|
}
|
|
if (scalar.Equals(Zero))
|
{
|
return Build.SameAs(this);
|
}
|
|
var result = Build.SameAs(this);
|
DoMultiply(scalar, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Multiplies a scalar to each element of the vector and stores the result in the result vector.
|
/// </summary>
|
/// <param name="scalar">The scalar to multiply.</param>
|
/// <param name="result">The vector to store the result of the multiplication.</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="result"/> are not the same size.</exception>
|
public void Multiply(T scalar, Vector<T> result)
|
{
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
if (scalar.Equals(One))
|
{
|
CopyTo(result);
|
return;
|
}
|
|
if (scalar.Equals(Zero))
|
{
|
result.Clear();
|
return;
|
}
|
|
DoMultiply(scalar, result);
|
}
|
|
/// <summary>
|
/// Computes the dot product between this vector and another vector.
|
/// </summary>
|
/// <param name="other">The other vector.</param>
|
/// <returns>The sum of a[i]*b[i] for all i.</returns>
|
/// <exception cref="ArgumentException">If <paramref name="other"/> is not of the same size.</exception>
|
/// <seealso cref="ConjugateDotProduct"/>
|
public T DotProduct(Vector<T> other)
|
{
|
if (Count != other.Count) throw new ArgumentException("All vectors must have the same dimensionality.", nameof(other));
|
|
return DoDotProduct(other);
|
}
|
|
/// <summary>
|
/// Computes the dot product between the conjugate of this vector and another vector.
|
/// </summary>
|
/// <param name="other">The other vector.</param>
|
/// <returns>The sum of conj(a[i])*b[i] for all i.</returns>
|
/// <exception cref="ArgumentException">If <paramref name="other"/> is not of the same size.</exception>
|
/// <exception cref="ArgumentNullException">If <paramref name="other"/> is <see langword="null"/>.</exception>
|
/// <seealso cref="DotProduct"/>
|
public T ConjugateDotProduct(Vector<T> other)
|
{
|
if (Count != other.Count) throw new ArgumentException("All vectors must have the same dimensionality.", nameof(other));
|
|
return DoConjugateDotProduct(other);
|
}
|
|
/// <summary>
|
/// Divides each element of the vector by a scalar.
|
/// </summary>
|
/// <param name="scalar">The scalar to divide with.</param>
|
/// <returns>A new vector that is the division of the vector and the scalar.</returns>
|
public Vector<T> Divide(T scalar)
|
{
|
if (scalar.Equals(One))
|
{
|
return Clone();
|
}
|
|
var result = Build.SameAs(this);
|
DoDivide(scalar, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Divides each element of the vector by a scalar and stores the result in the result vector.
|
/// </summary>
|
/// <param name="scalar">The scalar to divide with.</param>
|
/// <param name="result">The vector to store the result of the division.</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="result"/> are not the same size.</exception>
|
public void Divide(T scalar, Vector<T> result)
|
{
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
if (scalar.Equals(One))
|
{
|
CopyTo(result);
|
return;
|
}
|
|
DoDivide(scalar, result);
|
}
|
|
/// <summary>
|
/// Divides a scalar by each element of the vector.
|
/// </summary>
|
/// <param name="scalar">The scalar to divide.</param>
|
/// <returns>A new vector that is the division of the vector and the scalar.</returns>
|
public Vector<T> DivideByThis(T scalar)
|
{
|
var result = Build.SameAs(this);
|
DoDivideByThis(scalar, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Divides a scalar by each element of the vector and stores the result in the result vector.
|
/// </summary>
|
/// <param name="scalar">The scalar to divide.</param>
|
/// <param name="result">The vector to store the result of the division.</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="result"/> are not the same size.</exception>
|
public void DivideByThis(T scalar, Vector<T> result)
|
{
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
DoDivideByThis(scalar, result);
|
}
|
|
/// <summary>
|
/// Computes the canonical modulus, where the result has the sign of the divisor,
|
/// for each element of the vector for the given divisor.
|
/// </summary>
|
/// <param name="divisor">The scalar denominator to use.</param>
|
/// <returns>A vector containing the result.</returns>
|
public Vector<T> Modulus(T divisor)
|
{
|
var result = Build.SameAs(this);
|
DoModulus(divisor, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Computes the canonical modulus, where the result has the sign of the divisor,
|
/// for each element of the vector for the given divisor.
|
/// </summary>
|
/// <param name="divisor">The scalar denominator to use.</param>
|
/// <param name="result">A vector to store the results in.</param>
|
public void Modulus(T divisor, Vector<T> result)
|
{
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
DoModulus(divisor, result);
|
}
|
|
/// <summary>
|
/// Computes the canonical modulus, where the result has the sign of the divisor,
|
/// for the given dividend for each element of the vector.
|
/// </summary>
|
/// <param name="dividend">The scalar numerator to use.</param>
|
/// <returns>A vector containing the result.</returns>
|
public Vector<T> ModulusByThis(T dividend)
|
{
|
var result = Build.SameAs(this);
|
DoModulusByThis(dividend, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Computes the canonical modulus, where the result has the sign of the divisor,
|
/// for the given dividend for each element of the vector.
|
/// </summary>
|
/// <param name="dividend">The scalar numerator to use.</param>
|
/// <param name="result">A vector to store the results in.</param>
|
public void ModulusByThis(T dividend, Vector<T> result)
|
{
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
DoModulusByThis(dividend, result);
|
}
|
|
/// <summary>
|
/// Computes the remainder (vector % divisor), where the result has the sign of the dividend,
|
/// for each element of the vector for the given divisor.
|
/// </summary>
|
/// <param name="divisor">The scalar denominator to use.</param>
|
/// <returns>A vector containing the result.</returns>
|
public Vector<T> Remainder(T divisor)
|
{
|
var result = Build.SameAs(this);
|
DoRemainder(divisor, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Computes the remainder (vector % divisor), where the result has the sign of the dividend,
|
/// for each element of the vector for the given divisor.
|
/// </summary>
|
/// <param name="divisor">The scalar denominator to use.</param>
|
/// <param name="result">A vector to store the results in.</param>
|
public void Remainder(T divisor, Vector<T> result)
|
{
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
DoRemainder(divisor, result);
|
}
|
|
/// <summary>
|
/// Computes the remainder (dividend % vector), where the result has the sign of the dividend,
|
/// for the given dividend for each element of the vector.
|
/// </summary>
|
/// <param name="dividend">The scalar numerator to use.</param>
|
/// <returns>A vector containing the result.</returns>
|
public Vector<T> RemainderByThis(T dividend)
|
{
|
var result = Build.SameAs(this);
|
DoRemainderByThis(dividend, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Computes the remainder (dividend % vector), where the result has the sign of the dividend,
|
/// for the given dividend for each element of the vector.
|
/// </summary>
|
/// <param name="dividend">The scalar numerator to use.</param>
|
/// <param name="result">A vector to store the results in.</param>
|
public void RemainderByThis(T dividend, Vector<T> result)
|
{
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
DoRemainderByThis(dividend, result);
|
}
|
|
/// <summary>
|
/// Pointwise multiplies this vector with another vector.
|
/// </summary>
|
/// <param name="other">The vector to pointwise multiply with this one.</param>
|
/// <returns>A new vector which is the pointwise multiplication of the two vectors.</returns>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="other"/> are not the same size.</exception>
|
public Vector<T> PointwiseMultiply(Vector<T> other)
|
{
|
if (Count != other.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(other));
|
}
|
|
var result = Build.SameAs(this, other);
|
DoPointwiseMultiply(other, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Pointwise multiplies this vector with another vector and stores the result into the result vector.
|
/// </summary>
|
/// <param name="other">The vector to pointwise multiply with this one.</param>
|
/// <param name="result">The vector to store the result of the pointwise multiplication.</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="other"/> are not the same size.</exception>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="result"/> are not the same size.</exception>
|
public void PointwiseMultiply(Vector<T> other, Vector<T> result)
|
{
|
if (Count != other.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(other));
|
}
|
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
DoPointwiseMultiply(other, result);
|
}
|
|
/// <summary>
|
/// Pointwise divide this vector with another vector.
|
/// </summary>
|
/// <param name="divisor">The pointwise denominator vector to use.</param>
|
/// <returns>A new vector which is the pointwise division of the two vectors.</returns>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="divisor"/> are not the same size.</exception>
|
public Vector<T> PointwiseDivide(Vector<T> divisor)
|
{
|
if (Count != divisor.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(divisor));
|
}
|
|
var result = Build.SameAs(this, divisor);
|
DoPointwiseDivide(divisor, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Pointwise divide this vector with another vector and stores the result into the result vector.
|
/// </summary>
|
/// <param name="divisor">The pointwise denominator vector to use.</param>
|
/// <param name="result">The vector to store the result of the pointwise division.</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="divisor"/> are not the same size.</exception>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="result"/> are not the same size.</exception>
|
public void PointwiseDivide(Vector<T> divisor, Vector<T> result)
|
{
|
if (Count != divisor.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(divisor));
|
}
|
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
DoPointwiseDivide(divisor, result);
|
}
|
|
/// <summary>
|
/// Pointwise raise this vector to an exponent.
|
/// </summary>
|
/// <param name="exponent">The exponent to raise this vector values to.</param>
|
public Vector<T> PointwisePower(T exponent)
|
{
|
var result = Build.SameAs(this);
|
DoPointwisePower(exponent, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Pointwise raise this vector to an exponent and store the result into the result vector.
|
/// </summary>
|
/// <param name="exponent">The exponent to raise this vector values to.</param>
|
/// <param name="result">The matrix to store the result into.</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="result"/> are not the same size.</exception>
|
public void PointwisePower(T exponent, Vector<T> result)
|
{
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
DoPointwisePower(exponent, result);
|
}
|
|
/// <summary>
|
/// Pointwise raise this vector to an exponent and store the result into the result vector.
|
/// </summary>
|
/// <param name="exponent">The exponent to raise this vector values to.</param>
|
public Vector<T> PointwisePower(Vector<T> exponent)
|
{
|
if (Count != exponent.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(exponent));
|
}
|
|
var result = Build.SameAs(this);
|
DoPointwisePower(exponent, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Pointwise raise this vector to an exponent.
|
/// </summary>
|
/// <param name="exponent">The exponent to raise this vector values to.</param>
|
/// <param name="result">The vector to store the result into.</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="result"/> are not the same size.</exception>
|
public void PointwisePower(Vector<T> exponent, Vector<T> result)
|
{
|
if (Count != exponent.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(exponent));
|
}
|
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
DoPointwisePower(exponent, result);
|
}
|
|
/// <summary>
|
/// Pointwise canonical modulus, where the result has the sign of the divisor,
|
/// of this vector with another vector.
|
/// </summary>
|
/// <param name="divisor">The pointwise denominator vector to use.</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="divisor"/> are not the same size.</exception>
|
public Vector<T> PointwiseModulus(Vector<T> divisor)
|
{
|
if (Count != divisor.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(divisor));
|
}
|
|
var result = Build.SameAs(this, divisor);
|
DoPointwiseModulus(divisor, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Pointwise canonical modulus, where the result has the sign of the divisor,
|
/// of this vector with another vector and stores the result into the result vector.
|
/// </summary>
|
/// <param name="divisor">The pointwise denominator vector to use.</param>
|
/// <param name="result">The vector to store the result of the pointwise modulus.</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="divisor"/> are not the same size.</exception>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="result"/> are not the same size.</exception>
|
public void PointwiseModulus(Vector<T> divisor, Vector<T> result)
|
{
|
if (Count != divisor.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(divisor));
|
}
|
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
DoPointwiseModulus(divisor, result);
|
}
|
/// <summary>
|
/// Pointwise remainder (% operator), where the result has the sign of the dividend,
|
/// of this vector with another vector.
|
/// </summary>
|
/// <param name="divisor">The pointwise denominator vector to use.</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="divisor"/> are not the same size.</exception>
|
public Vector<T> PointwiseRemainder(Vector<T> divisor)
|
{
|
if (Count != divisor.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(divisor));
|
}
|
|
var result = Build.SameAs(this, divisor);
|
DoPointwiseRemainder(divisor, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Pointwise remainder (% operator), where the result has the sign of the dividend,
|
/// this vector with another vector and stores the result into the result vector.
|
/// </summary>
|
/// <param name="divisor">The pointwise denominator vector to use.</param>
|
/// <param name="result">The vector to store the result of the pointwise remainder.</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="divisor"/> are not the same size.</exception>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="result"/> are not the same size.</exception>
|
public void PointwiseRemainder(Vector<T> divisor, Vector<T> result)
|
{
|
if (Count != divisor.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(divisor));
|
}
|
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
DoPointwiseRemainder(divisor, result);
|
}
|
|
/// <summary>
|
/// Helper function to apply a unary function to a vector. The function
|
/// f modifies the vector given to it in place. Before its
|
/// called, a copy of the 'this' vector with the same dimension is
|
/// first created, then passed to f. The copy is returned as the result
|
/// </summary>
|
/// <param name="f">Function which takes a vector, modifies it in place and returns void</param>
|
/// <returns>New instance of vector which is the result</returns>
|
protected Vector<T> PointwiseUnary(Action<Vector<T>> f)
|
{
|
var result = Build.SameAs(this);
|
f(result);
|
return result;
|
}
|
|
/// <summary>
|
/// Helper function to apply a unary function which modifies a vector
|
/// in place.
|
/// </summary>
|
/// <param name="f">Function which takes a vector, modifies it in place and returns void</param>
|
/// <param name="result">The vector where the result is to be stored</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="result"/> are not the same size.</exception>
|
protected void PointwiseUnary(Action<Vector<T>> f, Vector<T> result)
|
{
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
f(result);
|
}
|
|
/// <summary>
|
/// Helper function to apply a binary function which takes a scalar and
|
/// a vector and modifies the latter in place. A copy of the "this"
|
/// vector is therefore first made and then passed to f together with
|
/// the scalar argument. The copy is then returned as the result
|
/// </summary>
|
/// <param name="f">Function which takes a scalar and a vector, modifies the vector in place and returns void</param>
|
/// <param name="other">The scalar to be passed to the function</param>
|
/// <returns>The resulting vector</returns>
|
protected Vector<T> PointwiseBinary(Action<T, Vector<T>> f, T other)
|
{
|
var result = Build.SameAs(this);
|
f(other, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Helper function to apply a binary function which takes a scalar and
|
/// a vector, modifies the latter in place and returns void.
|
/// </summary>
|
/// <param name="f">Function which takes a scalar and a vector, modifies the vector in place and returns void</param>
|
/// <param name="x">The scalar to be passed to the function</param>
|
/// <param name="result">The vector where the result will be placed</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="result"/> are not the same size.</exception>
|
protected void PointwiseBinary(Action<T, Vector<T>> f, T x, Vector<T> result)
|
{
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
f(x, result);
|
}
|
|
/// <summary>
|
/// Helper function to apply a binary function which takes two vectors
|
/// and modifies the latter in place. A copy of the "this" vector is
|
/// first made and then passed to f together with the other vector. The
|
/// copy is then returned as the result
|
/// </summary>
|
/// <param name="f">Function which takes two vectors, modifies the second in place and returns void</param>
|
/// <param name="other">The other vector to be passed to the function as argument. It is not modified</param>
|
/// <returns>The resulting vector</returns>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="other"/> are not the same size.</exception>
|
protected Vector<T> PointwiseBinary(Action<Vector<T>, Vector<T>> f, Vector<T> other)
|
{
|
if (Count != other.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(other));
|
}
|
|
var result = Build.SameAs(this, other);
|
f(other, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Helper function to apply a binary function which takes two vectors
|
/// and modifies the second one in place
|
/// </summary>
|
/// <param name="f">Function which takes two vectors, modifies the second in place and returns void</param>
|
/// <param name="other">The other vector to be passed to the function as argument. It is not modified</param>
|
/// <param name="result">The resulting vector</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="other"/> are not the same size.</exception>
|
protected void PointwiseBinary(Action<Vector<T>, Vector<T>> f, Vector<T> other, Vector<T> result)
|
{
|
if (Count != other.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(other));
|
}
|
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
f(other, result);
|
}
|
|
/// <summary>
|
/// Pointwise applies the exponent function to each value.
|
/// </summary>
|
public Vector<T> PointwiseExp()
|
{
|
return PointwiseUnary(DoPointwiseExp);
|
}
|
|
/// <summary>
|
/// Pointwise applies the exponent function to each value.
|
/// </summary>
|
/// <param name="result">The vector to store the result.</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="result"/> are not the same size.</exception>
|
public void PointwiseExp(Vector<T> result)
|
{
|
PointwiseUnary(DoPointwiseExp, result);
|
}
|
|
/// <summary>
|
/// Pointwise applies the natural logarithm function to each value.
|
/// </summary>
|
public Vector<T> PointwiseLog()
|
{
|
return PointwiseUnary(DoPointwiseLog);
|
}
|
|
/// <summary>
|
/// Pointwise applies the natural logarithm function to each value.
|
/// </summary>
|
/// <param name="result">The vector to store the result.</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="result"/> are not the same size.</exception>
|
public void PointwiseLog(Vector<T> result)
|
{
|
PointwiseUnary(DoPointwiseLog, result);
|
}
|
|
/// <summary>
|
/// Pointwise applies the abs function to each value
|
/// </summary>
|
public Vector<T> PointwiseAbs()
|
{
|
return PointwiseUnary(DoPointwiseAbs);
|
}
|
|
/// <summary>
|
/// Pointwise applies the abs function to each value
|
/// </summary>
|
/// <param name="result">The vector to store the result</param>
|
public void PointwiseAbs(Vector<T> result)
|
{
|
PointwiseUnary(DoPointwiseAbs, result);
|
}
|
|
/// <summary>
|
/// Pointwise applies the acos function to each value
|
/// </summary>
|
public Vector<T> PointwiseAcos()
|
{
|
return PointwiseUnary(DoPointwiseAcos);
|
}
|
|
/// <summary>
|
/// Pointwise applies the acos function to each value
|
/// </summary>
|
/// <param name="result">The vector to store the result</param>
|
public void PointwiseAcos(Vector<T> result)
|
{
|
PointwiseUnary(DoPointwiseAcos, result);
|
}
|
|
/// <summary>
|
/// Pointwise applies the asin function to each value
|
/// </summary>
|
public Vector<T> PointwiseAsin()
|
{
|
return PointwiseUnary(DoPointwiseAsin);
|
}
|
|
/// <summary>
|
/// Pointwise applies the asin function to each value
|
/// </summary>
|
/// <param name="result">The vector to store the result</param>
|
public void PointwiseAsin(Vector<T> result)
|
{
|
PointwiseUnary(DoPointwiseAsin, result);
|
}
|
|
/// <summary>
|
/// Pointwise applies the atan function to each value
|
/// </summary>
|
public Vector<T> PointwiseAtan()
|
{
|
return PointwiseUnary(DoPointwiseAtan);
|
}
|
|
/// <summary>
|
/// Pointwise applies the atan function to each value
|
/// </summary>
|
/// <param name="result">The vector to store the result</param>
|
public void PointwiseAtan(Vector<T> result)
|
{
|
PointwiseUnary(DoPointwiseAtan, result);
|
}
|
|
/// <summary>
|
/// Pointwise applies the atan2 function to each value of the current
|
/// vector and a given other vector being the 'x' of atan2 and the
|
/// 'this' vector being the 'y'
|
/// </summary>
|
/// <param name="other"></param>
|
public Vector<T> PointwiseAtan2(Vector<T> other)
|
{
|
return PointwiseBinary(DoPointwiseAtan2, other);
|
}
|
|
/// <summary>
|
/// Pointwise applies the atan2 function to each value of the current
|
/// vector and a given other vector being the 'x' of atan2 and the
|
/// 'this' vector being the 'y'
|
/// </summary>
|
/// <param name="other"></param>
|
/// <param name="result">The vector to store the result</param>
|
public void PointwiseAtan2(Vector<T> other, Vector<T> result)
|
{
|
PointwiseBinary(DoPointwiseAtan2, other, result);
|
}
|
|
/// <summary>
|
/// Pointwise applies the ceiling function to each value
|
/// </summary>
|
public Vector<T> PointwiseCeiling()
|
{
|
return PointwiseUnary(DoPointwiseCeiling);
|
}
|
|
/// <summary>
|
/// Pointwise applies the ceiling function to each value
|
/// </summary>
|
/// <param name="result">The vector to store the result</param>
|
public void PointwiseCeiling(Vector<T> result)
|
{
|
PointwiseUnary(DoPointwiseCeiling, result);
|
}
|
|
/// <summary>
|
/// Pointwise applies the cos function to each value
|
/// </summary>
|
public Vector<T> PointwiseCos()
|
{
|
return PointwiseUnary(DoPointwiseCos);
|
}
|
|
/// <summary>
|
/// Pointwise applies the cos function to each value
|
/// </summary>
|
/// <param name="result">The vector to store the result</param>
|
public void PointwiseCos(Vector<T> result)
|
{
|
PointwiseUnary(DoPointwiseCos, result);
|
}
|
|
/// <summary>
|
/// Pointwise applies the cosh function to each value
|
/// </summary>
|
public Vector<T> PointwiseCosh()
|
{
|
return PointwiseUnary(DoPointwiseCosh);
|
}
|
|
/// <summary>
|
/// Pointwise applies the cosh function to each value
|
/// </summary>
|
/// <param name="result">The vector to store the result</param>
|
public void PointwiseCosh(Vector<T> result)
|
{
|
PointwiseUnary(DoPointwiseCosh, result);
|
}
|
|
/// <summary>
|
/// Pointwise applies the floor function to each value
|
/// </summary>
|
public Vector<T> PointwiseFloor()
|
{
|
return PointwiseUnary(DoPointwiseFloor);
|
}
|
|
/// <summary>
|
/// Pointwise applies the floor function to each value
|
/// </summary>
|
/// <param name="result">The vector to store the result</param>
|
public void PointwiseFloor(Vector<T> result)
|
{
|
PointwiseUnary(DoPointwiseFloor, result);
|
}
|
|
/// <summary>
|
/// Pointwise applies the log10 function to each value
|
/// </summary>
|
public Vector<T> PointwiseLog10()
|
{
|
return PointwiseUnary(DoPointwiseLog10);
|
}
|
|
/// <summary>
|
/// Pointwise applies the log10 function to each value
|
/// </summary>
|
/// <param name="result">The vector to store the result</param>
|
public void PointwiseLog10(Vector<T> result)
|
{
|
PointwiseUnary(DoPointwiseLog10, result);
|
}
|
|
/// <summary>
|
/// Pointwise applies the round function to each value
|
/// </summary>
|
public Vector<T> PointwiseRound()
|
{
|
return PointwiseUnary(DoPointwiseRound);
|
}
|
|
/// <summary>
|
/// Pointwise applies the round function to each value
|
/// </summary>
|
/// <param name="result">The vector to store the result</param>
|
public void PointwiseRound(Vector<T> result)
|
{
|
PointwiseUnary(DoPointwiseRound, result);
|
}
|
|
/// <summary>
|
/// Pointwise applies the sign function to each value
|
/// </summary>
|
public Vector<T> PointwiseSign()
|
{
|
return PointwiseUnary(DoPointwiseSign);
|
}
|
|
/// <summary>
|
/// Pointwise applies the sign function to each value
|
/// </summary>
|
/// <param name="result">The vector to store the result</param>
|
public void PointwiseSign(Vector<T> result)
|
{
|
PointwiseUnary(DoPointwiseSign, result);
|
}
|
|
/// <summary>
|
/// Pointwise applies the sin function to each value
|
/// </summary>
|
public Vector<T> PointwiseSin()
|
{
|
return PointwiseUnary(DoPointwiseSin);
|
}
|
|
/// <summary>
|
/// Pointwise applies the sin function to each value
|
/// </summary>
|
/// <param name="result">The vector to store the result</param>
|
public void PointwiseSin(Vector<T> result)
|
{
|
PointwiseUnary(DoPointwiseSin, result);
|
}
|
|
/// <summary>
|
/// Pointwise applies the sinh function to each value
|
/// </summary>
|
public Vector<T> PointwiseSinh()
|
{
|
return PointwiseUnary(DoPointwiseSinh);
|
}
|
|
/// <summary>
|
/// Pointwise applies the sinh function to each value
|
/// </summary>
|
/// <param name="result">The vector to store the result</param>
|
public void PointwiseSinh(Vector<T> result)
|
{
|
PointwiseUnary(DoPointwiseSinh, result);
|
}
|
|
/// <summary>
|
/// Pointwise applies the sqrt function to each value
|
/// </summary>
|
public Vector<T> PointwiseSqrt()
|
{
|
return PointwiseUnary(DoPointwiseSqrt);
|
}
|
|
/// <summary>
|
/// Pointwise applies the sqrt function to each value
|
/// </summary>
|
/// <param name="result">The vector to store the result</param>
|
public void PointwiseSqrt(Vector<T> result)
|
{
|
PointwiseUnary(DoPointwiseSqrt, result);
|
}
|
|
/// <summary>
|
/// Pointwise applies the tan function to each value
|
/// </summary>
|
public Vector<T> PointwiseTan()
|
{
|
return PointwiseUnary(DoPointwiseTan);
|
}
|
|
/// <summary>
|
/// Pointwise applies the tan function to each value
|
/// </summary>
|
/// <param name="result">The vector to store the result</param>
|
public void PointwiseTan(Vector<T> result)
|
{
|
PointwiseUnary(DoPointwiseTan, result);
|
}
|
|
/// <summary>
|
/// Pointwise applies the tanh function to each value
|
/// </summary>
|
public Vector<T> PointwiseTanh()
|
{
|
return PointwiseUnary(DoPointwiseTanh);
|
}
|
|
/// <summary>
|
/// Pointwise applies the tanh function to each value
|
/// </summary>
|
/// <param name="result">The vector to store the result</param>
|
public void PointwiseTanh(Vector<T> result)
|
{
|
PointwiseUnary(DoPointwiseTanh, result);
|
}
|
|
/// <summary>
|
/// Computes the outer product M[i,j] = u[i]*v[j] of this and another vector.
|
/// </summary>
|
/// <param name="other">The other vector</param>
|
public Matrix<T> OuterProduct(Vector<T> other)
|
{
|
var matrix = Matrix<T>.Build.SameAs(this, Count, other.Count);
|
DoOuterProduct(other, matrix);
|
return matrix;
|
}
|
|
/// <summary>
|
/// Computes the outer product M[i,j] = u[i]*v[j] of this and another vector and stores the result in the result matrix.
|
/// </summary>
|
/// <param name="other">The other vector</param>
|
/// <param name="result">The matrix to store the result of the product.</param>
|
public void OuterProduct(Vector<T> other, Matrix<T> result)
|
{
|
if (Count != result.RowCount || other.Count != result.ColumnCount)
|
{
|
throw new ArgumentException("Matrix dimensions must agree.", nameof(result));
|
}
|
|
DoOuterProduct(other, result);
|
}
|
|
public static Matrix<T> OuterProduct(Vector<T> u, Vector<T> v)
|
{
|
return u.OuterProduct(v);
|
}
|
|
/// <summary>
|
/// Pointwise applies the minimum with a scalar to each value.
|
/// </summary>
|
/// <param name="scalar">The scalar value to compare to.</param>
|
public Vector<T> PointwiseMinimum(T scalar)
|
{
|
var result = Build.SameAs(this);
|
DoPointwiseMinimum(scalar, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Pointwise applies the minimum with a scalar to each value.
|
/// </summary>
|
/// <param name="scalar">The scalar value to compare to.</param>
|
/// <param name="result">The vector to store the result.</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="result"/> are not the same size.</exception>
|
public void PointwiseMinimum(T scalar, Vector<T> result)
|
{
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
DoPointwiseMinimum(scalar, result);
|
}
|
|
/// <summary>
|
/// Pointwise applies the maximum with a scalar to each value.
|
/// </summary>
|
/// <param name="scalar">The scalar value to compare to.</param>
|
public Vector<T> PointwiseMaximum(T scalar)
|
{
|
var result = Build.SameAs(this);
|
DoPointwiseMaximum(scalar, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Pointwise applies the maximum with a scalar to each value.
|
/// </summary>
|
/// <param name="scalar">The scalar value to compare to.</param>
|
/// <param name="result">The vector to store the result.</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="result"/> are not the same size.</exception>
|
public void PointwiseMaximum(T scalar, Vector<T> result)
|
{
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
DoPointwiseMaximum(scalar, result);
|
}
|
|
/// <summary>
|
/// Pointwise applies the absolute minimum with a scalar to each value.
|
/// </summary>
|
/// <param name="scalar">The scalar value to compare to.</param>
|
public Vector<T> PointwiseAbsoluteMinimum(T scalar)
|
{
|
var result = Build.SameAs(this);
|
DoPointwiseAbsoluteMinimum(scalar, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Pointwise applies the absolute minimum with a scalar to each value.
|
/// </summary>
|
/// <param name="scalar">The scalar value to compare to.</param>
|
/// <param name="result">The vector to store the result.</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="result"/> are not the same size.</exception>
|
public void PointwiseAbsoluteMinimum(T scalar, Vector<T> result)
|
{
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
DoPointwiseAbsoluteMinimum(scalar, result);
|
}
|
|
/// <summary>
|
/// Pointwise applies the absolute maximum with a scalar to each value.
|
/// </summary>
|
/// <param name="scalar">The scalar value to compare to.</param>
|
public Vector<T> PointwiseAbsoluteMaximum(T scalar)
|
{
|
var result = Build.SameAs(this);
|
DoPointwiseAbsoluteMaximum(scalar, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Pointwise applies the absolute maximum with a scalar to each value.
|
/// </summary>
|
/// <param name="scalar">The scalar value to compare to.</param>
|
/// <param name="result">The vector to store the result.</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="result"/> are not the same size.</exception>
|
public void PointwiseAbsoluteMaximum(T scalar, Vector<T> result)
|
{
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
DoPointwiseAbsoluteMaximum(scalar, result);
|
}
|
|
/// <summary>
|
/// Pointwise applies the minimum with the values of another vector to each value.
|
/// </summary>
|
/// <param name="other">The vector with the values to compare to.</param>
|
public Vector<T> PointwiseMinimum(Vector<T> other)
|
{
|
var result = Build.SameAs(this);
|
DoPointwiseMinimum(other, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Pointwise applies the minimum with the values of another vector to each value.
|
/// </summary>
|
/// <param name="other">The vector with the values to compare to.</param>
|
/// <param name="result">The vector to store the result.</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="result"/> are not the same size.</exception>
|
public void PointwiseMinimum(Vector<T> other, Vector<T> result)
|
{
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
DoPointwiseMinimum(other, result);
|
}
|
|
/// <summary>
|
/// Pointwise applies the maximum with the values of another vector to each value.
|
/// </summary>
|
/// <param name="other">The vector with the values to compare to.</param>
|
public Vector<T> PointwiseMaximum(Vector<T> other)
|
{
|
var result = Build.SameAs(this);
|
DoPointwiseMaximum(other, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Pointwise applies the maximum with the values of another vector to each value.
|
/// </summary>
|
/// <param name="other">The vector with the values to compare to.</param>
|
/// <param name="result">The vector to store the result.</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="result"/> are not the same size.</exception>
|
public void PointwiseMaximum(Vector<T> other, Vector<T> result)
|
{
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
DoPointwiseMaximum(other, result);
|
}
|
|
/// <summary>
|
/// Pointwise applies the absolute minimum with the values of another vector to each value.
|
/// </summary>
|
/// <param name="other">The vector with the values to compare to.</param>
|
public Vector<T> PointwiseAbsoluteMinimum(Vector<T> other)
|
{
|
var result = Build.SameAs(this);
|
DoPointwiseAbsoluteMinimum(other, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Pointwise applies the absolute minimum with the values of another vector to each value.
|
/// </summary>
|
/// <param name="other">The vector with the values to compare to.</param>
|
/// <param name="result">The vector to store the result.</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="result"/> are not the same size.</exception>
|
public void PointwiseAbsoluteMinimum(Vector<T> other, Vector<T> result)
|
{
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
DoPointwiseAbsoluteMinimum(other, result);
|
}
|
|
/// <summary>
|
/// Pointwise applies the absolute maximum with the values of another vector to each value.
|
/// </summary>
|
/// <param name="other">The vector with the values to compare to.</param>
|
public Vector<T> PointwiseAbsoluteMaximum(Vector<T> other)
|
{
|
var result = Build.SameAs(this);
|
DoPointwiseAbsoluteMaximum(other, result);
|
return result;
|
}
|
|
/// <summary>
|
/// Pointwise applies the absolute maximum with the values of another vector to each value.
|
/// </summary>
|
/// <param name="other">The vector with the values to compare to.</param>
|
/// <param name="result">The vector to store the result.</param>
|
/// <exception cref="ArgumentException">If this vector and <paramref name="result"/> are not the same size.</exception>
|
public void PointwiseAbsoluteMaximum(Vector<T> other, Vector<T> result)
|
{
|
if (Count != result.Count)
|
{
|
throw new ArgumentException("All vectors must have the same dimensionality.", nameof(result));
|
}
|
|
DoPointwiseAbsoluteMaximum(other, result);
|
}
|
|
/// <summary>
|
/// Calculates the L1 norm of the vector, also known as Manhattan norm.
|
/// </summary>
|
/// <returns>The sum of the absolute values.</returns>
|
public abstract double L1Norm();
|
|
/// <summary>
|
/// Calculates the L2 norm of the vector, also known as Euclidean norm.
|
/// </summary>
|
/// <returns>The square root of the sum of the squared values.</returns>
|
public abstract double L2Norm();
|
|
/// <summary>
|
/// Calculates the infinity norm of the vector.
|
/// </summary>
|
/// <returns>The maximum absolute value.</returns>
|
public abstract double InfinityNorm();
|
|
/// <summary>
|
/// Computes the p-Norm.
|
/// </summary>
|
/// <param name="p">The p value.</param>
|
/// <returns><c>Scalar ret = (sum(abs(this[i])^p))^(1/p)</c></returns>
|
public abstract double Norm(double p);
|
|
/// <summary>
|
/// Normalizes this vector to a unit vector with respect to the p-norm.
|
/// </summary>
|
/// <param name="p">The p value.</param>
|
/// <returns>This vector normalized to a unit vector with respect to the p-norm.</returns>
|
public abstract Vector<T> Normalize(double p);
|
|
/// <summary>
|
/// Returns the value of the absolute minimum element.
|
/// </summary>
|
/// <returns>The value of the absolute minimum element.</returns>
|
public abstract T AbsoluteMinimum();
|
|
/// <summary>
|
/// Returns the index of the absolute minimum element.
|
/// </summary>
|
/// <returns>The index of absolute minimum element.</returns>
|
public abstract int AbsoluteMinimumIndex();
|
|
/// <summary>
|
/// Returns the value of the absolute maximum element.
|
/// </summary>
|
/// <returns>The value of the absolute maximum element.</returns>
|
public abstract T AbsoluteMaximum();
|
|
/// <summary>
|
/// Returns the index of the absolute maximum element.
|
/// </summary>
|
/// <returns>The index of absolute maximum element.</returns>
|
public abstract int AbsoluteMaximumIndex();
|
|
/// <summary>
|
/// Returns the value of maximum element.
|
/// </summary>
|
/// <returns>The value of maximum element.</returns>
|
public T Maximum()
|
{
|
return At(MaximumIndex());
|
}
|
|
/// <summary>
|
/// Returns the index of the maximum element.
|
/// </summary>
|
/// <returns>The index of maximum element.</returns>
|
public abstract int MaximumIndex();
|
|
/// <summary>
|
/// Returns the value of the minimum element.
|
/// </summary>
|
/// <returns>The value of the minimum element.</returns>
|
public T Minimum()
|
{
|
return At(MinimumIndex());
|
}
|
|
/// <summary>
|
/// Returns the index of the minimum element.
|
/// </summary>
|
/// <returns>The index of minimum element.</returns>
|
public abstract int MinimumIndex();
|
|
/// <summary>
|
/// Computes the sum of the vector's elements.
|
/// </summary>
|
/// <returns>The sum of the vector's elements.</returns>
|
public abstract T Sum();
|
|
/// <summary>
|
/// Computes the sum of the absolute value of the vector's elements.
|
/// </summary>
|
/// <returns>The sum of the absolute value of the vector's elements.</returns>
|
public double SumMagnitudes()
|
{
|
return L1Norm();
|
}
|
}
|
}
|