- Create native project runtime.{rid}.Google.OrTools
- follow the microsoft convention e.g.:
https://www.nuget.org/packages/Microsoft.NETCore.App/
https://www.nuget.org/packages/runtime.linux-x64.Microsoft.NETCore.App/
- Target `make_dotnet` targets local nupkg instead of dll.
- Use 4096 RSA key for or-tools.snk
- Clean nuget cache in `clean_dotnet` recipe
Refactor:
- Move cs files to ortools/*/csharp
- Move dotnet project to ortools/dotnet/Google.OrTools
- Move example generation to temp_dotnet
- Avoid to mess the `BIN_DIR`
- Rework Google.OrTools.FSharp
Cleanup:
- Remove deps to netfx.props since we only support:
netstandard2.0 TFM and netcoreapp2.1 Runtime TFM
- Remove OrTools.nuspec.in
-> use newly added properties to .csproj format
- Remove of ortools/dotnet/OrTools project
- replaced by ortools/dotnet/Google.OrTools
- Remove provided protobuf.dll.
- Automatically retrieved from nuget.org
Misc:
- Add **/*.csproj to gitignore
- Add **/runtime.json to gitignore
- dotnet: Makefile windows fix
- make.exe doesn't support `else ifeq`
192 lines
4.4 KiB
C#
192 lines
4.4 KiB
C#
// Copyright 2010-2017 Google
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
namespace Google.OrTools.LinearSolver {
|
|
using System;
|
|
using System.Collections.Generic;
|
|
|
|
// Patch the MPVariable class to support the natural language API.
|
|
public partial class Variable {
|
|
public static LinearExpr operator+(Variable a, double v)
|
|
{
|
|
return new VarWrapper(a) + v;
|
|
}
|
|
|
|
public static LinearExpr operator+(double v, Variable a)
|
|
{
|
|
return a + v;
|
|
}
|
|
|
|
public static LinearExpr operator+(Variable a, LinearExpr b)
|
|
{
|
|
return new VarWrapper(a) + b;
|
|
}
|
|
|
|
public static LinearExpr operator+(Variable a, Variable b)
|
|
{
|
|
return new VarWrapper(a) + new VarWrapper(b);
|
|
}
|
|
|
|
public static LinearExpr operator+(LinearExpr a, Variable b)
|
|
{
|
|
return a + new VarWrapper(b);
|
|
}
|
|
|
|
public static LinearExpr operator-(Variable a, double v)
|
|
{
|
|
return new VarWrapper(a) - v;
|
|
}
|
|
|
|
public static LinearExpr operator-(double v, Variable a)
|
|
{
|
|
return v - new VarWrapper(a);
|
|
}
|
|
|
|
public static LinearExpr operator-(Variable a, LinearExpr b)
|
|
{
|
|
return new VarWrapper(a) - b;
|
|
}
|
|
|
|
public static LinearExpr operator-(LinearExpr a, Variable b)
|
|
{
|
|
return a - new VarWrapper(b);
|
|
}
|
|
|
|
public static LinearExpr operator-(Variable a, Variable b)
|
|
{
|
|
return new VarWrapper(a) - new VarWrapper(b);
|
|
}
|
|
|
|
public static LinearExpr operator-(Variable a)
|
|
{
|
|
return - new VarWrapper(a);
|
|
}
|
|
|
|
public static LinearExpr operator*(Variable a, double v)
|
|
{
|
|
return new VarWrapper(a) * v;
|
|
}
|
|
|
|
public static LinearExpr operator/(Variable a, double v)
|
|
{
|
|
return new VarWrapper(a) / v;
|
|
}
|
|
|
|
public static LinearExpr operator*(double v, Variable a)
|
|
{
|
|
return v * new VarWrapper(a);
|
|
}
|
|
|
|
public static RangeConstraint operator==(Variable a, double v)
|
|
{
|
|
return new VarWrapper(a) == v;
|
|
}
|
|
|
|
public static RangeConstraint operator==(double v, Variable a)
|
|
{
|
|
return v == new VarWrapper(a);
|
|
}
|
|
|
|
public static RangeConstraint operator!=(Variable a, double v)
|
|
{
|
|
return new VarWrapper(a) != v;
|
|
}
|
|
|
|
public static RangeConstraint operator!=(double v, Variable a)
|
|
{
|
|
return new VarWrapper(a) != v;
|
|
}
|
|
|
|
public static Equality operator==(Variable a, LinearExpr b)
|
|
{
|
|
return new VarWrapper(a) == b;
|
|
}
|
|
|
|
public static Equality operator==(LinearExpr a, Variable b)
|
|
{
|
|
return a == new VarWrapper(b);
|
|
}
|
|
|
|
public static VarEquality operator==(Variable a, Variable b)
|
|
{
|
|
return new VarEquality(a, b, true);
|
|
}
|
|
|
|
public static Equality operator!=(Variable a, LinearExpr b)
|
|
{
|
|
return new VarWrapper(a) != b;
|
|
}
|
|
|
|
public static Equality operator!=(LinearExpr a, Variable b)
|
|
{
|
|
return a != new VarWrapper(b);
|
|
}
|
|
|
|
public static VarEquality operator!=(Variable a, Variable b)
|
|
{
|
|
return new VarEquality(a, b, false);
|
|
}
|
|
|
|
public static RangeConstraint operator<=(Variable a, double v)
|
|
{
|
|
return new VarWrapper(a) <= v;
|
|
}
|
|
|
|
public static RangeConstraint operator>=(Variable a, double v)
|
|
{
|
|
return new VarWrapper(a) >= v;
|
|
}
|
|
|
|
public static RangeConstraint operator<=(double v, Variable a)
|
|
{
|
|
return new VarWrapper(a) >= v;
|
|
}
|
|
|
|
public static RangeConstraint operator>=(double v, Variable a)
|
|
{
|
|
return new VarWrapper(a) <= v;
|
|
}
|
|
|
|
public static RangeConstraint operator<=(Variable a, LinearExpr b)
|
|
{
|
|
return new VarWrapper(a) <= b;
|
|
}
|
|
|
|
public static RangeConstraint operator>=(Variable a, LinearExpr b)
|
|
{
|
|
return new VarWrapper(a) >= b;
|
|
}
|
|
|
|
public static RangeConstraint operator<=(Variable a, Variable b)
|
|
{
|
|
return new VarWrapper(a) <= new VarWrapper(b);
|
|
}
|
|
|
|
public static RangeConstraint operator>=(Variable a, Variable b)
|
|
{
|
|
return new VarWrapper(a) >= new VarWrapper(b);
|
|
}
|
|
|
|
public static RangeConstraint operator<=(LinearExpr a, Variable b)
|
|
{
|
|
return a <= new VarWrapper(b);
|
|
}
|
|
|
|
public static RangeConstraint operator>=(LinearExpr a, Variable b)
|
|
{
|
|
return a >= new VarWrapper(b);
|
|
}
|
|
}
|
|
|
|
} // namespace Google.OrTools.LinearSolver
|