YaccConstructor
YaccConstructor — это фреймворк для разработки генераторов синтаксических анализаторов, компиляторов компиляторов и прочего grammarware для .NET. По большей части он написан на F#. Также в рамках проекта создаются и другие инструменты для работы с грамматиками, которые можно найти в репозитории на GitHub.
Участники
Публикации

GRADESNDA '18 Proceedings of the 1st ACM SIGMOD Joint International Workshop on Graph Data Management Experiences & Systems (GRADES) and Network Data Analytics (NDA),
The generalization of matrixbased Valiant's contextfree language recognition algorithm for graph case is widely considered as a recipe for efficient contextfree path querying; however, no progress has been made in this direction so far. We propose the first generalization of matrixbased Valiant's algorithm for contextfree path querying. Our generalization does not deliver a truly subcubic worstcase complexity algorithm, whose existence still remains a hard open problem in the area. On the other hand, the utilization of matrix operations (such as matrix multiplication) in the process of contextfree path query evaluation makes it possible to efficiently apply a wide class of optimizations and computing techniques, such as GPGPU, parallel processing, sparse matrix representation, distributedmemory computation, etc. Indeed, the evaluation on a set of conventional benchmarks shows, that our algorithm outperforms the existing ones.

arXiv,
Graph data model is widely used in many areas, for example, bioinformatics, graph databases, RDF. One of the most common graph queries are navigational queries. The result of query evaluation are implicit relations between nodes of the graph, i.e. paths in the graph. A natural way to specify these relations is by specifying paths using formal grammars over edge labels. This type of queries is usually evaluated using the relational query semantics. There is a number of algorithms for query evaluation which use such semantics but they have computational problems with big data. One of the most common technique for efficient big data processing is GPGPU, but these algorithms do not allow to use this technique effectively. In this paper we propose a graph parsing algorithm for query evaluation which use relational query semantics and contextfree grammars, and is based on matrix operations which allows to speed up computations by means of GPGPU.

arXiv,
Graph data model and graph databases are very popular in various areas such as bioinformatics, semantic web, and social networks. One specific problem in the area is a path querying with constraints formulated in terms of formal grammars. The query in this approach is written as grammar, and paths querying is graph parsing with respect to given grammar. There are several solutions to it, but how to provide structural representation of query result which is practical for answer processing and debugging is still an open problem. In this paper we propose a graph parsing technique which allows one to build such representation with respect to given grammar in polynomial time and space for arbitrary contextfree grammar and graph. Proposed algorithm is based on generalized LL parsing algorithm, while previous solutions are based mostly on CYK or Earley algorithms, which reduces time complexity in some cases.

Proceedings of the Institute for System Programming,
There are numerous toolchains designed for certified programming, but F* is the only language that support both generalpurpose programming and semiautomated proving. We work on the application of this technique to a grammarware research and development project YaccConstructor. We present a work in progress verified implementation of transformation of Contextfree grammar to Chomsky normal form, that is making progress toward the certification of the entire project. Among other features, F* system allows to extract code in F# or OCaml languages from a program written in F*. YaccConstructor project is mostly written in F#, so this feature of F* is of particular importance because it allows to maintain compatibility between certified modules and those existing in the project which are not certified yet.
 Perspectives of System Informatics,
 Systems and Means of Informatics,
 Proceedings of the 11th Central & Eastern European Software Engineering Conference in Russia,
 Systems and Means of Informatics,
 Proceedings of 10th International Andrei Ershov Memorial Conference on Perspectives of System Informatics,
 Proceedings of the 10th Central and Eastern European Software Engineering Conference in Russia 2014,
 Proceedings of the 9th Central & Eastern European Software Engineering Conference in Russia,