Skip to main content

Official Stanford Karel library used in CS 106A

Project description

stanford-karel

Python 3.7+ PyPI version Build Status pre-commit.ci status GitHub license Downloads

This is a Python implementation of Karel for Stanford's CS 106A. This package is available on PyPI and allows you to run Karel programs without any additional setup!

Huge props to @nick-bowman for rewriting this project from scratch!

StanfordKarel now supports:

  • Pip-installable package means you can run Karel programs from anywhere!
  • Solution code no longer needed to grade assignments - instead, the output worlds are compared.
  • Karel in ASCII! Plus autograder support.
  • Improved autograding, testing, linting, and auto-formatting.
  • Exception trace makes suggestions if you misspell a command (e.g. turnLeft() -> turn_left()).

Usage

pip install stanfordkarel

Documentation

Follow the Karel tutorial on the Karel Reader!

Running Karel

First, ensure that StanfordKarel is correctly installed using pip. Any .py file can become a Karel program!

collect_newspaper_karel.py

from stanfordkarel import *


def main():
    """Karel code goes here!"""
    turn_left()
    move()
    turn_left()


if __name__ == "__main__":
    run_karel_program()

Save the file and run:

python collect_newspaper_karel.py

Karel Program

Available Commands

Karel Commands
move() right_is_clear() facing_east()
turn_left() right_is_blocked() not_facing_east()
put_beeper() beepers_present() facing_west()
pick_beeper() no_beepers_present() not_facing_west()
front_is_clear() beepers_in_bag() facing_south()
front_is_blocked() no_beepers_in_bag() not_facing_south()
left_is_clear() facing_north() paint_corner(color)
left_is_blocked() not_facing_north() corner_color_is(color)

Folder structure

You can set a default world by passing a world name to run_karel_program, e.g. run_karel_program("collect_newspaper_karel")

Worlds should be saved/loaded in a worlds/ folder in the same folder as the file being run.

  • assignment1/
    • worlds/ (additional worlds go here)
      • collect_newspaper_karel.w
      • collect_newspaper_karel_end.w
    • collect_newspaper_karel.py

Creating Worlds

If using the pip-installed version, create a Python file containing:

from stanfordkarel.world_editor import run_world_editor

if __name__ == "__main__":
    run_world_editor()

Then run python world_editor.py.

World Editor

Grading

./autograde runs the available tests using pytest in the tests/ folder and prints out any output differences in the world.

Functionality

The tests use the student's code and the expected world output to determine correctness. If the output is not the same, the test driver will print out an ASCII representation of the differences.

Autograder

Style

The autograde command also runs the builtin Karel Style Checker that performs linting automatically.

Development

Everything important is located in stanfordkarel/.

  • Python 3.5+ is required because of importlib.util.module_from_spec.
  • Python 3.6+ is required for f-strings.
  • Python 3.7+ is required for type annotations.
  • stanfordkarel/ is the exported package, which contains all of the available functions and commands for students to use.
  • karel_application.py is responsible for loading student code and displaying it to the screen.

Contributing

All issues and pull requests are much appreciated!

  • First, run pip install pre-commit and pre-commit install.
  • To see test coverage scripts and other auto-formatting tools, use pre-commit run.
  • To run all tests, run pytest.

Future Milestones

In the future, I hope to add:

  • Automatic student style checking
  • Ways of determining the student's strategy or approach from observing Karel movements
  • Autograde more worlds, broken down by assignment
  • Allow students to autograde their own work
  • Accessibility for visually-impaired students

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

stanfordkarel-0.2.7.tar.gz (43.3 kB view details)

Uploaded Source

Built Distribution

stanfordkarel-0.2.7-py3-none-any.whl (51.9 kB view details)

Uploaded Python 3

File details

Details for the file stanfordkarel-0.2.7.tar.gz.

File metadata

  • Download URL: stanfordkarel-0.2.7.tar.gz
  • Upload date:
  • Size: 43.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.10.0

File hashes

Hashes for stanfordkarel-0.2.7.tar.gz
Algorithm Hash digest
SHA256 54f22ac198ef1db7af8e9557f1830f8acc220e001d7fb511d82849d4236ee5f5
MD5 9ba845cecf6b30839efec35177a5a9cd
BLAKE2b-256 c2fb820f2da1222036286bda997b74aa40fb4d0bedd414667b7d0392c7318d87

See more details on using hashes here.

File details

Details for the file stanfordkarel-0.2.7-py3-none-any.whl.

File metadata

File hashes

Hashes for stanfordkarel-0.2.7-py3-none-any.whl
Algorithm Hash digest
SHA256 840b0fc759484631e81e2131de6932703677213f90c196d1e88920b429f921d0
MD5 c9afc41283905093c3b784c49f72e6ad
BLAKE2b-256 0cee65510dbb7dbaccb9f22763092a4731ef55c74fa5e7f3ccf6a6b84aaa519b

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page