import numpy as np
def icarl(video_memory,memory_size,video_index):
    num_store=0
    exemplar_features = []
    list_selected_idx = []  
    task_mean = np.mean(video_memory, axis=0)  
    num_store = 0
    while num_store <= memory_size:  
        S = np.sum(exemplar_features, axis=0)  
        phi = video_memory  
        mu = task_mean  
        mu_p = 1.0 / (num_store + 1) * (
                phi + S)  
        mu_p = mu_p / np.linalg.norm(mu_p)  
        dist = np.sqrt(np.sum((mu - mu_p) ** 2,
                              axis=1))  
        if num_store <= len(dist) - 2:  
            list_idx = np.argpartition(dist, num_store)[
                       :num_store + 1]  
            num_store = num_store + 1
        elif num_store < len(dist):  
            fixed_k = len(dist) - 2  
            list_idx = np.argpartition(dist, fixed_k)[:fixed_k + 2]  
            num_store = num_store + 1
        else:
            break
        for idx in list_idx:  
            if idx not in list_selected_idx:
                list_selected_idx.append(idx)
                exemplar_features.append(video_memory[idx])
                break
    selected_idx=[]
    for i in range(len(list_idx)):
        selected_idx.append(video_index[list_idx[i]])
    return selected_idx