function [interaction_points, ray_coeffs] = get_ray_chan(rays, freqs, method)
    % GET_RAY_CHAN Extract channel coefficients from ray tracing results
    %
    % Description:
    %   Computes channel coefficients and interaction points for each ray path
    %   using either Shooting and Bouncing Ray (SBR) method or Free Space
    %   Path Loss (FSPL) calculations.
    %
    % Inputs:
    %   rays   - Array of ray objects from ray tracer
    %   freqs  - Vector of frequencies in Hz for channel computation
    %   method - String specifying computation method: "sbr" or "fspl"
    %
    % Outputs:
    %   interaction_points - [3xN] matrix of final interaction point coordinates for N paths
    %   ray_coeffs         - [FxN] complex matrix of channel coefficients for F frequencies and N paths
    %
    % Example:
    %   rays = rayTrace(tx, rx, environment);
    %   freqs = linspace(2.4e9, 2.5e9, 10);
    %   [interaction_points, ray_coeffs] = get_ray_chan(rays, freqs, "sbr");

    n_paths = length(rays);
    n_freqs = length(freqs);

    interaction_points = zeros(3, n_paths);
    ray_coeffs = zeros(n_freqs, n_paths);

    for i = 1:n_paths

        if rays(i).LineOfSight
            points = [rays(i).TransmitterLocation rays(i).ReceiverLocation];
        else
            points = [rays(i).TransmitterLocation rays(i).Interactions.Location rays(i).ReceiverLocation];
        end

        interaction_points(:, i) = points(:, end - 1);

        for j = 1:n_freqs
            f = freqs(j);

            if strcmp(method, "sbr")
                path_loss = rays(i).PathLoss;
                phase = rays(i).PhaseShift;
            else
                prop_dist = rays(i).PropagationDistance;
                path_loss = fspl(prop_dist, f);
                phase = 2 * pi * f * prop_dist / physconst("lightspeed");
            end

            ray_coeffs(j, i) = 10 ^ (-path_loss / 20) * exp(-1j * phase);
        end
    end
end
