Pergunta

Eu gostaria de resolver o fatorial de um número. Minha regra fatorial está em um arquivo Prolog e estou conectando -o a um arquivo C ++. Alguém pode me dizer o que há de errado com o meu C ++ de interface para o Prolog?

my factorial.pl file:

factorial( 1, 1 ):-
    !.
factorial( X, Fac ):-
    X > 1,
    Y is X - 1,
    factorial( Y, New_Fac ),
    Fac is X * New_Fac.



my factorial.cpp file:

headerfiles

term_t tf;
term_t tx;
term_t goal_term;
functor_t goal_functor;

int main( int argc, char** argv )
{
    argv[0] = "libpl.dll";

    PL_initialise(argc, argv);

    PlCall( "consult('factorial.pl')" );

    cout << "Enter your factorial number: ";
    long nf;
    cin >> nf;

    tf = PL_new_term_ref();
    PL_put_integer( tf, nf );
    tx = PL_new_term_ref();

    goal_term = PL_new_term_ref();
    goal_functor = PL_new_functor( PL_new_atom("factorial"), 2 );
    rval = PL_cons_functor( goal_term, goal_functor, tf, tx );

    PL_halt( PL_toplevel() ? 0 : 1 );
}

Recebo o prompt Prolog, que é o que a última linha faz. Mas não recebo o resultado do cálculo fatorial, como:

?-  factorial( 5, X ).
X = 120
true

o que estou perdendo?

Obrigado,

Foi útil?

Solução 2

# include files

term_t tf;
term_t tx;
term_t goal_term;
functor_t goal_functor;

int main( int argc, char** argv )
{
    argv[0] = "libpl.dll";
    PL_initialise( argc, argv );

    PlCall( "consult( swi( 'plwin.rc' ) )" );
    PlCall( "consult( 'factorial.pl' )" );

    cout << " Enter your factorial number: ";
    long nf;
    cin >> nf;

    tf = PL_new_term_ref();
    PL_put_integer( tf, nf );
    tx = PL_new_term_ref();
    goal_term = PL_new_term_ref();
    goal_functor = PL_new_functor( PL_new_atom("factorial"), 2 );
    PL_cons_functor( goal_term, goal_functor, tf, tx );

    int fact;
    if( PL_call(goal_term, NULL) )
        {
            PL_get_integer( tx, &fact );
            cout << fact << endl;
        }
    else
        {
            PL_fail;
        }

    PL_halt( PL_toplevel() ? 0 : 1 );
}

Outras dicas

Não estou tão familiarizado com a ponte SWI Prolog - C/C ++, mas parece que você não está iniciando uma consulta depois de definir os termos. Você precisa usar PL_call ou PL_open_query e então imprima o resultado antes de entregar as coisas ao SWI-Prolog.

    PL_cons_functor( goal_term, goal_functor, tf, tx );
int nfactorial;
if (PL_call(goal_term, NULL)) {
    PL_get_integer(tx, &nfactorial);
    std::cout << "X = " << nfactorial << " ." << std::endl;
} else {
    PL_fail;
}
    PL_halt( PL_toplevel() ? 0 : 1 );

Eu não sei se você pode definir goal_term como a consulta de nível superior. Se você deseja que a consulta seja executada pela chamada para PL_toplevel, você pode construir a consulta como uma corda e passá-la como um argumento "-t" no vetor de argumento para PL_initialize.

Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top