Dev Encyclopedia;
Find out what that Sr. Developer is talking about
ACID Transactions
Ensure reliability in database operations
API Gateway
Manages requests and directs them to the correct services
API Versioning
Manage API changes by assigning version numbers
APIs
Application Programming Interfaces
APM (Application Performance Management)
Monitors and manages software application performance
AUC Curve
i.e. Area Under the Curve
Agile
A methology in Software Development
Angular
A TypeScript-based web application framework
Arguments
Values passed to functions to influence their behavior.
Artificial Intelligence
A frenemy
Asymmetric-cryptography
cryptographic scheme requiring two different keys, one for encryption and the other for decryption.
Authentication
Verifying user identity
Authorization
Determining user permissions
Autoencoders
Learns efficient data representations through compression and reconstruction.
Bagging
Combines predictions from multiple models for improved accuracy.
Bash
A unix shell and command language
Big O Notation
A term used to explain... algorithms?
Bioinformatics
Using technology to understand biological data
Blockchain
A chain of transactions
Boolean
A data type with true or false values.
Boosting
Builds models sequentially, with each correcting errors of the previous one.
Branching
Creating separate code versions
C#
A modern, OOP language from Microsoft
CQRS (Command Query Responsibility Segregation)
Separating read and write operations for efficiency
CSS
Cascading Style Sheets
Cache Invalidation
Remove outdated data to make room for fresh information
Caching
Storing data for quick access
Chaos Engineering
Practice of testing systems to withstand turbulent conditions
Classes
Blueprints for creating objects with defined properties and behaviors.
Cloud Computing
It's always fun on the clouds, until it starts "leaking"
Cloud Orchestration
Automated arrangement and coordination of cloud services
Cloud Security
Procedures and technology to secure cloud environments
Cluster Computing
Connecting multiple computers to work as a single system
Code Review
Checking code for quality and improvement
Code Smell
Indicators that code might need improvement.
Concurrency
Run multiple processes simultaneously for efficiency
Confusion Matrix
A table to evaluate classification model performance.
Containerization
Packaging applications for consistent deployment
Continuous Delivery (CD)
A software development practice often implemented with CI
Continuous Deployment
Automatic deployment of code changes
Continuous Integration (CI)
A software development practice
Convolutional Neural Networks
Analyzes grid-like data, such as images, using filters.
Cross-Entropy
Loss function measuring the difference between predicted and actual class labels.
Cross-Validation
Evaluates model performance on multiple data splits.
Cybersecurity
Staying secured in a a world of hackers
DRY Principle
Avoid code repetition
Dark Launch
Release features to a subset of users without their knowledge
Data Anonymization
Removing personal identifiers from data to protect privacy
Data Deduplication
Eliminate redundant data to increase storage efficiency
Data Governance
Management of data's availability, usability, integrity, and security
Data Lake
Vast storage for raw data in its native format
Data Lakehouse
Combine data lakes and warehouses for comprehensive storage
Data Lakes and Warehouses Integration
Combine raw and structured data storage for better management
Data Partitioning
Divide a database into distinct, independent parts
Data Replication
Copy data to ensure consistency and accessibility
Data Science
Science of converting information to Data
Data Serialization
Converting data for storage or transmission
Data Sharding
Splitting a database into smaller, faster parts
Data Structure
A way of oragnzing and storing data
Data Types
Categories defining the kind of data variables can hold.
Data Validation
Ensuring data accuracy and completeness
Data Warehouse
System for storing and managing large data for analysis
DataOps
An agile methodology for developing and maintaining data analytics
Database Indexing
Improve data retrieval speed in databases
Deadlock
A stand-off where processes block each other's progress
Debugger
Tool for finding and fixing code errors
Debugging
An interesting process that makes programmers yell "Just Why!?"
Decision Trees
Uses a tree-like model of decisions and their possible consequences.
Deep Learning
A subset of machine learning
Dependency Graph
Visualize dependencies in systems or projects
Deployment
Making applications available for use
Deployment Pipeline
Automated process for software changes
Design Patterns
Standard solutions to common design problems
DevOps
A set of practices that combine Dev and Ops
DevSecOps
Integrating security into the DevOps process
Dictionary
A collection of key-value pairs in programming.
Digital Twins
Virtual replicas of physical objects or systems
Distributed File System (DFS)
A network file system that spans multiple servers
Distributed Ledger Technology
Digital system recording transactions in multiple places simultaneously
Docker
The most popular Container tool
Docker Swarm
Management of Docker container clusters
Domain-Driven Design
Software development approach focused on core business concepts
Double
More precise and larger decimal numbers.
ETL (Extract, Transform, Load)
Process to collect, change, and store data
Edge AI
Bringing artificial intelligence to edge devices to process data locally
Edge Computing
Data processing closer to data sources
Edge Services
Technologies providing services closer to the user
End-to-End Test
Another type of testing
Ensemble Methods
Combines multiple models to improve overall performance.
Epochs
Training rounds in Machine Learning
Event Loop
Programming construct that waits for and dispatches events
Event Stream Processing
Analyze and process continuous streams of events
Event-Driven Architecture
Building software with actions triggering responses
Eventually Consistent Systems
Systems that eventually reach consistency over time
Explainable AI (XAI)
Making AI decisions understandable to humans
F1 Score
Harmonic mean of Precision and Recall for balanced evaluation.
Feature Branching
Isolate development in branches for easier integration
Feature Engineering
Creates or modifies features to enhance model performance.
Feature Scaling
Normalizes feature ranges for better model performance.
Federated Learning
Training AI models across multiple devices without sharing data
Floats
Numbers with decimal points for precision.
Flutter
An UI toolkit from Google
Fog Computing
Extending cloud computing to the edge of an enterprise's network
Front End
The visual and interactive parts of a website.
Full Stack
Development of both front end and back end.
Function as a Service (FaaS)
Execute code without managing infrastructure
Functions
Reusable blocks of code performing specific tasks.
GDPR
General Data Protection Regulation
Git
The most popular version control system
GitHub
Platform for code hosting and collaboration
Gradient Descent
Optimizes model parameters by minimizing errors.
Graph Databases
Databases storing data in nodes and edges to show relationships
GraphQL
Query language for APIs
HTML
HyperText Markup Language
Homomorphic Encryption
Performing computations on encrypted data without decryption
Horizontal Scaling
Add more machines to handle increased load
Hybrid Cloud
Combining public and private cloud environments for flexibility
Hyperparameter Tuning
Optimizes model settings to improve performance.
IDE
Integrated Development Environment for coding and debugging.
Immutable Data Structures
Data structures that cannot be modified after creation
Immutable Infrastructure
Infrastructure that is never modified after deployment
Infrastructure as Code (IaC)
Managing infrastructure through machine-readable scripts
Inheritance
Creating new classes from existing ones, inheriting their properties and behaviors.
Integration Test
Another type of testing
Internet of Things
A Network of things
IoT Edge Computing
Process data near its source in IoT devices
Iteration
A programming technique
JWT (JSON Web Tokens)
Securely transmit information as JSON
Java
A high-level programming-language
K-Means Clustering
Groups data into clusters based on similarity.
KISS Principle
Keep it simple to avoid complexity
Kanban
A visual workflow management method
Kotlin
A statically-typed programming language by JetBrains
Kubernetes
Platform for automating container management
LLMs
AI systems for understanding and generating text.
List
An ordered, changeable collection of items.
Load Test
A type of performance testing
Logistic Regression
Predicts probabilities for binary outcomes.
Machine Learning
AI exists thanks to this
Machine Learning Operations (MLOps)
Streamline machine learning processes using DevOps principles
Memory Leaks
Issues in memory management that can cause system crashes
Merging
Combining changes from branches
Message Brokers
Intermediaries that manage communication between apps
Message Queues
Manage asynchronous communication between processes
Micro-batching
Process small groups of data in short intervals
Microservices
Independent services working together
Microservices Architecture
Independent, small service modules in software
Mocking
Creating fake objects for testing
Monolith
A single, large application handling multiple tasks
Monolithic Architecture
Integrated large system design
Multi-Cloud Strategy
Using multiple cloud computing services to mitigate single-provider risks
Multi-Tenancy
Single instance of software serves multiple customers
Namespace
Organize code to avoid naming conflicts
Natural Language Processing
Enables computers to understand and process human language.
Network Slicing
Create multiple virtual networks on shared infrastructure
Neural Networks
Mimics the human brain to recognize patterns and make predictions.
NoSQL
A non-relational database management system
NoSQL Databases
Flexible, scalable data storage solutions
OAuth 2.0
Authorization framework for resource access
ORM (Object-Relational Mapping)
Mapping database tables to objects
Objects
Instances of classes with specific attributes and methods.
Open Source
Software with publicly accessible source code.
Optimistic Locking
Concurrency control method strategy.
Overfitting
When a model learns too much from training data, harming new data performance.
Performence Test
A type of testing focusing on applcation performence
Precision and Recall
Metrics for evaluating classification model accuracy and completeness.
Prototypes (Software Development)
Early models of software for testing
Pull Requests (PR)
Proposing and reviewing code changes
Quantum Computing
Sheldon Cooper's gonna love this
Quantum Cryptography
Using principles of quantum mechanics for secure communication
RESTful API
API using standard HTTP methods
ROC Curve
Graphical representation of a classifier's performance.
Random Forest
Combines multiple decision trees to improve accuracy.
Rate Limiting
Control the frequency of resource access to prevent overuse
ReactJS
A popular JS library for building user-interfaces
Reactive Programming
Handling data streams and changes in real time
Recurrent Neural Networks
Processes sequences of data, maintaining context over time.
Recursion
A programming technique
Recursion Depth
Used to elaborate on recusrion method
Refactoring
Improving code structure without changing behavior
Regularization
Prevents overfitting by adding penalties to model complexity.
Reinforcement Learning
Trains agents to make decisions by rewarding or punishing actions.
Ruby
Another simple, OOP language
Ruby on Rails
A web application framework written in Ruby
SOLID Principles
Guidelines for better software design
SQL
A relational database management system
Scalability
Capability of a system to handle growth
Scrum
A framework within the Agile methodology
Security Test
A test against hacking and whatnot
Server Sent Events (SSE)
Automatically update web pages with server data
Serverless Architecture
Cloud management of server operations
Serverless Computing
Cloud computing without managing servers.
Serverless Functions
Execute code without the need to manage servers
Service Discovery
Dynamic directory for services to find each other
Software Containers
Package an application and its dependencies into a unit
Stateful Widget
UI component that maintains state across sessions
Stateful vs Stateless Systems
Compare systems that maintain state with those that don't
Stress Test
A type of performance testing under pressure
String
A sequence of characters representing text.
Support Vector Machines
Finds the best boundary between classes in data.
Swift
A programming language from Apple
SwiftUI
Another framework from Apple
Syntax
Rules defining the structure and format of code.
Synthetic Data
Artificially generated data that mimics real data
Technical Debt
Extra work due to past shortcuts
Test-Driven Development
Or TDD, a software development approach
Testing
The ultimate fear of developers
The __init__ Function
A special method in Python Programming Language
Threads
Mini-programs running concurrently within a larger program.
Three-Sigma Rule
A rule of thumb in data science
Throttling
Control network traffic to prevent overloading
Tokenization
Convert sensitive data into non-sensitive tokens
Transfer Learning
Adapts pre-trained models for new but related tasks.
Tuple
An ordered, unchangeable collection of items.
Typescript
A superset of JavaScript
Underfitting
When a model is too simple to capture the underlying data patterns.
Unit test
A type of testing
Usability Test
A test that ensures that application is user-friendly
User-Acceptance Test (UAT)
Final user testing phase
Version Control
Recording every change
Vertical Scaling
Increase the capacity of a single server
Virtual Private Cloud (VPC)
Isolated cloud resources for enhanced security within a public cloud
VueJS
A aggressive progressive JavaScript framework
Web Flow
The sequence of user steps on a website.
Web Hooks
Automated messages between apps.
Web Scraping
Automatically collecting data from websites.
WebAssembly (Wasm)
High-performance web applications
WebRTC (Web Real-Time Communication)
Enabling real-time communication directly in web browsers
Zero Downtime Deployment
Update software without causing service disruption
Zero Trust Security Model
Security that trusts no one by default
gRPC
A high-performance framework for service communication
symmetric-cryptography
algorithms for cryptography that use the same cryptographic keys for both the encryption of plaintext.