{"cells":[{"cell_type":"code","execution_count":null,"metadata":{"id":"fiBU-etHJ36Y"},"outputs":[],"source":["import cvxpy as cp\n","import pandas as pd\n","import numpy as np\n","import csv\n","from scipy.linalg import eigh\n","from scipy.linalg import eigvals\n","from scipy.sparse import coo_matrix\n","from scipy.optimize import minimize_scalar\n","from scipy.optimize import root_scalar\n","import cvxpy as cp\n","import time\n","from google.colab import files\n","from scipy.stats import norm\n","from numpy.random import randint, choice\n","\n","# Parameters\n","p = 50  # number of atoms\n","m = 25  # dimension of data\n","n_old = 250  # number of lower-level samples\n","n_new = 250  # number of upper-level samples\n","sigma = 0.01  # noise level\n","max_time = 100  # max running time\n","\n","seed = 1\n","np.random.seed(seed)\n","\n","figs = True\n","\n","# True dictionary Dstar\n","Dstar = np.random.randn(m, p)\n","Dstar = Dstar / np.linalg.norm(Dstar, axis=0)  # Normalize the atoms\n","\n","k_spar = 5  # number of nonzeros in each coefficient vector\n","\n","# Old dataset (X_old and A_old)\n","mask = np.zeros((p, n_old))\n","for i in range(n_old):\n","    indices = choice(np.arange(round(4*p/5)), k_spar, replace=False)\n","    mask[indices, i] = (0.8 * np.random.rand(k_spar) + 0.2) * (2 * randint(0, 2, k_spar) - 1)\n","\n","X_old = mask  # true coefficient matrix for the old dataset\n","A_old = Dstar @ X_old + sigma * np.random.randn(m, n_old)\n","\n","# New dataset (X_new and A_new)\n","mask = np.zeros((p, n_new))\n","for i in range(n_new):\n","    indices = choice(np.arange(round(3*p/5), p), k_spar, replace=False)\n","    mask[indices, i] = (0.8 * np.random.rand(k_spar) + 0.2) * (2 * randint(0, 2, k_spar) - 1)\n","\n","X_new = mask  # true coefficient matrix for the new dataset\n","A_new = Dstar @ X_new + sigma * np.random.randn(m, n_new)\n","\n"]},{"cell_type":"code","source":["A_old = pd.read_csv('A_old.csv', header=None)\n","A_old = A_old.to_numpy()\n","A_new = pd.read_csv('A_new.csv', header=None)\n","A_new = A_new.to_numpy()\n","X_base = pd.read_csv('X_base.csv', header=None)\n","X_base = X_base.to_numpy()"],"metadata":{"id":"wkKH9xTHCD04"},"execution_count":null,"outputs":[]},{"cell_type":"code","execution_count":null,"metadata":{"id":"dmYQuOsQPxDL"},"outputs":[],"source":["D = cp.Variable((m,p))\n","inner = cp.Problem(cp.Minimize(cp.sum([cp.norm(A_old[:, j] - D @ X_base[:, j], 2)**2 for j in range(n_old)])/(2*n_old)), [cp.norm(D[:, j]) <= 1 for j in range(p)])\n","inner.solve()\n","g_opt = inner.value"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"xERR1_t8YDqF"},"outputs":[],"source":["delta = 3\n","def g(D, S):\n","    diff = A_old[:, S] - D @ X_base[:, S]  # Difference matrix (m x len(S))\n","    return np.sum(np.linalg.norm(diff, axis=0)**2) / (2 * len(S))\n","\n","def gradg(D, S):\n","    X_selected = X_base[:, S]\n","    return (D @ X_selected - A_old[:, S])@X_selected.T / len(S)\n","\n","def f(X,D,S):\n","    diff = A_new[:, S] - D @ X[:, S]  # Difference matrix (m x len(S))\n","    return np.sum(np.linalg.norm(diff, axis=0)**2) / (2 * len(S))\n","\n","def gradXf(X,D,S):\n","    gradXf = np.zeros_like(X)\n","    X_sel = X[:, S]\n","    A_sel = A_new[:, S]\n","    gradXf[:, S] = D.T @ (D @ X_sel - A_sel)\n","    return gradXf\n","\n","def gradDf(X,D,S):\n","    X_selected = X[:, S]\n","    diff = D @ X_selected - A_new[:, S]\n","    gradDf = diff@X_selected.T/len(S)\n","    return gradDf\n","\n","def lmoX(C1):\n","  V1 = np.zeros_like(C1)\n","  for j in range(n_new):\n","      idx = np.argmax(np.abs(C1[:, j]))  # Find the index of the max gradient\n","      V1[idx, j] = -delta * np.sign(C1[idx, j])\n","\n","  return V1\n","\n","def lmoD(C2):\n","  norms = np.linalg.norm(C2, axis=0)\n","  V2 = np.divide(-C2, norms, where=(norms > 0))\n","  return V2\n","\n","def simplex_projection(s):\n","  \"\"\"Projection onto the unit simplex.\"\"\"\n","  if np.sum(s) <=1 and np.all(s >= 0):\n","      return s\n","\n","  u = np.sort(s)[::-1]\n","  cssv = np.cumsum(u)\n","  rho = np.nonzero(u * np.arange(1, len(u)+1) > (cssv - 1))[0][-1]\n","  theta = (cssv[rho] - 1) / (rho + 1.0)\n","\n","  return np.maximum(s-theta, 0)\n","\n","def scaled_proj(c):\n","  sol = simplex_projection(np.abs(c)/delta)\n","  sol = delta*np.sign(c)*sol\n","  return sol\n","\n","def proj(C1, C2):\n","  V1 = np.zeros_like(C1)\n","  for j in range(n_new):\n","      V1[:, j] = scaled_proj(C1[:, j])\n","  V2 = C2 / np.maximum(np.linalg.norm(C2, axis=0),1)\n","  return V1, V2\n","\n","def clmo(C1, C2, A,b):\n","    V = cp.Variable((m, p))\n","    sub = cp.Problem(cp.Minimize(cp.trace(C2.T@V)), [cp.trace(A.T@V) <= b]+[cp.norm(V[:, j]) <= 1 for j in range(p)])\n","    sub.solve()\n","    V2 = V.value\n","\n","\n","    V1 = np.zeros_like(C1)\n","    for j in range(n_new):\n","        idx = np.argmax(np.abs(C1[:, j]))  # Find the index of the max gradient\n","        V1[idx, j] = -delta * np.sign(C1[idx, j])\n","    return V1, V2\n"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"WoZM_LlEWaXc"},"outputs":[],"source":["def irscg(init, budget, i):\n","  filename = 'irscg4_{}.csv'.format(i)\n","  iters = []\n","  inner = []\n","  outer = []\n","  time_elapsed = []\n","  oracles = []\n","\n","  oracle = 0\n","  count = 1\n","\n","  t = 0\n","  X, D = init\n","  varsigma = 0.1\n","\n","  ZX = 0\n","  ZD = 0\n","  s = 0\n","  elapsed_time = 0\n","  while elapsed_time <= budget:\n","\n","    start = time.time()\n","\n","    alpha = (t+1)**(-6/7)\n","    sigma = varsigma*(t+1)**(-2/7)\n","\n","    xi    = np.random.randint(0, n_old-1, size=1)\n","    theta = np.random.randint(0, n_new-1, size=1)\n","\n","\n","    if t == 0:\n","\n","      hat_gradXf= gradXf(X, D, theta)\n","      hat_gradDf= gradDf(X, D, theta)\n","      hat_gradg = gradg(D, xi)\n","\n","    else:\n","\n","      hat_gradXf = (1-alpha)*hat_gradXf + gradXf(X, D, theta) - (1-alpha)*gradXf(X_prev, D_prev, theta)\n","      hat_gradDf = (1-alpha)*hat_gradDf + gradDf(X, D, theta) - (1-alpha)*gradDf(X_prev, D_prev, theta)\n","      hat_gradg = (1-alpha)*hat_gradg +  gradg(D, xi)   - (1-alpha)* gradg(D_prev, xi)\n","\n","    VX = lmoX(hat_gradXf)\n","    VD = lmoD(sigma*hat_gradDf +hat_gradg)\n","    X_prev = X\n","    D_prev = D\n","    X = X + alpha*(VX-X)\n","    D = D + alpha*(VD-D)\n","\n","    s_prev = s\n","    s = s+(t+1)*sigma\n","    ZX = (s_prev*ZX-(t+1)*t*sigma*X_prev+(t+2)*(t+1)*sigma*X)/s\n","    ZD = (s_prev*ZD-(t+1)*t*sigma*D_prev+(t+2)*(t+1)*sigma*D)/s\n","    t += 1\n","\n","    end = time.time()\n","\n","    elapsed_time += end-start\n","\n","    oracle += 2\n","    if elapsed_time >= count:\n","      iters.append(t)\n","      inner.append(g(D,range( n_old))-g_opt)\n","      outer.append(f(X, D, range( n_old)))\n","      time_elapsed.append(elapsed_time)\n","      oracles.append(oracle)\n","      count += 1\n","  df = pd.DataFrame({\n","    't': iters,\n","    'inner': inner,\n","    'outer': outer,\n","    'oracles': oracles,\n","    'time_elapsed': time_elapsed})\n","  df.to_csv(filename, index=False)\n","  files.download(filename)\n","\n","\n","def irfscg(init, budget, i):\n","  filename = 'irfscg4_{}.csv'.format(i)\n","  iters = []\n","  inner = []\n","  outer = []\n","  time_elapsed = []\n","  oracles = []\n","  oracle = 0\n","  count = 1\n","  n = n_old\n","  t = 0\n","  q = np.floor(n**0.5)\n","  S = q\n","\n","  X,D = init\n","  ZX = 0\n","  ZD = 0\n","  s = 0\n","  w = 3/4\n","  varsigma = 0.1\n","\n","  elapsed_time = 0\n","  while elapsed_time <= budget:\n","\n","    start = time.time()\n","    if t < q:\n","      alpha = np.log(q+1)/(q+1)\n","    else:\n","      alpha = (t+1)**(-3/4)\n","\n","    sigma = varsigma*(max(t,q+1)+1)**(-0.5)\n","\n","    if t%q == 0:\n","      hat_gradXf = gradXf(X,D, range(n))\n","      hat_gradDf = gradDf(X,D, range(n))\n","      hat_gradg = gradg(D, range(n))\n","\n","    else:\n","      ind1 = np.random.randint(0, n-1, size=int(S))\n","      ind2 = np.random.randint(0, n-1, size=int(S))\n","\n","      hat_gradXf = hat_gradXf + gradXf(X,D,ind1) - gradXf(X_prev, D_prev, ind1)\n","      hat_gradDf = hat_gradDf + gradDf(X,D,ind1) - gradDf(X_prev, D_prev, ind1)\n","      hat_gradg = hat_gradg + gradg(D , ind2) - gradg(D_prev,ind2)\n","\n","    VX = lmoX(hat_gradXf)\n","    VD = lmoD(sigma*hat_gradDf +hat_gradg)\n","    X_prev = X\n","    D_prev = D\n","    X = X + alpha*(VX-X)\n","    D = D + alpha*(VD-D)\n","\n","    s_prev = s\n","    s = s+(t+1)*sigma\n","    ZX = (s_prev*ZX-(t+1)*t*sigma*X_prev+(t+2)*(t+1)*sigma*X)/s\n","    ZD = (s_prev*ZD-(t+1)*t*sigma*D_prev+(t+2)*(t+1)*sigma*D)/s\n","    t += 1\n","\n","    end = time.time()\n","\n","    elapsed_time += end-start\n","    if (t-1)%q == 0:\n","      oracle += 2*n\n","    else:\n","      oracle += 2*S\n","\n","    if elapsed_time >= count:\n","      iters.append(t)\n","      inner.append(g(D,range( n_old))-g_opt)\n","      outer.append(f(X, D, range( n_old)))\n","      time_elapsed.append(elapsed_time)\n","      oracles.append(oracle)\n","      count += 1\n","  df = pd.DataFrame({\n","    't': iters,\n","    'inner': inner,\n","    'outer': outer,\n","    'oracles': oracles,\n","    'time_elapsed': time_elapsed})\n","  df.to_csv(filename, index=False)\n","  files.download(filename)"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"-4ItzyI4Wc1W"},"outputs":[],"source":["def sbcgi(init,budget, i):\n","  filename = 'sbcgi4_{}.csv'.format(i)\n","  iters = []\n","  inner = []\n","  outer = []\n","  time_elapsed = []\n","  oracles = []\n","\n","\n","  count = 1\n","  n  = n_old\n","\n","  X, D,  oracle, elapsed_time = spiderfw(init, 100)\n","  g0 = g(D,range(n))\n","\n","\n","  t = 0\n","  while elapsed_time <= budget:\n","\n","    start = time.time()\n","\n","\n","    alpha = 0.1/(t+1)**(2/3)\n","\n","    xi    = np.random.randint(0, n-1, size=1)\n","    theta = np.random.randint(0, n-1, size=1)\n","\n","\n","    if t == 0:\n","\n","      hat_gradXf = gradXf(X, D, theta)\n","      hat_gradDf = gradDf(X, D, theta)\n","      hat_gradg = gradg(D, xi)\n","      hat_g     = g(D,xi)\n","\n","    else:\n","\n","      hat_gradXf = (1-alpha)*hat_gradXf + gradXf(X, D, theta) - (1-alpha)*gradXf(X_prev, D_prev, theta)\n","      hat_gradDf = (1-alpha)*hat_gradDf + gradDf(X, D, theta) - (1-alpha)*gradDf(X_prev, D_prev, theta)\n","      hat_gradg = (1-alpha)*hat_gradg +  gradg(D, xi)   - (1-alpha)* gradg(D_prev, xi)\n","      hat_g     = (1-alpha)* hat_g    +    g(D, xi)     - (1-alpha)*   g(D_prev, xi)\n","\n","    VX, VD = clmo(hat_gradXf, hat_gradDf, hat_gradg, np.trace(hat_gradg.T@D)+g0-hat_g+0.01/(t+1)**(1/3))\n","    X_prev = X\n","    D_prev = D\n","    X = X + alpha*(VX-X)\n","    D = D + alpha*(VD-D)\n","    t += 1\n","\n","    end = time.time()\n","\n","    elapsed_time += end-start\n","    oracle += 2\n","    if elapsed_time >= count:\n","      iters.append(t)\n","      inner.append(g(D,range( n_old))-g_opt)\n","      outer.append(f(X, D, range( n_old)))\n","      time_elapsed.append(elapsed_time)\n","      oracles.append(oracle)\n","      count += 1\n","  df = pd.DataFrame({\n","    't': iters,\n","    'inner': inner,\n","    'outer': outer,\n","    'oracles': oracles,\n","    'time_elapsed': time_elapsed})\n","  df.to_csv(filename, index=False)\n","  files.download(filename)\n","\n","def sbcgf(init, budget, i):\n","  filename = 'sbcgf4_{}.csv'.format(i)\n","  iters = []\n","  inner = []\n","  outer = []\n","  time_elapsed = []\n","  oracles = []\n","\n","  oracle = 0\n","  count = 1\n","\n","  n = n_old\n","\n","  t = 0\n","  q = np.floor(n**0.5)\n","  S = q\n","\n","  X, D, oracle, elapsed_time = spiderfw(init, 10**5)\n","  g0 = g(D, range(n))\n","\n","  t = 0\n","  while elapsed_time <= budget:\n","\n","    start = time.time()\n","\n","    alpha = 10**(-3)\n","\n","\n","    if t%q == 0:\n","      hat_gradXf = gradXf(X,D, range(n))\n","      hat_gradDf = gradDf(X,D, range(n))\n","      hat_gradg = gradg(D, range(n))\n","      hat_g = g(D,range(n))\n","\n","    else:\n","      ind1 = np.random.randint(0, n-1, size=int(S))\n","      ind2 = np.random.randint(0, n-1, size=int(S))\n","      #print(hat_gradXf.shape, gradXf(X,D,ind1).shape, gradXf(X_prev, D_prev, ind1).shape)\n","      hat_gradXf = hat_gradXf + gradXf(X,D,ind1) - gradXf(X_prev, D_prev, ind1)\n","      hat_gradDf = hat_gradDf + gradDf(X,D,ind1) - gradDf(X_prev, D_prev, ind1)\n","      hat_gradg = hat_gradg + gradg(D, ind2) - gradg(D_prev,ind2)\n","      hat_g     = hat_g + g(D, ind2) - g(D_prev, ind2)\n","\n","\n","\n","    VX, VD = clmo(hat_gradXf, hat_gradDf, hat_gradg, np.trace(hat_gradg.T@D)+g0-hat_g+0.01/(t+1)**(1/3))\n","    X_prev = X\n","    D_prev = D\n","    X = X + alpha*(VX-X)\n","    D = D + alpha*(VD-D)\n","    t += 1\n","\n","    end = time.time()\n","\n","    elapsed_time += end-start\n","    #print('Iteration: {}, inner-level in x: {}, outer-level in x: {}'.format(t,g(D,range(n_old)),f(X,D,range(n_new))))\n","    if (t-1)%q == 0:\n","      oracle += 2*n\n","    else:\n","      oracle += 2*S\n","\n","    if elapsed_time >= count:\n","      iters.append(t)\n","      inner.append(g(D,range( n_old))-g_opt)\n","      outer.append(f(X, D, range( n_old)))\n","      time_elapsed.append(elapsed_time)\n","      oracles.append(oracle)\n","      count += 1\n","  df = pd.DataFrame({\n","    't': iters,\n","    'inner': inner,\n","    'outer': outer,\n","    'oracles': oracles,\n","    'time_elapsed': time_elapsed})\n","  df.to_csv(filename, index=False)\n","  files.download(filename)"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"J2BI3TnlWu7F"},"outputs":[],"source":["def aripseg(init, budget, short, i):\n","  if short == True:\n","    gamma0 = 10**(-4)\n","    filename = 'aripseg_short4_{}.csv'.format(i)\n","  else:\n","    gamma0 = 10**(-2)\n","    filename = 'aripseg_long4_{}.csv'.format(i)\n","\n","  iters = []\n","  inner = []\n","  outer = []\n","  time_elapsed = []\n","  oracles = []\n","\n","  oracle = 0\n","  count = 1\n","  t = 0\n","  X, D = init\n","  n = n_old\n","  rho0 = 1\n","  Gamma = 0\n","  r = 0.5\n","  elapsed_time = 0\n","  while elapsed_time <= budget:\n","\n","    start = time.time()\n","\n","    gamma = gamma0/(t+1)**0.75\n","    rho = rho0*(t+1)**0.25\n","\n","    xi    = np.random.randint(0, n-1, size=1)\n","    theta = np.random.randint(0, n-1, size=1)\n","\n","\n","    hat_gradXf = gradXf(X, D,theta)\n","    hat_gradDf = gradDf(X, D,theta)\n","    hat_gradg = gradg(D, xi)\n","\n","    #Need to work on\n","    YX, YD = proj(X-gamma*hat_gradXf, D-gamma*(hat_gradDf+rho*hat_gradg))\n","\n","    xi    = np.random.randint(0, n-1, size=1)\n","    theta = np.random.randint(0, n-1, size=1)\n","\n","    hat_gradXf = gradXf(YX, YD,theta)\n","    hat_gradDf = gradDf(YX, YD,theta)\n","    hat_gradg = gradg(YD,xi)\n","\n","    X, D = proj(X-gamma*hat_gradXf, D-gamma*(hat_gradDf+rho*hat_gradg))\n","\n","    Gamma_prev = Gamma\n","    Gamma = Gamma+(gamma*rho)**r\n","\n","    if t == 0:\n","      bar_YX = X\n","      bar_YD = D\n","    else:\n","      bar_YX = (Gamma_prev*bar_YX+((gamma*rho)**r)*YX)/Gamma\n","      bar_YD = (Gamma_prev*bar_YD+((gamma*rho)**r)*YD)/Gamma\n","    t += 1\n","    end = time.time()\n","\n","    elapsed_time += end-start\n","    #print('Iteration: {}, inner-level: {}, outer-level: {}'.format(t,g(bar_YD,range(n)),f(bar_YX, bar_YD,range(n))))\n","    oracle += 4\n","    if elapsed_time >= count:\n","      iters.append(t)\n","      inner.append(g(bar_YD,range(n))-g_opt)\n","      outer.append(f(bar_YX, bar_YD,range(n)))\n","      time_elapsed.append(elapsed_time)\n","      oracles.append(oracle)\n","      count += 1\n","  df = pd.DataFrame({\n","    't': iters,\n","    'inner': inner,\n","    'outer': outer,\n","    'oracles': oracles,\n","    'time_elapsed': time_elapsed})\n","  df.to_csv(filename, index=False)\n","  files.download(filename)\n","\n","def dbgdsto(init, budget,short, i):\n","\n","  if short == True:\n","    gamma = 5*10**(-3)\n","    filename = 'dbgdsto_short4_{}.csv'.format(i)\n","  else:\n","    gamma = 10**(-2)\n","    filename = 'dbgdsto_long4_{}.csv'.format(i)\n","\n","  iters = []\n","  inner = []\n","  outer = []\n","  time_elapsed = []\n","  oracles = []\n","\n","  oracle = 0\n","  count = 1\n","  t = 0\n","  X,D = init\n","  alpha = 100\n","  beta = 100\n","  n = n_old\n","\n","  elapsed_time = 0\n","  while elapsed_time <= budget:\n","\n","    start = time.time()\n","\n","    xi    = np.random.randint(0, n-1, size=1)\n","    theta = np.random.randint(0, n-1, size=1)\n","\n","\n","    hat_gradXf = gradXf(X, D,theta)\n","    hat_gradDf = gradDf(X, D,theta)\n","    hat_gradg = gradg(D,xi)\n","    hat_g = g(D,xi)\n","\n","    norm_sq = np.linalg.norm(hat_gradg)**2\n","    hat_phi = min(alpha*(hat_g), beta*np.linalg.norm(norm_sq)**2)\n","    nu = max((hat_phi-np.trace(hat_gradDf.T@hat_gradg))/norm_sq, 0)\n","\n","    #Need to work on\n","    X, D = proj(X -gamma*hat_gradXf,D -gamma*(hat_gradDf+nu*hat_gradg))\n","\n","    t += 1\n","    end = time.time()\n","\n","    elapsed_time += end-start\n","    #print('Iteration: {}, inner-level: {}, outer-level: {}'.format(t,g(D,range(n)),f(X, D, range(n))))\n","    oracle += 2\n","    if elapsed_time >= count:\n","      iters.append(t)\n","      inner.append(g(D,range(n))-g_opt)\n","      outer.append(f(X, D, range(n)))\n","      time_elapsed.append(elapsed_time)\n","      oracles.append(oracle)\n","      count += 1\n","\n","  df = pd.DataFrame({\n","    't': iters,\n","    'inner': inner,\n","    'outer': outer,\n","    'oracles': oracles,\n","    'time_elapsed': time_elapsed})\n","  df.to_csv(filename, index=False)\n","  files.download(filename)"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"wUPKZwuDNkjD"},"outputs":[],"source":["def spiderfw(init, budget):\n","  X, D = init\n","  t = 0\n","  n = n_old\n","  q = np.ceil(np.sqrt(n))\n","  S = q\n","  oracle = 0\n","  time_elapsed = 0\n","  while t <= budget:\n","   start = time.time()\n","   eta = 0.1/(t+2)\n","   if t%q == 0:\n","      ind = range(n)\n","      hat_gradg = gradg(D, ind)\n","      oracle += n\n","   else:\n","      ind = np.random.randint(0, n-1, size=int(S))\n","      hat_gradg = hat_gradg + gradg(D,ind) - gradg(D_prev,ind)\n","      oracle += S\n","\n","   VD = lmoD(hat_gradg)\n","   D_prev = D\n","   D = D+eta*(VD-D)\n","\n","   t += 1\n","   end = time.time()\n","   time_elapsed += end-start\n","   #print('iteration: {}, inner-level: {}'.format(t, g(D,range(int(n)))))\n","   if (t-1)%q == 0:\n","      oracle += n\n","   else:\n","      oracle += S\n","  return X, D, oracle, time_elapsed\n","\n","\n"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"fHwOXQ1qSFIC"},"outputs":[],"source":["# D_init = np.random.randn(m, p)\n","# D_init = D_init / np.linalg.norm(D_init, axis=0)  # Normalize atoms\n","# X_init = np.random.randn(p, n_old)\n","# X_init = X_init / np.sum(np.abs(X_init), axis=0, keepdims=True)\n","# init = (X_init, D_init)"]},{"cell_type":"code","source":["budget = 60\n","for i in range(0,10):\n","  np.random.seed(i)\n","  D_init = np.random.randn(m, p)\n","  D_init = D_init / np.linalg.norm(D_init, axis=0)  # Normalize atoms\n","  X_init = np.random.randn(p, n_old)\n","  X_init = X_init / np.sum(np.abs(X_init), axis=0, keepdims=True)\n","  init = (X_init, D_init)\n","\n","\n","  irscg(init, budget,i)\n","  irfscg(init, budget,i)\n","  sbcgi(init,budget,i)\n","  sbcgf(init,budget,i)\n","  aripseg(init, budget, True,i)\n","  aripseg(init, budget, False,i)\n","  dbgdsto(init, budget, True,i)\n","  dbgdsto(init, budget, False,i)"],"metadata":{"id":"o06YpRyfmgpv"},"execution_count":null,"outputs":[]}],"metadata":{"colab":{"provenance":[],"authorship_tag":"ABX9TyOsYDM5ATeqCIkW/zBFOeh5"},"kernelspec":{"display_name":"Python 3","name":"python3"},"language_info":{"name":"python"}},"nbformat":4,"nbformat_minor":0}