using CombDiff
f, ctx = @pct begin
    @space T2Amp begin
        type = (N, N, N, N) -> R
        symmetries = (((2, 1, 3, 4), :neg), ((1, 2, 4, 3), :neg))
    end
    @space AERI begin
        type = (N, N, N, N) -> R
        #= symmetries = (((1, 2, 4, 3), :neg),) =#
        symmetries = (((1, 2, 4, 3), :neg), ((2, 1, 3, 4), :neg))
    end
    (N_o::N, f_o::Sym, x::AERI, t_1::RM, t_2::T2Amp, ϵ::RV) -> _
end;


# CCD Energy

ccd_e, _ = @pct f ctx begin
    f_o = (p::N, q::N) -> f_o(p, q) - delta(p, q, f_o(p, q))
    ph = (p::N) -> 𝕀(p, N_o, :d(p)') + 𝕀(N_o + 1, p, :c(p))
    H_0 = ((a::FField) -> sum(p, :II(ϵ(p)) ∘ a(p)' ∘ a(p)))(ph)
    V = ((a::FField) ->
        sum((p, q), :II(f_o(p, q) - sum(i, 𝕀(i, N_o, x(p, i, q, i)))) ∘ a(p)' ∘ a(q)) +
        sum((p, q, r, s), :II(0.25 * x(p, q, r, s)) ∘ a(p)' ∘ a(q)' ∘ a(s) ∘ a(r))
    )(ph)

    T2 = :II(0.25) ∘ sum((i, j, a, b), 𝕀(i, N_o, 𝕀(j, N_o, 𝕀(N_o + 1, a, 𝕀(N_o + 1, b, :II(t_2(i, j, a, b)) ∘ :c(a)' ∘ :c(b)' ∘ :d(j)' ∘ :d(i)')))))
    ψ = :II(1) + T2 + :II(0.25) ∘ T2 ∘ T2
    vac_exp((H_0 + V) ∘ ψ)
end
ccd_e_2 = eval_all(ccd_e)
ccd_e_3 = simplify(ccd_e_2) |> first
ccd_e_4 = fast_symmetry_reduction(ccd_e_3)
mathjax(ccd_e_4)


ccd_eqs, _ = @pct f ctx begin
    (a::N ∈ [N_o + 1, ∞], b::N ∈ [N_o + 1, ∞], i::N ∈ [1, N_o], j::N ∈ [1, N_o]) ->
        let V = ((a::FField) ->
                sum((k, l), :II(f_o(k, l) - sum(i, 𝕀(i, N_o, x(k, i, l, i)))) ∘ a(k)' ∘ a(l)) +
                sum((k, l, c, d), :II(0.25 * x(k, l, c, d)) ∘ a(k)' ∘ a(l)' ∘ a(d) ∘ a(c))
            )(
                (p::N) -> 𝕀(p, N_o, :d(p)') + 𝕀(N_o + 1, p, :c(p))
            )
            let T2 = :II(0.25) ∘ sum((k, l, c, d), 𝕀(k, N_o, 𝕀(l, N_o, 𝕀(N_o + 1, c, 𝕀(N_o + 1, d, :II(t_2(k, l, c, d)) ∘ :c(c)' ∘ :c(d)' ∘ :d(l)' ∘ :d(k)')))))
                let ψ = :II(1) + T2 + :II(0.25) ∘ T2 ∘ T2
                    vac_exp(:c(a) ∘ :c(b) ∘ :d(i) ∘ :d(j) ∘ V ∘ ψ)
                end
            end
        end
end

ccd_eqs_2 = eval_all(ccd_eqs)
ccd_eqs_3 = simplify(ccd_eqs_2) |> first
ccd_eqs_4 = fast_symmetry_reduction(ccd_eqs_3)
mathjax(ccd_eqs_4)

l_0, _ = @pct f ctx begin
    f_o = (p::N, q::N) -> f_o(p, q) - delta(p, q, f_o(p, q))
    ph = (p::N) -> 𝕀(p, N_o, :d(p)') + 𝕀(N_o + 1, p, :c(p))
    H_0 = ((a::FField) -> sum(p, :II(ϵ(p)) ∘ a(p)' ∘ a(p)))(ph)
    E_ref = :II(sum(i, 𝕀(i, N_o, ϵ(i))) - 0.5 * sum((i, j), 𝕀(i, N_o, 𝕀(j, N_o, x(i, j, i, j)))))
    T2 = :II(0.25) ∘ sum((i, j, a, b), 𝕀(i, N_o, 𝕀(j, N_o, 𝕀(N_o + 1, a, 𝕀(N_o + 1, b, :II(t_2(i, j, a, b)) ∘ :c(a)' ∘ :c(b)' ∘ :d(j)' ∘ :d(i)')))))
    ψ = :II(1) + T2
    (a::N ∈ [N_o + 1, ∞], b::N ∈ [N_o + 1, ∞], i::N ∈ [1, N_o], j::N ∈ [1, N_o]) ->
        vac_exp(:c(a) ∘ :c(b) ∘ :d(i) ∘ :d(j) ∘ (H_0 + :II(-1) ∘ E_ref) ∘ ψ)
end;
l_0

ccd_eqs, _ = @pct f ctx begin
    (a::N ∈ [N_o + 1, ∞], b::N ∈ [N_o + 1, ∞], i::N ∈ [1, N_o], j::N ∈ [1, N_o]) ->
        f_o = (p::N, q::N) -> f_o(p, q) - delta(p, q, f_o(p, q))
    ph = (p::N) -> 𝕀(p, N_o, :d(p)') + 𝕀(N_o + 1, p, :c(p))
    H_0 = ((a::FField) -> sum(p, :II(ϵ(p)) ∘ a(p)' ∘ a(p)))(ph)
    V = ((a::FField) ->
        sum((p, q), :II(f_o(p, q) - sum(i, 𝕀(i, N_o, x(p, i, q, i)))) ∘ a(p)' ∘ a(q)) +
        sum((p, q, r, s), :II(0.25 * x(p, q, r, s)) ∘ a(p)' ∘ a(q)' ∘ a(s) ∘ a(r))
    )(ph)
    E_ref = sum(i, 𝕀(i, N_o, ϵ(i))) - 0.5 * sum((i, j), 𝕀(i, N_o, 𝕀(j, N_o, x(i, j, i, j))))
    T2 = :II(0.25) ∘ sum((i, j, a, b), 𝕀(i, N_o, 𝕀(j, N_o, 𝕀(N_o + 1, a, 𝕀(N_o + 1, b, :II(t_2(i, j, a, b)) ∘ :c(a)' ∘ :c(b)' ∘ :d(j)' ∘ :d(i)')))))
    ψ = :II(1) + T2 + :II(0.25) ∘ T2 ∘ T2
    vac_exp(:c(a) ∘ :c(b) ∘ :d(i) ∘ :d(j) ∘ (H_0 + V - E_ref) ∘ ψ)
end

l_2, _ = @pct f ctx begin
    ph = (p::N) -> 𝕀(p, N_o, :d(p)') + 𝕀(N_o + 1, p, :c(p))
    H_2 = ((a::FField) -> sum((k, l, c, d), :II(0.25 * x(k, l, c, d)) ∘ a(k)' ∘ a(l)' ∘ a(d) ∘ a(c)))(ph)
    T2 = :II(0.25) ∘ sum((k, l, c, d), 𝕀(k, N_o, 𝕀(l, N_o, 𝕀(N_o + 1, c, 𝕀(N_o + 1, d, :II(t_2(k, l, c, d)) ∘ :c(c)' ∘ :c(d)' ∘ :d(l)' ∘ :d(k)')))))
    ψ = :II(1) + T2
    (a::N ∈ [N_o + 1, ∞], b::N ∈ [N_o + 1, ∞], i::N ∈ [1, N_o], j::N ∈ [1, N_o]) ->
        vac_exp(:d(i) ∘ :d(j) ∘:c(b) ∘ :c(a) ∘ H_2 ∘ ψ)
end; l_2

l_2_2 = eval_all(l_2)
l_2_3 = simplify(l_2_2) |> first;
l_2_4 = fast_symmetry_reduction(l_2_3)

f, ctx = @pct begin
    @space T2Amp begin
        type = (N, N, N, N) -> R
        symmetries = (((2, 1, 3, 4), :neg), ((1, 2, 4, 3), :neg))
    end
    @space AERI begin
        type = (N, N, N, N) -> R
        #= symmetries = (((1, 2, 4, 3), :neg),) =#
        symmetries = (((1, 2, 4, 3), :neg), ((2, 1, 3, 4), :neg))
    end

    @space SymOff begin
        type = (N, N) -> R
        symmetries = (((2, 1), :id),)
        off_diag = true
    end
    (N_o::N, f_o::SymOff, u::Sym, x::AERI, t_1::RM, t_2::T2Amp, ϵ::RV) -> _
end;

q, _ = @pct f ctx begin
    ph = (p::N) -> 𝕀(p, N_o, :d(p)') + 𝕀(N_o + 1, p, :c(p))
    H_2 = ((a::FField) -> sum((k, l, c, d), :II(0.25 * x(k, l, c, d)) ∘ a(k)' ∘ a(l)' ∘ a(d) ∘ a(c)))(ph)
    T2 = :II(0.25) ∘ sum((k, l, c, d), 𝕀(k, N_o, 𝕀(l, N_o, 𝕀(N_o + 1, c, 𝕀(N_o + 1, d, :II(t_2(k, l, c, d)) ∘ :c(c)' ∘ :c(d)' ∘ :d(l)' ∘ :d(k)')))))
    (a::N ∈ [N_o + 1, ∞], b::N ∈ [N_o + 1, ∞], i::N ∈ [1, N_o], j::N ∈ [1, N_o]) ->
    vac_exp(:d(i) ∘ :d(j) ∘:c(b) ∘ :c(a) ∘ H_2 ∘ :II(0.5) ∘  T2 ∘ T2)
end; q

q_2 = eval_all(q)
q_3 = simplify(q_2; settings=custom_settings(:gcd=>false)) |> first;
q_4 = fast_symmetry_reduction(q_3)
q_5 = clench(q_4)
q_6 = simplify(q_5; settings=custom_settings(:extract_intermediate=>true, :clench_sum=>true)) |> first


