using LinearAlgebra

function bpg(
    f,
    grad!,
    subproblem,
    x0,
    lmo,
    max_iteration::Int,
    verbose::Bool,
    trajectory::Bool,
    tol::Float64=1e-6,
)
    xk = deepcopy(x0)
    xk_old = deepcopy(x0)
    trajectory_list = []
    time_start = time_ns()
    gradient = zeros(length(x0))
    for i in 1:max_iteration
        if trajectory
            grad!(gradient, xk)
            v = FrankWolfe.compute_extreme_point(lmo, gradient)
            dual_gap = FrankWolfe.fast_dot(xk, gradient) - FrankWolfe.fast_dot(v, gradient)
            push!(trajectory_list, (i, deepcopy(f(xk)), 0, dual_gap, (time_ns() - time_start)/ 1e9))
        end
        xk_old, xk = deepcopy(xk), subproblem(xk)
    
        if norm(xk - xk_old) < tol
            break
        end
    end
    if trajectory
        return xk, trajectory_list
    else
        return xk
    end
end