function [obj_fun_val] = compute_obj_val(Data_struct,Var_struct,params)
%UNTITLED Summary of this function goes here
%   Detailed explanation goes here

%Take advantage of the stuff that has been precomputed during the pi_vec
%update.
temp_obj_fun = 0.5*Var_struct.temp_denom - Var_struct.p_vec_new'*Var_struct.rhsmat + 0.5*Var_struct.p_vec_new'*Var_struct.lhsmat*Var_struct.p_vec_new;

obj_fun_val = temp_obj_fun;


% M = Data_struct.M;
% 
% temp_obj_fun = 0; P_big = diag(Var_struct.p_vec_new);
% for m=1:M
%     temp_obj_fun = temp_obj_fun + params.m_vec_val(m)*0.5*norm(Data_struct.M1_vec(:,m) - Var_struct.Psi_new{m}*Var_struct.p_vec_new,2)^2;
%     for mm=(m+1):M
%         temp_obj_fun = temp_obj_fun + params.M_mat_val(m,mm)*0.5*norm(Data_struct.M2_mat{m,mm} - Var_struct.Psi_new{m}*P_big*Var_struct.Psi_new{mm}','fro')^2;
%         for mmm=(mm+1):M
%             temp_obj_fun = temp_obj_fun + params.M_tens_val(m,mm,mmm)*0.5*norm(Data_struct.M3_vec{m,mm,mmm} - krp(Var_struct.Psi_krps{mmm,mm},Var_struct.Psi_new{m})*Var_struct.p_vec_new,2)^2;
%         end
%     end
% end
% 
% obj_fun_val = temp_obj_fun;

end

