Tuesday, 16 April 2013

TOGAF

TOGAF®, an Open Group Standard, is a proven enterprise architecture methodology and framework used by the world's leading organizations to improve business efficiency. It is the most prominent and reliable enterprise architecture standard, ensuring consistent standards, methods, and communication among enterprise architecture professionals.TOGAF helps practitioners avoid being locked into proprietary methods, utilize resources more efficiently and effectively, and realize a greater return on investment.[1]

One of the goals of The Open Group Architecture Forum is to provide a forum within which both customer and vendor organizations can exchange feedback and experience in the use of TOGAF.

First published in 1995, TOGAF was based on the US Department of Defence Technical Architecture Framework for Information Management (TAFIM). From this sound foundation, The Open Group Architecture Forum has developed successive versions of TOGAF at regular intervals and published them on The Open Group public web site. (link) [2]

You can start by reading the case studies which shows TOGAF in use in a variety of situations. [3]
It is important to emphasize that no case study can provide a complete blueprint for how another organization should go about using TOGAF. All organizations are different, and each organization should understand what TOGAF has to offer, and adopt and adapt the parts that are useful for its needs.

References
1. The Open Group
2. Publications
3. Case Studies

Monday, 15 April 2013

Multicore Processors – Then , Now And Beyond..

 

galaxy-s4-htc-one-crystal-balldownload (1)download (2)download (3)

The day when HTC first released the windows pocket pc circa 2003 (XDA II) !!..I still remember fiddling around with Windows CE and .Net Compact Framework. I had even implemented a double buffering mechanism for rendering sprites on Windows Mobile (The complete source c0de of which is still available on my blog). The computing power on phones these days put all those things to shame. I now play GTA 3 on my iPhone effortlessly!!. Back in 2003, I had to buy a decent graphics card [PCI Express] for my PC in order to be able to support the massive area this game rendered as and when you explored the city..

Now, the smart phones Samsung Galaxy S4 V/s the HTC One is the battle for the quad core + category of smartphones today ( at the time of publishing this article.) [17].  Multicore processor products  today also include Apple’s iPad 3 with quad core for graphics and dual core for processing, XBox with 3 IBM Xenon Cores, Microsoft Surface with Quad-core NVIDIA Tegra 3 etc to name a few.

Why are multicore processors becoming so common these days ?. What is the future beyond multi core processors ?

Lets take a look at a bit of history on multicore processors now. From early 2007 onwards, we knew that Moore's law [1] was coming close to an end and that the era of parallel programming had begun to take shape with transistors not necessarily doubling but we began to see more cores instead. Now, why did this happen ?, Why didn’t the transistor count double on the same chip ?.
moores_law_chart  

As the microprocessor manufacturers tried to improve processor performance by adding transistors and logic to their CPU’s and increase clock frequencies, so did rise the complexity and the cost of manufacturing. The semiconductor industry had predicted that the clock rates would reach 12GHz by 2013.Take the Intel’s Pentium Processor for instance. The Intel's troubled Pentium processor so clearly illustrated, the laws of nature and diminishing returns were catching up to the Law of Moore. The complex logic required to implement execution pipelines and other throughput techniques required lots of expensive silicon real estate and were highly prone to post-manufacture errors, according to the SciDAC report.[2]

Let’s look at another example, Intel’s Tejas Processor – which was getting built as the successor to it’s Pentium 4 class of processors. As they tried to increase the clock speed, the power consumption started to increase to 100 watts(TDP). This was a big issue, since power draws more ampere as they are pushed to multi-gigahertz clock speeds, eating up wattage and becoming difficult to cool with conventional heat-sink technology. A processor with this specification was not just viable to produce.[3]

It was clear to chip makers that it was becoming exceedingly impractical (and sometimes impossible) to verify all that complex logic; the cost of these designs was reaching into the hundreds of millions of dollars. The SciDAC report cited "A View of the Parallel Computing Landscape,” a paper published in 2006 by a team of computer scientists from Lawrence Berkeley National Laboratory (LBNL) and the University of California (UC), Berkeley. The Berkeley scientists offered the following solutions for these processor issues: [2]

Power: Parallelism is an energy-efficient way to achieve performance. Many simple cores offer higher performance per unit area for parallel codes than a comparable design employing smaller numbers of complex cores.

Design Cost: The behaviour of a smaller, simpler processing element is much easier to predict within existing electronic design-automation workflows and more amenable to formal verification. Lower complexity makes the chip more economical to design and produce.

Defect Tolerance: Smaller processing elements provide an economical way to improve defect tolerance by providing many redundant cores that can be turned off if there are defects.[2]

Soon after, Chip manufacturer’s like Intel were clear from their experiments / experiences and tests that the future of computing was heading to multi-cores. Paul Otellini, Intel’s President announced (circa 2004)that “All of our microprocessor development going forwards is multi-core. We’ll add multi-cores into all products – notebooks, desktops and servers.”. The idea to parallelize existing tasks or to divide up multiple tasks to gain efficiency had caught up. Microsoft was keen to capitalize on multicore technology and it went ahead with this strategy on big scale shipping Windows code named Longhorn (Vista) operating system which supported it.[3]

With Intel, This direction of multi-core eventually development led to the birth of the Arrandale range of processors. Arrandale is the codename for a two core mobile processor used on the Intel 5 series chipset based platforms codenamed Calpella. Arrandale is comprised of a 32nm processor core and 45nm graphics & memory controller integrated in a multi-chip package. Arrandale is part of the family of 32nm processors codename Westmere based on Intel microarchitecture codename Nehalem and targeted for production in 4Q'09, with availability in 1Q'10. Check this table below to see the TDP’s of the Arrandale range of processors. [4]

Product Name                        Status    Embedded                     Recommended
Options Available Max TDP Customer Price
-----------------------------------------------------------------------------------------------
Intel® Pentium® Processor U5600 Launched No 18 W N/A
(3M Cache, 1.33 GHz)
Intel® Pentium® Processor U5400 Launched No 18 W N/A
(3M Cache, 1.20 GHz)
Intel® Pentium® Processor P6300 Launched No 35 W TRAY: $134.00
(3M Cache, 2.27 GHz)
Intel® Pentium® Processor P6200 Launched No 35 W TRAY: $134.00
(3M Cache, 2.13 GHz)
Intel® Pentium® Processor P6100 Launched No 35 W TRAY: $134.00
(3M Cache, 2.00 GHz)
Intel® Pentium® Processor P6000 Launched No 35 W N/A
(3M Cache, 1.86 GHz)
Intel® Core™ i7-680UM Processor Launched No 18 W N/A
(4M Cache, 1.46 GHz)
Intel® Core™ i7-660UM Processor Launched No 18 W TRAY: $289.00
(4M Cache, 1.33 GHz)
Intel® Core™ i7-660UE Processor Launched Yes 18 W TRAY: $301.00
(4M Cache, 1.33 GHz)
Intel® Core™ i7-660LM Processor Launched No 25 W N/A
(4M Cache, 2.26 GHz)
Intel® Core™ i7-640UM Processor Launched No 18 W N/A
(4M Cache, 1.20 GHz)
Intel® Core™ i7-640M Processor Launched No 35 W N/A
(4M Cache, 2.80 GHz)
Intel® Core™ i7-640LM Processor Launched No 25 W N/A
(4M Cache, 2.13 GHz)
Intel® Core™ i7-620UM Processor Launched No 18 W N/A
(4M Cache, 1.06 GHz)
Intel® Core™ i7-620UE Processor Launched Yes 18 W TRAY: $289.00
(4M Cache, 1.06 GHz)
Intel® Core™ i7-620M Processor Launched Yes 35 W TRAY: $332.00
(4M Cache, 2.66 GHz)
Intel® Core™ i7-620LM Processor Launched No 25 W TRAY: $300.00
(4M Cache, 2.00 GHz)
Intel® Core™ i7-620LE Processor Launched Yes 25 W TRAY: $311.00
(4M Cache, 2.00 GHz)
Intel® Core™ i7-610E Processor Launched Yes 35 W TRAY: $320.00
(4M Cache, 2.53 GHz)
Intel® Core™ i5-580M Processor Launched No 35 W N/A
(3M Cache, 2.66 GHz)
Intel® Core™ i5-560UM Processor Launched No 18 W N/A
(3M Cache, 1.33 GHz)
Intel® Core™ i5-560M Processor Launched No 35 W N/A
(3M Cache, 2.66 GHz)
Intel® Core™ i5-540UM Processor Launched No 18 W TRAY: $250.00
(3M Cache, 1.20 GHz)
Intel® Core™ i5-540M Processor Launched No 35 W TRAY: $257.00
(3M Cache, 2.53 GHz) BOX : $269.00
Intel® Core™ i5-520UM Processor Launched No 18 W N/A
(3M Cache, 1.06 GHz)
Intel® Core™ i5-520M Processor Launched Yes 35 W TRAY: $225.00
(3M Cache, 2.40 GHz)
Intel® Core™ i5-520E Processor Launched Yes 35 W TRAY: $224.00
(3M Cache, 2.40 GHz)
Intel® Core™ i5-480M Processor Launched No 35 W N/A
(3M Cache, 2.66 GHz)
Intel® Core™ i5-470UM Processor Launched No 18 W N/A
(3M Cache, 1.33 GHz)
Intel® Core™ i5-460M Processor Launched No 35 W N/A
(3M Cache, 2.53 GHz)
Intel® Core™ i5-450M Processor Launched No 35 W TRAY: $210.00
(3M cache, 2.40 GHz)
Intel® Core™ i5-430UM Processor Launched No 18 W N/A
(3M cache, 1.20 GHz)
Intel® Core™ i5-430M Processor Launched No 35 W N/A
(3M Cache, 2.26 GHz)
Intel® Core™ i3-390M Processor Launched No 35 W TRAY: $225.00
(3M Cache, 2.66 GHz)
Intel® Core™ i3-380UM Processor Launched No 18 W TRAY: $250.00
(3M Cache, 1.33 GHz)
Intel® Core™ i3-380M Processor Launched No 35 W TRAY: $225.00
(3M Cache, 2.53 GHz)
Intel® Core™ i3-370M Processor Launched No 35 W TRAY: $210.00
(3M cache, 2.40 GHz)
Intel® Core™ i3-350M Processor Launched No 35 W TRAY: $225.00
(3M Cache, 2.26 GHz)
Intel® Core™ i3-330UM Processor Launched No 18 W N/A
(3M cache, 1.20 GHz)
Intel® Core™ i3-330M Processor Launched No 35 W TRAY: $225.00
(3M Cache, 2.13 GHz)
Intel® Core™ i3-330E Processor Launched Yes 35 W TRAY: $177.00
(3M Cache, 2.13 GHz)
Intel® Celeron® Processor U3600 Launched No 18 W N/A
(2M Cache, 1.20 GHz)
Intel® Celeron® Processor U3405 Launched Yes 18 W TRAY: $134.00
(2M Cache, 1.07 GHz)
Intel® Celeron® Processor U3400 Launched No 18 W N/A
(2M Cache, 1.06 GHz)
Intel® Celeron® Processor P4600 Launched No 35 W TRAY: $86.00
(2M Cache, 2.00 GHz)
Intel® Celeron® Processor P4505 Launched Yes 35 W TRAY: $86.00
(2M Cache, 1.86 GHz)
Intel® Celeron® Processor P4500 Launched Yes 35 W TRAY: $86.00
(2M Cache, 1.86 GHz)

 

Well, Intel had by then successfully reduced the size of it’s processors to 32nm in order to gain efficiency on the Core i3, i5 & i7 multicore processors. All of them gave good results and are mostly seen on many laptops today including the Mac. [5]

And now, with the Ivy Bridge Chip [6], Intel has released a set of powerful and power efficient processors to be produced from it’s 22nm process built with the revolutionary 3-D Tri-gate technology [7]. With this triple-gate transistor [9], Intel has reinvented the technology that powers every computing device -- indeed, all of today's electronics -- and in doing so, has broken the size restrictions currently inherent in today's microprocessors. The breakthrough is not so much the Tri-Gate technology, which was first unveiled by Intel in 2002. What's significant is that the company has developed a process for mass-producing the circuits in a process that's 22 billionths of a meter thick, about a third thinner than the 32-nm process it uses for Sandy Bridge microprocessor architecture. [8] (a human hair is about 100,000-nm thick)

According to an Intel announcing the news [10], Intel's 3-D Tri-Gate transistors will operate at lower voltage and with lower leakage. "The additional control enables as much transistor current flowing as possible when the transistor is in the 'on' state (for performance), and as close to zero as possible when it is in the 'off' state (to minimize power), and enables the transistor to switch very quickly between the two states." With performance increases according to claims of as much as 37 percent compared with 32-nm planar-transistor devices and consuming less than half the power, the new parts will be highly suited to small handheld devices such as smartphones, medical devices, media players, portable gaming systems and anything that can benefit from the ability to switch quickly between high performance and low power consumption. In essence, everything these days.[11]

This capability will no doubt benefit Microsoft Surface for Windows 8, a full-featured tablet that's built around Ivy Bridge. Perhaps more impressive is the Surface for Windows RT, which will incorporate Nvidia Tegra 3 quad-core processor. Technically considered to be a system-on-chip, the Tegra 3 casts four 1.4GHz Cortex A9 cores on the die along with a fifth low-power core that can perform all functions during device standby. The Tegra 3 system-on-chip also includes a GeForce GPU with as many as 12 graphics processor cores and supports a maximum resolution of 2,560 x 1,600 pixels. Google’s Nexus 7 tablet also will feature the Tegra 3.[13]


Intel’s MIC (Many Integrated Core) [12]  puts 32 cores on a single chip and makes them available for highly parallel applications in high-performance computing such as those for climate simulation, energy research and genetic analysis. According to Intel, Developers applications written in standard programming languages can still take advantage of these extremely high levels of application performance. Code-named Knights Ferry, the Intel MIC boards are even being experimented with to run applications that use cloud-based ray tracing, a compute-intensive light rendering technique used in video games that's currently limited to dedicated, high-end graphics processors. This allows laptops, smartphones and other lightweight computing devices to experience sophisticated games without a heavy GPU. Once such a technology becomes mainstream, tasks that were once the province of supercomputers will be available from the average smartphone.


Now, Let’s take a look at how ARM Processors having been shaping the mobile [14] / hand-held low powered devices which noticeably starting from the iPhone in 2007. Apple's A4/A5/A5X, Nvidia's Tegra, Samsung's Exynos and Texas Instruments' OMAP products all integrate ARM processors into what is known as a system-on-a-chip (SoC). SoCs merge many of the essential components of a computer (such as the CPU, RAM, ROM etc.) on a single chip which allows devices that utilize them to be lightweight and compact. These SoCs have gone on to be implemented in blockbuster products such as Apple's iPhone and iPad or Samsung's series of Galaxy phones. ARM's presence as the CPU and architecture of choice on many mobile devices cannot be understated as estimates put their numbers in the billions.


What’s Qualcomm brewing?, Qualcomm considers Snapdragon [18] a "platform" for use in smartphones, tablets, and hand helds.Snapdragon is a family of mobile system on chips (SoC). The original Snapdragon CPU, dubbed Scorpion, is Qualcomm's own design. It has many features similar to those of the ARM Cortex-A8 core and it is based on the ARM v7 instruction set, but theoretically has much higher performance for multimedia-related SIMD operations.The successor to Scorpion, found in S4 Snapdragon SoCs is named Krait and has many similarities with the ARM Cortex-A15 CPU and is also based on the ARMv7instruction set.All Snapdragon processors contain the circuitry to decode high-definition video (HD) resolution at 720p or 1080p depending on the Snapdragon chipset. Adreno, the company's proprietary GPU technology, integrated into Snapdragon chipsets (and certain other Qualcomm chipsets) is Qualcomm's own design, using assets the company acquired from AMD. The Adreno 225 GPU in Snapdragon S4 SoCs adds support for DirectX 9/Shader Model 3.0 which makes it compatible with Microsoft's Windows 8.Compared to System on chips from many competitors, Snapdragon SoCs have been unique in that they have had the antenna for cellular communication on-die. That is, they do not require a separate external antenna on the PCB. Since Snapdragon S4, the majority of S4 SoCs also features on-die Wi-Fi, GPS/GLONASS and Bluetooth basebands. This integration reduces the complexity and cost of the final design for the OEM. It also has the advantage of benefiting from advancements made in the manufacturing process, for example 28 nm in most S4 SoCs, thus providing antennas and other dedicated circuitry with lower power characteristics than external chips manufactured with older processes.


AMD—unable to mimic this success in more recent years, has shifted their focus towards both enthusiast and budget-oriented system configurations. As a result, AMD is considered to be a viable alternative to Intel. Their current offerings are flanked by the Phenom series processors and Fusion APU processors. The Fusion APU (AMD A-Series) is a relatively new platform (as of 2011 and on going) that attempts to merge high-end graphical capabilities on the same chip as the processor. This means if your work or play requires a powerful graphics card, then AMD can potentially offer a cost effective alternative.[16]


The Future Of ComputingQuantum Theory or Atomic Physics. My previous blog post and thoughts on the future of  nano-technology, it’s constraints and how the future could take shape with Quantum Theory (with respect to Computing).


References


1. Moore’s law
2. crn.com
3. Intel’s Tejas Processor
4. Arrandale
5. Benchmarks for products with Arandale

6. Ivy Bridge Chip
7. Making of the Intel Chip, 22nm / 3D Transistors , PDF

8. Pentium flaws aid Intel in Sandy Bridge
9. Intel’s 3D Transistors
10. Intel reinvents transistors using new 3-D structure
11. Intel’s 3-D Transistor explained
12. Intel MIC
13. NVIDIA Tegra 4
14. ARM – Cortex , 2007 Annual Report
15. Mobile Virtualization
16. Intel, AMD & ARM Processors – Comparison

17.
 Galaxy S4 Vs HTC One
18. Qualcomm Snapdragon Processors


All views expressed here are a study based on my interest and not biased towards a product or company. – Sudhir Murthy.  2013.

Karnataka Handbook–Govt. Of Karnataka

I came across this website of the Government of Karnataka which details on

  • Geography
  • Districts
  • Mines and Minerals
  • Water Resources
  • Tourism
  • Government
  • Citizen Services
  • and a Complete Handbook of Karnataka. (which imho, is very detailed and nice.)

  and it’s always nice to see that the website’s running on the Microsoft platform !!.

Saturday, 13 April 2013

JavaScript Cloth Simulation

http://codepen.io/anon/pen/khwqm
Take a look at the source c0d3 on the right in the link. Its there to be modified and try out different parameters. I’m posting the source below.  The author has it free to be re-used.
Check out more from the same guys at http://lonely-pixel.com/. There are some mind boggling examples..

/*
Copyright (c) 2013 lonely-pixel.com, Stuffit at codepen.io (http://codepen.io/stuffit)

View this and others at http://lonely-pixel.com

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
*/

document.getElementById('close').onmousedown = function(e) {
e.preventDefault();
document.getElementById('info').style.display = 'none';
return false;
};

// settings

var physics_accuracy = 5,
mouse_influence = 20,
mouse_cut = 6,
gravity = 900,
cloth_height = 30,
cloth_width = 50,
start_y = 20,
spacing = 7,
tear_distance = 60;


window.requestAnimFrame =
window.requestAnimationFrame ||
window.webkitRequestAnimationFrame ||
window.mozRequestAnimationFrame ||
window.oRequestAnimationFrame ||
window.msRequestAnimationFrame ||
function(callback) {
window.setTimeout(callback, 1000 / 60);
};

var canvas,
ctx,
cloth,
boundsx,
boundsy,
mouse = {
down: false,
button: 1,
x: 0,
y: 0,
px: 0,
py: 0
};

window.onload = function() {

canvas = document.getElementById('c');
ctx = canvas.getContext('2d');

canvas.width = canvas.clientWidth;
canvas.height = 376;

canvas.onmousedown = function(e) {
mouse.button = e.which;
mouse.px = mouse.x;
mouse.py = mouse.y;
var rect = canvas.getBoundingClientRect();
mouse.x = e.clientX - rect.left,
mouse.y = e.clientY - rect.top,
mouse.down = true;
e.preventDefault();
};

canvas.onmouseup = function(e) {
mouse.down = false;
e.preventDefault();
};

canvas.onmousemove = function(e) {
mouse.px = mouse.x;
mouse.py = mouse.y;
var rect = canvas.getBoundingClientRect();
mouse.x = e.clientX - rect.left,
mouse.y = e.clientY - rect.top,
e.preventDefault();
};

canvas.oncontextmenu = function(e) {
e.preventDefault();
};

boundsx = canvas.width - 1;
boundsy = canvas.height - 1;

ctx.strokeStyle = 'rgba(222,222,222,0.6)';
cloth = new Cloth();
update();
};

var Point = function(x, y) {

this.x = x;
this.y = y;
this.px = x;
this.py = y;
this.vx = 0;
this.vy = 0;
this.pin_x = null;
this.pin_y = null;
this.constraints = [];
};

Point.prototype.update = function(delta) {

if (mouse.down) {

var diff_x = this.x - mouse.x,
diff_y = this.y - mouse.y,
dist = Math.sqrt(diff_x * diff_x + diff_y * diff_y);

if (mouse.button == 1) {

if(dist < mouse_influence) {
this.px = this.x - (mouse.x - mouse.px) * 1.8;
this.py = this.y - (mouse.y - mouse.py) * 1.8;
}

} else if (dist < mouse_cut) this.constraints = [];
}

this.add_force(0, gravity);

delta *= delta;
nx = this.x + ((this.x - this.px) * .99) + ((this.vx / 2) * delta);
ny = this.y + ((this.y - this.py) * .99) + ((this.vy / 2) * delta);

this.px = this.x;
this.py = this.y;

this.x = nx;
this.y = ny;

this.vy = this.vx = 0
};

Point.prototype.draw = function() {

if (this.constraints.length <= 0) return;

var i = this.constraints.length;
while(i--) this.constraints[i].draw();
};

Point.prototype.resolve_constraints = function() {

if (this.pin_x != null && this.pin_y != null) {

this.x = this.pin_x;
this.y = this.pin_y;
return;
}

var i = this.constraints.length;
while(i--) this.constraints[i].resolve();

this.x > boundsx ? this.x = 2 * boundsx - this.x : 1 > this.x && (this.x = 2 - this.x);
this.y < 1 ? this.y = 2 - this.y : this.y > boundsy && (this.y = 2 * boundsy - this.y);
};

Point.prototype.attach = function(point) {

this.constraints.push(
new Constraint(this, point)
);
};

Point.prototype.remove_constraint = function(lnk) {

var i = this.constraints.length;
while(i--) if(this.constraints[i] == lnk) this.constraints.splice(i, 1);
};

Point.prototype.add_force = function(x, y ) {

this.vx += x;
this.vy += y;
};

Point.prototype.pin = function(pinx, piny) {
this.pin_x = pinx;
this.pin_y = piny;
};

var Constraint = function(p1, p2) {

this.p1 = p1;
this.p2 = p2;
this.length = spacing;
};

Constraint.prototype.resolve = function() {

var diff_x = this.p1.x - this.p2.x,
diff_y = this.p1.y - this.p2.y,
dist = Math.sqrt(diff_x * diff_x + diff_y * diff_y),
diff = (this.length - dist) / dist;

if (dist > tear_distance) this.p1.remove_constraint(this);

var px = diff_x * diff * 0.5;
var py = diff_y * diff * 0.5;

this.p1.x += px;
this.p1.y += py;
this.p2.x -= px;
this.p2.y -= py;
};

Constraint.prototype.draw = function() {

ctx.moveTo(this.p1.x, this.p1.y);
ctx.lineTo(this.p2.x, this.p2.y);
};

var Cloth = function() {

this.points = [];

var start_x = canvas.width / 2 - cloth_width * spacing / 2;

for(var y = 0; y <= cloth_height; y++) {

for(var x = 0; x <= cloth_width; x++) {

var p = new Point(start_x + x * spacing, start_y + y * spacing);

y == 0 && p.pin(p.x, p.y);
y != 0 && p.attach(this.points[x + (y - 1) * (cloth_width + 1)]);
x != 0 && p.attach(this.points[this.points.length - 1]);

this.points.push(p);
}
}
};

Cloth.prototype.update = function() {

var i = physics_accuracy;

while(i--) {
var p = this.points.length;
while(p--) this.points[p].resolve_constraints();
}

i = this.points.length;
while(i--) this.points[i].update(.016);
};

Cloth.prototype.draw = function() {

ctx.beginPath();

var i = cloth.points.length;
while(i--) cloth.points[i].draw();

ctx.stroke();
};

function update() {

ctx.clearRect(0, 0, canvas.width, canvas.height);

cloth.update();
cloth.draw();

requestAnimFrame(update);
}


CSS
Notice the canvas element..



* {
margin: 0;
overflow:hidden;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
-o-user-select: none;
user-select: none;
}

body {
background:#333;
}

canvas {
background:#333;
width:100%;
height:376px;
margin:0 auto;
display:block;
}

#info {
position:absolute;
left:-1px;
top:-1px;
width:auto;
max-width:380px;
height:auto;
background:#f2f2f2;
border-bottom-right-radius:10px;
}

#top {
background:#fff;
width:100%;
height:auto;
position:relative;
border-bottom:1px solid #eee;
}

p {
font-family:Arial, sans-serif;
color:#666;
text-align:justify;
font-size: 16px;
margin:10px;
}

a {
font-family:sans-serif;
color:#444;
text-decoration:none;
font-size: 20px;
}

#site {
float:left;
margin: 10px;
color: #38a;
border-bottom:1px dashed #888;
}

#site:hover {
color: #7af;
}

#close {
float:right;
margin: 10px;
}

#p {
font-family: Verdana, sans-serif;
position:absolute;
right:10px;
bottom:10px;
color:#adf;
border: 1px dashed #555;
padding:4px 8px;
}


HTML
Notice the canvas element


<canvas id = "c" > </canvas>

<a target="_blank" href="http://codepen.io/stuffit/pen/fhjvk" id="p">New pen: Like playing with physics? Click here!</a>

<div id="info">
<div id="top">
<a target="_blank" id="site" href="http://lonely-pixel.com">my website</a>
<a id="close" href="">close</a>
</div>
<p>
<br>
- Tear the cloth with your mouse.<br><br>
- Right click and drag to cut the cloth<br><br>
- Reduce physics_accuracy if it's laggy.<br><br>
</p>
</div>


Friday, 12 April 2013

Security consultant hijacks plane's navigation system

A security consultant has demonstrated a successful hack of the plane's navigation system using a custom built android app which could transmit navigation signals to the plane's control system thereby compromising the entire navigation system of the aircraft. It's as if you could control the entire navigation of the plane from the android app. 


Quote : - By taking advantage of two new technologies for the discovery, information gathering and exploitation phases of the attack, and by creating an exploit framework (SIMON) and an Android app (PlaneSploit) that delivers attack messages to the airplanes' Flight Management Systems (computer unit + control display unit), he demonstrated the terrifying ability to take complete control of aircraft by making virtual planes "dance to his tune."

More Here