# Please check "GPU_MAPPING.md" to see how to define the topology
# You can define a cluster containing multiple GPUs within multiple machines by defining `gpu_mapping.yaml` as follows:

# config_cluster0:
#     host_name_node0: [num_of_processes_on_GPU0, num_of_processes_on_GPU1, num_of_processes_on_GPU2, num_of_processes_on_GPU3, ..., num_of_processes_on_GPU_n]
#     host_name_node1: [num_of_processes_on_GPU0, num_of_processes_on_GPU1, num_of_processes_on_GPU2, num_of_processes_on_GPU3, ..., num_of_processes_on_GPU_n]
#     host_name_node_m: [num_of_processes_on_GPU0, num_of_processes_on_GPU1, num_of_processes_on_GPU2, num_of_processes_on_GPU3, ..., num_of_processes_on_GPU_n]


# this is used for 10 clients and 1 server training within a single machine which has 4 GPUs
mapping_default:
    ChaoyangHe-GPU-RTX2080Tix4: [2, 3, 3, 3]

# this is used for 4 clients and 1 server training within a single machine which has 4 GPUs
mapping_config1_5:
    host1: [2, 1, 1, 1]

mapping_config8_10:
    host1: [2, 2, 2, 1, 1, 1, 1, 1]

# this is used for 10 clients and 1 server training within a single machine which has 4 GPUs
mapping_config2_11:
    host1: [3, 3, 3, 2]

# this is used for 10 clients and 1 server training within a single machine which has 8 GPUs
mapping_config3_11:
    host1: [1, 2, 2, 1, 2, 1, 1, 1]

# this is used for 4 clients and 1 server training within a single machine which has 8 GPUs, but you hope to skip the GPU device ID.
mapping_config4_5:
    host1: [1, 0, 0, 1, 1, 0, 1, 1]

# this is used for 4 clients and 1 server training using 6 machines, each machine has 2 GPUs inside, but you hope to use the second GPU.
mapping_config5_6:
    host1: [0, 1]
    host2: [0, 1]
    host3: [0, 1]
    host4: [0, 1]
    host5: [0, 1]

mapping_config_4_GPUs_lambda4:
    lambda-server-vital: [2, 3, 3, 3]


mapping_config_4_7_GPUs_lambda4:
    lambda-server-vital: [0, 0, 0, 0, 2, 3, 3, 3]


mapping_a100_2_gpu:
    g1ldev3: [6, 5]

mapping_g1lmd2_8_gpu:
    g1lmd2: [2, 2, 2, 1, 1, 1, 1, 1]

mapping_g1lmd2_8_gpu_l:
    g1lmd2: [1, 1, 1, 1, 2, 2, 2, 1]

mapping_g1lmd3_8_gpu:
    g1lmd3: [2, 2, 2, 1, 1, 1, 1, 1]


mapping_g1lmd2_1st_4_gpu:
    g1lmd2: [3, 3, 3, 2, 0, 0, 0, 0]

mapping_g1lmd2_last_4_gpu:
    g1lmd2: [0, 0, 0, 0, 3, 3, 3, 2]

mapping_g1lmd3_1st_4_gpu:
    g1lmd2: [3, 3, 3, 2, 0, 0, 0, 0]

mapping_g1lmd3_last_4_gpu:
    g1lmd2: [0, 0, 0, 0, 3, 3, 3, 2]

gld23k_0:
    host1: [2, 2, 2, 1, 1, 1, 1, 1]

gld23k_1:
    host1: [1, 2, 2, 2, 1, 1, 1, 1]

gld23k_2:
    host1: [1, 1, 2, 2, 2, 1, 1, 1]