Tree [b41f7e] default /

Read Only access

File Date Author Commit
 Test 2010-03-30 mtnyogi mtnyogi [6de8ee] Renamed all modules (e.g., in examples) ...
 doc 2010-03-30 mtnyogi mtnyogi [efc767] Added check for .pyw files for Windows.
 examples 2010-03-30 mtnyogi mtnyogi [6de8ee] Renamed all modules (e.g., in examples) ...
 experimental 2009-10-28 mtnyogi mtnyogi [ff7730] merged and tested
 pyke 2010-04-21 mtnyogi mtnyogi [b41f7e] Fixed forall/require/python-clause bug in forwa...
 .hgignore 2010-03-12 mtnyogi mtnyogi [4db827] Post release cleanup
 .hgtags 2010-03-12 mtnyogi mtnyogi [9bb5bf] Added tag 1.1 for changeset c3939a649e0a
 LICENSE 2009-11-02 mtnyogi mtnyogi [f00035] First cut at updating the documentation. 2009-11-04 mtnyogi mtnyogi [9b4890] Cleaning up make_release script
 README.txt 2010-03-12 mtnyogi mtnyogi [bd6133] Release documentation for 1.1
 RELEASE_NOTES-1.txt 2010-03-12 mtnyogi mtnyogi [bd6133] Release documentation for 1.1
 RELEASE_NOTES-pre1.0.txt 2009-11-02 mtnyogi mtnyogi [73803c] Numerous changes preparing for new installation...
 hgrc_keywords 2009-07-25 mtnyogi mtnyogi [c9dde1] Added .hgignore
 make_doc_tarball 2009-11-04 mtnyogi mtnyogi [7931ab] Release documentation for 1.0.4
 make_release 2010-03-12 mtnyogi mtnyogi [4db827] Post release cleanup 2010-03-12 mtnyogi mtnyogi [bd6133] Release documentation for 1.1
 testpyke 2010-02-25 mtnyogi mtnyogi [f16399] Took out %var syntax from goal.compile.

Read Me

Pyke: Python Knowledge Engine

Version: 1.1

Both forward-chaining and backward-chaining rules (which may include python
code) are compiled into python. Can also automatically assemble python
programs out of python functions which are attached to backward-chaining


This is published under the MIT License.  The copyright and license are in
the file "LICENSE" in the source directory.


The complete documentation is at:

A copy of the html documentation is also included in the "doc/html" directory
within the source distribution.


Pyke requires python 2.5 or later.  Check with:

    $ python --version

You can download python at:


    1. Download and unzip the source distribution for the version of Python
       that you want to use.

       If you want to use Python 2.5 or 2.6, you need to use the

       If you want to use Python 3.x, you need to use the

    2. Open a command line window in the directory above.
    3. Run "python build"
    4. As administrator, run: "python install"

See for more


The source distribution contains the pyke source code, documentation (both
source and html), unit tests, and examples.


Each example is in a separate subdirectory under the "examples" directory.
Each example has a README.txt file that explains how to run it.

The family_relations example is a good place to start.  It shows several
solutions to the same problem.  It also has an example of a few rule
optimizations that result in a 100 times performance improvement on this

The sqlgen example uses Sqlite3 (or MySQL) and the python sqlite3 (or MySQLdb)
modules.  It has a function that reads the schema information into pyke facts.
Then the rules in database.krb automatically figure out how to join tables
together to retrieve a list of column names, generate the SQL select
statements and return a plan to execute this SQL statement and return the
results as a dictionary.

The web_framework example uses the sqlgen example.  This demonstrates the use
of multiple rule bases.  The web_framework is a WSGI application that uses the
HTMLTemplate package (install this as administrator with "pip install
HTMLTemplate" or "easy_install HTMLTemplate" -- be sure to get version 1.5 or
later).  It gets the column names from the HTMLTemplate and feeds those to the
sqlgen example to generate a plan to retrieve the data.  It then builds a plan
to populate the template and return the finished HTML document.  It also
caches the plans so that they don't have to be re-generated for each request.
This makes it run a full 10 times faster than the same example done in
TurboGears 2!  The example includes a wsgiref simple_server setup to run it
as an http server so that you can access it through your browser.

The learn_pyke example is an incomplete attempt at a computer based training
program.  It only deals with the topic of pattern matching.  It is left here
as an example of using question bases.

The findall, forall, knapsack, notany and towers_of_hanoi examples are each
very small.

See for more information.


Pyke uses the doctest-tools package to run its doctests.  You can run the
"" program from doctest-tools in any subdirectory, or in the
top-level directory.  You can install doctest-tools as administrator with:

    # pip install doctest-tools

The top-level directory also has it's own "testpyke" script that removes all
compiled_krb directories, then runs the script (from doctest-tools)
twice.  The first time forces pyke to recompile everything, and the second
time runs the same tests again having pyke re-use the compiled results from
the previous run.  If the "testpyke" program is not on your path, run it as:

    $ ./testpyke


See for information
about doing development work on Pyke.  Contributions of any kind are welcome!

Get latest updates about Open Source Projects, Conferences and News.

Sign up for the SourceForge newsletter:

No, thanks