ME4104 Final Oral Presentation

MN26 Development of Technology Enhanced Contents for ME4262 Automation in Manufacturing
Tan Guo Xiang
A0086024L
1. Introduction
2. Literature Review
3. Analysis and Review of Tool Used
4. Implementation Details
5. Conclusion
6. Recommendation of Future Work
Contents
Introduction
Introduction
Literature Review
Analysis and Review of Tools
Implementation Details
Conclusion
Recommendation for Future Study


Increase Mobile Adoption Rate
Mobile Phone Penetration rate from 2003 – 2014 from Infocomm Development Authority of Singapore
Adoption of mobile devices by students to study increase in the near future.

Problem: Non-Responsive Web Content


Problem: Administrative Overhead with Polling System
Polls provide lecturers with a shorter feedback loop during teaching.
However, commercial solutions require each student to be issued with a keypad over the course of the semester.
Problem: Difficulty in Visualizing Concepts

Videos demonstrating the concept clearly are hard to find online and tend to be meant as commercial advertisement.
Image Source: ME4262 Lecture 2 Notes
Literature Review
Introduction
Literature Review
Analysis and Review of Tools
Implementation Details
Conclusion
Recommendation for Future Study
Massive Open Online Courses
- Massive Open Online Courses are courses held online and is open to anyone in the world.
- Students in under developed countries are entitled to high quality education content as their peers in more developed countries.
- Examples are Khan Academy which focuses on primary school education while Coursera focuses on University level.
Massive Open Online Courses

Image Source: https://www.khanacademy.org/
Massive Open Online Courses

Image Source: https://www.khanacademy.org/
HTML5

- HTML is a markup language created 18 years ago which did not cater to dynamic media content.
- HTML5 was standardized in 2014 adding video and audio elements.
- HTML is currently the adopted language of the web browser to display content.
Image Source: https://w3.org/
JavaScript
- JavaScript is a dynamic computing language most commonly used in web browsers.
- Using JavaScript, developers can create dynamic content that responds to user actions.
- Allows asynchronous retrieval of data.

Image Source: http://upload.wikimedia.org/wikipedia/commons/6/6a/JavaScript-logo.png
Responsive Web Design

Image Source: http://blog.froont.com/9-basic-principles-of-responsive-web-design/
Responsive Web Design
Image Source: http://blog.froont.com/9-basic-principles-of-responsive-web-design/

QR Code

- First used in the Japanese automotive industry to keep track of components in the process line.
- QR codes are prominently used for marketing purposes where links to website are stored in the QR code reducing friction for users.
Analysis and Review of Tools
Introduction
Literature Review
Analysis and Review of Tools
Implementation Details
Conclusion
Recommendation for Future Study
Foundation Framework
- Foundation is a open sourced framework developed by ZURB in 2011.
- Aimed at making responsive web design easy to implement for developers.
- Provide default break points for common screen sizes.

Image Source: http://foundation.zurb.com/
Foundation Framework
Image Source: http://foundation.zurb.com/


Ruby on Rails
Image Source: http://rubyonrails.org
- Ruby on Rails is a web application development framework written in the Ruby programming language.
- Allow users to quickly create web applications without worrying about the many layers of the internet.
- Known for its simplicity and ease of use.

Ruby on Rails

SOLIDWORKS Motion Study
- SOLIDWORKS Motion is one of the simulation tools that comes along with SOLIDWORKS.
- It allows users to run motion simulation on their design in an environment with real world parameters and limitations.
- Addition of components such as motors, gravity and contact bodies make it easy for the user to create a simulation for their visualization needs.
Implementation Details
Introduction
Literature Review
Analysis and Review of Tools
Implementation Details
Conclusion
Recommendation for Future Study
Responsive Dynamic Graphs


Responsive Dynamic Graphs
Responsive Dynamic Graphs

Implementation Details of Graphs
1. Including necessary libraries
2. Implementing the layout
3. Implementation of solutions based on the requirements of the question
4. Making graphs dynamic by responding to user input
Including necessary libraries
<script src='../../d3.min.js'></script>
<script src='../../nv.d3/nv.d3.min.js'></script>
<script src='../../jquery-2.1.1.min.js'></script>
<script src='../../foundation-5.3.0/js/foundation.min.js'></script>
<script src='../../foundation-5.3.0/js/vendor/modernizr.js'></script>
<script src='../../jquery-ui-1.11.1/jquery-ui.min.js'></script>
<script src='../../jquery.ui.touch-punch.min.js'></script>
<meta content='width=device-width, initial-scale=1.0' name='viewport'>
<script> Tag
<meta> Tag
Implementing the Layout

Implementing the Layout

Implementing the equations
<script>
jQuery(function($) {
function calculateVariableCostofLabour(labourCost, labourOverhead, productionRate) {
return (labourCost * (100 + labourOverhead) / 100 / productionRate);
}
function calculateUniformAnnualCost(machineCost, maintenanceCost, salvageValue, rateOfReturn, serviceLife) {
var capitalReturnFactor = calculateCapitalReturnFactor(rateOfReturn, serviceLife).toFixed(5);
var sinkingFundFactor = calculatorSinkingFundFactor(rateOfReturn, serviceLife).toFixed(5);
return ((machineCost * capitalReturnFactor) + maintenanceCost - (salvageValue * sinkingFundFactor));
}
function calculateUniformAnnualCostWithMachineOverhead(uniformAnnualCost, machineOverheadRate) {
machineOverheadRate = machineOverheadRate / 100;
return (uniformAnnualCost * (1 + machineOverheadRate));
}
function calculateCapitalReturnFactor(rateOfReturn, serviceLife) {
rateOfReturn = rateOfReturn * 0.01;
return ((rateOfReturn * Math.pow((rateOfReturn + 1), serviceLife)) / (Math.pow((rateOfReturn + 1), serviceLife) - 1));
}
function calculateLabourCostPerUnit(labourRate, productionRate) {
return (labourRate / productionRate);
}
function calculateVariableCost(labourCost, materialCost) {
return (labourCost + materialCost);
}
function calculateVariableCostOvertime(labourCost, materialCost, labourOvertimeRate) {
return ((labourCost * (1 + (labourOvertimeRate / 100))) + materialCost);
}
function calculateElecricityRate(electricityConsumption, powerConsumption, productionRate) {
return (electricityConsumption * powerConsumption / productionRate);
}
function calculateOvertimeCost(cost, variableCostWithOverhead, variableCostOvertimeWithOverhead, productionRate, projectedSales, maximumProductionCapcity) {
var currentSales = productionRate * 8 * 5 * 50;
var salesDifference = projectedSales - currentSales;
projectedSales = (projectedSales >= maximumProductionCapcity) ? maximumProductionCapcity : projectedSales;
if (!drawOvertime || salesDifference < 0) {
var variableCost = variableCostWithOverhead * projectedSales
} else {
var variableCost = (variableCostWithOverhead * currentSales) + (variableCostOvertimeWithOverhead * salesDifference);
}
return variableCost + cost;
}
function calculateRentPerAnnum(monthlyRent, factorySpace) {
return (monthlyRent * 12 * factorySpace);
}
function calculatorSinkingFundFactor(rateOfReturn, serviceLife) {
rateOfReturn = rateOfReturn * 0.01;
return (rateOfReturn/(Math.pow((1 + rateOfReturn), serviceLife) - 1));
}
function calculateRevenue(revenue, numberOfUnits) {
return (revenue * numberOfUnits);
}
function calculateCost(cost, variableCost, number_of_units) {
return Number((cost + (variableCost * number_of_units)).toFixed(2));
}
function roundUp(x){
var y = Math.pow(10, parseInt(x).toString().length - 1);
x = (x / y);
x = Math.ceil(x);
x = x * y;
return x;
}
Drawing the Graphs
var lowerBound = 0;
var upperBound = 0;
var upperBoundMax = 0;
var slider;
var $slider = $('#range-slider');
var drawOvertime = false;
var ProfitBreakEvenGraph = {
_init: function() {
var widget = this;
nv.addGraph(function() {
var chart = nv.models.lineChart()
.margin({left: 80, right: 40}) //Adjust chart margins to give the x-axis some breathing room.
.useInteractiveGuideline(false)
.showLegend(true) //Show the legend, allowing users to turn on/off line series.
.showYAxis(true) //Show the y-axis
.showXAxis(true) //Show the x-axis
;
chart.xAxis //Chart x-axis settings
.axisLabel("Annual Output (units)")
chart.yAxis //Chart y-axis settings
.axisLabel('Cost / Revenue ($)')
/* Done setting the chart up? Time to render it!*/
var myData = widget._generateLineData(false);
d3.select('#chart svg') //Select the <svg> element you want to render the chart in.
.datum(myData) //Populate the <svg> element with chart data...
.call(chart); //Finally, render the chart!
//Update the chart when window resizes.
nv.utils.windowResize(function() { chart.update() });
d3.select('.draw-overtime').on('click', function() {
drawOvertime = !drawOvertime;
if (drawOvertime) {
d3.select(this).text('Remove Overtime');
d3.select(this).attr('class', 'alert button radius tiny draw-overtime');
d3.select('.a-profit-header').text('Method A Profit Based on Projected Sales With Overtime');
d3.select('.b-profit-header').text('Method B Profit Based on Projected Sales With Overtime');
} else {
d3.select(this).text('Draw Overtime');
d3.select(this).attr('class', 'success button radius tiny draw-overtime');
d3.select('.a-profit-header').text('Method A Profit Based on Projected Sales');
d3.select('.b-profit-header').text('Method B Profit Based on Projected Sales');
}
widget._updateChart(chart, false)
});
d3.selectAll('input').each(function() {
d3.select(this).on('input', function() {
widget._updateChart(chart, false);
$rangeInputValue.text(lowerBound + '-' + upperBound);
})
});
$rangeInputValue = $('#range-input-value');
slider = $slider.slider({
range: true,
min: lowerBound,
max: upperBoundMax,
values: [lowerBound, upperBound],
slide: function(event, ui) {
lowerBound = ui.values[0];
upperBound = ui.values[1];
widget._updateChart(chart, true);
$rangeInputValue.text(lowerBound + '-' + upperBound);
}
});
$rangeInputValue.text(lowerBound + '-' + upperBound);
return chart;
});
},
_updateChart: function(chart, isSlider) {
var myData = this._generateLineData(isSlider);
d3.select('#chart svg')
.datum(myData)
.call(chart)
},
Making Graphs Dynamic

Making Graphs Dynamic
Making Graphs Dynamic
d3.selectAll('input').each(function() {
d3.select(this).on('input', function() {
widget._updateChart(chart, false);
$rangeInputValue.text(lowerBound + '-' + upperBound);
})
});
POLLMe - On Demand Web Based Polling Application
Demo
POLLMe - On Demand Web Based Polling Application

Animation for Manufacturing Processes

Animation for Manufacturing Processes
Animation for Manufacturing Processes

Animation for Manufacturing Processes
Implementation Details

Implementation Details

Implementation Details



Implementation Details


Implementation Details


Conclusion
Introduction
Literature Review
Analysis and Review of Tools
Implementation Details
Conclusion
Recommendation for Future Study
- Technology enabled learning comes with many benefits that can help students learn better and it is crucial that educators continue to seek out new opportunities.
- Responsive and Dynamic Break Even Graphs.
- POLLMe - On demand polling web application for lectureres.
- Better visualization with 3D animations.
Conclusion
Recommendation for Future Study
Introduction
Literature Review
Analysis and Review of Tools
Implementation Details
Conclusion
Recommendation for Future Study
- Test out the new content and obtain feedback from students to see if they have benefited from the new content.
- POLLMe can applied to many modules. It would be good that other users can pioneer it and provide feedback based on the usage. The application can then be developed further.
Recommendation for Further Work
Thank You!
Questions?
FYP Final Presentation
By tgxworld
FYP Final Presentation
- 1,913