Skip to content

giganticode/probes

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

54 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Quickstart

  1. First we will create a virtual environment with anaconda.
    If you do not have anaconda installed, please check the installation instructions here.

       $ conda create --name probe_env python=3.8
    
  2. Next we will activate the virtual environment.

       $ conda activate probe_env
    
  3. Once we are done with that, we will clone this github repository and cd into it.

       $ git clone https://github.com/giganticode/probes.git && cd probes/
    
  4. Next we will install all the necessary packages in the requirements.txt file

       $ pip3 install -r requirements.txt
    
  5. We will then begin generating input feature vectors from the pre-trained model weights.

       $ CUDA_VISIBLE_DEVICES=0 python3 probe_extractor.py
    
  6. Finally, we will use the pre-trained vectors to make some predictions.

       $ CUDA_VISIBLE_DEVICES=0 python3 probe_classifier.py > results.txt
    

Hurray! You're done! 🎉
The final task accuracies of each model (layer by layer) will be saved in results.txt file.

NOTE: In steps 5 & 6, we assume that you have access to a gpu with the cuda toolkit installed. If you are using a cpu instead, you can simply run the python scripts without the CUDA_VISIBLE_DEVICES=0 part.


Model Performance by Tasks

Code Length Prediction Generic badge

Code Length Prediction Results

AST Node Tagging Task Generic badge

AST Node Tagging Results

Cyclomatic Complexity Generic badge

Cyclomatic Complexity Results

Invalid Type Prediction Generic badge

Invalid Type Prediction Results


Acknowledgements

This repository uses and is built upon the following works:

License

MIT license

About

Probing pre-trained source code models

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages