Skip to main content

Enable mental simulation of multiple cognitive models within the Cognitive Architecture ACT-R

Project description

Build Status Coverage Status PyPI version fury.io PyPI license PyPI pyversions

ActMS - python interface

This is a library to enable mental simulation of multiple cognitive models within the Cognitive Architecture ACT-R.

ACT-MS (ACT-R Mental Simulation) is an implementation based on the Python dispatcher included in ACT-R Version 7.13, which facilitates the use of ACT-R commands within a Python environment and vice versa. ACT-MS incorporates multiple functions relevant to coordinate the simultaneous simulation of multiple ACT-R models. An exemplary use case can be found in the below publication [1].

Overall, the library contains methods to:

  • to forward and exchange parameters between the metamodel and the submodels.
  • save the exchanged simulation parameters in a dictionary.
  • enable utility learning over multiple ACT-R runs by saving the utility of one run respectively.

Structure of MS implementation

Installation

pip install pyactms

or

pip install git+https://github.com/seblum/actms

Usage

Take a look at the examples folder for an exemplary use case.

Call of the method simulate-submodel in a production of the metamodel to start the mental simulation of another specified ACT-R model middle-model.

(p simulate-middle-submodel
  =goal>
    state           simulate-submodel
    action          =actionnumber
  =imaginal>
==>
  =imaginal>
  =goal>
    state           free
    action          =actionnumber
!eval! ("simulate-submodel" "middle-model" =actionnumber)
  )

Call of the method return-from-submodel in a production of the submodel to forward given parameters to the metamodel and save them within a specific slot of the imaginal chunk resultactionone.

(P action-retour-1
   =goal>
     state          action-1
     action	    1
   ?manual>   
     state          free
   =imaginal>
     response       =duration
==>
   +manual>              
     cmd	    press-key     
     key       	    =duration
   -imaginal>
   =goal>
     state 	    idle
     action	    idle
!eval! ("return-from-submodel" =duration 1 "retrieve-action" "resultactionone")
  )

Initialization of ACT-MS. Saving the session number in the simulation results. Run of ACT-R model. Fetching the saved simulation / forwarded paramenters and saving them to a dataframe. Printing the dataframe.

import actr
import actms as ms
session = 1

actms = ActMS('mainmodelname')

actr.run_until_condition("end-program", True)       

# return simulation results as df
printer = actms.Protocol("Session", session)

printer.to_csv('simulation_results.csv')

Files

  • actms.py - Contains the interface of ACT-MS and methods to load a user data set into the visicon of ACT-R.

  • actr.py - Contains the dispatcher of ACT-R version 7.12., which is necessary to form a connection between python and ACT-R (see http://act-r.psy.cmu.edu/).

Example

  • RUN-metamodel.py

  • EF-submodel-left.lisp

  • EF-metamodel.lisp

TODO

Possible additional feature to add:

  • Add more dynamic and additional possibilites to save simulation parameters
  • Add more possibilities to exchange parameters
  • Add debugging support

Developing pyactms

To install pyactcv along with the tools to develop and run tests please run the following in your virtualenv:

$ pip install -e .[dev]

Bibliography

[1] new paper

Download files

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

Source Distribution

pyactms-0.0.2.tar.gz (20.7 kB view details)

Uploaded Source

Built Distribution

pyactms-0.0.2-py3-none-any.whl (11.2 kB view details)

Uploaded Python 3

File details

Details for the file pyactms-0.0.2.tar.gz.

File metadata

  • Download URL: pyactms-0.0.2.tar.gz
  • Upload date:
  • Size: 20.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.23.0 setuptools/50.3.0 requests-toolbelt/0.9.1 tqdm/4.44.1 CPython/3.6.10

File hashes

Hashes for pyactms-0.0.2.tar.gz
Algorithm Hash digest
SHA256 3b6bcd893958cc2defe5c03d179e5c568280b7a80b3eb2f55e5474e0598bbfef
MD5 e50d0495406286da4266884aadaa2ee4
BLAKE2b-256 518ada00bca10f71e5acdf24ec872aa0732aba80f1a06e3968d4ed6854b270eb

See more details on using hashes here.

File details

Details for the file pyactms-0.0.2-py3-none-any.whl.

File metadata

  • Download URL: pyactms-0.0.2-py3-none-any.whl
  • Upload date:
  • Size: 11.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.23.0 setuptools/50.3.0 requests-toolbelt/0.9.1 tqdm/4.44.1 CPython/3.6.10

File hashes

Hashes for pyactms-0.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 93fca6d1e0937357c915a22b2e9d5d4f8570a7a5604c05015c7ca468eef5b82e
MD5 b6b068ee2ae91035a38c680c4c72dab2
BLAKE2b-256 bd45c096a4d516af709303a56056b205019ba870283b9fd194c1ef80a8ce390c

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