Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/thorium/linq.expression.optimizer

System.Linq.Expression expressions optimizer. http://thorium.github.io/Linq.Expression.Optimizer
https://github.com/thorium/linq.expression.optimizer

boolean-algebra expression-tree linq mathematical-expressions optimisation optimization reduction sql

Last synced: 2 days ago
JSON representation

System.Linq.Expression expressions optimizer. http://thorium.github.io/Linq.Expression.Optimizer

Awesome Lists containing this project

README

        

[![Issue Stats](http://issuestats.com/github/thorium/Linq.Expression.Optimizer/badge/issue)](http://issuestats.com/github/thorium/Linq.Expression.Optimizer)
[![Issue Stats](http://issuestats.com/github/thorium/Linq.Expression.Optimizer/badge/pr)](http://issuestats.com/github/thorium/Linq.Expression.Optimizer)

# Linq.Expression.Optimizer

Lightweight optimizer of System.Linq.Expression expressions.
Just basic boolean algebra and reductions, constant and tuple/anonymous type eliminations.
For side-effect-free Expressions. No compilation-subjective optimizations.
This is meant to be used with expressions that are not compiled but transferred to other domains.

Supported frameworks: Net 3.5, Net 4.5-... (and Mono), .NET Standard 1.6 (so also .NET Core)

## Supported optimizations

Example as a quote. There are various other cases also.

- Replace constants comparisons: ` 3 < 4 -> true `
- Remove anonymous types: ` new AnonymousObject(Item1 = x, Item2 = "").Item1 --> x `
- Cut not used condition: ` if false then x else y -> y `
- Remove not: ` not(false) -> true `
- Binary tree balancing: ` a or (b or (c or (d or (e or (f or (g or h)))))) -> ((a or b) or (c or d)) or ((e or f) or (g or h)) `
- Captured closure constant ("free variable") evaluation: ` y = 3 and (y + x) -> (3 + x) `
- Execute simple math: `5 * 3 -> 15`
- Boolean algebra reductions:
* gather ` (x or y) and (x or z) -> x or (y and z) `
* identity ` false or y -> y `
* annihilate ` true or x -> true `
* absorb ` x and (x or y) -> x `
* idempotence ` y or y -> y `
* complement ` x and not(x) -> false `
* doubleNegation ` not(not(y)) -> y `
* deMorgan ` not(x) and not(y) -> not(x or y) `

## Background

This is a side-track from [SQLProvider](https://github.com/fsprojects/SQLProvider), excellent tool that is
kind of OR-mapper with auto-generated objects, so it compiles any databases to .NET-language, and works
fast on design time in Visual Studio or other editors.

But I needed better SQL-queries. So this optimises .NET LINQ-expressions.
These expressions were not meant to be compiled, so [Nessos LinqOptimizer](https://github.com/nessos/LinqOptimizer) was not the right tool.
I thought that .NET would optimize these automatically, but no.

Read the [Getting started tutorial](http://thorium.github.io/Linq.Expression.Optimizer/index.html#Getting-started) to learn more.

Documentation: http://thorium.github.io/Linq.Expression.Optimizer

## Maintainer(s)

- [@thorium](https://github.com/thorium)

If you want more optimizations, please feel free to send PRs!