0.2.6 • Published 5 months ago

nrn-agents v0.2.6

Weekly downloads
-
License
ISC
Repository
-
Last release
5 months ago

install size Twitter LinkedIn

This is the main package for NRN Agents, it is focused on creating agents that learn via imitation or reinforcement learning. The primary use case for nrn-agents is creating intelligent agents that game learn how to play games.

Useful Links

Documentation

Demos coming soon!

Installation

You can install the package using NPM as follows:

npm install nrn-agents

Agent Creation

In order to create an agent, we have to import the AgentFactory and call either the createDemoAgent or createAgent methods. In either case, we have the ability to create a randomly initialized model or load in a pre-trained model. More details are provided in the docs.

Demo

To get the full capabilities of NRN, we require developers to onboard on our platform. However, if a developer just wants to test out NRN, we allow them to create a demo agent for quick prototyping. This way developers can see how to incorporate NRN into their game loop before onboarding and registering a model architecture.

const { AgentFactory } = require("nrn-agents")

const modelData = {
  config: {
    inputDim: 5,
    neurons: [12, 6],
    actionOrder: ["action 1", "action 2"],
    modelType: "neural-network",
  },
}

const agent = AgentFactory.createDemoAgent(modelData)

Production

With the demo agent, we defined some hyperparameters for the neural network, but in the production agents, developers first have to register their architecture on our dashboard. The registration process involves defining all the architecture hyperparameters. Once registered, we simply provide the architecture id, and it will create the model scaffolding using the hyperparemeters that were defined. This allows for the easy creation of many models using the same set of hyperparams.

const { AgentFactory } = require("nrn-agents")

AgentFactory.setGameId("game-id")
AgentFactory.setApiKey("training-api-key")

const architectureId = "perfect-architecture-id"
const agentName = "Agent A.G.N.E.S."

const agent = AgentFactory.createAgent("reinforcement", architectureId, agentName)
await agent.initialize()

Basic Usage

The most basic methods that are called when incorporating NRN agents into a gameloop is selectAction and collect.

Take an Action

In order to take an action in the game, call the selectAction method, where the input is a 2D array.

const action = agent.selectAction(state)

Collect Data

To collect data, call the collect method. At a minimum, the data object must have the current state and the action selected (as a one-hot encoded vector). Additionally, you can provide more info which can be useful for reward shaping.

agent.collect({ state, action, info })

Registration

Before creating an agent, we must register its architecture. It's easier to register via our dashboard, but we also allow developers to register model architectures through code as well.

const { Registry } = require("nrn-agents")

Registry.setApiKey("admin-api-key")

const registry = new Registry("game-id")

const registryInputs = {
  modelType: "neural-network",
  architectureId: "perfect-architecture-id",
  numberOfStates: 10,
  possibleActions: {
    direction: {
      order: ["up", "down", "idle"],
    },
  },
}

await registry.register(registryInputs)
0.2.6

5 months ago

0.2.5

5 months ago

0.2.4

5 months ago

0.2.3

5 months ago

0.2.2

5 months ago

0.2.1

6 months ago

0.2.0

6 months ago

0.1.6

6 months ago

0.1.5

6 months ago

0.1.4

6 months ago

0.1.3

6 months ago

0.1.2

6 months ago

0.1.1

6 months ago

0.1.0

6 months ago