Welcome to my Scientific Research Repository!
This repository contains code and data related to my Scientific Research project. This project is massive and complex, containing multiple tools and exploring different goals and research questions. With that in mind, each of the directories in this repository has its own README.md
file explaining it's purpose and how it contributes to the overall research project.
The main tool is the Worked Example Miner, which is a comprehensive tool for Java repository analysis. This tool integrates CK, PyDriller, and RefactoringMiner to analyze Java repositories and generate data and metadata about the software evolution. This tool has really grown and evolved over time, and it's now a powerful tool for analyzing Java repositories, so it is now a submodule of this repository. With that in mind, you can find the Worked Example Miner repository by just opening the Worked-Example-Miner
directory in this repository or here. A Github Workflow is also available to update the submodule automatically every hour, so you don't need to worry about updating it manually, just be aware that, in order to clone this repository with the submodule, you need to use the --recurse-submodules
flag, as explained in the Clone with Submodule or Clone Submodule sections.
The Word2Vec tool is also used to perform similarity analysis between various texts, such as code snippets and questions. This analysis aids in identifying patterns and relationships that may not be immediately evident.
This repository stands as the cornerstone for the extensive code, data, and insights generated through our focused research into the similarity of texts in order to suggest similar solved issues to unsolved issues on platforms like Github or Stack Overflow. As our project has advanced, i've developed interest in understanding the nuances of software development and code evolution, particularly within the realm of Distributed Systems, which is now the main goal of my research and the tool related to it, the Worked Example Miner, which is a submodule of this repository.
In order to clone this repository without the submodule (Worked-Example-Miner), you can use the following command:
git clone https://github.com/BrenoFariasdaSilva/Scientific-Research
In order to clone this repository with the submodule (Worked-Example-Miner), you can use the following command:
git clone --recurse-submodules https://github.com/BrenoFariasdaSilva/Scientific-Research.git
In case you have already cloned the repository and forgot to clone the submodule, you can use the following command to clone the submodule:
git submodule init
git submodule update
-
Similarity Analysis:
- Explore different similarity algorithms, including Word2Vector, Yake, Sentence Bert, and TF-IDF, to evaluate the similarity between texts.
- Create datasets for storing solved and unsolved questions and recommend changes based on the similarity of these questions.
-
Enhancing the given data:
- Analyze the results of the usage of the similarity algorithms to suggest similar solved issues to unsolved issues using different aspects, like a code snippet, a question, or a title or a mix of them.
-
Enhancing Code Solutions:
- Investigate the use of tools like ChatGPT and GitHub Copilot to improve students' code solutions when they are stuck.
- Utilize CK to generate Code Metrics for repositories like Apache Commons-lang and Jabref.
- Employ PyDriller to traverse the commit tree in the repository and run CK for every commit hash.
-
Providing Data to AI Tools:
- Gather valuable data to provide to tools like ChatGPT and GitHub Copilot, showcasing what constitutes good code and why.
- Explore how contextual information, such as code samples, can assist these tools in suggesting better code improvements for students.
Our research project involves expertise in the following areas:
- Python Language.
- Similarity Measures (Word2Vec, Yake, Sentence Bert, TF-IDF).
- Apache Commons-lang (Java Library).
- Jabref (Bibliography Reference Manager).
- GitHub Repositories.
- Data Collection and Analysis.
Other skills are required but are related to the Worked Example Miner and are well explained in its repository.
Feel free to explore the code and data in this repository. If you have any questions or suggestions, please don't hesitate to reach out to me.
Each directory in this repository has its own README.md file explaining its purpose. Please refer to individual README files for more details.
As a technique rooted in natural language processing, Word2Vec is applied to perform similarity analysis between various texts, such as code snippets and questions. This analysis aids in identifying patterns and relationships that may not be immediately evident.
As mentioned earlier, the Worked Example Miner is a comprehensive tool for Java repository analysis. This tool integrates CK, PyDriller, and RefactoringMiner to analyze Java repositories and generate data and metadata about the software evolution. This tool has really grown and evolved over time, and it's now a powerful tool for analyzing Java repositories, so it is now a submodule of this repository. With that in mind, you can find the Worked Example Miner directory documentation here
Our research encompasses a diverse set of open-source projects available on GitHub, chosen for their relevance and the rich insights they provide into various aspects of software development and maintenance. Below is a brief overview of each repository and its role in our study:
- Purpose: Apache Commons Lang is a library with helper utilities for the java.lang API, notably String manipulation methods, basic numerical methods, object reflection, and concurrency, among others.
- Usage in Research: We leverage this repository to study code evolution and gather code metrics using CK. It serves as a prime example of library development practices and evolution in the Java ecosystem.
- Purpose: JabRef is an open-source bibliography reference manager. It uses BibTeX as its native format, facilitating the organization of references for researchers and academicians.
- Usage in Research: This repository is utilized to analyze code solutions, extract code metrics using CK, and understand the code evolution of a real-world application, offering insights into application development and maintenance practices.
The Worked Example Miner tool analyzes different repositories, which are the Apache Kafka and Apache ZooKeeper repositories. They are used to represent the state of the art in Distributed Systems (DS) and are expected to provide valuable insights into code evolution and quality. In order to read more about the Worked Example Miner repositories, read here.
- Setence Bert: Sentence-BERT is an adaptation of the BERT (Bidirectional Encoder Representations from Transformers) model, specifically optimized for sentence-level embeddings. Unlike traditional BERT that requires comparing all possible sentence pairs to find the most similar sentences, SBERT generates embeddings that are directly comparable in vector space. This means it can efficiently perform similarity analysis between sentences, making it highly effective for tasks such as semantic search, sentiment analysis, and duplicate question detection. Its ability to understand the nuanced meanings of sentences makes it a powerful tool for any application requiring deep semantic understanding.
- TF-IDF (Term Frequency-Inverse Document Frequency): TF-IDF is a statistical measure used to evaluate the importance of a word within a document in relation to a collection of documents, known as a corpus. This technique is grounded in the idea that the significance of a word increases proportionally to the number of times it appears in the document but is offset by its frequency in the corpus. TF-IDF is instrumental in performing similarity analysis between texts by identifying which words are most distinguishing between them. It's widely used in document classification, search engine optimization (SEO), and information retrieval systems to rank the relevance of documents and texts.
- Yake (Yet Another Keyword Extractor): YAKE is an unsupervised, lightweight, and efficient algorithm designed for automatic keyword extraction from individual documents. Unlike other keyword extraction methods that rely on large corpora or deep linguistic knowledge, YAKE focuses on statistical features from the text itself, such as word frequency, position, and co-occurrence information. This makes YAKE particularly useful for extracting relevant and meaningful keywords from texts, aiding in summarization, indexing, and categorization tasks without the need for extensive computational resources.
- Word2Vec: Word2Vec is a groundbreaking neural network-based technique developed to convert text into numerical form, allowing machines to understand human language. It maps words into a high-dimensional vector space, where semantically similar words are positioned closely together. Word2Vec is versatile in performing similarity analysis not only between words but also between larger text structures like sentences, paragraphs, and documents by averaging the word vectors. Its application extends beyond similarity analysis to include language modeling, translation, and even exploring syntactic and semantic word relationships. Word2Vec's ability to capture the context of words within documents makes it invaluable for a wide range of natural language processing (NLP) applications.
In order to read about the tools utilized in the Worked Example Miner, read here.
Contributions are what make the open-source community such an amazing place to learn, inspire, and create. Any contributions you make are greatly appreciated. If you have suggestions for improving the code, your insights will be highly welcome. In order to contribute to this project, please follow the guidelines below or read the CONTRIBUTING.md file for more details on how to contribute to this project, as it contains information about the commit standards and the entire pull request process. Please follow these guidelines to make your contributions smooth and effective:
-
Set Up Your Environment: Ensure you've followed the setup instructions in the Setup section to prepare your development environment.
-
Make Your Changes:
- Create a Branch:
git checkout -b feature/YourFeatureName
- Implement Your Changes: Make sure to test your changes thoroughly.
- Commit Your Changes: Use clear commit messages, for example:
- For new features:
git commit -m "FEAT: Add some AmazingFeature"
- For bug fixes:
git commit -m "FIX: Resolve Issue #123"
- For documentation:
git commit -m "DOCS: Update README with new instructions"
- For refactorings:
git commit -m "REFACTOR: Enhance component for better aspect"
- For snapshots:
git commit -m "SNAPSHOT: Temporary commit to save the current state for later reference"
- For new features:
- See more about crafting commit messages in the CONTRIBUTING.md file.
- Create a Branch:
-
Submit Your Contribution:
- Push Your Changes:
git push origin feature/YourFeatureName
- Open a Pull Request (PR): Navigate to the repository on GitHub and open a PR with a detailed description of your changes.
- Push Your Changes:
-
Stay Engaged: Respond to any feedback from the project maintainers and make necessary adjustments to your PR.
-
Celebrate: Once your PR is merged, celebrate your contribution to the project!
We thank the following people who contributed to this project:
Breno Farias da Silva |
This project is licensed under the Apache License 2.0. This license permits use, modification, distribution, and sublicense of the code for both private and commercial purposes, provided that the original copyright notice and a disclaimer of warranty are included in all copies or substantial portions of the software. It also requires a clear attribution back to the original author(s) of the repository. For more details, see the LICENSE file in this repository.