<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://mediawiki.zeropage.org/index.php?action=history&amp;feed=atom&amp;title=ProgrammingPearls%2FColumn6</id>
	<title>ProgrammingPearls/Column6 - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://mediawiki.zeropage.org/index.php?action=history&amp;feed=atom&amp;title=ProgrammingPearls%2FColumn6"/>
	<link rel="alternate" type="text/html" href="https://mediawiki.zeropage.org/index.php?title=ProgrammingPearls/Column6&amp;action=history"/>
	<updated>2026-05-14T18:12:18Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.39.8</generator>
	<entry>
		<id>https://mediawiki.zeropage.org/index.php?title=ProgrammingPearls/Column6&amp;diff=37618&amp;oldid=prev</id>
		<title>imported&gt;Unknown at 05:24, 7 February 2021</title>
		<link rel="alternate" type="text/html" href="https://mediawiki.zeropage.org/index.php?title=ProgrammingPearls/Column6&amp;diff=37618&amp;oldid=prev"/>
		<updated>2021-02-07T05:24:03Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;__TOC__&lt;br /&gt;
&lt;br /&gt;
== Perspective on Programming ==&lt;br /&gt;
&lt;br /&gt;
=== A Case Study ===&lt;br /&gt;
* 어떤 프로그램이 1년 걸렸었는데 단계별로 쪼개서 튜닝을 했더니 하루만에 되더라하는 내용이 씌어있다.&lt;br /&gt;
* 그 단계를 살펴보면,&lt;br /&gt;
** 알고리즘과 자료구조의 교체 : Sequential 한것을 Binary Tree로 교체함으로써 O(n*n)이 O(n*lg n)으로 줄었다.&lt;br /&gt;
** 알고리즘의 튜닝 &lt;br /&gt;
** 자료구조의 개조&lt;br /&gt;
** 코드 튜닝&lt;br /&gt;
** 시스템 독립적인 코드 튜닝 : double형보다 시간이 절반 정도 걸리는 float를 썼다.&lt;br /&gt;
** 시스템 의존적인 코드 튜닝 : 크리티컬한 부분을 어셈블리로 다시 짰다.&lt;br /&gt;
** 하드웨어 업글 : 부동소숫점 연산 가속기를 사용&lt;br /&gt;
* 이 각각의 단계에서 빨라진 만큼을 다 곱하니 대략 400이 나오더라하는 내용이 씌어있다.&lt;br /&gt;
&lt;br /&gt;
=== Design Level ===&lt;br /&gt;
* 디자인 레벨에 관한 가이드&lt;br /&gt;
** 문제 정의&lt;br /&gt;
** 시스템 구조 &lt;br /&gt;
** 알고리즘과 자료구조&lt;br /&gt;
** 코드 튜닝&lt;br /&gt;
** 시스템 소프트웨어&lt;br /&gt;
** 하드웨어&lt;br /&gt;
&lt;br /&gt;
=== Principles ===&lt;br /&gt;
* 심플한 디자인의 중요성은 아무리 강조해도 지나치지 않다.&lt;br /&gt;
* 적은 양의 스피드업을 원한다면 가장 고치기 쉬운 부분만을 고치자.&lt;br /&gt;
* 많은 양의 스피드업을 원한다면 다단계를 고치자. 한군데를 고침으로써 다른 부분도 고칠것이 생긴다.&lt;br /&gt;
----&lt;br /&gt;
[[ProgrammingPearls]]&lt;br /&gt;
&lt;/div&gt;</summary>
		<author><name>imported&gt;Unknown</name></author>
	</entry>
</feed>