JP2008217061A - Simd型マイクロプロセッサ - Google Patents
Simd型マイクロプロセッサ Download PDFInfo
- Publication number
- JP2008217061A JP2008217061A JP2007049387A JP2007049387A JP2008217061A JP 2008217061 A JP2008217061 A JP 2008217061A JP 2007049387 A JP2007049387 A JP 2007049387A JP 2007049387 A JP2007049387 A JP 2007049387A JP 2008217061 A JP2008217061 A JP 2008217061A
- Authority
- JP
- Japan
- Prior art keywords
- arithmetic
- processor element
- processor
- arithmetic units
- assigned
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
- 230000001174 ascending effect Effects 0.000 claims description 15
- 238000000034 method Methods 0.000 claims description 7
- 238000010586 diagram Methods 0.000 description 24
- 238000004364 calculation method Methods 0.000 description 7
- 238000013500 data storage Methods 0.000 description 2
- 230000005540 biological transmission Effects 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30003—Arrangements for executing specific machine instructions
- G06F9/30007—Arrangements for executing specific machine instructions to perform operations on data operands
- G06F9/3001—Arithmetic instructions
- G06F9/30014—Arithmetic instructions with variable precision
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/38—Concurrent instruction execution, e.g. pipeline or look ahead
- G06F9/3885—Concurrent instruction execution, e.g. pipeline or look ahead using a plurality of independent parallel functional units
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/38—Concurrent instruction execution, e.g. pipeline or look ahead
- G06F9/3885—Concurrent instruction execution, e.g. pipeline or look ahead using a plurality of independent parallel functional units
- G06F9/3887—Concurrent instruction execution, e.g. pipeline or look ahead using a plurality of independent parallel functional units controlled by a single instruction for multiple data lanes [SIMD]
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- Computational Mathematics (AREA)
- Mathematical Analysis (AREA)
- Mathematical Optimization (AREA)
- Pure & Applied Mathematics (AREA)
- Image Processing (AREA)
Abstract
【解決手段】グローバルプロセッサ、及び複数のプロセッサエレメントを備え、各プロセッサエレメントは複数の演算ユニットを含み、グローバルプロセッサからの制御によって、プロセッサエレメントにおける演算ユニットの連結構成を一律に変更し、演算ユニットが連結されて若しくは独立してなる演算単位のプロセッサエレメントでの数、及び、演算単位で処理されるデータのデータ幅を変更するSIMD型マイクロプロセッサにおいて、上記プロセッサエレメントにおける演算単位に対して、ラベル値を割り付け、割り付けたラベル値を処理に使用することを特徴とする。
【選択図】図1
Description
グローバルプロセッサ、及び複数のプロセッサエレメントを備え、
各プロセッサエレメントは複数の演算ユニットを含み、
グローバルプロセッサからの制御によって、プロセッサエレメントにおける演算ユニットの連結構成を一律に変更し、演算ユニットが連結されて若しくは独立してなる演算単位のプロセッサエレメントでの数、及び、演算単位で処理されるデータのデータ幅を変更するSIMD型マイクロプロセッサである。そのようなSIMD型マイクロプロセッサにおいて、
上記プロセッサエレメントにおける演算単位に対して、ラベル値を割り付け、割り付けたラベル値を処理に使用することを特徴とする。
上記プロセッサエレメントにおける演算単位に対して割り付けられるラベル値を、上記演算単位で使用するデータの一つとして生成する
ことを特徴とする請求項1に記載のSIMD型マイクロプロセッサである。
上記ラベル値を、グローバルプロセッサからの指定により行う各プロセッサエレメントの各演算単位での範囲選択に用いる
ことを特徴とする請求項1又は2に記載のSIMD型マイクロプロセッサである。
請求項3に記載のSIMD型マイクロプロセッサであって、
各プロセッサエレメントは2個の演算ユニットを含み、
(A)各プロセッサエレメントに含まれる2つの演算ユニットを一律に連動して動作させ、各プロセッサエレメントで一組ずつ演算データを処理する場合に、
各プロセッサエレメントに含まれる演算ユニット2つずつに1つのラベル値を、そのラベル値がプロセッサエレメントの並びに対して昇順又は降順になるように付与する第1のラベル値割り付け、
(B)各プロセッサエレメントに含まれる2つの演算ユニットを一律に独立して動作させ、各プロセッサエレメントで二組ずつ演算データを処理する場合に、
各プロセッサエレメントに含まれる演算ユニット2つに2つのラベル値を、そのラベル値が2つの演算ユニットにて昇順又は降順になるように付与し、
次いで、隣接するプロセッサエレメントに移り、続きとなるラベル値を用いて、再び、演算ユニット2つに2つのラベル値をそのラベル値が2つの演算ユニットにて昇順又は降順になるように付与する第2のラベル値割り付け、及び、
(C)各プロセッサエレメントに含まれる2つの演算ユニットを一律に独立して動作させ、各プロセッサエレメントで二組ずつ演算データを処理する場合に、
各プロセッサエレメントに含まれる演算ユニット2つに2つのラベル値を、そのラベル値が2つの演算ユニットにて同じになるように付与し、
更に、プロセッサエレメントの並びに対して昇順又は降順になるように付与する第3のラベル値割り付け
の少なくとも3通りのラベル値の割り付けに、対応するものであり、
各プロセッサエレメントの2つの演算ユニットは、自らに割り付けられたラベル値が、グローバルプロセッサから指定される選択範囲内にあるか否かを判定する判定回路を夫々備えており、
まず、各プロセッサエレメントの各演算ユニットには上記(B)の第2のラベル値割り付けに従って、ラベル値が割り付けられており、
上記(A)の第1のラベル値割り付け、又は、上記(C)の第3のラベル値割り付けに対応する場合には、グローバルプロセッサからの選択範囲の指定値を2倍して、各プロセッサエレメントの各演算ユニットに与え、各演算ユニットに備わる判定回路は最下位1ビットを判定に加えない
ことを特徴とするSIMD型マイクロプロセッサである。
図11は、本発明の第1の実施形態に係るSIMD型マイクロプロセッサ2の概略の構成図である。SIMD型マイクロプロセッサ2は、概略、グローバルプロセッサ30、プロセッサエレメントグループ72、及び外部インターフェース70から構成される。プロセッサエレメントグループ72は複数のPEの配列体(集合体)であり、後で説明するように各PEの演算器が演算アレイ62に属しており、各PEのレジスタがレジスタファイル60に属している。
(A) PEごとに1つの32ビット演算を実行
(B) PEごとに2つの16ビット演算を同時に実行
図5は、本発明の第2の実施形態に係るSIMD型マイクロプロセッサ2の詳細な構成図である。本発明の第2の実施形態に係るSIMD型マイクロプロセッサ2は、上記の第1の実施形態に係るSIMD型マイクロプロセッサ2と略同様のものであり、同一部位には同一符号を付して説明を省略する。
図9は、本発明の第3の実施形態に係るSIMD型マイクロプロセッサ2に含まれるプロセッサエレメント4の演算部14の詳細な構成図である。本発明の第3の実施形態に係るSIMD型マイクロプロセッサ2は、上記の第1又は第2の実施形態に係るSIMD型マイクロプロセッサ2と略同様のものであり、同一部位には同一符号を付して説明を省略する。
Claims (4)
- グローバルプロセッサ、及び複数のプロセッサエレメントを備え、
各プロセッサエレメントは複数の演算ユニットを含み、
グローバルプロセッサからの制御によって、プロセッサエレメントにおける演算ユニットの連結構成を一律に変更し、演算ユニットが連結されて若しくは独立してなる演算単位のプロセッサエレメントでの数、及び、演算単位で処理されるデータのデータ幅を変更するSIMD型マイクロプロセッサにおいて、
上記プロセッサエレメントにおける演算単位に対して、ラベル値を割り付け、割り付けたラベル値を処理に使用することを特徴とするSIMD型マイクロプロセッサ。 - 上記プロセッサエレメントにおける演算単位に対して割り付けられるラベル値を、上記演算単位で使用するデータの一つとして生成する
ことを特徴とする請求項1に記載のSIMD型マイクロプロセッサ。 - 上記ラベル値を、グローバルプロセッサからの指定により行う各プロセッサエレメントの各演算単位に対する範囲選択に用いる
ことを特徴とする請求項1又は2に記載のSIMD型マイクロプロセッサ。 - 請求項3に記載のSIMD型マイクロプロセッサであって、
各プロセッサエレメントは2個の演算ユニットを含み、
(A)各プロセッサエレメントに含まれる2つの演算ユニットを一律に連動して動作させ、各プロセッサエレメントで一組ずつ演算データを処理する場合に、
各プロセッサエレメントに含まれる演算ユニット2つずつに1つのラベル値を、そのラベル値がプロセッサエレメントの並びに対して昇順又は降順になるように付与する第1のラベル値割り付け、
(B)各プロセッサエレメントに含まれる2つの演算ユニットを一律に独立して動作させ、各プロセッサエレメントで二組ずつ演算データを処理する場合に、
各プロセッサエレメントに含まれる演算ユニット2つに2つのラベル値を、そのラベル値が2つの演算ユニットにて昇順又は降順になるように付与し、
次いで、隣接するプロセッサエレメントに移り、続きとなるラベル値を用いて、再び、演算ユニット2つに2つのラベル値をそのラベル値が2つの演算ユニットにて昇順又は降順になるように付与する第2のラベル値割り付け、及び、
(C)各プロセッサエレメントに含まれる2つの演算ユニットを一律に独立して動作させ、各プロセッサエレメントで二組ずつ演算データを処理する場合に、
各プロセッサエレメントに含まれる演算ユニット2つに2つのラベル値を、そのラベル値が2つの演算ユニットにて同じになるように付与し、
更に、プロセッサエレメントの並びに対して昇順又は降順になるように付与する第3のラベル値割り付け
の少なくとも3通りのラベル値の割り付けに、対応するものであり、
各プロセッサエレメントの2つの演算ユニットは、自らに割り付けられたラベル値が、グローバルプロセッサから指定される選択範囲内にあるか否かを判定する判定回路を夫々備えており、
まず、各プロセッサエレメントの各演算ユニットには上記(B)の第2のラベル値割り付けに従って、ラベル値が割り付けられており、
上記(A)の第1のラベル値割り付け、又は、上記(C)の第3のラベル値割り付けに対応する場合には、グローバルプロセッサからの選択範囲の指定値を2倍して、各プロセッサエレメントの各演算ユニットに与え、各演算ユニットに備わる判定回路は最下位1ビットを判定に加えない
ことを特徴とするSIMD型マイクロプロセッサ。
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2007049387A JP4801605B2 (ja) | 2007-02-28 | 2007-02-28 | Simd型マイクロプロセッサ |
US12/038,518 US8060726B2 (en) | 2007-02-28 | 2008-02-27 | SIMD microprocessor, image processing apparatus including same, and image processing method used therein |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2007049387A JP4801605B2 (ja) | 2007-02-28 | 2007-02-28 | Simd型マイクロプロセッサ |
Publications (2)
Publication Number | Publication Date |
---|---|
JP2008217061A true JP2008217061A (ja) | 2008-09-18 |
JP4801605B2 JP4801605B2 (ja) | 2011-10-26 |
Family
ID=39717260
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2007049387A Expired - Fee Related JP4801605B2 (ja) | 2007-02-28 | 2007-02-28 | Simd型マイクロプロセッサ |
Country Status (2)
Country | Link |
---|---|
US (1) | US8060726B2 (ja) |
JP (1) | JP4801605B2 (ja) |
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2010122741A (ja) * | 2008-11-17 | 2010-06-03 | Kumamoto Univ | データ処理装置 |
US8001506B2 (en) | 2008-01-22 | 2011-08-16 | Ricoh Company, Ltd. | SIMD image forming apparatus for minimizing wiring distance between registers and processing devices |
JP2012190389A (ja) * | 2011-03-14 | 2012-10-04 | Ricoh Co Ltd | プロセッサ装置及びその演算方法 |
JP2014016894A (ja) * | 2012-07-10 | 2014-01-30 | Renesas Electronics Corp | 並列演算装置、並列演算装置を備えたデータ処理システム、及び、データ処理プログラム |
WO2016024508A1 (ja) * | 2014-08-12 | 2016-02-18 | 高田 周一 | マルチプロセッサ装置 |
Families Citing this family (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9996500B2 (en) * | 2011-09-27 | 2018-06-12 | Renesas Electronics Corporation | Apparatus and method of a concurrent data transfer of multiple regions of interest (ROI) in an SIMD processor system |
US11106268B2 (en) * | 2018-07-29 | 2021-08-31 | Redpine Signals, Inc. | Method and system for saving power in a real time hardware processing unit |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2006260479A (ja) * | 2005-03-18 | 2006-09-28 | Ricoh Co Ltd | Simd型マイクロプロセッサ及びデータ処理方法 |
JP2007034473A (ja) * | 2005-07-25 | 2007-02-08 | Ricoh Co Ltd | Simd型マイクロプロセッサにおけるデータ処理方法 |
Family Cites Families (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4748585A (en) * | 1985-12-26 | 1988-05-31 | Chiarulli Donald M | Processor utilizing reconfigurable process segments to accomodate data word length |
EP0424618A3 (en) * | 1989-10-24 | 1992-11-19 | International Business Machines Corporation | Input/output system |
US5590356A (en) * | 1994-08-23 | 1996-12-31 | Massachusetts Institute Of Technology | Mesh parallel computer architecture apparatus and associated methods |
JP2002007359A (ja) | 2000-06-21 | 2002-01-11 | Sony Corp | Simd制御並列処理方法および装置 |
JP2002091929A (ja) | 2000-09-11 | 2002-03-29 | Matsushita Electric Ind Co Ltd | Simd型並列処理装置 |
US7158141B2 (en) * | 2002-01-17 | 2007-01-02 | University Of Washington | Programmable 3D graphics pipeline for multimedia applications |
-
2007
- 2007-02-28 JP JP2007049387A patent/JP4801605B2/ja not_active Expired - Fee Related
-
2008
- 2008-02-27 US US12/038,518 patent/US8060726B2/en not_active Expired - Fee Related
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2006260479A (ja) * | 2005-03-18 | 2006-09-28 | Ricoh Co Ltd | Simd型マイクロプロセッサ及びデータ処理方法 |
JP2007034473A (ja) * | 2005-07-25 | 2007-02-08 | Ricoh Co Ltd | Simd型マイクロプロセッサにおけるデータ処理方法 |
Cited By (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8001506B2 (en) | 2008-01-22 | 2011-08-16 | Ricoh Company, Ltd. | SIMD image forming apparatus for minimizing wiring distance between registers and processing devices |
JP2010122741A (ja) * | 2008-11-17 | 2010-06-03 | Kumamoto Univ | データ処理装置 |
JP2012190389A (ja) * | 2011-03-14 | 2012-10-04 | Ricoh Co Ltd | プロセッサ装置及びその演算方法 |
JP2014016894A (ja) * | 2012-07-10 | 2014-01-30 | Renesas Electronics Corp | 並列演算装置、並列演算装置を備えたデータ処理システム、及び、データ処理プログラム |
WO2016024508A1 (ja) * | 2014-08-12 | 2016-02-18 | 高田 周一 | マルチプロセッサ装置 |
US10754818B2 (en) | 2014-08-12 | 2020-08-25 | ArchiTek Corporation | Multiprocessor device for executing vector processing commands |
Also Published As
Publication number | Publication date |
---|---|
US8060726B2 (en) | 2011-11-15 |
US20080209165A1 (en) | 2008-08-28 |
JP4801605B2 (ja) | 2011-10-26 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP4801605B2 (ja) | Simd型マイクロプロセッサ | |
CN1127687C (zh) | 带外部协处理器可访问的上下文切换寄存器组的risc处理器 | |
US3537074A (en) | Parallel operating array computer | |
EP0539595A1 (en) | Data processor and data processing method | |
JPH06230969A (ja) | プロセッサ | |
JPS61110256A (ja) | 複数の演算部を有するプロセツサ | |
JP3971535B2 (ja) | Simd型プロセッサ | |
WO2016024508A1 (ja) | マルチプロセッサ装置 | |
KR20010072491A (ko) | 산술 논리 유닛 및 스택을 가지는 데이터 프로세서,멀티미디어 장치 및 컴퓨터 프로그램 제품 | |
EP1220089B1 (en) | Method for executing conditional branch instructions in a data processor and corresponding data processor | |
JP3935678B2 (ja) | Simd積和演算方法、積和演算回路、および、半導体集積回路装置 | |
JPS59106075A (ja) | デ−タ処理システム | |
JP5145659B2 (ja) | ベクトルリネーミング方式およびベクトル型計算機 | |
US20100088493A1 (en) | Image processing device and data processor | |
JP4482356B2 (ja) | Simdプロセッサを用いた画像処理方法及び画像処理装置 | |
EP0177268B1 (en) | Programmable data path width in a programmable unit having plural levels of subinstructions sets | |
JP2008071037A (ja) | Simd型マイクロプロセッサ | |
US20090187738A1 (en) | Simd-type microprocessor, method of processing data, image data processing system, and method of processing image data | |
KR20010072490A (ko) | 레지스터 스택을 포함하는 데이터 프로세서, 그 처리방법, 컴퓨터 프로그램 제품 및 멀티미디어 장치 | |
JP2006515446A (ja) | 関連アプリケーションを相互参照するカルテシアンコントローラを有するデータ処理システム | |
JPH06309349A (ja) | プログラム制御のプロセッサ | |
JP2011118744A (ja) | 情報処理装置 | |
JP2002091929A (ja) | Simd型並列処理装置 | |
JP4413905B2 (ja) | Simd型プロセッサ | |
JP2011134042A (ja) | Simd型マイクロプロセッサおよびsimd型マイクロプロセッサのデータ整列方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20090325 |
|
A977 | Report on retrieval |
Free format text: JAPANESE INTERMEDIATE CODE: A971007 Effective date: 20110425 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20110510 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20110708 |
|
TRDD | Decision of grant or rejection written | ||
A01 | Written decision to grant a patent or to grant a registration (utility model) |
Free format text: JAPANESE INTERMEDIATE CODE: A01 Effective date: 20110802 |
|
A01 | Written decision to grant a patent or to grant a registration (utility model) |
Free format text: JAPANESE INTERMEDIATE CODE: A01 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20110805 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20140812 Year of fee payment: 3 |
|
R150 | Certificate of patent or registration of utility model |
Free format text: JAPANESE INTERMEDIATE CODE: R150 |
|
LAPS | Cancellation because of no payment of annual fees |