<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>JugglerShu.Net &#187; Structure and Interpretation of Computer Programs</title>
	<atom:link href="http://programming.jugglershu.net/wp/?cat=94&#038;feed=rss2" rel="self" type="application/rss+xml" />
	<link>http://programming.jugglershu.net/wp</link>
	<description>Nothing But Programming</description>
	<lastBuildDate>Wed, 15 Apr 2020 08:11:15 +0000</lastBuildDate>
	<language>ja</language>
		<sy:updatePeriod>hourly</sy:updatePeriod>
		<sy:updateFrequency>1</sy:updateFrequency>
	<generator>https://wordpress.org/?v=3.9.40</generator>
	<item>
		<title>UCBerkeley CS61A Structure and Interpretation of Computer Programming Week2</title>
		<link>http://programming.jugglershu.net/wp/?p=564</link>
		<comments>http://programming.jugglershu.net/wp/?p=564#comments</comments>
		<pubDate>Sat, 06 Nov 2010 20:38:00 +0000</pubDate>
		<dc:creator><![CDATA[shu]]></dc:creator>
				<category><![CDATA[Structure and Interpretation of Computer Programs]]></category>

		<guid isPermaLink="false">http://programming.jugglershu.net/wp/?p=564</guid>
		<description><![CDATA[だいぶ間が開いてしまったがSICPのWeek2。http://itunes.apple.com/WebObjects/MZStore.woa/wa/viewiTunesUCollection?id=354818464#ls=1 教科書はオンラインで読むこともできる。Structure and Interpretation of Computer Programs（SICP)http://www-m <a class="more-link" href="http://programming.jugglershu.net/wp/?p=564">続きを読む <span class="meta-nav">&#8594;</span></a>]]></description>
				<content:encoded><![CDATA[<p>だいぶ間が開いてしまったがSICPのWeek2。<br /><a href="http://itunes.apple.com/WebObjects/MZStore.woa/wa/viewiTunesUCollection?id=354818464#ls=1">http://itunes.apple.com/WebObjects/MZStore.woa/wa/viewiTunesUCollection?id=354818464#ls=1</a></p>
<p>教科書はオンラインで読むこともできる。<br /><a href="http://www-mitpress.mit.edu/sicp/full-text/book/book.html">Structure and Interpretation of Computer Programs（SICP)http://www-mitpress.mit.edu/sicp/full-text/book/book.html</a></p>
<p>宿題や試験の内容はこちら。（宿題はCourse Reading Vol1にある。）<br /><a href="http://www-inst.eecs.berkeley.edu/~cs61a/fa10/">http://www-inst.eecs.berkeley.edu/~cs61a/fa10/</a></p>
<h4>Lecture 3</h4>
<p>主な内容
<ul>
<li>Function as Arguments( Higher-order function )</li>
<li>関数の表記について（ |-> という表記 )</li>
<li>lamda関数</li>
</ul>
<p>関数の表記 |-> &#8220;maps to&#8221;についての説明はなんとなく聞くことになるけど、SICP 69ページのFixed-Pointの計算でsquare rootを計算するところでその理解が必要になる。（詳しくは後述）</p>
<p>lamda関数については、その歴史から話が始まる。アロンゾチャーチという人が、数学を関数を元に説明しようとしたところから始まっている、というような話だった。その後、AI研究者のジョンJohn McCarthyが、その考え方をLispに取り入れたとのこと。<br />
<h4>Lecture 4</h4>
<p>主な内容
<ul>
<li>First Class Data</li>
<li>Functionを返すFunction</li>
<li>letについて</li>
</ul>
<p>基本的には高階関数の話<br />
<h4>宿題</h4>
<p>宿題はSICPのSection1.3を読むこと。Section1.2は飛ばしてあとでやるとのこと。読むに当たって知っておいた方が良さそうな英単語は<br />converge 収束する<br />differentiable 微分可能<br />derivative 導関数</p>
<p>いくつか注意が必要なところがあったので、メモ。<br />まず、SICP67-68は飛ばしてもよい。これは宿題の指示にも書いてある。</p>
<p>それから、その次の「Finding fixed points of function」というところ。まずFixed pointが何なのか分からないといまいちピンとこない。日本語では不動点 http://ja.wikipedia.org/wiki/%E4%B8%8D%E5%8B%95%E7%82%B9 となるらしい。これを一通り見ればどういうことなのか分かる。<br />それから、69ページのこのFixed pointの計算を使ってルートを解くところで、y |-> x/y とかなっていて、x,yの二つの変数が出てきてそれでどうして計算ができるのかと一瞬戸惑うのだが、よく見ればこれはyの関数であって、xは定数であることが分かる（このことに気づかないと理解するのに時間がかかる。）。<br />これは、まさに授業中に言っていたことだ。ax+bとかあったら、勝手にxを変数だと思い込むくせが悪いのだろう。正確な関数の記述はx |-> ax+b ということだ。</p>
<p>読み終わったら、指示にしたがってSICPの練習問題を解く。<br />教科書の練習問題は、基本的なことが主なので問題ない。<br />難しかったのはCourse ReaderのWeek2のExtra for expertsの問題。<br />これはできなかった。なんとなく考え方としては関数を返す関数を書いて・・・2重にすれば・・・などと考えたけどうまくいかなかった。決して方向性は間違っていなかったようなきがするけど。</p>
<p>これはY Combinatorというものらしい。詳しくは以下を参照<br />http://www.ece.uc.edu/~franco/C511/html/Scheme/ycomb.html</p>
</p>]]></content:encoded>
			<wfw:commentRss>http://programming.jugglershu.net/wp/?feed=rss2&#038;p=564</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>UCBerkeley CS61A Structure and Interpretation of Computer Programming Week1</title>
		<link>http://programming.jugglershu.net/wp/?p=570</link>
		<comments>http://programming.jugglershu.net/wp/?p=570#comments</comments>
		<pubDate>Thu, 30 Sep 2010 12:45:00 +0000</pubDate>
		<dc:creator><![CDATA[shu]]></dc:creator>
				<category><![CDATA[Free Lectures]]></category>
		<category><![CDATA[Structure and Interpretation of Computer Programs]]></category>

		<guid isPermaLink="false">http://programming.jugglershu.net/wp/?p=570</guid>
		<description><![CDATA[いろいろな大学が授業の様子をYouTubeやiTunesUで公開しているというのは、いままでもブログに何度か書いてきた。ここへ来て、真面目に順番に授業を受けようと思い、始めている。一つ受ける度に、ブログにそのまとめを載せていこうと思う。これから、この教材を使って勉強しようとする人のガイドになればと思う。 第一段はUCBerkeleyのCS61A(Structure and Interpretati <a class="more-link" href="http://programming.jugglershu.net/wp/?p=570">続きを読む <span class="meta-nav">&#8594;</span></a>]]></description>
				<content:encoded><![CDATA[<p>いろいろな大学が授業の様子をYouTubeやiTunesUで公開しているというのは、いままでもブログに何度か書いてきた。<br />ここへ来て、真面目に順番に授業を受けようと思い、始めている。<br />一つ受ける度に、ブログにそのまとめを載せていこうと思う。これから、この教材を使って勉強しようとする人のガイドになればと思う。</p>
<p>第一段はUCBerkeleyのCS61A(Structure and Interpretation of Computer Programming)。授業は以下のサイトにある。<br /><a href="http://itunes.apple.com/WebObjects/MZStore.woa/wa/viewiTunesUCollection?id=354818464#ls=1">http://itunes.apple.com/WebObjects/MZStore.woa/wa/viewiTunesUCollection?id=354818464#ls=1</a></p>
<p>教科書は有名な本だが、Structure and Interpretation of Computer Programs（SICP)となっている。教科書はオンラインで読むこともできる。<br /><a href="http://www-mitpress.mit.edu/sicp/full-text/book/book.html">http://www-mitpress.mit.edu/sicp/full-text/book/book.html</a></p>
<p>また、宿題や試験の内容がここにある。（宿題はCourse Reading Vol1にある。）<br /><a href="http://www-inst.eecs.berkeley.edu/~cs61a/fa10/">http://www-inst.eecs.berkeley.edu/~cs61a/fa10/</a></p>
<p>スケジュールを見ると、大体一週間に2～4講義分ぐらい進むらしい。Course Reading Vol1には、Week1、Week2とかかれていて、それぞれやることが書いてあるので、それに併せて、ビデオを見ながら進めようと思う。<br />やり方としては先に教科書を読んでビデオを見て、宿題をやってもよいし、先にビデオを見て宿題をやってから本を読んでもよいし、教科書と授業の順番はどうでもよいと思う。<br />僕はビデオを見て、教科書を読んで、宿題を行うという順で行った。</p>
<p>この授業にはCourse Reading Vol1とVol2という二つがある。<br />Vol1はセメスターごとに少しずつ変更になる内容のもので、宿題などが載っている。先ほどのサイトからダウンロードできる。Vol2は、セメスターごとにほとんど変更のないもので、毎回同じものを使っているらしい。これもダウンロードできる。ただし最初のうちは関係なさそうなので、用意するのは教科書とVol1があれば大丈夫。（残念ながらビデオの授業のCourse Readingそのものは手に入れることはできそうにないので、現在配られているものを利用している。）</p>
<p>授業で使われているSchemeプログラムはSTkというものらしく、さきほどのコースのウェブサイトからダウンロードできる。</p>
<p>今回はWeek1
<ul>
<li>教材Vol1: Week1</li>
<li>教科書: Section 1.1</li>
<li>iTunesU: Lecture1 &#8211; Lecture2</li>
</ul>
<p>
<h4>Lecture1</h4>
<p>主な内容は<br />-Schemeの使い方<br />&#8211; 簡単な計算<br />&#8211; 関数定義<br />-コースオーバービュー</p>
<p>Schemeの使い方では、たった40分程度だが、先生は「これでSchemeの90%はみんな理解したことになる」と言っている。それぐらい簡単なものだということを言っている。</p>
<p>コースのオーバービューとしては、「プログラミングは&#8221;very very easy&#8221;だ。中学生でもできる。それは天才だからじゃなくて、簡単だからだ。」というのを強く言っていたのが印象的だった。<br />残念ながらこのiTunesUのビデオはなぜか途中で切れたようになっている。</p>
<p>
<h4>Lecture2</h4>
<p>おもな内容は<br />-コースオーバービューの続き<br />&#8211; Functional Programmingを学ぶ意味<br />&#8211; コンピュータの抽象化<br />- -宿題や試験についての注意<br />-Schemeの使い方その２<br />&#8211; 条件分岐<br />&#8211; Applicative orderとNormal order</p>
<p>「Functional Programmingを学ぶ重要性の一つは、今日のプログラムが並列性を持つようになってきているからである。」とか、コンピュータの抽象化についての話と続く。<br />さらにSchemeの使い方が続く。主に条件分岐やApplicative OrderやNormal Orderなどの話がメイン<br />Functional Progurammingを行っている限り、Applicative OrderかNormal Orderかは関係ない。つまり結果が計算の順番によらないということを強調していた。並列処理プログラムを書くときの重要な考え方なんだろう。</p>
<h4>宿題</h4>
<p>さてビデオを見た後で、宿題に取りかかる。<br />Homework Week1を読むと、まず、教科書のセクション1.1と1.3を読むようにと書いてある。おおよそビデオで習ったことなので話はスムーズにす進む。ただし、1.3の内容は来週の予習となっている。</p>
<p>宿題はプログラムを書くものが多いので、環境を整える必要がある。コースのウェブサイトにあるリンクから各環境用のSTkをインストールする。授業で使われているScheme処理系はfirstやbfといった関数が予め定義されている。これはstk-simplyというプログラムを利用すればよいことになっている。（普通のSTkにはこれらの関数はない。）</p>
<p>宿題には教科書の一部の問題を解くようにと指示されていたり、その場に問題が載っていたりする。<br />ひとまず、Week1の宿題の問題をすべて実際に解いてみた。簡単なものもあれば、難しいものもある。<br />デバッグの方法がよくわからないので、うまく動かないと頑張ってどこが悪いのか探さなくてはいけない。慣れてくると意外とすんなりと書けるようになってくる。</p>
</p>]]></content:encoded>
			<wfw:commentRss>http://programming.jugglershu.net/wp/?feed=rss2&#038;p=570</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>
