# LNN
**Repository Path**: mirrors_ibm/LNN
## Basic Information
- **Project Name**: LNN
- **Description**: A `Neural = Symbolic` framework for sound and complete weighted real-value logic
- **Primary Language**: Unknown
- **License**: Apache-2.0
- **Default Branch**: master
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 0
- **Created**: 2021-11-27
- **Last Updated**: 2025-09-14
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
[](https://github.com/IBM/LNN/actions/workflows/build.yml?query=branch%3Amaster)
[](https://makeapullrequest.com)
[](https://github.com/IBM/LNN/blob/master/LICENSE)
[](https://bestpractices.coreinfrastructure.org/projects/5926)
[](https://github.com/psf/black)
# Logical Neural Networks
LNNs are a novel `Neuro = Symbolic` framework designed to seamlessly provide key
properties of both neural nets (learning) and symbolic logic (knowledge and reasoning).
- Every neuron has a meaning as a component of a formula in a weighted
real-valued logic, yielding a highly interpretable disentangled representation.
- Inference is omnidirectional rather than focused on predefined target
variables, and corresponds to logical reasoning, including classical
first-order logic theorem proving as a special case.
- The model is end-to-end differentiable, and learning minimizes a novel loss
function capturing logical contradiction, yielding resilience to inconsistent
knowledge.
- It also enables the open-world assumption by maintaining bounds on truth values
which can have probabilistic semantics, yielding resilience to incomplete
knowledge.
## Quickstart
To install the LNN:
1. Make sure that the python version you use in line with our [setup](https://github.com/IBM/LNN/blob/master/setup.py) file, using a fresh environment is always a good idea:
```commandline
conda create -n lnn python=3.9 -y
conda activate lnn
```
2. Install the `master` branch to keep up to date with the latest supported features:
```commandline
pip install git+https://github.com/IBM/LNN
```
## Contribution
Contributions to the LNN codebase are welcome!
Please have a look at the [contribution guide](https://github.com/IBM/LNN/blob/master/CONTRIBUTING.md) for more information on how to set up the LNN for contributing and how to follow our development standards.
## Documentation
| [Read the Docs][Docs] | [Academic Papers][Papers] | [Educational Resources][Education] | [Neuro-Symbolic AI][Neuro-Symbolic AI] | [API Overview][API] | [Python Module][Module] |
|:-----------------------:|:---------------------------:|:-----------------:|:----------:|:-------:|:-------:|
| [
][Docs] | [
][Papers] | [
][Education] | [
][Neuro-Symbolic AI] | [
][API] | [
][Module] |
## Citation
If you use Logical Neural Networks for research, please consider citing the
reference paper:
```raw
@article{riegel2020logical,
title={Logical neural networks},
author={Riegel, Ryan and Gray, Alexander and Luus, Francois and Khan, Naweed and Makondo, Ndivhuwo and Akhalwaya, Ismail Yunus and Qian, Haifeng and Fagin, Ronald and Barahona, Francisco and Sharma, Udit and others},
journal={arXiv preprint arXiv:2006.13155},
year={2020}
}
```
[Docs]: https://ibm.github.io/LNN/introduction.html
[Papers]: https://ibm.github.io/LNN/papers.html
[Education]: https://ibm.github.io/LNN/education/education.html
[API]: https://ibm.github.io/LNN/usage.html
[Module]: https://ibm.github.io/LNN/lnn/LNN.html
[Neuro-Symbolic AI]: https://research.ibm.com/teams/neuro-symbolic-ai