Grammas are the language of languages. A grammar defines a language. Behind every language, there is a grammar that determines its structure.
In computer science, the most common type of grammar is the context-free grammar. Context-free grammars have sufficent richness to describle the recursive syntactic structure of many languages.
A set of rules is the core components of a grammar. Each rule has two parts: (1)a name and (2) an expression of the name.
For instance, if we were creating a grammar to handle english text, we might add a rule like:
noun-phras may expand into article noun