/**
 * @author Theodore Kruczek.
 * @license MIT
 * @copyright (c) 2022-2025 Theodore Kruczek 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.
 */
import { J2000 } from '../coordinate/J2000.js';
import { AngularDistanceMethod } from '../enums/AngularDistanceMethod.js';
import { Degrees, Kilometers, Radians } from '../main.js';
import { Vector3D } from '../operations/Vector3D.js';
import { EpochUTC } from '../time/EpochUTC.js';
export declare class RAE {
    epoch: EpochUTC;
    rng: Kilometers;
    azRad: Radians;
    elRad: Radians;
    /** The range rate of the satellite relative to the observer in kilometers per second. */
    rngRate?: number;
    /** The azimuth rate of the satellite relative to the observer in radians per second. */
    azRateRad?: number;
    /** The elevation rate of the satellite relative to the observer in radians per second. */
    elRateRad?: number;
    constructor(epoch: EpochUTC, rng: Kilometers, azRad: Radians, elRad: Radians, 
    /** The range rate of the satellite relative to the observer in kilometers per second. */
    rngRate?: number, 
    /** The azimuth rate of the satellite relative to the observer in radians per second. */
    azRateRad?: number, 
    /** The elevation rate of the satellite relative to the observer in radians per second. */
    elRateRad?: number);
    static fromDegrees(epoch: EpochUTC, range: Kilometers, azimuth: Degrees, elevation: Degrees, rangeRate?: number, azimuthRate?: number, elevationRate?: number): RAE;
    /**
     * Create a [Razel] object from an inertial [state] and [site] vector.
     * @param state The inertial [state] vector.
     * @param site The observer [site] vector.
     * @returns A new [Razel] object.
     */
    static fromStateVector(state: J2000, site: J2000): RAE;
    /**
     * Gets the azimuth in degrees.
     * @returns The azimuth in degrees.
     */
    get az(): Degrees;
    /**
     * Gets the elevation angle in degrees.
     * @returns The elevation angle in degrees.
     */
    get el(): Degrees;
    /**
     * Gets the azimuth rate in degrees per second.
     * @returns The azimuth rate in degrees per second, or undefined if it is not available.
     */
    get azRate(): number | undefined;
    /**
     * Gets the elevation rate in degrees per second.
     * @returns The elevation rate in degrees per second, or undefined if the elevation rate is not set.
     */
    get elRate(): number | undefined;
    toString(): string;
    /**
     * Return the position relative to the observer [site].
     *
     * An optional azimuth [az] _(rad)_ and elevation [el] _(rad)_ value can be
     * passed to override the values contained in this observation.
     * @param site The observer [site].
     * @param azRad Azimuth _(rad)_.
     * @param elRad Elevation _(rad)_.
     * @returns A [Vector3D] object.
     */
    position(site: J2000, azRad?: Radians, elRad?: Radians): Vector3D<Kilometers>;
    /**
     * Convert this observation into a [J2000] state vector.
     *
     * This will throw an error if the [rangeRate], [elevationRate], or
     * [azimuthRate] are not defined.
     * @param site The observer [site].
     * @returns A [J2000] state vector.
     */
    toStateVector(site: J2000): J2000;
    /**
     * Calculate the angular distance _(rad)_ between this and another [Razel]
     * object.
     * @param razel The other [Razel] object.
     * @param method The angular distance method to use.
     * @returns The angular distance _(rad)_.
     */
    angle(razel: RAE, method?: AngularDistanceMethod): number;
    /**
     * Calculate the angular distance _(°)_ between this and another [Razel]
     * object.
     * @param razel The other [Razel] object.
     * @param method The angular distance method to use.
     * @returns The angular distance _(°)_.
     */
    angleDegrees(razel: RAE, method?: AngularDistanceMethod): number;
}
