Skip to content

sandsmark/kart

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

#The Kartering (working title)

startscreen

screenshot

tldr; connect to the server at localhost over port 31337. You send a single bitmapped number to select what to do (for example "9\n" to accelerate and turn right), and receive a JSON status update everytime you do so. The first AI to complete a set number of laps wins!

The number is used as a bitmap, so set a bit to do that action:

Action Player 1 Player 2 Bit in map
Accelerate Up W 0
Decelerate Down S 1
Turn left Left A 2
Turn right Right D 3
Drift Comma C 4
Use powerup Period V 5

Some pseudo C code to use it:

    #define NET_INPUT_UP 1<<0
    #define NET_INPUT_DOWN 1<<1
    #define NET_INPUT_LEFT 1<<2
    #define NET_INPUT_RIGHT 1<<3
    #define NET_INPUT_SPACE 1<<4
    #define NET_INPUT_RETURN 1<<5

    char action = NET_INPUT_UP;
    if (want_to_turn_left) {
        action |= NET_INPUT_LEFT;
    }
    send_byte(action);

On connect you will receive a JSON object giving you your ID and describing the map:

{
    "id": 0,
    "map": {
        "tile_width": 128,
        "tile_height": 128,
        "tiles": [
            [ ".", ".", ".", ".", ".", ".", ".", "." ],
            [ ".", "/", "-", "-", "-", "`", ".", "." ],
            [ ".", "|", ".", ".", ".", "|", ".", "." ],
            [ ".", "|", ".", ".", ".", "|", ".", "." ],
            [ ".", "\\", "-", "-", "-", ",", ".", "." ],
            [ ".", ".", ".", ".", ".", ".", ".", "." ]
        ],
        "modifiers": [
            {
                "type": "mud",
                "x": 168,
                "y": 218,
                "width": 64,
                "height": 64
            },
            {
                "type": "booster",
                "x": 418,
                "y": 538,
                "width": 32,
                "height": 32
            },
            {
                "type": "ice",
                "x": 638,
                "y": 188,
                "width": 64,
                "height": 64
            }
        ],
        "path": [
            { "tile_x": 3, "tile_y": 1 },
            { "tile_x": 4, "tile_y": 1 },
            { "tile_x": 5, "tile_y": 1 },
            { "tile_x": 5, "tile_y": 2 },
            { "tile_x": 5, "tile_y": 3 },
            { "tile_x": 5, "tile_y": 4 },
            { "tile_x": 4, "tile_y": 4 },
            { "tile_x": 3, "tile_y": 4 },
            { "tile_x": 2, "tile_y": 4 },
            { "tile_x": 1, "tile_y": 4 },
            { "tile_x": 1, "tile_y": 3 },
            { "tile_x": 1, "tile_y": 2 }
        ]
    }
}

The types of powerups are:

  • "banana": a banana that you can drop, causes players that hit it to stop and spin
  • "greenshell": a shell you can shoot that subtly homes in on the nearest player
  • "blueshell": a shell that you can shoot that subtly homes in on the leading player
  • "redshell": a shell that you can shoot that just goes straight forward and bounces around
  • "oil": allows you to drop oil that causes players that drive over it to veer off course
  • "mushroom": gives you a speedup for 2500ms
  • "bigmushroom": gives you a speedup for 2500ms, doubles your size
  • "lightning": causes all causes all cars in front of you to halve in size, lose their powerups and lose 10% speed
  • "star": gives you a speedup for 2500ms, makes you invincible to all kinds of negative effects for 2500ms, causes cars that you collide with to stop and spin

It should be self-explanatory (otherwise please file an issue here on github or contact us otherwise so we can explain better here).

Then, each time you send a command (invalid or valid), you will get back a status update JSON object like this:

{
    "cars": [
        {
            "id": 0,
            "direction": {
                "x": 1,
                "y": 0
            },
            "velocity": {
                "x": 0,
                "y": 0
            },
            "pos": {
                "x": 448,
                "y": 153
            },
            "drift": 0,
            "width": 30,
            "height": 16
        }
    ],
    "shells": [
        {
            "type": "blue",
            "x": 342,
            "y": 233,
            "dx": 0.5,
            "dy": 0.3
        }
    ],
    "boxes": [
        { "x": 576, "y": 153, "width": 16, "height": 16 },
        { "x": 576, "y": 174, "width": 16, "height": 16 },
        { "x": 576, "y": 195, "width": 16, "height": 16 },
        { "x": 576, "y": 216, "width": 16, "height": 16 },
        { "x": 448, "y": 537, "width": 16, "height": 16 },
        { "x": 448, "y": 558, "width": 16, "height": 16 },
        { "x": 448, "y": 579, "width": 16, "height": 16 },
        { "x": 448, "y": 600, "width": 16, "height": 16 }
    ],
    "items": [
        {
            "type": "oil",
            "x": 168,
            "y": 218,
            "width": 64,
            "height": 64
        }
    ]
}

NOTE: the actual JSON you receive is minified, and each initial or status update is a single object on a single line, terminated by a newline:

{"cars":[{"id":0,"direction":{"x":1,"y":0},"velocity":{"x":0,"y":0},"pos":{"x":448,"y":153},"drift":0,"width":30,"height":16}],"shells":[]}

All messages back and forth are terminated by a newline.

Build instructions

TL;DR: Install the SDL2 development headers, and run "make".

Building on Ubuntu

On Ubuntu (14.04), which packages you need to install might not be obvious, so try this:

sudo apt-get install build-essential libsdl2-dev

From there, it's just to run make, turn kart into an executable, and execute it!

make
chmod +x kart
./kart

CREDITS:

Graphics by 'Kari Nordmann' (alias).

Some compatibility code for windows is licensed under the ISC license: Copyright (c) 1996,1999 by Internet Software Consortium.

A header for windows compatibility is licensed under the GPLv2+: By Gerald Combs [email protected] Copyright 1998 Gerald Combs

The rest of the code is under an MIT license: Copyright (c) 2014, 2015 Lars-Ivar Hesselberg Simonsen Copyright (c) 2014, 2015 Martin Tobias Holmedahl Sandsmark

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

About

Compocase for the AI programming competition at The Gathering 2015

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages