Linear programming is a technique to solve optimization problems whose constraints and outcome are represented by linear relationships.
Simply put, linear programming allows to solve problems of the following kind:
- Maximize/minimize $\hat C^T \hat X$
- Under the constraint $\hat A \hat X \leq \hat B$
- And the constraint $\hat X \geq 0$
This doesn’t seem much when you glance at it but in practice it is a powerful tool that can be used to make decisions in practical life scenarios.
It is often the case that we need to make decisions based on constraints. Often the invisible and most harsh constraint is time, but generally speaking there are a lot of other constraints that we need to take into account. A simple set of examples would be:
- I want to change my heating system. I want to minimize the cost of the system and the bills, what kind of heating system should I install? A pellet stove? Electric radiators?
- I want to obtain the maximum profit from the sale of these two products I produce. In what quantities should I produce each product?
- And so on…
Linear programming can help you with these kind of decisions where:
- The function you are trying to optimize is a linear combination of the decision variables (this might not always be the case).
- The constraints you have are a linear combination of the decision variables. 
An example of linear optimization
I’m going to implement in R an example of linear optimization that I found in the book “Modeling and Solving Linear Programming with R” by Jose M. Sallan, Oriol Lordan and Vincenc Fernandez. The example is named “Production of two models of chairs” and can be found at page 57, section 3.5. I’m going to solve only the first point.
The problem text is the following
A company produces two models of chairs: 4P and 3P. The model 4P needs 4 legs, 1 seat and 1 back. On the other hand, the model 3P needs 3 legs and 1 seat. The company has a initial stock of 200 legs, 500 seats and 100 backs. If the company needs more legs, seats and backs, it can buy standard wood blocks, whose cost is 80 euro per block. The company can produce 10 seats, 20 legs and 2 backs from a standard wood block. The cost of producing the model 4P is 30 euro/chair, meanwhile the cost of the model 3P is 40 euro/chair. Finally, the company informs that the minimum number of chairs to produce is 1000 units per month. Define a linear programming model, which minimizes the total cost (the production costs of the two chairs, plus the buying of new wood blocks).
Problem definition
First, we need to translate the problem in a mathematical way. Let’s define the following variables
- $x_{4p}$ is the number of 4P chairs to be produced.
- $x_{3p}$ is the number of 3P chairs to be produced.
- $x_w$ is the number of wood blocks to be bought.
Now we can define $\hat X = \begin{pmatrix} x_{4p} \\ x_{3p} \\ x_w \end{pmatrix}$ as the decision variable vector. Note that it must be $\hat X \geq 0$.
We would like to minimize the total cost so we must set our objective function as follows
$$cost(x_{4p}, x_{3p}, x_w) = 30 x_{4p} + 40 x_{3p} + 80 x_w = MIN(cost) $$
which means that $\hat C = \begin{pmatrix} 30 \\ 40 \\ 80 \end{pmatrix}$.
The constraints can be set in the following way
- For the seats $$ x_{4p} + x_{3p} \leq 500 + 10 x_w $$
- For the legs $$ 4 x_{4p} + 3 x_{3p} \leq 200 + 20 x_w $$
- For the backs $$ x_{4p} \leq 100 + 2 x_w $$
- Minimum number of chairs produced $$ x_{4p} + x_{3p} \geq 1000 $$
We can now define the coefficient matrix $A = \begin{pmatrix} 1 & 1 & -10 & \\ 4 & 3 & -20 & \\ 1 & 0 & -2 & \\ - 1 & - 1 & 0 & \end{pmatrix} $ and $B = \begin{pmatrix} 500 \\ 200 \\ 100 \\ -1000 \end{pmatrix}$.
R implementation and solution
We are now ready to implement this is in R. There are many different packages which can solve this kind of problems but my favourites are lpSolve and lpSolveAPI which is a kind of API built on top of lpSolve. I will use both.
A nice feature about the lpSolve package is that you can specify the direction of the constraints. Indeed in our case the last constraint of minimum number of chairs produced does not fit in with the mathematical definiton of the problem that we gave in the previous paragraph. Here we can either change the signs (and therefore the inequality direction) or specify the inequality direction in lpSolve. I’ll do this second way.
We can set that all the variables should be integers by setting the argument “all.int=TRUE” in the lpSolve::lp function. Of course, lpSolve can work with both integers and real numbers.
It’s also particularly important to check the status at the end of the execution: if it is 0, then a solution has been found but if it is 2 then this means that there is no feasible solution.
 
Hi,
ReplyDeletewith the intpoint package you can solve lp problemas graphically in two dimensiones, and you can compare the simplex with the interior point (karmarkar) method
https://www.rdocumentation.org/packages/intpoint/versions/1.0
Hello! Thanks for reading and for the package suggestion!
DeleteI appreciate your effort. Keep motivating us. For the persons who want to join any institute for computer software training courses can join ZENITECH.
ReplyDeleteThanks for such a great article here. I was searching for something like this for quite a long time and at last, I’ve found it on your blog. It was definitely interesting for me to read about their market situation nowadays.angularjs best training center in chennai | angularjs training in velachery | angularjs training in chennai | angularjs training in omr
ReplyDeleteThanks for Sharing a very Informative Post and I Must say its really helpful for us.your blog helps me to know more about the course.
ReplyDeletePython Course in Delhi
Thanks for Sharing a very Informative Post and I Must say its really helpful for.your blog helps me to know more about the course.
Python Course in Noida
Thanks for Sharing a very Informative Post and I Must say its really helpful for.your blog helps me to know more about the course.
Python Course in Gurgaon
Thanks for sharing such a great blog Keep posting..
ReplyDeletePython Training
Python Course
Situs Poker Terbaik dan Terpercaya...
ReplyDeleteSilakan kunjungi situs kami
https://www.hobiqq.pw
BandarQ
BandarQ Online
Agen BandarQ
BandarQ Indonesia
Agen BandarQ Indonesia
Agen BandarQ Online Indonesia
Awesome post. You Post is very informative. Thanks for Sharing.
ReplyDeleteR programming training in Noida
This comment has been removed by the author.
ReplyDeleteI was surfing net and fortunately came across this site and found very interesting stuff here. Its really fun to read. I enjoyed a lot. Thanks for sharing this wonderful information.
ReplyDeletecs作业
Thanks! You folks help me and my student A LOT!
ReplyDeleteThanks for this informative blog.
ReplyDelete- Casino India
This article is a great article that I have seen in my python programming career so far.
ReplyDeletehire python developers in US
Learn Trending Coding Languages like Java, C++, HTML, Python, Android from here for free !
ReplyDeleteIntelliMindz is the best IT Training in Bangalore with placement, offering 200 and more software courses with 100% Placement Assistance.
ReplyDeleteR Programming Online Course
R Programming Course in Bangalore
R Programming Training in Chennai
Queen Casino | Komono Casino
ReplyDeletePlay at Queen Casino in Komono, ON. クイーンカジノ Enjoy 24/7 friendly customer bk8 service and online slot 카지노 play! Rating: 5 · 7 votes · Free · Game
nice blog I got more knowledge about programing thank you so much for sharing programing language knowledge. and anyone want learn data science course in mumbai visit here
ReplyDeleteAmazing Blog. thank you for sharing this information. Data analytics course is an interdisciplinary field that combines elements of mathematics, statistics, computer science, and domain knowledge to extract insights and knowledge from structured and unstructured data.
ReplyDeleteGet ready to enter a new era of mobile brilliance as OnePlus unveils its latest flagship masterpiece, the OnePlus 12. A testament to relentless innovation and unwavering dedication to crafting exceptional user experiences, the OnePlus 12 is poised to redefine the smartphone landscape. Prepare to be captivated by its cutting-edge technology, unparalleled performance, and mesmerizing visuals.
ReplyDeleteA Performance Juggernaut
At the heart of the OnePlus 12 lies the Qualcomm Snapdragon 8 Gen 3 processor, a veritable powerhouse that elevates mobile performance to unprecedented heights. This octa-core beast unleashes raw power, ensuring seamless multitasking, effortless handling of demanding applications, and an unparalleled gaming experience. Whether you’re a multitasking maestro, a graphics aficionado, or simply seeking the smoothest, most responsive smartphone experience, the OnePlus 12 is your answer.
Une entrée très intéressante pleine d’informations inspirantes. Veuillez également visiter le Gowork FR Blog
ReplyDeleteAre you looking to invest in invoice discounting minimum investment? Falcon makes it easy with low minimum investment options. Get started today with Falcon’s simple and flexible invoice discounting solutions. Ideal for businesses seeking to boost cash flow without big upfront costs.
ReplyDeleteSupport a better future with our NGO in Mathura. We help those in need by providing education, healthcare, and basic needs. Join us in making a positive change in the lives of many. Every small effort counts. Let's build a stronger, caring community together.
ReplyDeleteEngineering4India helps you find the best engineering colleges in Punjab. Get details on top colleges, courses, and admission requirements. Choose the right college for a successful engineering career. Explore Punjab's leading institutions with Engineering4India and make the best choice easily.
ReplyDeleteVelthrad Consultants helps you set up your business in DIFC easily. Our experts guide you through all steps, from paperwork to approvals. Get quick and reliable service for your DIFC business setup consultant. Contact Velthrad for hassle-free assistance today.
ReplyDeleteAre you looking to master Python programming and enhance your career prospects? Join the Python Course in Gurgaon at APTRON Gurgaon, a top-tier training institute renowned for delivering quality education and hands-on experience. Whether you're a beginner or an experienced programmer, this course is tailored to meet the needs of every aspiring developer.
ReplyDeleteHi,
ReplyDeleteGreat Blog! Your insights are spot on Linear programming in R. I especially appreciate your points. You've done your research. Keep up the excellent work! Looking forward to reading more from you.
Here is sharing Machine Learning Online Training related stuff that may be helpful to you.
Machine Learning Training
Website Developer in Janakpuri
ReplyDeleteJanakpuri’s Leading Website Developer Services
Custom Website Developer in Janakpuri
Skilled Web Development in Janakpuri
Affordable Web Developer Near Janakpuri
Full-Service Website Developer in Janakpuri
Professional Web Development in Janakpuri
Expert Website Designer in Janakpuri
Janakpuri Website Development Specialists
Hi,
ReplyDeleteGreat Article! Your insights are spot on Linear programming in R. I especially appreciate your points. You've done your research. Keep up the excellent work! I'm looking forward to reading more from you.
Here is information about the R Programming for Data Science Online Training related stuff that may be helpful to you.
R Programming for Data Science Training
Get EB1A green card help for tech professionals at EB1A Experts. We guide you step by step and make the process simple. Get your green card fast with expert support. Visit our website today.
ReplyDeletePrevent thread damage and metal fusion with anti seize high tech paste from Spleca Solutions. Trusted quality for harsh industrial settings.
ReplyDeleteYour blog is friendly and warm.Struggling with your research paper? Our expert assignment help offers tailored guidance to ensure your success. Get started today for top-notch support!Need assistance with your research paper? Our dedicated team provides expert help to enhance your writing and boost your grades. Contact us for reliable support!Achieve academic excellence with our research paper assignment help. Our experienced writers are here to guide you through every step of the writing process.
ReplyDeleteHi,
ReplyDeleteGreat Article! Your insights are spot on in Increditools.The Beginner programmer . I especially appreciate your points. You've done your research. Keep up the excellent work! I'm looking forward to reading more from you.
Here is Informatica Admin Training related stuff that may be helpful to you.
Looking to take the CMAT exam? KollegeApply is a helpful platform. It provides detailed insights into registration, exam pattern, important dates, and a list of top MBA colleges accepting CMAT scores — perfect for management aspirants.
ReplyDelete