Please use this identifier to cite or link to this item:
https://hdl.handle.net/1822/79821
Title: | Improving the efficiency of the energy-split tool to compute the energy of very large molecular systems |
Author(s): | Pereira, Sara Alexandra da Silva |
Advisor(s): | Proença, Alberto José Pereira, André Martins Fernandes, Henrique Sousa, Sérgio |
Keywords: | Energy-split Intramolecular energy Development framework HPC Energia intramolecular Framework de desenvolvimento |
Issue date: | 10-Aug-2021 |
Abstract(s): | The Energy-Split tool receives as input pieces of a very large molecular system and computes
all intra and inter-molecular energies, separately calculating the energies of each fragment
and then the total energy of the molecule. It takes into account the connectivity information
among atoms in a molecule to compute (i) the energy of all terms involving atoms covalently
bonded, namely bonds, angles, dihedral angles, and improper angles, and (ii) Coulomb
and the Van der Waals energies, that are independent of the atom’s connections, which
have to be computed for every atom in the system. The required operations to obtain the
total energy of a large molecule are computationally intensive, which require an efficient
high-performance computing approach to obtain results in an acceptable time slot.
The original Energy-Split Tcl code was thoroughly analyzed to be ported to a parallel and
more efficient C++ version. New data structures were defined with data locality features, to
take advantage of the advanced features present in current laptop or server systems. These
include the vector extensions to the scalar processors, an efficient on-chip memory hierarchy,
and the inherent parallelism in multicore devices. To improve the Energy-Split’s sequential
variant a parallel version was developed using auxiliary libraries. Both implementations
were tested on different multicore devices and optimized to take the most advantage of the
features in high performance computing.
Significant results by applying professional performance engineering approaches, namely
(i) by identifying the data values that can be represented as Boolean variables (such as
variables used in auxiliar data structures on the traversal algorithm that computes the
Euclidean distance between atoms), leading to significant performance improvements due to
the reduced memory bottleneck (over 10 times faster), and (ii) using an adequate compress
format (CSR) to represent and operate on sparse matrices (namely matrices with Euclidean
distances between atoms pairs, since all distances further the cut-off distance (user defined)
are considered as zero, and these are the majority of values).
After the first code optimizations, the performance of the sequential version was improved
by around 100 times when compared to the original version on a dual-socket server. The
parallel version improved up to 24 times, depending on the molecules tested, on the same
server. The overall picture shows that the Energy-Split code is highly scalable, obtaining
better results with larger molecule files, even when the atom’s arrangement influences the
algorithm’s performance. A ferramenta Energy-Split recebe como ficheiro de input a descrição de fragmentos de um sistema molecular de grandes dimensões, de maneira a calcular os valores de energia intramolecular. Separadamente, também efetua o cálculo da energia de cada fragmento e a energia total de uma molécula. Ao mesmo tempo, tem em conta a informação das ligações entre átomos de uma molécula para calcular (i) a energia que envolve todos os átomos ligados covalentemente, nomeadamente bonds, angles, dihedral angles and improper angles, e (ii) energias de Coulomb e Vand der Waals, que são independentes das conexões dos átomos e têm de ser calculadas para cada átomo do sistema. Para cada átomo, o Energy-Split calcula a energia de interação com todos os outros átomos do sistema, considerando a partição da molécula em fragmentos, feita num programa open source, Visual Molecular Dynamics. As operações para o cálculo destas energias podem levar a tarefas muito intensivas, computacionalmente, fazendo com que seja necessário utilizar uma abordagem que tire proveito de computação de alto desempenho de modo a desenvolver código mais eficiente. O código fornecido, em Tcl, foi profundamente analisado e convertido para uma versão paralela e, mais eficiente, em C++. Ao mesmo tempo, foram definidas novas estruturas de dados, que aproveitam a boa localidade dos mesmos para tirar vantagem das extensões vetoriais presentes em qualquer computador e, também, para explorar o paralelismo inerente a máquinas multicore. Assim, foi implementada uma versão paralela do código convertido numa fase anterior com recurso ao uso de bibliotecas auxiliares. Ambas as versões foram testadas em diferentes ambientes multicore e otimizadas de maneira a ser possível tirar o máximo partido da computação de alto desempenho para obter os melhores resultados. Após a aplicação de técnicas de engenharia de performance como (i) a identificação de dados que poderiam ser representados em formatos mais leves como variáveis booleanas (por exemplo, variáveis usadas em estruturas de dados auxiliares ao cálculo da distância Euclideana entre átomos, utilizadas no algoritmo de travessia da molécula), o que levou a melhorias significativas na performance (cerca de 10 vezes) devido à redução de sobrecarga da memória. (ii) a utilização de um formato adequado para a representação de matirzes esparsas (nomeadamente a de representação das mesmas distâncias Euclidianas do primeiro ponto, uma vez que todas as distâncias que ultrapassem a distância de cutoff (definida pelo utilizador) são consideradas como 0, representado a maioria dos valores). 3 4 Depois das otimizações à versão sequencial, esta apresentou uma melhoria de cerca de 100 vezes em relação à versão original. A versão paralela foi melhorada até 24 vezes, dependendo das moléculas em questão. No geral, o código é escalável, uma vez que apresenta melhores resultados consoante o aumento do tamanho das moléculas testadas, apesar de se concluir que a disposição dos átomos também influencia a perfomance do algoritmo. |
Type: | Master thesis |
Description: | Dissertação de mestrado integrado em Computer Engineering |
URI: | https://hdl.handle.net/1822/79821 |
Access: | Open access |
Appears in Collections: | BUM - Dissertações de Mestrado DI - Dissertações de Mestrado |
Files in This Item:
File | Description | Size | Format | |
---|---|---|---|---|
Sara Alexandra da Silva Pereira.pdf | Dissertação de Mestrado | 3,59 MB | Adobe PDF | View/Open |
This item is licensed under a Creative Commons License