当前位置: 首页>>代码示例>>C++>>正文


C++ DataNode::getSlot方法代码示例

本文整理汇总了C++中DataNode::getSlot方法的典型用法代码示例。如果您正苦于以下问题:C++ DataNode::getSlot方法的具体用法?C++ DataNode::getSlot怎么用?C++ DataNode::getSlot使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在DataNode的用法示例。


在下文中一共展示了DataNode::getSlot方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: main

//unsigned char buffer[STATIC_ALLOCATOR_SIZE];
//StaticAllocator myAlloc(buffer, STATIC_ALLOCATOR_SIZE);
int main(int argc, char *argv[]) {
    running = true;

    if ( argc < 7 ) {
        printf( "Start this DataNetwork Qualia client with 7 arguments:\n");
        printf( "host ip (e.g. 127.0.0.1), the IP address of the host running the DataNetwork server\n");
        printf( "port (e.g. 7000), the port this client will use for OSC messages\n");
        printf( "name (e.g. example_client), the name by which this client will be identified in the DataNetwork\n");
        printf( "node for light input data, node for settings, node for output\n");
        printf( "lambda, gamma, epsilon, learning rate, hidden layers, reward node\n");
        printf( "For example:\n");
        printf( "%s 127.0.0.1 7000 QualiaClient 37 4001 5001 0.9 0.1 0.5 0.1 3 3001\n", argv[0]);
        return EXIT_SUCCESS;
    }

    float lambda = atof( argv[7] );
    float gamma = atof( argv[8] );
    float epsilon = atof( argv[9] );
    float learning = atof( argv[10] );
    int n_hidden = atoi( argv[11] );

    float settingsid = atoi( argv[5] );
    DataNode * settingsNode = NULL;

    // initialise datanetwork:
    // create a data network:
    DataNetwork * dn = new DataNetwork();
    // create an osc client interface for it:
    dn->createOSC( argv[1], argv[2], argv[3] );
    // register with the host:
    dn->registerMe();
    dn->subscribeNode( settingsid, true );

    //Alloc::init(&myAlloc);
//   DummyAgent agent;
    QLearningEGreedyPolicy egreedy( epsilon );
    NeuralNetwork net(DIM_OBSERVATIONS + DIM_ACTIONS, n_hidden, 1, learning);
    QLearningAgent agent(&net, DIM_OBSERVATIONS, DIM_ACTIONS, n_actions, lambda, gamma, &egreedy, false);
    // lambda = 1.0 => no history
    // gamma
    PolytopeLightEnvironment * env = new PolytopeLightEnvironment( dn, argv[3], atoi(argv[4]), atoi(argv[12]), atoi(argv[6]) );
    Qualia qualia(&agent, env);
//  RLQualia qualia(&agent, &env);

    dn->setQuitFunction( &quitNow );

    qualia.init();
    qualia.start();

    while( running ) {
        if ( settingsNode == NULL ) {
            settingsNode = dn->getNode( settingsid );
        }
        if ( settingsNode != NULL ) {
            env->set_delay( settingsNode->getSlot(0)->getValue() );
            agent.lambda = settingsNode->getSlot(1)->getValue();
            agent.gamma = settingsNode->getSlot(2)->getValue();
            egreedy.epsilon = settingsNode->getSlot(3)->getValue();
            net.learningRate = settingsNode->getSlot(4)->getValue();
        }
//  for (int i=0; i<10; i++) {
        qualia.step();

// #if is_computer()
//     printf("Current agent action: %d\n", agent.currentAction.conflated());
//     printf("Current environment observation: %f %f\n", (double)env->currentObservation.observations[0], (double)env->currentObservation.observations[1]);
// #endif
    }

//  if (myAlloc.nLeaks)
//    printf("WARNING: Static Allocator has leaks: %d\n", myAlloc.nLeaks);

    dn->unregisterMe();
    return 0;
}
开发者ID:sensestage,项目名称:qualia,代码行数:77,代码来源:polytope_light.cpp


注:本文中的DataNode::getSlot方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。