{
  "task": {
    "CA": {
      "task_description": "The Combinatorial Auction (CA) task is a combinatorial optimization problem where a set of items is auctioned to a set of bidders. Each bidder can bid on a combination of items, and the goal is to maximize the total revenue by selecting a subset of bids that satisfy the constraints.",
      "variable_type": {
        "x": {
          "type": "binary",
          "description": "The variable x_i indicates whether bid i is accepted (1) or not (0). The variable x is used to make decisions about which bids to include in the solution. For each bid, x_i is either 0 or 1, where 1 means the bid is selected and 0 means it is not selected.",
          "index": "x_i",
          "range": "{0, 1}",
          "constraints": "For each bid i, x_i is a binary decision variable representing whether the bid is included in the solution. The value of x_i can only be 0 or 1, and the decision to include or exclude a bid impacts the satisfaction of the constraints."
        }
      },
      "constraint_type": {
        "Item Allocation Constraint": {
          "type": "linear, inequality, leq, SetPacking",
          "description": "Constraint c_j ensuring that each item j in {1, 2, ..., n_items} can only be selected by one bid (x_k). The sum of x_i for each item j must be leq 1. It is useful to prevent the solution from becoming infeasible or too costly by limiting the number of bids that can be selected in the final solution.",
          "index": "c_j (j <= n_items )",
          "expression": "sum(x_i for i in bids) <= 1, where i in {1, 2, ..., n_bids}",
          "constraints": "For each item j, the sum of x_i (where i is a bid associated with item j) should be at most 1, ensuring that no item is selected by more than one bid."
        },
        "Substitutable Bids Constraint": {
          "type": "linear inequality, leq, SetPacking",
          "description": "Ensures that at most one bid from each group of substitutable bids can be accepted. This constraint enforces mutual exclusivity among substitutable bids generated by the same bidder.",
          "index": "c_k (n_items <= k <= n_constraints)",
          "expression": "sum_{b_i in B_j} x_i leq 1, where B_j is a substitutable bid group for bidder j",
          "constraints": "For each substitutable bid group B_j (generated by a bidder), the sum of decision variables x_i for all bids b_i in the group must be less than or equal to 1. This ensures that no more than one bid from the group is accepted. Here, x_i is a binary decision variable where x_i=1 indicates bid b_i is accepted, and x_i=0 indicates it is rejected. j is the index of the substitutable bid group."
        },
        "objective": {
          "type": "linear",
          "description": "Objective function to maximize the total revenue by selecting a subset of bids that satisfy the constraints.",
          "index": "obj",
          "expression": "maximize sum(revenue_i * x_i for i in bids), where i in {1, 2, ..., n_bids}",
          "constraints": "The objective function is to maximize the total revenue by selecting a subset of bids that satisfy the constraints. The revenue_i is the revenue generated by bid i, and x_i is the binary decision variable indicating whether bid i is selected."
        }
      },
      "edges": [
        {
          "source": "0",
          "target": "0"
        },
        {
          "source": "0",
          "target": "1"
        },
        {
          "source": "0",
          "target": "3"
        }
      ]
    },
    "WA": {
      "task_description": "The Workload Apportionment (WA) task is a combinatorial optimization problem that aims to minimize the total cost of processing workloads while ensuring robustness against worker failures. Each worker has a fixed capacity and activation cost, and each workload has specific processing requirements and allowed workers. The goal is to allocate work to workers while considering these constraints and minimizing costs.",
      "variable_type": {
        "worker_used": {
          "type": "binary",
          "description": "Indicates whether worker_i is activated (1) or not (0). Activating a worker incurs its fixed activation cost.",
          "index": "worker_used_i",
          "range": "{0, 1}",
          "constraints": "worker_used_i = 1 if any workload is assigned to worker i; otherwise, worker_used_i = 0."
        },
        "reserved_capacity": {
          "type": "continuous",
          "description": "Indicates the amount of work reserved on worker_i for workload_j. This value cannot exceed the worker's capacity and must be non-negative.",
          "index": "reserved_capacity_i_j",
          "range": "[0, inf)",
          "constraints": "reserved_capacity_i_j must be non-negative and can only be assigned to workers allowed to process workload_j."
        }
      },
      "constraint_type": {
        "worker_used_ct": {
          "type": "linear, inequality, greater or eq, variable bound",
          "description": "Tracks whether a worker_i is activated when it is assigned workload_j.",
          "index": "worker_used_ct_i_j",
          "expression": " worker_used_i * capacity_i >= reserved_capacity_i_j",
          "constraints": "If any capacity is reserved on a worker for a workload, the worker must be activated."
        },
        "worker_capacity_ct": {
          "type": "linear, inequality, less or eq, General Linear",
          "description": "Ensures that the total reserved capacity on a worker does not exceed its maximum capacity.",
          "index": "worker_capacity_ct_i",
          "expression": "sum(reserved_capacity_i_j for all j) <= capacity_i",
          "constraints": "Total reserved capacity for all workloads on a worker must respect its capacity."
        },
        "workload_ct": {
          "type": "linear, inequality, greater or eq, General Linear",
          "description": "Ensures that there is sufficient capacity to process workload_j even if any one worker_i fails.",
          "index": "workload_ct_j_failure_i",
          "expression": "sum(reserved_capacity_k_j for all k != i) >= workload_amount_j",
          "constraints": "The sum of capacities reserved for a workload across all active workers except the failing worker must meet or exceed the workload's requirements."
        },
        "objective": {
          "type": "linear",
          "description": "Minimizes the total activation and reservation costs of all workers.",
          "index": "obj",
          "expression": "minimize sum(worker_used_i * activation_cost_i for all i) + sum(reserved_capacity_i_j * cost_per_unit_capacity_i_j for all i, j)",
          "constraints": "Objective function combines the fixed activation cost of workers and the cost of reserved capacities for workloads."
        }
      },
      "edges": [
        {
          "source": "0",
          "target": "0"
        },
        {
          "source": "1",
          "target": "0"
        },
        {
          "source": "1",
          "target": "1"
        },
        {
          "source": "1",
          "target": "2"
        },
        {
          "source": "0",
          "target": "3"
        },
        {
          "source": "1",
          "target": "3"
        }
      ]
    },

    "IP": {
      "task_description": "The Imbalance Problem (IP) task involves placing items into bins while minimizing the imbalance of resource usage across all bins. Each item has fixed resource requirements for multiple resource types, and each bin has fixed capacities for these resources. The goal is to allocate items to bins in a way that minimizes the normalized imbalance of resources.",
      "variable_type": {
        "place": {
          "type": "binary",
          "description": "Indicates whether item formula_i is placed in bin formula_b (1) or not (0).",
          "index": "place_i_b",
          "range": "{0, 1}",
          "constraints": "place_i_b = 1 if item i is placed in bin b; otherwise, place_i_b = 0."
        },
        "deficit": {
          "type": "continuous",
          "description": "Tracks the normalized imbalance of resource formula_r in bin formula_b. A higher value indicates a greater imbalance.",
          "index": "deficit_b_r",
          "range": "{0, 1}",
          "constraints": "deficit_b_r must be a non-negative continuous variable representing the normalized imbalance for each bin and resource."
        },
        "max_deficit": {
          "type": "continuous",
          "description": "Tracks the maximum normalized imbalance of resource formula_r across all bins.",
          "index": "max_deficit_r",
          "range": "{0, 1}",
          "constraints": "max_deficit_r must be a non-negative continuous variable representing the maximum normalized imbalance for each resource across all bins."
        }
      },
      "constraint_type": {
        "copies_ct": {
          "type": "linear, equality, SetPartitioning",
          "description": "Ensures that each item formula_i is placed in exactly one bin.",
          "index": "copies_ct_i",
          "expression": "sum(place_i_b for all b) = 1",
          "constraints": "Each item must be placed in one and only one bin."
        },
        "supply_ct": {
          "type": "linear, inequality, less or eq, Knapsack",
          "description": "Ensures that the total resource usage for formula_r in bin formula_b does not exceed the bin's capacity.",
          "index": "supply_ct_b_r",
          "expression": "sum(place_i_b * resource_required_i_r for all i) <= resource_available_b_r",
          "constraints": "Total resource usage for a bin must respect its capacity for each resource."
        },
        "deficit_ct": {
          "type": "linear, inequality, greater or eq, Mixed Binary",
          "description": "Tracks the normalized imbalance of resource formula_r in bin formula_b.",
          "index": "deficit_ct_b_r",
          "expression": "deficit_b_r >= (sum(place_i_b * resource_required_i_r for all i) / resource_available_b_r) - 1",
          "constraints": "Deficit for a resource in a bin must reflect the normalized imbalance."
        },
        "max_deficit_ct": {
          "type": "linear, inequality, greater or eq, General Linear",
          "description": "Tracks the maximum normalized imbalance of resource formula_r across all bins.",
          "index": "max_deficit_ct_r",
          "expression": "max_deficit_r >= deficit_b_r for all b",
          "constraints": "The maximum deficit for each resource must be greater than or equal to the deficit in any bin."
        },
        "objective": {
          "type": "linear",
          "description": "Minimizes the maximum normalized imbalance of resources across all bins.",
          "index": "obj",
          "expression": "minimize max(max_deficit_r for all r)",
          "constraints": "Objective function aims to minimize the maximum normalized imbalance of resource usage across bins."
        }
      },
      "edges": [
        {
          "source": "0",
          "target": "0"
        },
        {
          "source": "0",
          "target": "1"
        }
      ]
    },

    "IS": {
      "task_description": "The Maximum Independent Set (IS) task is a combinatorial optimization problem where the goal is to select the largest subset of vertices in a graph such that no two selected vertices are adjacent.",
      "variable_type": {
        "x": {
          "type": "binary",
          "description": "The variable x_i indicates whether vertex i is included in the independent set (1) or not (0). For each vertex i, x_i in {0,1}.",
          "index": "x_i",
          "range": "{0, 1}",
          "constraints": "Each x_i must be 0 or 1, and selecting x_i = 1 means vertex i is in the solution subset."
        }
      },
      "constraint_type": {
        "Edge Conflict Constraint": {
          "type": "linear, inequality, leq, SetPacking",
          "description": "Ensures that no two adjacent vertices are both selected in the independent set. For every edge (i, j), x_i + x_j ≤ 1.",
          "index": "c_(i,j) for each edge (i,j)",
          "expression": "x_i + x_j ≤ 1, for each edge (i,j) in E",
          "constraints": "For every edge (i,j) in the graph, the sum of x_i and x_j must be at most 1, ensuring that vertices i and j cannot both be included in the independent set."
        },
        "objective": {
          "type": "linear",
          "description": "Objective function to maximize the number of selected vertices (the size of the independent set).",
          "index": "obj",
          "expression": "maximize sum(x_i) for i in {0, 1, ..., n_vertices-1}",
          "constraints": "We want to select as many vertices as possible, subject to the constraint that no two adjacent vertices are both selected."
        }
      },
      "edges": [
        {
          "source": "0",
          "target": "0"
        },
        {
          "source": "0",
          "target": "1"
        }
      ]
    },
    "MVC": {
      "task_description": "The Minimum Vertex Cover (MVC) problem is a combinatorial optimization task. Given an undirected graph G = (V,E) with a weight w_v for each node v ∈ V, the goal is to select a subset of nodes V′ ⊆ V with the minimum sum of weights such that for every edge (u,v) ∈ E, at least one of its endpoints u or v is included in V′.",
      "variable_type": {
        "x": {
          "type": "binary",
          "description": "The variable x_v indicates whether vertex v is included in the vertex cover (1) or not (0). For each vertex v, x_v in {0,1}.",
          "index": "x_v",
          "range": "{0, 1}",
          "constraints": "If x_v = 1, vertex v is part of the cover; if x_v = 0, it is not."
        }
      },
      "constraint_type": {
        "Edge Coverage Constraint": {
          "type": "linear, inequality, geq, SetCovering",
          "description": "Ensures that each edge has at least one endpoint in the vertex cover. For every edge (u,v), x_u + x_v ≥ 1.",
          "index": "c_(u,v) for each edge (u,v)",
          "expression": "x_u + x_v ≥ 1, for each (u,v) in E",
          "constraints": "If an edge (u,v) is present, at least one of x_u or x_v must be 1."
        },
        "objective": {
          "type": "linear",
          "description": "Objective function to minimize the total weight of the selected vertices in the cover.",
          "index": "obj",
          "expression": "minimize sum (w_v * x_v) for v in V, w_v is  weights of edges ",
          "constraints": "We want to choose a set of vertices that covers all edges while minimizing the sum of the selected vertices’ weights."
        }
      },
      "edges": [
        {
          "source": "0",
          "target": "0"
        },
        {
          "source": "0",
          "target": "1"
        }
      ]
    },

    "MMCN": {
      "task_description": "The Middle-Mile Consolidation Network Design (MMCN) task is a tactical freight transportation planning problem where a set of commodities must be transported from fixed origins (vendors) to fixed destinations (last-mile centers). The objective is to determine optimal consolidation paths and dispatch frequencies over a single-mode freight network, such that all commodity demands are met and the total transportation and handling cost is minimized. This BI variant considers only one transportation mode per arc, and models dispatch frequencies as integer variables.",
      "variable_type": {
        "x": {
          "type": "binary",
          "description": "The variable x_r indicates whether a specific route r is selected for a commodity k. It takes the value 1 if the route is used and 0 otherwise. Each route corresponds to a feasible consolidation path from the origin to the destination of a commodity.",
          "index": "x_r",
          "range": "{0, 1}",
          "constraints": "For each commodity k, exactly one route r must be selected such that x_r = 1. The selection of x_r determines how demand flows through the network and which arcs (legs) require dispatch capacity."
        },
        "y": {
          "type": "non-negative integers",
          "description": "The variable y_l indicates the number of dispatches (i.e., frequency) assigned to arc l (a leg in the network). Each arc has a fixed single transportation mode and a maximum capacity per dispatch (e.g., 12,000 lbs/truckload).",
          "index": "y_l",
          "range": " [0, inf], non-negative integers",
          "constraints": "The value of y_l determines how many trucks (or dispatches) are allocated to arc l within the planning period (e.g., per week). Each dispatch (truck) on arc l can carry up to Q_l_max units of load. Therefore, y_l * Q_l_max represents the **total available transportation capacity** on arc l. This capacity must be sufficient to carry the total demand assigned to arc l via all selected routes x_r. For example, if arc l has Q_l_max = 12,000 lbs and the total demand routed through l is 30,000 lbs, then y_l must be at least 3 (i.e., 3 trucks × 12,000 = 36,000 ≥ 30,000). This implies a hidden relationship of the form: sum_{r ∋ l} V_k * x_r ≤ Q_l_max * y_l, which is explicitly modeled as an Arc Capacity Constraint. If y_l = 0, then no dispatch is assigned to arc l, implying that no selected route may use this arc."
        }
      },
      "constraint_type": {
        "Route Selection Constraint": {
          "type": "linear, equality, Set Partitioning",
          "description": "Ensures that each commodity selects exactly one feasible route.",
          "index": "c_k (k in commodities)",
          "expression": "sum(x_r for r in R_k) == 1, where R_k is the set of valid routes for commodity k",
          "constraints": "This constraint guarantees that exactly one route is selected for each commodity, ensuring a unique transport plan from vendor to last-mile center."
        },
        "Arc Capacity Constraint": {
          "type": "linear, inequality, leq, General Linear",
          "description": "Ensures that the total demand assigned to each arc via selected routes does not exceed the arc’s total dispatch capacity (dispatch frequency * truck capacity).",
          "index": "c_l (l in arcs)",
          "expression": "sum(V_k * x_r for all l in r) ≤ Q_max_l * y_l",
          "constraints": "For each arc l, the sum of all demand volumes from selected routes that include l must be less than or equal to the total capacity provided by y_l dispatches of trucks with maximum capacity Q_max_l. This prevents overloading any arc in the network."
        },
        "objective": {
          "type": "linear",
          "description": "Objective function to minimize the total cost of transportation and handling, including route-based consolidation costs and arc dispatch costs.",
          "index": "obj",
          "expression": "minimize sum(C_r * x_r for all r) + sum(A_l * y_l for all l)",
          "constraints": "The objective function minimizes the total cost consisting of (1) the cost C_r associated with selecting a route r (including transfer and consolidation handling), and (2) the cost A_l of dispatching trucks along arc l at frequency y_l. Both terms contribute to the operational cost of the middle-mile logistics network."
      }
      },
      "edges": [
        {
          "source": "0", 
          "target": "0"
        },
        {
          "source": "0",
          "target": "1"
        },
        {
          "source": "0",
          "target": "2"
        },
        {
          "source": "1",
          "target": "1"
        },
        {
          "source": "1",
          "target": "2"
        }
      ]
    },

    "MMCN2": {
      "task_description": "The Middle-Mile Consolidation Network Design (MMCN) task is a tactical freight transportation planning problem in which a set of commodities must be moved from fixed origins (vendors) to fixed destinations (last-mile centers). The BC variant allows for multiple transportation modes per arc and models dispatch frequency selection using binary variables, while shipment volumes are represented using continuous variables. The objective is to determine the optimal set of commodity routes, dispatch frequencies, and shipment volumes across the multimodal network to minimize total cost while satisfying lead-time and capacity constraints.",
      "variable_type": {
        "x": {
          "type": "binary",
          "description": "The variable x_r indicates whether a specific route r is selected for a commodity k. It takes the value 1 if the route is used and 0 otherwise. Each route corresponds to a feasible consolidation path from the origin to the destination of a commodity.",
          "index": "x_r",
          "range": "{0, 1}",
          "constraints": "For each commodity k, exactly one route r must be selected such that x_r = 1. The selected route determines which arcs and modes are activated and how demand is routed through the network."
        },
        "z": {
          "type": "binary",
          "description": "The variable z_{lmω} indicates whether a particular frequency level ω is selected for arc l using mode m. Only one frequency level can be selected per arc-mode pair.",
          "index": "z_{lmω}",
          "range": "{0, 1}",
          "constraints": "For each arc l and mode m, at most one frequency ω can be selected, enforced by: sum(z_{lmω}) ≤ 1. The value of z_{lmω} determines the total dispatch capacity available on that arc-mode pair and affects both capacity constraints and lead-time constraints."
        },
        "v": {
          "type": "non-negative continuous",
          "description": "The variable v_{lm} indicates the total shipment volume assigned to arc l using mode m, aggregated over all commodities routed through that arc-mode pair.",
          "index": "v_{lm}",
          "range": "[0, inf)",
          "constraints": "The shipment volume v_{lm} must not exceed the total transportation capacity provided by the selected dispatch frequency: v_{lm} ≤ ∑_ω (Q_max_{lm} × ω × z_{lmω}). This ensures that the scheduled dispatches can accommodate the total assigned flow."
        }
      },
      "constraint_type": {
        "Route Selection Constraint": {
          "type": "linear, equality, Set Partitioning",
          "description": "Ensures that each commodity selects exactly one feasible route.",
          "index": "c_k (k in commodities)",
          "expression": "sum(x_r for r in R_k) == 1, where R_k is the set of valid routes for commodity k",
          "constraints": "Each commodity must be transported using exactly one route. This constraint enforces the uniqueness of route selection for every commodity."
        },
        "Arc Volume Upper Bound Constraint": {
          "type": "linear, inequality, leq",
          "description": "Ensures that the volume assigned to each arc-mode pair does not exceed the dispatch capacity available from the selected frequency.",
          "index": "c_{lm}",
          "expression": "v_{lm} ≤ sum_ω (Q_max_{lm} * ω * z_{lmω})",
          "constraints": "For each arc-mode pair (l,m), the shipment volume v_{lm} must not exceed the total capacity provided by dispatch frequency selection z_{lmω}. This constraint avoids overloading any arc."
            },
        "Arc Volume Lower Bound Constraint": {
            "type": "linear, inequality, geq",
            "description": "Ensures that the volume assigned to each arc-mode pair is sufficient to justify the selected dispatch frequency, avoiding underutilized dispatching.",
            "index": "c_{lm}",
            "expression": "v_{lm} ≥ sum_ω (Q_min_{lm} * ω * z_{lmω})",
            "constraints": "For each arc-mode pair (l,m), if a frequency is selected via z_{lmω}, then v_{lm} must be at least the corresponding minimal justified volume. This enforces consistency between dispatch decisions and flow assignment."
              },
        "Volume Aggregation Constraint": {
          "type": "linear, equality",
          "description": "Ensures that the total shipment volume v_{lm} on each arc-mode pair reflects the cumulative demand routed via selected paths.",
          "index": "c_{lm} (for each arc-mode pair)",
          "expression": "v_{lm} = sum(V_k * x_r for all r including arc l with mode m)",
          "constraints": "For each arc-mode pair (l,m), the total volume v_{lm} must match the sum of all demand from selected paths that use that arc-mode. This constraint establishes the flow conservation relationship between path selections and arc volumes."
        },
        "Frequency Selection Constraint": {
          "type": "linear, inequality, leq",
          "description": "Ensures that at most one frequency level is selected per arc-mode pair.",
          "index": "c_{lm} (for each arc-mode pair)",
          "expression": "sum(z_{lmω} for ω in Ω_lm) ≤ 1",
          "constraints": "For each arc-mode pair (l,m), only one frequency level ω may be selected, enforcing discrete frequency assignment and simplifying dispatch planning."
        },
        "Route-Waiting-Time Constraint": {
          "type": "linear, inequality, geq",
          "description": "Linearized lead-time constraint enforcing a bound on the expected waiting time across the selected route, based on dispatch frequencies.",
          "index": "c_r (per route r)",
          "expression": "-ρ_r * x_r - sum((1/ω) * z_{lmω}) ≥ -W̄_r",
          "constraints": "If a route is selected (x_r = 1), the total expected waiting time based on 1/ω for each arc-mode-frequency used must be no more than W̄_r. If the route is not selected (x_r = 0), this constraint is relaxed. This ensures lead-time compliance."
        },
        "Route-to-Frequency Coupling Constraint": {
          "type": "linear, inequality, leq",
          "description": "Ensures that if a route r is selected, then the corresponding arc-mode-frequency variables z_{lmω} must be activated to support it.",
          "index": "c_{r,l} (for route r including arc l)",
          "expression": "x_r ≤ sum(z_{lmω} for ω in Ω_lm)",
         "constraints": "If a route x_r is selected and uses arc l with mode m, then at least one dispatch frequency on that arc-mode pair must be activated. This constraint enforces operational consistency between route selection and network activation."
            },
        "objective": {
          "type": "linear",
          "description": "Objective function to minimize the total cost of transportation and handling, including fixed route costs, dispatch frequency costs, and volume-based transportation costs.",
          "index": "obj",
          "expression": "minimize sum(C_r * x_r for all r) + sum(A_{lmω} * z_{lmω} for all l, m, ω) + sum(B_{lm} * v_{lm} for all l, m)",
          "constraints": "The objective combines: (1) route selection costs C_r, (2) frequency selection costs A_{lmω}, and (3) volume-dependent shipping costs B_{lm}, and seeks to minimize the total operational cost."
      }
      },
      "edges": [
        {
          "source": "0",
          "target": "0"
        },
        {
          "source": "0",
          "target": "3"
        },
        {
          "source": "0",
          "target": "5"
        },
        {
          "source": "0",
          "target": "6"
        },
        {
          "source": "0",
          "target": "7"
        },
        {
          "source": "1",
          "target": "1"
        },
        {
          "source": "1",
          "target": "2"
        },
        {
          "source": "1",
          "target": "4"
        },
        {
          "source": "1",
          "target": "5"
        },
        {
          "source": "1",
          "target": "6"
        },
        {
          "source": "1",
          "target": "7"
        },
        {
          "source": "2",
          "target": "1"
        },
        {
          "source": "2",
          "target": "2"
        },
        {
          "source": "2",
          "target": "3"
        },
        {
          "source": "2",
          "target": "7"
        }
      ]
    }
  }
}

