{
  "total_entries": 120,
  "disciplines": [
    {
      "discipline_name": "Theoretical Computer Science",
      "discipline_icon": "🧠",
      "description": "This field provides the fundamental mathematical basis of computation, exploring its limits, efficiency, and the formal logic that governs it.",
      "total_entries_in_discipline": 43,
      "sub_disciplines": [
        {
          "sub_discipline_name": "Computability and Complexity Theory",
          "entry_count": 6,
          "entries": [
            {
              "term": "NL (complexity)",
              "definition": "A complexity class for problems that can be solved by a nondeterministic computer using only a logarithmic amount of memory."
            },
            {
              "term": "Forcing (computability)",
              "definition": "A technique borrowed from set theory that's used to explore the relative difficulty of non-computable problems."
            },
            {
              "term": "Multiparty communication complexity",
              "definition": "The study of how much information multiple parties need to exchange to collectively solve a computational problem."
            },
            {
              "term": "Parallel computation thesis",
              "definition": "A hypothesis suggesting a fundamental relationship between the time a parallel computer takes and the memory a sequential computer uses to solve the same problem."
            },
            {
              "term": "Post-Turing machine",
              "definition": "A model of computation, equivalent in power to a Turing machine, that's often used in proofs of undecidability."
            },
            {
              "term": "Self-referential encoding",
              "definition": "Techniques like Gödel numbering where a system can refer to itself, which is a cornerstone of proving the limits of computation."
            }
          ]
        },
        
        {
          "sub_discipline_name": "Logic in Computer Science",
          "entry_count": 12,
          "entries": [
            {
              "term": "Deductive lambda calculus",
              "definition": "A version of lambda calculus that explicitly treats proofs as objects of computation, connecting logic directly to programming."
            },
            {
              "term": "Feferman-Vaught theorem",
              "definition": "A theorem from model theory used to understand the logical properties of complex structures by breaking them down into simpler parts."
            },
            {
              "term": "Kleene-Brouwer order",
              "definition": "A specific way to define a total order on a set of finite sequences, used in computability theory and descriptive set theory."
            },
            {
              "term": "Lambda-mu calculus",
              "definition": "An extension to lambda calculus that provides a computational interpretation for classical logic, handling concepts like control flow (e.g., `call/cc`)."
            },
            {
              "term": "Lindström quantifier",
              "definition": "A type of generalized quantifier that helps to characterize the expressive power of different logical systems."
            },
            {
              "term": "Reverse mathematics",
              "definition": "A branch of mathematical logic that seeks to determine the minimum set of axioms required to prove particular mathematical theorems."
            },
            {
              "term": "Second-order propositional logic",
              "definition": "A logic that extends standard propositional logic by allowing quantification over propositions themselves."
            },
            {
              "term": "Skolem arithmetic",
              "definition": "A non-standard model of arithmetic that is computationally interesting because it has a decidable theory."
            },
            {
              "term": "Substructural logic",
              "definition": "A class of logics that reject or restrict standard logical rules, making them useful for modeling resources, state, or other computational phenomena that can't be freely duplicated or discarded."
            },
            {
              "term": "Tennenbaum's theorem",
              "definition": "A theorem stating that no non-standard model of Peano arithmetic can be computable, highlighting the deep connection between arithmetic and computation."
            },
            {
              "term": "Unique homomorphic extension theorem",
              "definition": "A foundational result in algebra and logic ensuring that certain structure-preserving maps can be uniquely extended."
            },
            {
              "term": "Wadge hierarchy",
              "definition": "An infinitely detailed classification of the complexity of sets of infinite sequences, used in descriptive set theory."
            }
          ]
        },
        
        {
          "sub_discipline_name": "Mathematical Foundations",
          "entry_count": 25,
          "entries": [
            {
              "term": "Abstract Wiener space",
              "definition": "A mathematical construction from analysis used to rigorously define probabilities on infinite-dimensional spaces."
            },
            {
              "term": "Cobordism hypothesis",
              "definition": "A central theorem in topological quantum field theory with deep connections to the theory of computation."
            },
            {
              "term": "Complementary series representation",
              "definition": "A concept from group theory that appears in the harmonic analysis of graphs and networks."
            },
            {
              "term": "D-module",
              "definition": "A concept from abstract algebra used in symbolic computation to develop algorithms for solving systems of differential equations."
            },
            {
              "term": "Differentiable stack",
              "definition": "A highly abstract geometric object that generalizes manifolds, used in theoretical frameworks that inform quantum computing."
            },
            {
              "term": "Discrete Morse theory",
              "definition": "A combinatorial version of Morse theory used in computational topology to simplify complex data sets while preserving their essential topological features."
            },
            {
              "term": "Duality theory for distributive lattices",
              "definition": "A fundamental link between algebraic structures and topology, which is used in the semantics of programming languages."
            },
            {
              "term": "Graph homology",
              "definition": "An algebraic tool for studying the \"shape\" of graphs and networks, allowing algorithms to find higher-order structures like cycles and cavities."
            },
            {
              "term": "Henstock-Kurzweil integral",
              "definition": "A generalized definition of the integral that can handle more \"badly behaved\" functions than the standard Riemann or Lebesgue integrals."
            },
            {
              "term": "Infinite loop space machine",
              "definition": "A construction in algebraic topology that has connections to homotopy type theory, a new foundation for mathematics used in modern proof assistants."
            },
            {
              "term": "Johnson graph",
              "definition": "A specific type of graph from combinatorics whose properties are useful in the design of computer networks and the analysis of error-correcting codes."
            },
            {
              "term": "K-theory spectrum",
              "definition": "An object in algebraic topology with applications in classifying phases of matter, which is relevant to topological quantum computing."
            },
            {
              "term": "Minimal surface",
              "definition": "A surface that locally minimizes its area, a concept from geometry used extensively in computer graphics to create realistic shapes and in optimization problems."
            },
            {
              "term": "Min-plus matrix multiplication",
              "definition": "A variation of matrix multiplication used in graph algorithms (like finding the shortest paths between all pairs of nodes) and dynamic programming."
            },
            {
              "term": "Newman-Janis algorithm",
              "definition": "A technique from general relativity for generating new solutions to Einstein's field equations, relevant to computational physics."
            },
            {
              "term": "Noncommutative standard model",
              "definition": "An application of noncommutative geometry to particle physics, whose simulations push the boundaries of high-performance computing."
            },
            {
              "term": "Pairing function",
              "definition": "A function that reversibly maps two integers to a single integer, used in computability theory to encode complex data structures into a simple numerical format."
            },
            {
              "term": "Resolvent formalism",
              "definition": "A set of techniques from functional analysis used to study the spectra of operators, with applications in spectral graph theory for analyzing network properties."
            },
            {
              "term": "Ricci curvature",
              "definition": "A concept from geometry, adapted for discrete networks, that measures local connectivity and is used to find communities, bottlenecks, and important nodes."
            },
            {
              "term": "Simplicial space",
              "definition": "A type of topological space built from simple geometric shapes (points, lines, triangles), used in computational topology to model the shape of data."
            },
            {
              "term": "Stochastic thermodynamics",
              "definition": "A framework that extends thermodynamics to small, fluctuating systems, with deep connections to the energy efficiency of computation."
            },
            {
              "term": "Stone's theorem",
              "definition": "A fundamental theorem in functional analysis that provides the rigorous mathematical link between the dynamics of a quantum system and its energy operator, essential for quantum computing."
            },
            {
              "term": "Temperley-Lieb algebra",
              "definition": "An algebraic structure that arose in statistical mechanics and has connections to knot theory and the design of topological quantum computers."
            },
            {
              "term": "Weak derivative",
              "definition": "A generalization of the concept of a derivative, which is essential for the theory behind the Finite Element Method used in virtually all modern engineering and physics simulation software."
            },
            {
              "term": "Weyl-Brauer matrices",
              "definition": "Matrices from representation theory used to analyze symmetries in quantum systems, particularly in quantum information theory."
            }
          ]
        }
      ]
    },
    {
      "discipline_name": "Algorithmic Theory",
      "discipline_icon": "⚙️",
      "description": "This domain focuses on the design, analysis, and implementation of efficient methods for solving computational problems and organizing data.",
      "total_entries_in_discipline": 11,
      "sub_disciplines": [
        {
          "sub_discipline_name": "Graph and String Algorithms",
          "entry_count": 3,
          "entries": [
            {
              "term": "Bidirected graph",
              "definition": "A type of graph where each end of an edge has its own direction, useful for modeling certain types of network flows and matching problems."
            },
            {
              "term": "Commentz-Walter algorithm",
              "definition": "A highly efficient string-matching algorithm that combines the best features of other algorithms to find multiple patterns in a text simultaneously."
            },
            {
              "term": "Shortest common supersequence",
              "definition": "The problem of finding the shortest possible string that contains two or more other strings as subsequences."
            }
          ]
        },
        {
          "sub_discipline_name": "Data Structures and Compression",
          "entry_count": 2,
          "entries": [
            {
              "term": "Compressed cover tree",
              "definition": "A data structure used for efficient nearest-neighbor search in high-dimensional spaces, which adapts to the data's intrinsic complexity."
            },
            {
              "term": "Smallest grammar problem",
              "definition": "The challenge of finding the smallest possible context-free grammar that generates exactly one given string, a fundamental problem in data compression."
            }
          ]
        },
        {
          "sub_discipline_name": "Combinatorial Optimization",
          "entry_count": 2,
          "entries": [
            {
              "term": "Blahut-Arimoto algorithm",
              "definition": "An iterative algorithm used to find the capacity of a communication channel and in rate-distortion theory for data compression."
            },
            {
              "term": "Matroid-constrained number partitioning",
              "definition": "A variation of the number partitioning problem where the solution must also satisfy structural constraints defined by a matroid."
            }
          ]
        },
        {
          "sub_discipline_name": "Algorithmic Information Theory",
          "entry_count": 3,
          "entries": [
            {
              "term": "Algorithmically random sequence",
              "definition": "An infinite sequence of bits that is incompressible, meaning it can't be generated by any computer program smaller than the sequence itself."
            },
            {
              "term": "K-trivial set",
              "definition": "A set of numbers that is highly non-random and compressible, having very low Kolmogorov complexity."
            },
            {
              "term": "Solomonoff's theory of inductive inference",
              "definition": "A formal theory of prediction that uses the principles of algorithmic complexity to create a universal model for inductive reasoning."
            }
          ]
        },
        {
          "sub_discipline_name": "Algorithmic Game Theory",
          "entry_count": 1,
          "entries": [
            {
              "term": "Generalized first-price auction",
              "definition": "An auction mechanism, studied in algorithmic game theory, that's common in online advertising."
            }
          ]
        }
      ]
    },
    {
      "discipline_name": "Artificial Intelligence and Machine Learning",
      "discipline_icon": "🤖",
      "description": "This broad field involves creating systems that can learn from data, reason, and act intelligently.",
      "total_entries_in_discipline": 17,
      "sub_disciplines": [
        {
          "sub_discipline_name": "Learning Theory and Models",
          "entry_count": 4,
          "entries": [
            {
              "term": "Energy-based model (EBM)",
              "definition": "A type of generative model that learns the underlying probability distribution of data by assigning a low \"energy\" to correct examples and a high energy to incorrect ones."
            },
            {
              "term": "Kernel Normal Form",
              "definition": "A method for representing kernel-based learning algorithms in a canonical way to analyze their properties."
            },
            {
              "term": "Transduction (machine learning)",
              "definition": "A type of learning where the model makes predictions only for the specific test data it's given, rather than learning a general rule that applies to any future data."
            },
            {
              "term": "Vapnik-Chervonenkins theory",
              "definition": "A central part of statistical learning theory that provides a mathematical framework for understanding how well a machine learning model can generalize from a limited amount of training data."
            }
          ]
        },
        {
          "sub_discipline_name": "Bayesian and Probabilistic Methods",
          "entry_count": 5,
          "entries": [
            {
              "term": "Bayesian search theory",
              "definition": "The application of Bayesian statistics to the problem of efficiently finding a lost object by continuously updating the probability of its location based on search efforts."
            },
            {
              "term": "Dependent Dirichlet process",
              "definition": "A flexible Bayesian nonparametric model used for clustering data that evolves over time or has dependencies between data points."
            },
            {
              "term": "Dirichlet process",
              "definition": "A popular tool in Bayesian nonparametrics that allows a model to infer the number of clusters in a dataset from the data itself, rather than needing it to be specified in advance."
            },
            {
              "term": "Neural network Gaussian process",
              "definition": "A powerful model that combines the flexibility of deep neural networks with the uncertainty quantification of Gaussian processes."
            },
            {
              "term": "Variable-order Markov model",
              "definition": "A sequence model that adapts the amount of past context it uses to predict the next item, making it more flexible than a fixed-order Markov model."
            }
          ]
        },
        {
          "sub_discipline_name": "Logic, Reasoning, and Knowledge Representation",
          "entry_count": 3,
          "entries": [
            {
              "term": "Calculus of predispositions",
              "definition": "A formal system for representing and reasoning about context and likelihood."
            },
            {
              "term": "Constraint composite graph",
              "definition": "A graphical structure used to represent and solve complex constraint satisfaction problems."
            },
            {
              "term": "Stable model semantics",
              "definition": "A foundational concept in answer set programming, a form of declarative programming used to solve difficult search and optimization problems."
            }
          ]
        },
        {
          "sub_discipline_name": "Robotics and Embodied AI",
          "entry_count": 1,
          "entries": [
            {
              "term": "Developmental robotics",
              "definition": "A subfield of robotics that aims to create robots that learn and develop skills progressively over time, inspired by how human children learn."
            }
          ]
        },
        {
          "sub_discipline_name": "Specialized Domains and Applications",
          "entry_count": 4,
          "entries": [
            {
              "term": "Bayesian estimation of templates in computational anatomy",
              "definition": "The use of Bayesian methods to create representative anatomical models (templates) from collections of medical images, like brain scans."
            },
            {
              "term": "Generalized blockmodeling of valued networks",
              "definition": "A technique in network science for discovering and summarizing large-scale patterns in networks where the connections have different strengths or values."
            },
            {
              "term": "Maximal entropy random walk",
              "definition": "A method for defining a random walk on a graph that is as unbiased as possible, subject to certain known constraints."
            },
            {
              "term": "Physics-informed neural networks (PINNs)",
              "definition": "Neural networks that are constrained during training to obey the laws of physics, described by partial differential equations, allowing them to learn from both data and physical principles."
            }
          ]
        }
      ]
    },
    {
      "discipline_name": "Cryptography",
      "discipline_icon": "🔒",
      "description": "This field is dedicated to techniques for secure communication, covering encryption, authentication, and privacy.",
      "total_entries_in_discipline": 12,
      "sub_disciplines": [
        {
          "sub_discipline_name": "Cryptosystems and Primitives",
          "entry_count": 4,
          "entries": [
            {
              "term": "Convolution random number generator",
              "definition": "A type of pseudorandom number generator constructed using a convolution operation."
            },
            {
              "term": "Doubling-oriented Doche-Icart-Kohel curve",
              "definition": "A specific form of an elliptic curve designed to be highly efficient and resistant to certain side-channel attacks."
            },
            {
              "term": "Rabin cryptosystem",
              "definition": "An asymmetric encryption algorithm whose security is mathematically proven to be as difficult as factoring large numbers."
            },
            {
              "term": "Undeniable signature",
              "definition": "A digital signature scheme where the signer's cooperation is required to verify the signature, preventing the signature from being publicly verifiable without their consent."
            }
          ]
        },
        {
          "sub_discipline_name": "Cryptanalysis",
          "entry_count": 4,
          "entries": [
            {
              "term": "Acoustic cryptanalysis",
              "definition": "A side-channel attack where an adversary uses the sounds produced by a computer's electronic components during a cryptographic operation to extract secret keys."
            },
            {
              "term": "Function field sieve",
              "definition": "The most efficient known classical algorithm for factoring very large integers, making it relevant to assessing the security of RSA encryption."
            },
            {
              "term": "Pohlig-Hellman algorithm",
              "definition": "An algorithm for computing discrete logarithms that is efficient when the order of the group has small prime factors."
            },
            {
              "term": "Rotational cryptanalysis",
              "definition": "A cryptanalytic technique used to attack a certain class of simple, fast ciphers known as ARX (Add-Rotate-XOR) ciphers."
            }
          ]
        },
        {
          "sub_discipline_name": "Secure Protocols",
          "entry_count": 2,
          "entries": [
            {
              "term": "Distributed key generation",
              "definition": "A cryptographic protocol where a group of parties jointly generates a shared secret key without any single party ever knowing the entire key."
            },
            {
              "term": "Mix network",
              "definition": "An anonymous communication protocol that obscures the link between a sender and receiver by routing messages through a chain of proxy servers that shuffle them."
            }
          ]
        },
        {
          "sub_discipline_name": "Foundational Concepts",
          "entry_count": 2,
          "entries": [
            {
              "term": "Noisy-storage model",
              "definition": "A theoretical model in cryptography that explores the possibility of secure storage under the assumption that an adversary can only get a slightly corrupted or \"noisy\" version of a stored secret key."
            },
            {
              "term": "Random oracle",
              "definition": "An idealized black box in cryptographic proofs that responds to every unique query with a truly random output. It's used as a theoretical benchmark for hash functions."
            }
          ]
        }
      ]
    },
    {
      "discipline_name": "Quantum Computing",
      "discipline_icon": "⚛️",
      "description": "This emerging field uses the principles of quantum mechanics to develop new types of computers that can solve certain problems much faster than classical computers.",
      "total_entries_in_discipline": 11,
      "sub_disciplines": [
        {
          "sub_discipline_name": "Quantum Complexity and Models",
          "entry_count": 2,
          "entries": [
            {
              "term": "Fredkin gate",
              "definition": "A universal, reversible 3-bit logic gate that conserves the number of 0s and 1s, making it useful in reversible and quantum computing."
            },
            {
              "term": "PostBQP",
              "definition": "A theoretical quantum complexity class that grants a quantum computer the ability to \"post-select\" on a desired measurement outcome, giving it immense (and likely physically unrealistic) computational power."
            }
          ]
        },
        {
          "sub_discipline_name": "Quantum Algorithms and Information",
          "entry_count": 4,
          "entries": [
            {
              "term": "Algorithmic cooling",
              "definition": "A set of techniques for purifying the state of qubits in a quantum computer, effectively \"cooling\" them to a purer computational state."
            },
            {
              "term": "Bound entanglement",
              "definition": "A strange form of quantum entanglement from which it's impossible to distill any maximally entangled pure states (like Bell pairs), even though the state is entangled."
            },
            {
              "term": "Classical shadow",
              "definition": "An efficient method for learning many properties of a quantum state from a surprisingly small number of quantum measurements."
            },
            {
              "term": "Hidden subgroup problem (HSP)",
              "definition": "A general problem in mathematics that unifies many of the key problems—including factoring and discrete log—that can be solved efficiently on a quantum computer."
            }
          ]
        },
        {
          "sub_discipline_name": "Quantum Foundations and Simulation",
          "entry_count": 4,
          "entries": [
            {
              "term": "Bosonization",
              "definition": "A powerful theoretical technique that allows physicists to map a system of interacting fermions (like electrons) to an equivalent system of bosons (like photons), which can be easier to solve."
            },
            {
              "term": "Continuous-time quantum Monte Carlo",
              "definition": "A class of algorithms used on classical computers to simulate the behavior of quantum many-body systems."
            },
            {
              "term": "Generalized probabilistic theory",
              "definition": "A mathematical framework for exploring physical theories that could be even more general than quantum mechanics."
            },
            {
              "term": "Quantum contextuality",
              "definition": "A key feature of quantum mechanics which states that the result of a measurement can depend on which other compatible measurements are performed at the same time."
            }
          ]
        },
        {
          "sub_discipline_name": "Interdisciplinary Applications",
          "entry_count": 1,
          "entries": [
            {
              "term": "Quantum artificial life",
              "definition": "A field that uses quantum computing to simulate and explore the fundamental properties of living systems and abiogenesis."
            }
          ]
        }
      ]
    },
    {
      "discipline_name": "Scientific Computing",
      "discipline_icon": "💻",
      "description": "This area focuses on the development of numerical algorithms and software for solving problems in science and engineering, often involving large-scale simulations.",
      "total_entries_in_discipline": 13,
      "sub_disciplines": [
        {
          "sub_discipline_name": "Numerical Methods",
          "entry_count": 5,
          "entries": [
            {
              "term": "Biconjugate gradient method",
              "definition": "An iterative algorithm for solving large, sparse systems of linear equations."
            },
            {
              "term": "H-matrix (Hierarchical Matrix)",
              "definition": "A data format that allows for the efficient, compressed representation of certain dense matrices that arise in scientific simulations."
            },
            {
              "term": "Matrix analytic method",
              "definition": "A set of techniques used for solving problems in stochastic modeling, particularly in queueing theory."
            },
            {
              "term": "Sobol sequence",
              "definition": "A type of quasi-random sequence designed to cover a space more evenly than purely random numbers, leading to faster convergence in Monte Carlo simulations."
            },
            {
              "term": "Symbolic-numeric computation",
              "definition": "A field that combines the exactness of symbolic computation (computer algebra) with the speed of numerical methods to solve complex problems."
            }
          ]
        },
        {
          "sub_discipline_name": "Computational Physics and Engineering",
          "entry_count": 6,
          "entries": [
            {
              "term": "Blind deconvolution",
              "definition": "The problem of recovering a sharp image or signal when the exact nature of the blurring process is unknown."
            },
            {
              "term": "Computational Fluid Dynamics for Phase Change Materials",
              "definition": "The use of CFD techniques to simulate complex fluid flow and heat transfer in materials that are melting or freezing."
            },
            {
              "term": "Discrete exterior calculus",
              "definition": "A framework that discretizes the language of differential geometry, allowing for the creation of physics simulators that better preserve fundamental physical laws."
            },
            {
              "term": "Perfectly matched layer (PML)",
              "definition": "An artificial absorbing layer used in numerical simulations of wave phenomena (like electromagnetics or acoustics) to prevent waves from reflecting off the boundaries of the simulation domain."
            },
            {
              "term": "Synchronization of chaos",
              "definition": "The phenomenon where two or more chaotic systems can adjust their dynamics to oscillate in synchrony, which is studied via numerical simulation."
            },
            {
              "term": "Variational integrator",
              "definition": "A numerical method for simulating physical systems that is derived from a discretized version of a physical principle (like the principle of least action), which helps it to conserve energy and momentum better over long simulations."
            }
          ]
        },
        {
          "sub_discipline_name": "Optimization and Control",
          "entry_count": 2,
          "entries": [
            {
              "term": "Differential dynamic programming",
              "definition": "An algorithm for trajectory optimization that iteratively finds the best way for a system (like a robot) to move to achieve a goal."
            },
            {
              "term": "Invariant extended Kalman filter",
              "definition": "A version of the extended Kalman filter designed to work with systems that have symmetries (like a robot moving in 3D space), leading to better consistency and accuracy."
            }
          ]
        }
      ]
    },
    {
      "discipline_name": "Programming Languages and Formal Methods",
      "discipline_icon": "📝",
      "description": "This field covers the design and analysis of programming languages, as well as formal techniques for proving the correctness of software and hardware.",
      "total_entries_in_discipline": 13,
      "sub_disciplines": [
        {
          "sub_discipline_name": "Formal Semantics and Rewriting Systems",
          "entry_count": 2,
          "entries": [
            {
              "term": "Abstract rewriting machine",
              "definition": "A computational model that generalizes term rewriting and lambda calculus, used to study the fundamental properties of computation."
            },
            {
              "term": "Kahn process networks",
              "definition": "A model of computation for parallel systems where deterministic processes communicate through unbounded channels, guaranteeing that the overall system's behavior is also deterministic."
            }
          ]
        },
        {
          "sub_discipline_name": "Type Theory and Program Analysis",
          "entry_count": 3,
          "entries": [
            {
              "term": "Canonicalization",
              "definition": "The process of converting data that has more than one possible representation into a standard, \"canonical\" form."
            },
            {
              "term": "Dependent ML",
              "definition": "A programming language that integrates dependent types, which allow types to depend on values, enabling a much higher level of static program verification."
            },
            {
              "term": "Typestate analysis",
              "definition": "A form of static program analysis that tracks the \"state\" of an object to ensure it's used correctly (e.g., a file is not read from after it has been closed)."
            }
          ]
        },
        {
          "sub_discipline_name": "Formal Verification",
          "entry_count": 4,
          "entries": [
            {
              "term": "Circuit extraction",
              "definition": "The process of automatically generating a verified computer program or hardware circuit directly from a formal proof written in constructive logic."
            },
            {
              "term": "Formal equivalence checking",
              "definition": "A technique used in hardware design to mathematically prove that two different circuit designs have exactly the same behavior."
            },
            {
              "term": "Formal proof",
              "definition": "A proof in which every logical step is verified down to the fundamental axioms of the system, often created and checked with computer assistance."
            },
            {
              "term": "Matching logic",
              "definition": "A formal logic framework for the specification and verification of computer programs."
            }
          ]
        },
        {
          "sub_discipline_name": "Automata and Formal Languages",
          "entry_count": 4,
          "entries": [
            {
              "term": "Büchi-Elgot-Trakhtenbrot theorem",
              "definition": "A key result that connects finite automata (simple computing machines) with formal logic, showing that the languages they recognize are exactly those definable in a specific logical system."
            },
            {
              "term": "Pebble automaton",
              "definition": "A type of abstract machine that can move on an input tape and drop a finite number of \"pebbles\" to mark positions, making it more powerful than a standard automaton."
            },
            {
              "term": "Semi-Thue system",
              "definition": "A formal system for rewriting strings, which forms the basis of formal grammars and is a universal model of computation."
            },
            {
              "term": "Two-way finite automaton",
              "definition": "An abstract machine that can read its input tape by moving both left and right."
            }
          ]
        }
      ]
    }
  ]
}