Skip to main content

The Codex Paper Has Been Published: the Idea Behind GitHub Copilot


 

The Codex paper has been published yesterday. Codex is a GPT language model finetuned on publicly available code from GitHub which has Python code-writing capabilities. A distinct production version of Codex powers GitHub Copilot. This paper focuses on the work leading to the early Codex models. The main task is the generation of standalone Python functions from docstrings, and the automated evaluation of the correctness of code samples through unit tests (this is in contrast to natural language generation, where samples are typically evaluated by heuristics or by human evaluators). To solve a problem in the test set, the authors generate multiple samples from the models, and check if any of them passes the unit tests.

The raw training dataset was collected in May 2020 from 54 million public software repositories hosted on GitHub, containing 179 GB of unique Python files under 1 MB. Then it has been filtered by removing files which were likely auto-generated, had average line length greater than 100, had maximum line length greater than 1000 or contained a small percentage of alphanumeric characters. After the filtering, the final dataset totaled 159 GB.

Along with the paper, HumanEval, an evaluation framework as been released in a GitHub repo.

I am not going through the details of the technical work that has been done to achieve the presented results, as they are clearly explained in the paper, so anyone could read from there. Instead, I want to highlight some important considerations after reading the comprehensive limitations and risks sections of this paper. 

Codex it is not sample efficient to train. The selected training dataset comprises a significant fraction of publicly available Python code on GitHub, totaling hundreds of millions of lines of code. But even seasoned developers do not encounter anywhere near this amount of code over their careers. Indeed, a strong student who completes an introductory computer science course is expected to be able to solve a larger fraction of problems than Codex final model.

Codex has the potential to be useful in a range of ways, such as help onboard users to new codebases, reduce context switching for experienced coders, enable non-programmers to write specifications and have Codex draft implementations, or aid in education and exploration. However, Codex also raises significant safety challenges, does not always produce code that is aligned with user intent and has the potential to be misused.

Code generation and associated capabilities have several possible economic and labor market impacts. While Codex at its current capability level may somewhat reduce the cost of producing software by increasing programmer productivity, the size of this effect may be limited by the fact that engineers don’t spend their full day writing code. Daily important tasks include conferring with colleagues, writing design specifications, upgrading existing software stacks, etc.

Because Codex can produce vulnerable or misaligned code, qualified operators should review its generations before executing or trusting them, absent appropriate precautions. Probably future code generation models may be able to trained to produce more secure code than the average developer, but this is still far from achievement to my opinion.

Codex, same as any other technology or ML/AI model could also be misused to aid cybercrime. Although this is worthy of concern, the authors believe that at their current level of capability, Codex models do not materially lower the barrier to entry for malware development. Anyway more powerful code generation models will lead to future advancements, and therefore further research into mitigations and continued study of model capabilities are mandatory.

At the same time, the non-deterministic nature of systems like Codex could enable more advanced malware. This non-determinism makes it easier to create diverse software that accomplish the same tasks. While software diversity can sometimes aid defenders, it presents unique challenges for traditional malware detection and antivirus systems that rely on fingerprinting and signature-matching against previously sampled binaries. A more capable code generation model could conceivably advance techniques for generating polymorphic malware. Application security and model deployment strategies including rate-limiting access and abuse monitoring can manage this threat in the near term; however, the efficacy of these mitigations may scale sublinearly as more capable models are developed.

Codex, like other large generative models, has an energy footprint from both training and inference. The original training of GPT-3-12B consumed hundreds of petaflop/sdays of compute, while fine-tuning it to create Codex-12B consumed a similar amount of compute. Looking more long-term, the compute demands of code generation could grow to be much larger than Codex’s training if significant inference is used to tackle challenging problems.

Conclusions:

  • According to the paper authors, models like this should be developed, used, but their capabilities explored carefully with an eye towards maximizing their positive social impacts and minimizing intentional or unintentional harms that their use might cause. Which is exactly my point of view since I have heard of Copilot for the first time. A contextual approach is critical to effective hazard analysis and mitigation, though a few broad categories of mitigations are important to consider in any deployment of code generation models (and in general for any generative model).
  • Don't forget that coding is a broad activity which involves much much more than synthesizing code from docstrings. So, software engineers and data scientists wouldn't be replaced so easy yet.

Comments

  1. Great Post! Thanks for sharing. Keep sharing such information.

    python training

    ReplyDelete
  2. Great Post I am regular reader of your blogs. I found your blogs very helpful for students i already shared your blogs multiple times with students.Apply Now For Best Machine Learning Training Course

    ReplyDelete
  3. Pretty Post! Thank you so much for sharing this good content, it was so nice to read and useful to improve my knowledge as an updated one, keep blogging.

    Python Certification Training in Electronic City

    ReplyDelete
  4. Nice information about web app thanks for sharing this article.

    web application

    ReplyDelete

Post a Comment

Popular posts from this blog

Exporting InfluxDB data to a CVS file

Sometimes you would need to export a sample of the data from an InfluxDB table to a CSV file (for example to allow a data scientist to do some offline analysis using a tool like Jupyter, Zeppelin or Spark Notebook). It is possible to perform this operation through the influx command line client. This is the general syntax: sudo /usr/bin/influx -database '<database_name>' -host '<hostname>' -username '<username>'  -password '<password>' -execute 'select_statement' -format '<format>' > <file_path>/<file_name>.csv where the format could be csv , json or column . Example: sudo /usr/bin/influx -database 'telegraf' -host 'localhost' -username 'admin'  -password '123456789' -execute 'select * from mem' -format 'csv' > /home/googlielmo/influxdb-export/mem-export.csv

jOOQ: code generation in Eclipse

jOOQ allows code generation from a database schema through ANT tasks, Maven and shell command tools. But if you're working with Eclipse it's easier to create a new Run Configuration to perform this operation. First of all you have to write the usual XML configuration file for the code generation starting from the database: <?xml version="1.0" encoding="UTF-8" standalone="yes"?> <configuration xmlns="http://www.jooq.org/xsd/jooq-codegen-2.0.4.xsd">   <jdbc>     <driver>oracle.jdbc.driver.OracleDriver</driver>     <url>jdbc:oracle:thin:@dbhost:1700:DBSID</url>     <user>DB_FTRS</user>     <password>password</password>   </jdbc>   <generator>     <name>org.jooq.util.DefaultGenerator</name>     <database>       <name>org.jooq.util.oracle.OracleDatabase</name>     ...

Using Rapids cuDF in a Colab notebook

During last Spark+AI Summit Europe 2019 I had a chance to attend a talk from Miguel Martinez  who was presenting Rapids , the new Open Source framework from NVIDIA for GPU accelerated end-to-end Data Science and Analytics. Fig. 1 - Overview of the Rapids eco-system Rapids is a suite of Open Source libraries: cuDF cuML cuGraph cuXFilter I enjoied the presentation and liked the idea of this initiative, so I wanted to start playing with the Rapids libraries in Python on Colab , starting from cuDF, but the first attempt came with an issue that I eventually solved. So in this post I am going to share how I fixed it, with the hope it would be useful to someone else running into the same blocker. I am assuming here you are already familiar with Google Colab. I am using Python 3.x as Python 2 isn't supported by Rapids. Once you have created a new notebook in Colab, you need to check if the runtime for it is set to use Python 3 and uses a GPU as hardware accelerator. You...