Я разбираю довольно простой формат файла, состоящий из серии строк, каждая строка имеет некоторые разделенные пробелом поля, которые выглядят следующим образом:
l 0x9823 1
s 0x1111 3
l 0x1111 12
⋮
Я использую SWI-Prolog. Это DCG, который у меня есть до сих пор:
:- consult(library(pure_input)).
load_trace(Filename, Traces) :-
phrase_from_file(trace_file_phrase(Traces), Filename).
trace_file_phrase([]) --> [].
trace_file_phrase([T|Ts]) --> trace_phrase(T), trace_file_phrase(Ts).
trace_phrase(access(Type, Address, SinceLast)) -->
access_type(Type), space,
address(Address), space,
nat(SinceLast), newline.
access_type(load) --> "l".
access_type(store) --> "s".
address(Number) --> "0x", hexnum(Number).
hexdigit(N) --> digit(N).
hexdigit(10) --> "a". hexdigit(11) --> "b". hexdigit(12) --> "c".
hexdigit(13) --> "d". hexdigit(14) --> "e". hexdigit(15) --> "f".
hexnum(N) --> hexdigit(D), hexnum(D, N).
hexnum(N, N) --> [].
hexnum(A, N) --> hexdigit(D), { A1 is A*16 + D }, hexnum(A1, N).
newline --> "\n".
space --> " ".
%% the following two productions are courtesy of Lars Mans at
%% /info/126176/parsing-numbers-with-multiple-digits-in-prolog
digit(0) --> "0". digit(1) --> "1". digit(2) --> "2".
digit(3) --> "3". digit(4) --> "4". digit(5) --> "5".
digit(6) --> "6". digit(7) --> "7". digit(8) --> "8".
digit(9) --> "9".
nat(N) --> digit(D), nat(D,N).
nat(N,N) --> [].
nat(A,N) --> digit(D), { A1 is A*10 + D }, nat(A1, N).
Как упоминалось в комментарии, я вырезал обработку чисел из Разбор чисел с несколькими цифрами в Prolog.
Проблема, с которой я сталкиваюсь, - некоторые из этих файлов большие, например, порядка 5-10 МБ. Для этого стека по умолчанию в SWI-Prolog недостаточно, и синтаксический анализ этих файлов занимает значительное время, порядка 5-15 секунд. У меня есть несколько вопросов об этой ситуации:
- Где проблема эффективности в этом коде? Я думаю, что это либо в
trace_file_phrase//1
, либоnat//1
, но это просто догадки. - Если проблема представляет собой список, есть ли лучший способ обрабатывать списки с DCG, чем это?
- Как, в общем, диагностировать и обрабатывать проблемы с производительностью с помощью DCG, таких как это?