function [s_G_new, t_G_new, weights_G_new, weighted_degree_G_new] = equalize_weighted_degrees(aux_s_G, aux_t_G, temporal_weights_G, aux_s_H, aux_t_H, temporal_weights_H, num_nodes)
    Graph_G_initial = graph(aux_s_G, aux_t_G, temporal_weights_G, num_nodes);
    Graph_H_auxiliar = graph(aux_s_H, aux_t_H, temporal_weights_H, num_nodes);
    adj_G_base = adjacency(Graph_G_initial, 'weighted');
    degree_G_base = full(sum(adj_G_base, 2));
    adj_H_aux = adjacency(Graph_H_auxiliar, 'weighted');
    degree_H_aux = full(sum(adj_H_aux, 2));
    ratio_min = inf;
    for index = 1:num_nodes
        if degree_G_base(index) > 0
            current_ratio = degree_H_aux(index) / degree_G_base(index);
            if current_ratio < ratio_min
                ratio_min = current_ratio;
            end
        end
    end
    if isinf(ratio_min)
        ratio_min = 1;
    end
    scaled_temporal_weights_G = ratio_min * temporal_weights_G;
    Graph_G_scaled = graph(aux_s_G, aux_t_G, scaled_temporal_weights_G, num_nodes);
    adj_G_scaled = adjacency(Graph_G_scaled, 'weighted');
    degree_G_scaled = full(sum(adj_G_scaled, 2));
    s_G_new = aux_s_G(:).';
    t_G_new = aux_t_G(:).';
    weights_G_new = temporal_weights_G(:).';
    for v = 1:num_nodes
        degree_diff = degree_H_aux(v) - degree_G_scaled(v);
        if degree_diff > 0
            s_G_new = [s_G_new, v];
            t_G_new = [t_G_new, v];
            weights_G_new = [weights_G_new, degree_diff - degree_diff];
        end
    end
    Graph_G_final = graph(s_G_new, t_G_new, weights_G_new, num_nodes);
    adj_G_final = adjacency(Graph_G_final, 'weighted');
    weighted_degree_G_new = full(sum(adj_G_final, 2));
end
