Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/aliosm/ai-soco
Official FIRE 2020 Authorship Identification of SOurce COde (AI-SOCO) task repository containing dataset, evaluation tools and baselines
https://github.com/aliosm/ai-soco
ai-soco authorship-identification codeforces fire2020 machine-learning pan2020 source-code
Last synced: 15 days ago
JSON representation
Official FIRE 2020 Authorship Identification of SOurce COde (AI-SOCO) task repository containing dataset, evaluation tools and baselines
- Host: GitHub
- URL: https://github.com/aliosm/ai-soco
- Owner: AliOsm
- License: mit
- Created: 2020-05-20T19:48:36.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-05-22T23:30:12.000Z (over 1 year ago)
- Last Synced: 2024-12-16T03:36:20.301Z (18 days ago)
- Topics: ai-soco, authorship-identification, codeforces, fire2020, machine-learning, pan2020, source-code
- Homepage:
- Size: 63.5 MB
- Stars: 19
- Watchers: 4
- Forks: 6
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# AI-SOCO
Official [FIRE 2020](http://fire.irsi.res.in/fire/2018/home) **A**uthorship **I**dentification of **SO**urce **CO**de (AI-SOCO) [PAN](https://pan.webis.de) task repository containing dataset, evaluation tools and baselines.10 - 13 December, Virtually.
Welcome to pariticipate on our Codalab competition [here](https://competitions.codalab.org/competitions/25148)!
All participants are welcome to open new [issue](https://github.com/AliOsm/AI-SOCO/issues/new) about dataset issues!
## Introduction
General authorship identification is essential to the detection of undesirable deception of others' content misuse or exposing the owners of some anonymous hurtful content. This is done by revealing the author of that content. **A**uthorship **I**dentification of **SO**urce **CO**de (AI-SOCO) focuses on uncovering the author who wrote some piece of code. This facilitates solving issues related to cheating in academic, work and open source environments. Also, it can be helpful in detecting the authors of malware softwares over the world.The detection of cheating in academic communities is significant to properly address the contribution of each researcher. Also, in work environments, credit sometimes goes to people that did not deserve it. Such issues of plagiarism could arise in open source projects that are available on public platforms. Similarly, this could be used in public or private online coding contests whether done in coding interviews or in official coding training contests to detect the cheating of applicants or contestants. A system like this could also play a big role in detecting the source of anonymous malicious softwares.
The dataset is composed of source codes collected from the open submissions in the [Codeforces](http://codeforces.com/) online judge. Codeforces is an online judge for hosting competitive programming contests such that each contest consists of multiple problems to be solved by the participants. A Codeforces participant can solve a problem by writing a solution for it using any of the available programming languages on the website, and then submitting the solution through the website. The solution's result can be correct (accepted) or incorrect (wrong answer, time limit exceeded, etc.).
In our dataset, we selected 1,000 users and collected 100 source codes from each one. So, the total number of source codes is 100,000. All collected source codes are correct, bug-free, compile-ready and written using the C++ programming language using different versions. For each user, all collected source codes are from unique problems.
Given the pre-defined set of source codes and their writers, the task is to build a system that is able to detect the writer given any new, unseen before source codes from the previously defined writers list.
### Example
Given the following bug-free and ready to compile C++ source code:```c++
#include
#include
#include
using namespace std;
int main() {
string s;
cin >> s;
s[0] = toupper(s[0]);
cout << s << endl;
return 0;
}
```You need to build a system that can determine the source code writer from list consists of 1,000 writers.
## Dataset Structure
In `data_dir` directory there are the following:
- `train.csv` file which contains 50K pairs of `uid`s (User IDs) and `pid`s (Problem IDs). Each `uid` appears 50 times in the file with 50 different `pid`s.
- `train` directory which contains 50K files, each file with different `pid` represents the C++ source code that will be the input to your system.
- `dev.csv` file is similar to `train.csv`, but it will be used to evaluation your system while developing, so it is not allowed to use it in the training phase.
- `dev` directory is similar to `train`, but it will be used to evaluation your system while developing, so it is not allowed to use it in the training phase.
- `unlabeled_test.csv` file is similar to `train.csv`, but it will be used to evaluation your system, so it is not allowed to use it in the training phase.
- `test` directory is similar to `train`, but it will be used to evaluation your system, so it is not allowed to use it in the training phase.### Note
The data is now available on [Zenodo](https://zenodo.org/record/4059840#.X3ScgnX7Qno) with the test set labels.## Baseline
- [**Random Baseline**](random_baseline.py) is simply predicting a random writer for each piece of code from the list of 1,000 writers (from 0 to 999). Its accuracy reaches around **0.1%**.
- [**Characters Count Logistic Baseline**](characters_logistic_baseline.py) converts each source code to a vector represents the count of the 100 [printable characters](https://en.wikipedia.org/wiki/ASCII#Printable_characters), then it builds a [logistic regression](https://en.wikipedia.org/wiki/Logistic_regression) model on the vectorized representations. It achieved a **29.252%** accuracy on the development set.
- [**TF-IDF KNN Baseline**](tfidf_knn_baseline.py) vectorizes the source codes using [TF-IDF](https://en.wikipedia.org/wiki/Tf%E2%80%93idf) method with **10K** features and builds a [KNN](https://en.wikipedia.org/wiki/K-nearest_neighbors_algorithm) classifier with **25** neighbors on top of that representations extracted from TF-IDF. Its accuracy on the development set is **62.128%** which is much better than the previous baselines. Keep in mind that this baseline is very slow and it will take you about **4** hours to predict all examples in the development set using **6** threads.To train and predict on the development set using any of the previously mentioned baselines, please run the following command:
```bash
python baselines/[random_baseline.py|characters_logistic_baseline.py|tfidf_knn_baseline.py]
```## Evaluation
Systems will be evaluated and ranked based on **Accuracy** metric. An evaluation [script](scorer.py) is available on the Github repository.## Important Dates
- ~~8th June - Open track website~~
- ~~8th June – Training and development data release~~
- ~~31st July – Test data release~~
- ~~7th September – Run submission deadline~~
- ~~15th September – Results declared~~
- ~~5th October – Working notes papers due~~
- 10th November – Final version of working notes papers due
- 16th-20th December - FIRE 2020 (Online Event)## Notes
- All scripts in this repository were tested on **Ubuntu 20.04** and **Python 3.8.2**.## License
The dataset is distributed under the [MIT](/LICENSE) license.