-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathAccelerationMagnitude.g.cs
More file actions
49 lines (44 loc) · 3.17 KB
/
AccelerationMagnitude.g.cs
File metadata and controls
49 lines (44 loc) · 3.17 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
// Copyright (c) ktsu.dev
// All rights reserved.
// Licensed under the MIT license.
// <auto-generated />
namespace ktsu.Semantics.Quantities;
using System.Numerics;
/// <summary>
/// Magnitude (Vector0) quantity for the Acceleration dimension.
/// </summary>
/// <typeparam name="T">The numeric storage type.</typeparam>
public record AccelerationMagnitude<T> : PhysicalQuantity<AccelerationMagnitude<T>, T>, IVector0<AccelerationMagnitude<T>, T>
where T : struct, INumber<T>
{
/// <summary>Gets a quantity with value zero.</summary>
public static AccelerationMagnitude<T> Zero => Create(T.Zero);
/// <summary>
/// Creates a new <see cref="AccelerationMagnitude{T}"/> from a value in MetersPerSecondSquared.
/// </summary>
/// <param name="value">The value in MetersPerSecondSquared.</param>
/// <returns>A new <see cref="AccelerationMagnitude{T}"/> instance.</returns>
/// <exception cref="System.ArgumentException">Thrown when the resulting magnitude would be negative.</exception>
public static AccelerationMagnitude<T> FromMetersPerSecondSquared(T value) => Create(Vector0Guards.EnsureNonNegative(value, nameof(value)));
/// <summary>
/// Subtracts two AccelerationMagnitude values, returning the absolute difference as a non-negative AccelerationMagnitude.
/// Magnitude subtraction stays a magnitude (per the unified-vector model).
/// </summary>
[System.Diagnostics.CodeAnalysis.SuppressMessage("Usage", "CA2225:Operator overloads have named alternates", Justification = "Physics quantity operator")] public static AccelerationMagnitude<T> operator -(AccelerationMagnitude<T> left, AccelerationMagnitude<T> right) => Create(T.Abs(left.Quantity - right.Quantity));
/// <summary>
/// Multiplies AccelerationMagnitude by Mass to produce ForceMagnitude.
/// </summary>
[System.Diagnostics.CodeAnalysis.SuppressMessage("Usage", "CA2225:Operator overloads have named alternates", Justification = "Physics quantity operator")] public static ForceMagnitude<T> operator *(AccelerationMagnitude<T> left, Mass<T> right) => Multiply<ForceMagnitude<T>>(left, right);
/// <summary>
/// Multiplies AccelerationMagnitude by Duration to produce Speed.
/// </summary>
[System.Diagnostics.CodeAnalysis.SuppressMessage("Usage", "CA2225:Operator overloads have named alternates", Justification = "Physics quantity operator")] public static Speed<T> operator *(AccelerationMagnitude<T> left, Duration<T> right) => Multiply<Speed<T>>(left, right);
/// <summary>
/// Divides AccelerationMagnitude by Duration to produce JerkMagnitude.
/// </summary>
[System.Diagnostics.CodeAnalysis.SuppressMessage("Usage", "CA2225:Operator overloads have named alternates", Justification = "Physics quantity operator")] public static JerkMagnitude<T> operator /(AccelerationMagnitude<T> left, Duration<T> right) => Divide<JerkMagnitude<T>>(left, right);
/// <summary>
/// Divides AccelerationMagnitude by JerkMagnitude to produce Duration.
/// </summary>
[System.Diagnostics.CodeAnalysis.SuppressMessage("Usage", "CA2225:Operator overloads have named alternates", Justification = "Physics quantity operator")] public static Duration<T> operator /(AccelerationMagnitude<T> left, JerkMagnitude<T> right) => Divide<Duration<T>>(left, right);
};