2022-06-10 11:50:59 +02:00
|
|
|
openapi: 3.0.3
|
|
|
|
info:
|
|
|
|
version: 0.1.0
|
|
|
|
title: Schemata for command instructions
|
2022-06-11 16:07:23 +02:00
|
|
|
servers:
|
|
|
|
- url: "."
|
2022-06-10 11:50:59 +02:00
|
|
|
paths: {}
|
|
|
|
components:
|
|
|
|
schemas:
|
|
|
|
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
# Commands
|
|
|
|
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
Commands:
|
|
|
|
description: |-
|
|
|
|
List of commands to test algorithms/datastructures.
|
|
|
|
type: array
|
|
|
|
items:
|
|
|
|
$ref: "#/components/schemas/Command"
|
|
|
|
default: []
|
|
|
|
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
# Command
|
|
|
|
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
Command:
|
|
|
|
description: |-
|
|
|
|
Instructions for command to call
|
2022-06-11 16:07:23 +02:00
|
|
|
type: object
|
2022-06-10 11:50:59 +02:00
|
|
|
required:
|
|
|
|
- name
|
2022-06-11 16:07:23 +02:00
|
|
|
properties:
|
2022-06-10 11:50:59 +02:00
|
|
|
name:
|
|
|
|
$ref: '#/components/schemas/EnumAlgorithmNames'
|
|
|
|
additionalProperties: true
|
|
|
|
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2022-06-14 01:34:44 +02:00
|
|
|
# Algorithm: Tarjan
|
2022-06-10 11:50:59 +02:00
|
|
|
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
CommandTarjan:
|
|
|
|
description: |-
|
|
|
|
Instructions for execution of Tarjan-Algorithm
|
|
|
|
type: object
|
|
|
|
required:
|
|
|
|
- name
|
2022-06-10 16:04:30 +02:00
|
|
|
- nodes
|
|
|
|
- edges
|
2022-06-10 11:50:59 +02:00
|
|
|
properties:
|
2022-06-11 16:07:23 +02:00
|
|
|
name:
|
|
|
|
$ref: '#/components/schemas/EnumAlgorithmNames'
|
2022-06-10 16:04:30 +02:00
|
|
|
nodes:
|
2022-06-10 16:05:15 +02:00
|
|
|
type: array
|
2022-06-11 16:07:23 +02:00
|
|
|
items:
|
|
|
|
anyOf:
|
|
|
|
- type: integer
|
|
|
|
- type: number
|
|
|
|
- type: string
|
2022-06-10 16:04:30 +02:00
|
|
|
edges:
|
|
|
|
type: array
|
|
|
|
items:
|
|
|
|
type: array
|
|
|
|
minItems: 2
|
|
|
|
maxItems: 2
|
2022-06-11 16:07:23 +02:00
|
|
|
items:
|
|
|
|
anyOf:
|
|
|
|
- type: integer
|
|
|
|
- type: number
|
|
|
|
- type: string
|
2022-06-10 11:50:59 +02:00
|
|
|
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2022-06-14 01:34:44 +02:00
|
|
|
# Algorithm: TSP
|
2022-06-10 11:50:59 +02:00
|
|
|
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
CommandTsp:
|
|
|
|
description: |-
|
|
|
|
Instructions for execution of TSP-Algorithm
|
|
|
|
type: object
|
|
|
|
required:
|
|
|
|
- name
|
|
|
|
- optimise
|
|
|
|
- dist
|
|
|
|
properties:
|
2022-06-11 16:07:23 +02:00
|
|
|
name:
|
|
|
|
$ref: '#/components/schemas/EnumAlgorithmNames'
|
2022-06-10 11:50:59 +02:00
|
|
|
dist:
|
|
|
|
type: array
|
|
|
|
items:
|
|
|
|
type: array
|
|
|
|
items:
|
|
|
|
type: number
|
|
|
|
optimise:
|
2022-06-14 01:34:44 +02:00
|
|
|
$ref: '#/components/schemas/EnumOptimiseMode'
|
2022-06-10 11:50:59 +02:00
|
|
|
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2022-06-14 01:34:44 +02:00
|
|
|
# Algorithm: Hirschberg
|
2022-06-10 11:50:59 +02:00
|
|
|
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
CommandHirschberg:
|
|
|
|
description: |-
|
|
|
|
Instructions for execution of Hirschberg-Algorithm
|
|
|
|
type: object
|
|
|
|
required:
|
|
|
|
- name
|
2022-06-10 12:44:04 +02:00
|
|
|
- word1
|
|
|
|
- word2
|
2022-06-10 11:50:59 +02:00
|
|
|
properties:
|
2022-06-11 16:07:23 +02:00
|
|
|
name:
|
|
|
|
$ref: '#/components/schemas/EnumAlgorithmNames'
|
2022-06-10 11:50:59 +02:00
|
|
|
word1:
|
|
|
|
description: Word that gets placed vertically in algorithm.
|
|
|
|
type: string
|
|
|
|
word2:
|
|
|
|
description: Word that gets placed horizontally in algorithm
|
|
|
|
type: string
|
|
|
|
once:
|
|
|
|
type: boolean
|
|
|
|
default: false
|
2022-06-14 01:34:44 +02:00
|
|
|
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
# Algorithm: Rucksack Branch & Bound
|
|
|
|
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
CommandRucksack:
|
|
|
|
description: |-
|
|
|
|
Instructions for execution of Branch & Bound-Algorithm for the Rucksack-Problem
|
|
|
|
type: object
|
|
|
|
required:
|
|
|
|
- algorithm
|
2022-06-14 14:40:02 +02:00
|
|
|
- max-cost
|
|
|
|
- costs
|
2022-06-14 01:34:44 +02:00
|
|
|
- values
|
|
|
|
properties:
|
|
|
|
algorithm:
|
|
|
|
$ref: '#/components/schemas/EnumRucksackAlgorithm'
|
|
|
|
allow-fractional:
|
|
|
|
type: boolean
|
|
|
|
default: false
|
2022-06-14 14:40:02 +02:00
|
|
|
max-cost:
|
|
|
|
description: Upper bound for total cost of rucksack.
|
2022-06-14 01:34:44 +02:00
|
|
|
type: number
|
|
|
|
minimum: 0
|
2022-06-14 14:40:02 +02:00
|
|
|
costs:
|
|
|
|
description: Array of cost for each item (e.g. volume, weight, price, time, etc.).
|
2022-06-14 01:34:44 +02:00
|
|
|
type: array
|
|
|
|
items:
|
|
|
|
type: number
|
|
|
|
exclusiveMinimum: 0
|
|
|
|
values:
|
2022-06-14 14:40:02 +02:00
|
|
|
description: Value extracted from each item (e.g. energy, profit, etc.).
|
2022-06-14 01:34:44 +02:00
|
|
|
type: array
|
|
|
|
items:
|
|
|
|
type: number
|
|
|
|
items:
|
|
|
|
description: Optional names of the items (if empty, defaults to 1-based indexes).
|
|
|
|
type: array
|
|
|
|
items:
|
|
|
|
type: string
|
|
|
|
default: []
|
2022-06-10 11:50:59 +02:00
|
|
|
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
# Enum Algorithm Names
|
|
|
|
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
EnumAlgorithmNames:
|
|
|
|
description: |-
|
|
|
|
Enumeration of possible algorithm options.
|
|
|
|
type: string
|
|
|
|
enum:
|
|
|
|
- TARJAN
|
|
|
|
- TSP
|
|
|
|
- HIRSCHBERG
|
2022-06-14 01:34:44 +02:00
|
|
|
- RUCKSACK
|
2022-06-10 11:50:59 +02:00
|
|
|
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2022-06-14 01:34:44 +02:00
|
|
|
# Enum Optimise Mode
|
2022-06-10 11:50:59 +02:00
|
|
|
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2022-06-14 01:34:44 +02:00
|
|
|
EnumOptimiseMode:
|
2022-06-10 11:50:59 +02:00
|
|
|
description: |-
|
2022-06-14 01:34:44 +02:00
|
|
|
Enumeration of optimisation modi.
|
2022-06-10 11:50:59 +02:00
|
|
|
type: string
|
|
|
|
enum:
|
|
|
|
- MIN
|
|
|
|
- MAX
|
2022-06-14 01:34:44 +02:00
|
|
|
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
# Enum Rucksack mode for algorithm
|
|
|
|
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
EnumRucksackAlgorithm:
|
|
|
|
description: |-
|
|
|
|
Enumeration of mode for Rucksack problem
|
|
|
|
type: string
|
|
|
|
enum:
|
|
|
|
- GREEDY
|
|
|
|
- BRANCH-AND-BOUND
|