This extension provides functions to work with linear programs and other optimisation problems.
Generate a random partition of n
into k
parts, with smallest part at least minimum
.
Solve a linear program with minimum constraints for each product, maximum constraints for each resource, numbers of each resource used in each product, and a straight line objective function
- minimum_x, minimum_y: minimum allocations for each product
- resources_x, resources_y: numbers of each resource used to make 1 unit of each product
- max_resource_1, max_resource_2: available quantities of each resource
- profit_x, profit_y: profit per unit of each product
Looks at the following intersection points:
- 0 - resource 1 with minimum x
- 1 - resource 2 with minimum x
- 2 - resource 1 with minimum y
- 3 - resource 2 with minimum y
- 4 - resource 1 with resource 2
Returns the index of the intersection point giving maximum profit
With program encoded as above, returns the coordinates [x,y]
of the point giving the maximum profit
With program encoded as above, returns an array of booleans specifying which lines are binding (touching the optimal solution), from the following: [resource 1, resource 2, minimum x, minimum y]
Use the NW corner algorithm to generate a first guess at an optimal solution to a transportation problem. supplies
specifies the number of units supplied by each source, and demand
specifies the number of units demanded by each destination.
Returns a matrix of the number of units to transport from each source to each destination.
HTML representation of the stages of the NW corner algorithm
Find the solution to the transportation problem which minimises total cost.
Returns a matrix of the number of units to transport from each source to each destination.
HTML representation of the stages of the minimum cost algorithm.
Returns a list [m,rows,columns]
, where m
is the shadow cost of each cell in the assignment matrix, and rows
and columns
give the shadow costs for each row and column, respectively.
Returns true
if the given assignment (matrix of number of units to deliver from each source to each destination) minimises the total cost.
Returns true
if the given assignment is valid - the amount supplied from each source doesn't exceeed the available supply, and the amount delivered to each destination doesn't exceed the demand.
Returns true
if the stepping stone algorithm to find an optimal assignment terminates.
Find an optimal solution to the given assignment problem, with the stepping stones method, starting with the given assignment.
Returns a matrix of assignments.
HTML representation of the steps of the stepping stone method.
Total cost of the given assignment
A table showing the cost matrix for the given assignment problem
A table showing the given assignment
LaTeX description of the calculation of the total cost of the given assignment
A table showing the costs for each worker at each job. worker_name
and job_name
give the headings for workers and jobs, respectively (e.g., "Delivery driver" and "Route")
Perform the Hungarian algorithm to assign workers to jobs, minimising the total cost. Returns a matrix with 1
in the cell (worker,job)
when the corresponding worker is assigned to the corresponding job, and 0
otherwise.
HTML representation of the steps of the Hungarian algorithm.
HTML graph showing the given set of points in a 2D decision problem. utility
is a list of 2d coordinates [x,y]
, and actions
is a list of labels.
HTML graph showing the utility set, with the expected value criterion line defined by prob_state_1
and prob_state_2
.
Expected value of perfect information in the given decision problem, with the given (vector or list of) probabilities.
Solve the given linear programming problem with the simplex method
Matrix representing the optimal tableau when the simplex algorithm terminates.
List specifying which row each variable is basic in, in the given simplex tableau, or-1
if the variable is not basic.
HTML representation of the steps of the simplex method.
HTML representation of an optimal simplex tableau for the given problem.
The convex hull of the given list of points. Returns a list of points, in clockwise order.