Specialized Coding Copilots? Microsoft Talks ‘Copilot for Infrastructure as Code’
Just as the initial influx of do-everything large language models (LLMs) have been advancing along with smaller and more specialized AI constructs, the same could happen to Microsoft’s coding-specific GitHub Copilot.
Conceivably, the company could produce smaller, customized, targeted copilots for specific coding use cases, domains or even programming languages.
While the advantages of such an approach haven’t yet been debated a lot, much less realized, Microsoft provides a hint of what might come in a recent article, “Unleashing GitHub Copilot for Infrastructure as Code.”
Note that the article’s discussion of “GH Copilot for Infra” does not refer to a new tool, but rather an approach using existing Visual Studio Code and its GitHub Copilot extension, requiring a license.
But what if it became a discrete new, specialized tool, followed by others?
Noting the challenges faced by infrastructure professionals, the article states: “Leveraging GitHub Copilot to generate infra code specifically for infrastructure professionals is helping to revolutionize the way infrastructure is written, addressing the pain points experienced by professionals in the field.”
The significance of GitHub Copilot for Infra, the company said, is illustrated by the following benefits:
- Code Generation with accuracy: Copilot harnesses the power of machine learning to interpret the intent behind prompts and swiftly generate precise infrastructure code. It understands the context of infrastructure tasks, allowing professionals to express their requirements in natural language and receive corresponding code suggestions.
- Streamlining the IaC Development Process: By automating the generation of infrastructure code, Copilot significantly streamlines the IaC development process. Infrastructure professionals can now focus on higher-level design decisions and business logic rather than wrestling with syntax intricacies.
- Consistency Across Environments and Projects: GH Copilot ensures consistency across environments by generating standardized code snippets. Whether deploying resources in a development, testing, or production environment, GH Copilot helps maintain uniformity in configurations.
- Accelerating Onboarding and Learning: For new team members and those less familiar with IaC, GH Copilot serves as an invaluable learning service. It provides real-time examples and best practices, fostering a collaborative environment where knowledge is shared seamlessly.
- Efficiency and Time Savings: The efficiency gains brought about by GH Copilot are substantial. Infrastructure professionals can witness a dramatic reduction in development cycles, allowing for faster iteration and deployment of infrastructure changes.
Supporting the idea that an infrastructure or other specialized coding copilots could be in the works is the fact that in the non-development realm, Microsoft already offers (or is working on) a bevy of specialized copilots, including ones for Microsoft 365, security, sales and so on. For example, Microsoft describes Microsoft Dynamics 365 Copilot as “the world’s first copilot in both CRM and ERP” that can work with the company’s Power Platform.
The notion that infrastructure or other specialized coding copilots are a viable concept is discussed in a comment to Microsoft’s “GH Copilot for Infra” article that read in part: “we really don’t need to confuse things by redefining GitHub Copliot as InfraCopilot or JavaScriptCopilot or dotnetCopilot etc etc etc unless they are built not just using GitHub Copilot as the underlying tool but one that works across not only GitHub but internet searches and other data stores like GitLab or Bitbucket or blogposts or internal applications like knowledgebases etc.”
Notably, Microsoft Research is investigating “Copilots for Specialized Domains” with one example of that being a “NextGen Communications Copilot” article that discusses a paper about “Adapting foundation models to specialized domains like 5G to enable a conversational artificial intelligence tool for information synthesis of wireless communication specifications.”
“This paper presents NextGen Communications Copilot, a conversational artificial intelligence tool for information synthesis of wireless communication specifications,” the overview said. “The system builds on top of recent advancements in foundation models and consists of three key additional components: a domain-specific database, a context extractor, and a feedback mechanism.”
It mentions information extracted from a “database of wireless technical specifications” and “reference responses created by subject matter experts” that helped demonstrate more relevant answers compared to those “achieved by state-of-the-art tools like ChatGPT.”
When we asked Microsoft Copilot about the possibility for specialized copilots in the development world, it envisioned:
- Use Case: Data Science and Machine Learning
- What It Does: Generates Python code for data preprocessing, feature engineering, model training, and evaluation. Provides insights on statistical analysis, visualization, and hyperparameter tuning.
- Features:
- Auto-generates pipelines for common ML tasks.
- Suggests optimal algorithms based on dataset characteristics.
- Integrates with popular libraries like Pandas, NumPy, and Scikit-Learn.
- Use Case: Web Development (HTML, CSS, JavaScript)
- What It Does: Assists in building web applications, responsive layouts, and interactive UIs.
- Creates HTML templates for common components (headers, forms, cards).
- Suggests CSS styles and animations.
- Generates JavaScript snippets for event handling and DOM manipulation.
- Use Case: Backend Development (Node.js, Django, Flask)
- What It Does: Helps build APIs, handle databases, and manage server-side logic.
- Generates Express.js routes and middleware.
- Creates database queries (SQL or NoSQL).
- Assists with authentication and authorization.
Features:
- Use Case: Mobile App Development (iOS, Android)
- What It Does: Simplifies app creation, UI design, and cross-platform development.
- Generates SwiftUI/Kotlin code for screens and navigation.
- Suggests best practices for performance and memory management.
- Integrates with Firebase or GraphQL for backend services.
Features:
- Use Case: Scripting and Automation (Bash, PowerShell, Python)
- What It Does: Automates repetitive tasks, system administration, and scripting.
- Creates Bash scripts for file manipulation, backups, and cron jobs.
- Suggests PowerShell commands for Windows automation.
- Generates Python scripts for data processing or web scraping.
Features:
- Use Case: Embedded Systems (C/C++, Rust)
- What It Does: Aids in firmware development, IoT devices, and microcontrollers.
- Generates C/C++ code for device drivers and low-level hardware access.
- Suggests memory-efficient algorithms.
- Assists with real-time constraints.
Features:
- Use Case: Cloud Services (AWS, Azure, GCP)
- What It Does: Simplifies cloud resource provisioning, serverless functions, and APIs.
- Generates AWS CloudFormation or Terraform templates.
- Suggests Lambda functions, API Gateway configurations, and IAM policies.
- Integrates with cloud SDKs.
Features:
- Use Case: Game Development (Unity, Unreal Engine)
- What It Does: Facilitates game mechanics, physics, and asset management.
- Creates Unity scripts for player movement, collisions, and animations.
- Suggests shaders and particle effects.
- Assists with level design and scene transitions.
Features:
- Use Case: Security and Penetration Testing
- What It Does: Helps identify vulnerabilities, secure code, and perform security audits.
- Generates secure authentication mechanisms (OAuth, JWT).
- Suggests input validation and encryption practices.
- Assists with OWASP Top Ten mitigation.
Features:
- Use Case: Quantum Computing (Qiskit, Cirq)
- What It Does: Supports quantum circuit design, error correction, and quantum algorithms.
- Generates Qiskit or Cirq code for quantum gates and circuits.
- Suggests optimization techniques for noisy quantum computers.
- Assists with quantum simulations.
Features:
“Remember, these are fictional names, but who knows? Maybe one day we’ll see specialized coding assistants tailored to these specific domains! π” Copilot concluded.
Indeed. Who knows?