<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ja">
	<id>https://monobook.org/w/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=2001%3AF73%3A93E0%3A7B00%3A41BC%3AEC10%3AD4BE%3A622B</id>
	<title>MonoBook - 利用者の投稿記録 [ja]</title>
	<link rel="self" type="application/atom+xml" href="https://monobook.org/w/api.php?action=feedcontributions&amp;feedformat=atom&amp;user=2001%3AF73%3A93E0%3A7B00%3A41BC%3AEC10%3AD4BE%3A622B"/>
	<link rel="alternate" type="text/html" href="https://monobook.org/wiki/%E7%89%B9%E5%88%A5:%E6%8A%95%E7%A8%BF%E8%A8%98%E9%8C%B2/2001:F73:93E0:7B00:41BC:EC10:D4BE:622B"/>
	<updated>2026-06-05T22:02:50Z</updated>
	<subtitle>利用者の投稿記録</subtitle>
	<generator>MediaWiki 1.42.1</generator>
	<entry>
		<id>https://monobook.org/w/index.php?title=%E3%82%BF%E3%82%A4%E3%83%AB%E3%83%99%E3%83%BC%E3%82%B9%E3%83%AC%E3%83%B3%E3%83%80%E3%83%AA%E3%83%B3%E3%82%B0&amp;diff=23100</id>
		<title>タイルベースレンダリング</title>
		<link rel="alternate" type="text/html" href="https://monobook.org/w/index.php?title=%E3%82%BF%E3%82%A4%E3%83%AB%E3%83%99%E3%83%BC%E3%82%B9%E3%83%AC%E3%83%B3%E3%83%80%E3%83%AA%E3%83%B3%E3%82%B0&amp;diff=23100"/>
		<updated>2024-10-14T03:26:06Z</updated>

		<summary type="html">&lt;p&gt;2001:F73:93E0:7B00:41BC:EC10:D4BE:622B: &lt;/p&gt;
&lt;hr /&gt;
&lt;div&gt;&#039;&#039;&#039;タイルベースレンダリング&#039;&#039;&#039;（[[英語]]：tile based rendering)とは、 [[コンピューター・グラフィックス]]において、1つの画面を描画生成する際に、1画面を複数のタイルに分割してタイル単位で描画を行う手法です。古くは「チャンクレンダリング」「分割レンダリング」などとも呼ばれました。&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;
&lt;br /&gt;
「少ないメモリ」「遅いメモリ」という条件下では 従来方式では[[シェーダー]]が空回りしている時間が長くなりますが、 タイル方式であれば[[シェーダー]]を遊ばせることなくフル稼働させやすいという特性があります。&lt;br /&gt;
&lt;br /&gt;
20世紀のメモリ容量が多くても数MBだった時代には夢のような技術あり、「[[ハードウェア]]を安く作れると夢のような手法」だと言われました。&lt;br /&gt;
==利点：メモリを節約できる==&lt;br /&gt;
一般的なレンダリング手法では描画作業用に画面解像度相当の[[カラーバッファ]]や[[深度バッファ]]や[[ステンシルバッファ]]などを必要とします。これらは20世紀の[[パソコン]]で主流だった[[VGA]]([[640x480]])でも1MB以上が必要です。&lt;br /&gt;
&lt;br /&gt;
さらにこれを60fpsで描画しようとするとメモリ帯域が問題になります。&lt;br /&gt;
&lt;br /&gt;
一方、タイルベースレンダリングでは作業用に必要なメモリ容量が「タイルの大きさ」で済みます。16x16や32x32という超低解像度を格納する程度のメモリなら高価で高速な[[SRAM]]も採用できます。&lt;br /&gt;
&lt;br /&gt;
[[ファイル:Tiled base rendering 1.png|none]]&lt;br /&gt;
&lt;br /&gt;
なお、メモリ容量については昨今のバカみたいにメモリを搭載した[[パソコン]]や[[スマホ]]では[[フルHD]]([[1920x1080]])でも数十MB程度なのであまり問題にならなくなりました。&lt;br /&gt;
&lt;br /&gt;
一方、メモリ帯域に関しては今でも厳し状況が続いています。[[パソコン]]向けの[[ビデオカード]]では「やれ[[GDDR]]だ」「やれ[[HBM]]だ」と力技で解決が試みられていますが、スマホはバカみたいに遅い[[LPDDR]]がいまだに主流なので問題になることが多くあります。&lt;br /&gt;
&lt;br /&gt;
==利点：タイルを再利用できる==&lt;br /&gt;
シーンの「動きが小さい」と判断した場合、クソ真面目に描画せずに、前フレームで生成したタイルに[[アフィン変換]]をかけたものを出力することで手抜きができます。あくまで近似画像であり当然ながら画質は微妙になりますが描画負荷は大幅に下がります。シーンの動きが大きい場合は残念なことになります。地味に20世紀の低性能な[[GPU]]では重要な要素だったようです。&lt;br /&gt;
&lt;br /&gt;
==欠点：オーバードローが発生する==&lt;br /&gt;
「タイルをまたぐ[[ポリゴン]]」を描画する場合はそのタイル数だけ[[シェーダー]]が動くことになります。いわゆる[[オーバードロー]]です。&lt;br /&gt;
&lt;br /&gt;
以下の例では1[[ポリゴン]]を描画するのに灰色の4タイルそれぞれで[[シェーダー]]が動いてしまいます。&lt;br /&gt;
[[ファイル:Tiled base rendering 2.png|none]]&lt;br /&gt;
&lt;br /&gt;
==欠点：タイル割当が重い==&lt;br /&gt;
タイルベースレンダリングでは以下のような工程になる。&lt;br /&gt;
# バーテックスシェーダー実行&lt;br /&gt;
# ポリゴンをタイルに割り当てる&lt;br /&gt;
# タイル単位でピクセルシェーダー実行&lt;br /&gt;
&lt;br /&gt;
この処理はシーン内のポリゴン数が増えれば増えるほど重くなる。[[PowerVR]]が登場したころの[[ローポリゴン]]が主流の時代には問題にならなかったが、ポリゴン数が激増すると、この処理は無視できないほど高負荷になった。&lt;br /&gt;
&lt;br /&gt;
== 採用事例 ==&lt;br /&gt;
タイルベースレンダリングは、[[マイクロソフト]]が絶賛し「[[Talisman]]」をぶち上げ、[[NEC]]が「[[PowerVR]]」を製造してしまい、[[セガ]]が[[ドリームキャスト]]に採用された。 一方、[[プレイステーション2]]は「[[力こそパワー]]」であると2560ビットの超高速バスを採用した。&lt;br /&gt;
&lt;br /&gt;
21世紀になるとタイルベースレンダリングは「忘れ去られた技術」になっていたが、[[iPhone]]が採用し復活を果たした。 これは[[スティーブ・ジョブズ]]の厳しい筐体サイズや消費電力への要求に応えるためだと思われる。&lt;br /&gt;
== 関連項目 ==&lt;br /&gt;
* [[フォワードレンダリング]]&lt;br /&gt;
* [[遅延レンダリング]]&lt;/div&gt;</summary>
		<author><name>2001:F73:93E0:7B00:41BC:EC10:D4BE:622B</name></author>
	</entry>
</feed>