{"cells":[{"cell_type":"markdown","metadata":{"id":"1QUJFmiYqfzR"},"source":["## QQA"]},{"cell_type":"code","execution_count":3,"metadata":{"executionInfo":{"elapsed":3679,"status":"ok","timestamp":1727793719308,"user":{"displayName":"yamato","userId":"18149854186417180194"},"user_tz":-540},"id":"E6r4BR_9qUzY"},"outputs":[],"source":["import torch\n","import networkx as nx\n","from main import utils\n","from main import qqa\n","from main import instance\n","\n","device = torch.device('cuda:0' if torch.cuda.is_available() else 'cpu')"]},{"cell_type":"code","execution_count":4,"metadata":{"executionInfo":{"elapsed":12,"status":"ok","timestamp":1727793719308,"user":{"displayName":"yamato","userId":"18149854186417180194"},"user_tz":-540},"id":"x3G7EW1ZqcYU"},"outputs":[],"source":["SEED = 0\n","utils.fix_seed(SEED)\n","torch_type = torch.float32"]},{"cell_type":"markdown","source":["## Maximum Independent Set"],"metadata":{"id":"wQ_v7Eere-Vd"}},{"cell_type":"markdown","metadata":{"id":"ECaYAG6zqlkR"},"source":["### Step 1: Load Problem and Set Hyperparameters"]},{"cell_type":"code","execution_count":5,"metadata":{"executionInfo":{"elapsed":16829,"status":"ok","timestamp":1727793736127,"user":{"displayName":"yamato","userId":"18149854186417180194"},"user_tz":-540},"id":"_FpZNBeuqwZU"},"outputs":[],"source":["# Graph Parameters\n","N, d, p = 10000, 100, None\n","nx_graph = nx.random_regular_graph(d=d, n=N, seed=SEED)\n","Q_mat = utils.qubo_dict_to_torch(nx_graph, instance.gen_q_dict_mis_sym(nx_graph, penalty=2)).to(device)\n","\n","# QQA Parameters\n","parallel_size=100\n","num_epoch=int(1e4)\n","lr=1\n","temp=1e-3\n","min_bg=-2\n","max_bg=0.1\n","curve_rate=4\n","div_param=0.1\n","check_interval=1000"]},{"cell_type":"markdown","metadata":{"id":"PK3kApE_q1SS"},"source":["### Step 2: Define Loss Function"]},{"cell_type":"code","execution_count":6,"metadata":{"executionInfo":{"elapsed":15,"status":"ok","timestamp":1727793736129,"user":{"displayName":"yamato","userId":"18149854186417180194"},"user_tz":-540},"id":"wBNVTSGGq4-m"},"outputs":[],"source":["def loss_func(x):\n","    return torch.einsum('bi,ij,bj->b', x, Q_mat, x)"]},{"cell_type":"markdown","metadata":{"id":"Nheh9c_nq8VD"},"source":["### Step 3: Run QQA"]},{"cell_type":"code","execution_count":7,"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"elapsed":191227,"status":"ok","timestamp":1727793927343,"user":{"displayName":"yamato","userId":"18149854186417180194"},"user_tz":-540},"id":"2-app1OzrExB","outputId":"8754837b-5e0e-41a1-edbf-e266b0452b40"},"outputs":[{"output_type":"stream","name":"stdout","text":["EPOCH:0, LOSS:49721208.0, PENALTY:799894.125, PARAM:-2.0\n","EPOCH:1000, LOSS:169569.015625, PENALTY:183611.0, PARAM:-1.79\n","EPOCH:2000, LOSS:98238.3125, PENALTY:149255.53125, PARAM:-1.58\n","EPOCH:3000, LOSS:33151.60546875, PENALTY:110212.265625, PARAM:-1.37\n","EPOCH:4000, LOSS:-16084.150390625, PENALTY:75748.8125, PARAM:-1.1600000000000001\n","EPOCH:5000, LOSS:-30861.75390625, PENALTY:62788.78125, PARAM:-0.95\n","EPOCH:6000, LOSS:-40765.265625, PENALTY:51797.40625, PARAM:-0.74\n","EPOCH:7000, LOSS:-49729.90234375, PENALTY:38191.6875, PARAM:-0.53\n","EPOCH:8000, LOSS:-62459.09375, PENALTY:6802.5908203125, PARAM:-0.32000000000000006\n","EPOCH:9000, LOSS:-64448.0, PENALTY:0.0, PARAM:-0.1100000000000001\n","EPOCH:9999, LOSS:-64448.0, PENALTY:0.0, PARAM:0.09979000000000005\n"]}],"source":["best_bit_string, runtime = qqa.optimize(N,\n","                                    loss_func,\n","                                    parallel_size=parallel_size,\n","                                    num_epoch=num_epoch,\n","                                    lr=lr,\n","                                    temp=temp,\n","                                    device=device,\n","                                    min_bg=min_bg,\n","                                    max_bg=max_bg,\n","                                    curve_rate=curve_rate,\n","                                    div_param=div_param,\n","                                    check_interval=check_interval\n","                                    )"]},{"cell_type":"code","execution_count":8,"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"elapsed":512,"status":"ok","timestamp":1727793927841,"user":{"displayName":"yamato","userId":"18149854186417180194"},"user_tz":-540},"id":"2YxC3e1vrG_U","outputId":"9aeaee30-9343-4f82-912b-8201e25f31b7"},"outputs":[{"output_type":"stream","name":"stdout","text":["Independent set size: 656 Violation: 0\n"]}],"source":["size_mis, _, number_violation = utils.postprocess_mis(best_bit_string, nx_graph)\n","print(f\"Independent set size: {size_mis} Violation: {number_violation}\")"]},{"cell_type":"markdown","source":["## Graph Coloring"],"metadata":{"id":"wb_P9Bm6fOBX"}},{"cell_type":"markdown","source":["### Step 1: Load Problem and Set Hyperparameters"],"metadata":{"id":"iHSaPmotfSyg"}},{"cell_type":"code","source":["# Graph Parameters\n","N, d, p = 1000, 10, None\n","nx_graph = nx.random_regular_graph(d=d, n=N, seed=SEED)\n","adj_maxtrix = torch.tensor(nx.adjacency_matrix(nx_graph, nodelist=[i for i in range(N)]).toarray(), device=device, dtype=torch_type)\n","num_color = 5\n","\n","# QQA Parameters\n","parallel_size=100\n","num_epoch=int(1e4)\n","lr=0.1\n","temp=1e-3\n","min_bg=-2\n","max_bg=0.1\n","curve_rate=4\n","div_param=0.1\n","check_interval=1000"],"metadata":{"id":"xFtxJ5OefUA4","executionInfo":{"status":"ok","timestamp":1727793927842,"user_tz":-540,"elapsed":10,"user":{"displayName":"yamato","userId":"18149854186417180194"}}},"execution_count":9,"outputs":[]},{"cell_type":"markdown","source":["### Step 2: Define Loss Function"],"metadata":{"id":"2f5W0n3Pffdy"}},{"cell_type":"code","source":["## Define Loss Function\n","def loss_func(x):\n","    return torch.sum(torch.einsum('bis,ij,bjs->bs', x, adj_maxtrix, x)/2, dim=1)"],"metadata":{"id":"cB44YHdFfruP","executionInfo":{"status":"ok","timestamp":1727793928914,"user_tz":-540,"elapsed":1080,"user":{"displayName":"yamato","userId":"18149854186417180194"}}},"execution_count":10,"outputs":[]},{"cell_type":"markdown","source":["### Step 3: Run QQA"],"metadata":{"id":"u3WCJ9dFfj0y"}},{"cell_type":"code","source":["best_string, runtime = qqa.optimize_categorical(N,\n","                                                num_color,\n","                                                loss_func,\n","                                                parallel_size=parallel_size,\n","                                                num_epoch=num_epoch,\n","                                                lr=lr,\n","                                                temp=temp,\n","                                                device=device,\n","                                                min_bg=min_bg,\n","                                                max_bg=max_bg,\n","                                                curve_rate=curve_rate,\n","                                                div_param=div_param,\n","                                                check_interval=check_interval\n","                                                )"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"8a2gJ_oEfuXg","executionInfo":{"status":"ok","timestamp":1727793962321,"user_tz":-540,"elapsed":33416,"user":{"displayName":"yamato","userId":"18149854186417180194"}},"outputId":"95438774-c529-43c4-c50c-629fc626161f"},"execution_count":11,"outputs":[{"output_type":"stream","name":"stdout","text":["EPOCH:0, LOSS:100018.640625, PENALTY:99416.59375, PARAM:-2.0\n","EPOCH:1000, LOSS:34982.125, PENALTY:93113.625, PARAM:-1.79\n","EPOCH:2000, LOSS:34066.03515625, PENALTY:92589.15625, PARAM:-1.58\n","EPOCH:3000, LOSS:32909.99609375, PENALTY:91831.6796875, PARAM:-1.37\n","EPOCH:4000, LOSS:31343.701171875, PENALTY:90639.6484375, PARAM:-1.1600000000000001\n","EPOCH:5000, LOSS:29045.580078125, PENALTY:88571.625, PARAM:-0.95\n","EPOCH:6000, LOSS:25075.625, PENALTY:84250.0078125, PARAM:-0.74\n","EPOCH:7000, LOSS:16940.814453125, PENALTY:72897.4375, PARAM:-0.53\n","EPOCH:8000, LOSS:4910.4140625, PENALTY:45458.3828125, PARAM:-0.32000000000000006\n","EPOCH:9000, LOSS:374.71246337890625, PENALTY:26472.13671875, PARAM:-0.1100000000000001\n","EPOCH:9999, LOSS:87.61386108398438, PENALTY:35.251853942871094, PARAM:0.09979000000000005\n"]}]},{"cell_type":"code","source":["number_violation = utils.postprocess_coloring(best_string, num_color, nx_graph)\n","print(f\"Violation: {number_violation}\")"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"kTpH3dkHf0Cb","executionInfo":{"status":"ok","timestamp":1727793962322,"user_tz":-540,"elapsed":29,"user":{"displayName":"yamato","userId":"18149854186417180194"}},"outputId":"b101e36a-0903-4aa6-8291-02a23c7092c1"},"execution_count":12,"outputs":[{"output_type":"stream","name":"stdout","text":["Violation: 0\n"]}]}],"metadata":{"accelerator":"GPU","colab":{"gpuType":"T4","provenance":[]},"kernelspec":{"display_name":"Python 3","name":"python3"},"language_info":{"name":"python"}},"nbformat":4,"nbformat_minor":0}