CA2216698C - Method and apparatus for simultaneous shape-dependent access to picture data stored at a plurality of addresses - Google Patents
Method and apparatus for simultaneous shape-dependent access to picture data stored at a plurality of addresses Download PDFInfo
- Publication number
- CA2216698C CA2216698C CA002216698A CA2216698A CA2216698C CA 2216698 C CA2216698 C CA 2216698C CA 002216698 A CA002216698 A CA 002216698A CA 2216698 A CA2216698 A CA 2216698A CA 2216698 C CA2216698 C CA 2216698C
- Authority
- CA
- Canada
- Prior art keywords
- data
- accessing
- accessed
- memory
- polygon shape
- 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.)
- Expired - Fee Related
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/06—Addressing a physical block of locations, e.g. base addressing, module addressing, memory dedication
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/0207—Addressing or allocation; Relocation with multidimensional access, e.g. row/column, matrix
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T1/00—General purpose image data processing
- G06T1/20—Processor architectures; Processor configuration, e.g. pipelining
-
- G—PHYSICS
- G09—EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
- G09G—ARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
- G09G5/00—Control arrangements or circuits for visual indicators common to cathode-ray tube indicators and other visual indicators
- G09G5/36—Control arrangements or circuits for visual indicators common to cathode-ray tube indicators and other visual indicators characterised by the display of a graphic pattern, e.g. using an all-points-addressable [APA] memory
- G09G5/39—Control of the bit-mapped memory
- G09G5/393—Arrangements for updating the contents of the bit-mapped memory
-
- G—PHYSICS
- G09—EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
- G09G—ARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
- G09G2360/00—Aspects of the architecture of display systems
- G09G2360/12—Frame memory handling
- G09G2360/121—Frame memory handling using a cache memory
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- Mathematical Physics (AREA)
- Computer Hardware Design (AREA)
- Image Generation (AREA)
- Multi Processors (AREA)
- Memory System (AREA)
- Image Input (AREA)
Abstract
A control means 101 is responsive to the shape of data inputted by inputting means 32 to control designating means 102 to switch addresses of a memory 18 designated for accessing means 103a to 103d. The designating means 102 designates to the accessing means 103a to 103d addresses of the memory 18 to be accessed under control by the control means 101. The accessing means 103a to 103d simultaneously access plural addresses of the memory 18 designated by the designating means 102. By switching simultaneously accessible addresses for accessing the memory with a minimum number of accessing operations for performing pre-set data processing operations, data processing may be improved in efficiency.
Description
CA 02216698 2004-10-18 , DESCRIPTION
Method and Apparatus for Simultaneous Shape-Dependent Access to Picture Data Stored at a Plurality of Addresses This invention relates to a memory accessing method for having access to a frame buffer by pixel interleaving and a data processing apparatus for performing pre-set data processing by accessing a frame buffer by the above memory accessing method. The memory accessing method and the data processing apparatus are usable for a video game machine or a graphic computer system as video equipment employing a computer.
Background Art In a picture generating apparatus for generating data of a picture outputted to and displayed on a display device, that is output display picture data, for a television receiver, a monitor receiver or a cathode ray tube (CRT) display device, used in a video game device or a graphics computer system, a dedicated drawing device is provided between a central processing unit (CPU) and a frame buffer for enabling high-speed processing.
That is,,in the above picture generating apparatus, the CPU
when generating a picture performs geometry processing, such as coordinate transformation or clipping or light source calculations, instead of directly accessing the frame~buffer. The CPU then defines a three-dimensional model as a combination of basis unit figures, such as triangular or quadrangular figures, formulates a drawing command for drawing a three-dimensional picture, and sends the drawing command to the drawing device.
For example, if, in the above-described picture generating apparatus, a three-dimensional object is represented, the object is resolved into plural polygons, and a drawing command associated with each polygon is transmitted from a CPU to a drawing device.
The drawing device interprets the drawing command sent from the CPU
and executes rendering processing of computing colors and Z-values of all pixels making up the polygon from the Z-values for writing pixel data in a frame buffer for drawing a picture in a frame buffer.
The Z-value represents color data and depth of all pixels making up a polygon, that is, the Z-value is the information representing the distance along the depth from the viewing point.
Meanwhile, the above-described picture generating device has the function of executing pixel interleaving of writing plural pixel data at a time with plural addresses of a frame buffer as accessing unit, and is configured for accessing the frame buffer by this function.
However, with the pixel interleaving performed by the above picture generating device, plural simultaneously accessible addresses are fixed from one accessing unit to another.
Therefore, if a picture represented by the plural simultaneously accessible addresses and a picture drawn on the frame buffer, that is the shape on the memory of data actually desired to be accessed, are not coincident with each other, the number of times of accessing the frame buffer is undesirably increased.
Moreover, if the number of times of accessing the frame buffer is increased, the data processing carried out on the picture generating device is worsened.
In view of the above-depicted status of the art, the present invention has the following objects.
Specifically, it is an object of the present invention to provide a memory accessing method in which simultaneously accessible addresses are changed over for enabling the memory to be accessed with a minimum number of times of accessing operations for raising the memory accessing efficiency.
It is another object of the present invention to provide a data processing apparatus in which simultaneously accessible addresses are changed over for enabling the memory to be accessed with a minimum number of times of accessing operations for raising the data processing efficiency.
Disclosure of the Invention In one aspect, the present invention provides a memory accessing method for simultaneously accessing a plurality of addresses of a memory wherein addresses to be accessed simultaneously are determined depending on the shape on the memory of data desired to be accessed.
In the memory accessing method according to the present invention, the above data may be picture data.
Method and Apparatus for Simultaneous Shape-Dependent Access to Picture Data Stored at a Plurality of Addresses This invention relates to a memory accessing method for having access to a frame buffer by pixel interleaving and a data processing apparatus for performing pre-set data processing by accessing a frame buffer by the above memory accessing method. The memory accessing method and the data processing apparatus are usable for a video game machine or a graphic computer system as video equipment employing a computer.
Background Art In a picture generating apparatus for generating data of a picture outputted to and displayed on a display device, that is output display picture data, for a television receiver, a monitor receiver or a cathode ray tube (CRT) display device, used in a video game device or a graphics computer system, a dedicated drawing device is provided between a central processing unit (CPU) and a frame buffer for enabling high-speed processing.
That is,,in the above picture generating apparatus, the CPU
when generating a picture performs geometry processing, such as coordinate transformation or clipping or light source calculations, instead of directly accessing the frame~buffer. The CPU then defines a three-dimensional model as a combination of basis unit figures, such as triangular or quadrangular figures, formulates a drawing command for drawing a three-dimensional picture, and sends the drawing command to the drawing device.
For example, if, in the above-described picture generating apparatus, a three-dimensional object is represented, the object is resolved into plural polygons, and a drawing command associated with each polygon is transmitted from a CPU to a drawing device.
The drawing device interprets the drawing command sent from the CPU
and executes rendering processing of computing colors and Z-values of all pixels making up the polygon from the Z-values for writing pixel data in a frame buffer for drawing a picture in a frame buffer.
The Z-value represents color data and depth of all pixels making up a polygon, that is, the Z-value is the information representing the distance along the depth from the viewing point.
Meanwhile, the above-described picture generating device has the function of executing pixel interleaving of writing plural pixel data at a time with plural addresses of a frame buffer as accessing unit, and is configured for accessing the frame buffer by this function.
However, with the pixel interleaving performed by the above picture generating device, plural simultaneously accessible addresses are fixed from one accessing unit to another.
Therefore, if a picture represented by the plural simultaneously accessible addresses and a picture drawn on the frame buffer, that is the shape on the memory of data actually desired to be accessed, are not coincident with each other, the number of times of accessing the frame buffer is undesirably increased.
Moreover, if the number of times of accessing the frame buffer is increased, the data processing carried out on the picture generating device is worsened.
In view of the above-depicted status of the art, the present invention has the following objects.
Specifically, it is an object of the present invention to provide a memory accessing method in which simultaneously accessible addresses are changed over for enabling the memory to be accessed with a minimum number of times of accessing operations for raising the memory accessing efficiency.
It is another object of the present invention to provide a data processing apparatus in which simultaneously accessible addresses are changed over for enabling the memory to be accessed with a minimum number of times of accessing operations for raising the data processing efficiency.
Disclosure of the Invention In one aspect, the present invention provides a memory accessing method for simultaneously accessing a plurality of addresses of a memory wherein addresses to be accessed simultaneously are determined depending on the shape on the memory of data desired to be accessed.
In the memory accessing method according to the present invention, the above data may be picture data.
In the memory accessing method according to the present invention, the addresses to be accessed may be determined depending on the aspect ratio of the shape.
In the memory accessing method according to the present invention, the addresses to be accessed may be selected from a plurality of patterns.
In another aspect, the present invention provides a data processing apparatus for performing pre-set data processing by simultaneously accessing a plurality of addresses on a memory including accessing means for simultaneously accessing a plurality of addresses on the memory, and control means for determining the addresses simultaneously accessed by the accessing means depending on the shape of input data.
In the data processing apparatus of the present invention, data is picture data.
In the data processing apparatus of the present invention, the control means determines the simultaneously accessed addresses depending on the aspect ratio of the shape of the input data.
In the data processing apparatus of the present invention, the control means selects the accessed addresses from plural patterns.
Brief Description of The Drawings Fig.l is a block diagram showing the structure of a video game machine employing a data processing device according to the present invention.
Fig.2 is a bock diagram showing the structure of a picture processing device of the video game machine and a frame buffer.
Fig.3 is a block diagram showing the structure of a second bus switcher of the picture processing device.
Fig.4 illustrates accessing the inside of a first polygon drawn on a memory bank of the frame buffer.
Fig.5 illustrates an interleaving pattern to be accessed when accessing the inside of a first polygon.
Fig.6 illustrates masking processing in case of accessing the inside of the first polygon on the address basis.
Fig.7 illustrates an accessing address obtained by the masking processing.
Fig.8 illustrates accessing the inside of the shape of a second polygon drawn on a memory bank of the frame buffer with a (4x4) interleaving pattern.
Fig.9 illustrates an interleaving pattern to be accessed when having access to the inside of the second polygon with the (4x4) interleaving pattern.
Fig.lO illustrates masking processing when having access to the inside of the shape of the second polygon on the basis of the (4x4) interleaving pattern.
Fig.ll illustrates accessing the inside of the shape of the second polygon with a (8x2) interleaving pattern.
Fig. l2 illustrates an interleaving pattern to be accessed when having access to the inside of of the shape of the second polygon with the (8x2) interleaving pattern.
Fig.l3 illustrates masking processing when having access to the inside of the shape of the second polygon on the address basis within the (8X2) interleaving pattern.
Fig.l4 illustrates accessing the inside of the shape of the second polygon with a (16X1) interleaving pattern.
Fig. l5 illustrates an interleaving pattern to be accessed when accessing the inside of the shape of the second polygon with a (16X1) interleaving pattern.
Fig.l6 illustrates masking processing when having access to the inside of the shape of the second polygon on the address basis within the (16X1) interleaving pattern.
Fig. l7 illustrates processing for computing the aspect ratio of the shape of the polygon drawn on a memory bank of the above frame buffer.
Fig. l8 is a pattern diagram showing five interleaving patterns each having 16 addresses.
Fig. l9 is a plan view showing a video game machine according to the present invention.
Fig.20 is a back side view of the video game machine.
Fig.21 is a side view showing the video game machine.
Fig.22 is a plan view of a CD-ROM loaded on the video game machine.
Best Mode for Carrying Out the Invention Referring to the drawings, preferred embodiments of the present invention will be explained in detail.
The memory accessing method according to the present invention is carried out by a video game machine configured as shown in Fig.l. The video game machine is an apparatus employing a data processing device according to the present invention.
The video game machine executes a game in accordance with instructions by the user by reading and executing a game program stored in an auxiliary memory device such as an optical disc, and has two sorts of buses, namely a main bus 1 and a sub-bus 2. The main bus 1 and the sub-bus 2 are interconnected via a bus controller 16.
To the main bus 1 are connected a central processing unit (CPU) 11, made up of a micro-processor, a main memory 12, made up of a random access memory (RAM), a main dynamic memory access controller or main DMAC 13, a MPEG decoder 14 and a picture processing unit or graphic processing unit (GPU) 15.
To the sub-bus 2 are connected a subsidiary central processing unit or sub-CPU 21, made up of a micro-processor, a subsidiary memory 22, made up of a random access memory (RAM), a subsidiary dynamic memory accessing controller or sub DMAC 23, a read-only memory (ROM) 24, having stored therein a program, such as an operating system, a sound processing unit (SPU) 25, a communication controller or asynchronous transmission mode (ATM) 26, an auxiliary storage device 27, an input device 28 and a CD-ROM driver 30.
First, on the side of the main bus 1, the bus controller 16 is a device on the main bus 1 for switching between the main bus 1 and the sub-bus 2, and is opened in an initial state.
The main CPU 11 is a device on the main bus 1 operating by a program on the main memory 12. Since the bus controller 16 is open on start-up, the Main CPU 11 reads in a boot program from the ROM
24 on the sub-bus 2 in order to load an aplication program and necessary data from the auxiliary storage device 27 on the main memory 12 or on devices on the sub-bus 2.
On the main CPU 11 is loaded a geometry transfer engine (GTE) 17 for performing processing such as coordinate transformation.
This GTE 17 has a parallel computing mechanism for carrying ut plural computing processing operations in parallel and is responsive to a request for computing processing from the CPU 11 in order to carry out fast processing operations, such as coordinate transformation, light source calculations, matrix or vector operations. Based on the results of computing processing operations by the GTE 17, the main CPU 11 defines a three-dimensional model as a combination of basic unit figures, such as triangles or quadrangles, formulates a drawing command associated with each polygon for drawing a three-dimensional picture and packetizes the drawing command in order to route the resulting command packet to the GPU 15.
The main DMAC 13 is a device on the main bus 1 for performing control such as DMA transfer on the devices on the main bus 1. If the bus controller 16 is open, the main DMAC 13 also controls the devices on the sub-bus 2.
The CPU 15 is a device on the main bus 1 functioning as a rendering processor. This GPU 15 interprets the drawing command sent from the main CPU 11 or main DMAC 13 as command packet and performs rendering processing of calculating Z-values and colors of all pixels making up a polygon for writing pixel data in the frame buffer 18.
The GPU 15 will be explained subsequently in detail.
The MDEC 14 is an I/0 connection device operable in parallel with the main CPU 11 and is a device functioning as a picture expansion engine. The MDEC 14 decodes picture data compressed and encoded by orthogonal transform, such as discrete cosine transform.
On the sub-bus 2, the sub-CPU 21 is a device on the sub-bus 2 operating in accordance with a program on the sub-memory 22.
The sub-DMAC 23 is a device on the sub-bus 2 for performing control such as DMAC transfer for devices on the sub-bus 2. This sub-DMAC 23 can acquire bus rights only when the bus controller 16 is closed.
The SPU 25 is a device on the sub-bus 2 functioning as a sound processor. This SPU 25 is responsive to a sound command sent as a command packet from the sub-CPU 21 or sub-DMAC 23 as a command packet to read out sound source data from the sound memory 29 to output the read-out data.
The ATM 26 s a communication device on the sub-bus 2.
The auxiliary storage device 27 is a data input/output device on the sub-bus 2 and is made up of a non-volatile memory, such as a flash memory. This auxiliary storage device 27 temporarily holds on memory data such as game progress or scores.
The input device 28 is an input device from other equipments, such as a control pad on the sub-bus 2, man-machine interface, picture input or speech input.
The CD-ROM driver 30 is an input device on the sub-bus 2 and reproduces an application program and necessary data from the CD-ROM.
That is, in the above-described video game machine, the geometry processing system, executing geometry processing, such as coordinate transformation, clipping or light source calculations, formulating a drawing command for defining a three-dimensional model as combination of basic unit figures (polygons) such as triangles or quadrangles for drawing a three-dimensional picture, and sending out the drawing command associated with each polygon as command packet to the main bus 1, is made up of the main CPU 11 and the GTE 17 on the main bus 1. Also, in the video game machine, the rendering processing system for formulating pixel data of each polygon based on the drawing command from the geometry processing system for writing a figure in the frame buffer 18 by way of rendering processing for drawing a figure in the frame buffer 18 is constituted by the GPU 15.
The above-mentioned GPU 15 is explained in detail.
Referring to Fig.2, the GPU 15 includes a packet engine 31 connected to the main bus 1 shown in Fig.l and performs rendering processing of writing pixel data of each polygon in the frame buffer 18 by the pre-processor 32 and the drawing engine 33 in accordance with the drawing command sent as a command packet from the main CPU 11 or main DMAC 13 shown in Fig.l over the main bus 1 to the packet engine 31, reading out pixel data of the picture drawn in the frame buffer 18 and furnishing the read-out pixel data via CRT controller 34 as video signals to a television receiver or a monitor receiver, not shown.
The packet engine 31 develops the command packet sent from the main CPU 11 or main DMAC 13 shown in Fig.l over the main bus 1 on a register, not shown.
The pre-processor 32 generates polygon data in accordance with the drawing command sent to the packet engine 31 as command packet and performs pre-set pre-processing, such as polygon division as later explained, on the polygon data, while generating various data such as apex point coordinate information for the respective polygons required by the drawing engine 33, address information such as texture or MIP map texture, or control information, such as pixel interleaving.
The drawing engine 33 includes N polygon engines 33A1, 33A2, ..., 33AN, connected to the pre-processor 32, N texture engines 33B1, 33B2, ..., 33BN, connected to the polygon engines 33A1, 33A2, ..., 33AN, a first bus switcher 33C, connected to the texture engines 33B1, 33B2, . . . , 33BN, M pixel engines 33D1, 33D2, . . . , 33DM, connected to the first bus switcher 33C, a second bus switcher 33E, connected to the pixel engines 33D1, 33D2, ..., 33DM, a texture cache 33F connected to the second bus switcher 33E, and a GLUT cache 33G connected to the texture cache 33F.
In the drawing engine 33, the N polygon engines 33A1, 33A2, ..., 33AN sequentially generate polygons in accordance with the drawing command on the basis of the polygon data pre-processed by the pre-processor 32 for performing parallel shading processing from one polygon to another.
The N texture engines 33B1, 33B2,..., 33BN perform texture mapping or MIP map processing in parallel, based on the texture data supplied from the texture cache 33F via color lookup table (CLUT) cache 33G, on the polygons generated by the polygon engines 33A1, 33A2, ..., 33AN.
The pre-processor 32 previously furnishes the address information, such as texture or MIP map texture, bonded to the polygons processed by the N texture engines 33B1, 33B2, ..., 33BN, to the texture cache 33F. Based on the above address information, the necessary texture data is transferred from the texture area on the frame buffer 18. To the GLUT cache 33G CLUT data to be referred to during texture drawing is transferred from the CLUT
area on the frame buffer 18.
The polygon data, processed with texture mapping or MIP map processing by the N texture engines 33B1, 33B2, ..., 33BN, are transferred via first bus switcher 33C to M pixel engines 33D1, 33D2, ..., 33DM.
The M pixel engines 33D1, 33D2, ..., 33DM perform various picture processing operations, such as Z-buffer processing or anti-aliasing processing, in parallel, for generating M pixel data.
The M pixel data, generated by the M pixel engines 33D1, 33D2, ..., 33DM, are written in the frame buffer 18 via second bus switcher 33E.
The second bus switcher 33E is fed with the pixel interleaving control information from the pre-processor 32. The second bus switcher 33E as a function of performing pixel interleaving processing of selecting L pixel data from the M pixel data generated by the M pixel engines 33D1, 33D2, ..., 33DM in accordance with the above control information for writing M pixel data using the M storage locations conforming to the shape of the polygon drawn on the frame buffer 18 as accessing unit.
The pixel interleaving processing performed by the second bus switcher 33E will be explained subsequently.
The drawing engine 33 generates and writes all pixel data of each polygon in the frame buffer 18, based on the polygon data pre-processed by the pre-processor 32, for drawing a picture defined as the combination of the polygons by the drawing command on the frame buffer 18.
Thus the pixel data of the picture drawn on the frame buffer 18 is read out by the second bus switcher 33E so as to be furnished via CRTC 34 as video signals to a television receiver or to a monitor receiver, not shown.
The pixel interleaving processing performed by the above-mentioned second bus switcher 33E is now specifically explained.
Referring to Fig.3, the second bus switcher 33E includes a control circuit 101 fed with an output of the pre-processor 32 shown in Fig.2, a selector 102 fed with an output of the control circuit 101 and plural multiplexer/demultiplexers (MUX/DMUX) 103a, 103b, 103c, 103d, ... each fed with an output of the selector 102.
The MUX/DMUX 103a, 103b, 103c, 103d, ... are connected to the frame buffer 18 and to the drawing engine 33 shown in Fig.2.
The frame buffer 18 is made up of plural memory banks [1] , [2] , . . . , [X] , . . . , [L] , as shown in Fig.2. Each of the memory banks [1], [2], ..., [X], ..., [L] is made up of a rectangular area represented by 16 addresses (interleaving patterns), so that the 16 addresses can be accessed simultaneously.
Therefore, the memory bank [X], for example, of the frame buffer 18, has 16 input/output ports Po to P15 for accessing the addresses Ao to A15. Of the MUX/DMUX 103a, 103b, 103c, 103d, ... , the four MUX/DMUX 103a, 103b, 103c, 103d are each connected to 16 input/output ports Po to P15.
Also, the four MUX/DMUX 103a, 103b, 103c, 103d are connected in association with four pixel engines 33DX1, 33DX2, 33DX3 and 33DX4 of the drawing engine 33.
Since the memory banks other than the memory bank [X] are configured similarly to the above-mentioned memory bank [X], the detailed description therefor is not made for simplicity. The accessing operation performed by the second bus switcher 33E on the other memory banks is similar to that performed by the second bus switcher 33E on the memory bank [X] as later explained. Therefore, in the following description, only the accessing operation performed by the second bus switcher 33E on the memory bank [X] is explained.
First, a series of operations by the second bus switcher 33E
is explained.
If, for example, the shape of a polygon drawn on the memory bank [X] is a triangle TAHC (the shape of the first polygon) as shown in Fig.4, the control circuit 101 is first fed from the pre-processor 32 with the pixel interleaving control information.
Based on the pixel interleaving control information from the pre-processor 32, the control circuit 101 changes over an interleaving pattern, used for accessing the inside of the triangle TABS, to, for example, a (4X4) interleaving pattern.
The method for changing over the interleaving pattern in the control circuit 101 will be later explained in detail.
Of plural interleaving patterns formed on the memory bank [X], such interleaving pattern to be accessed, that is, such interleaving pattern as permits the inside of the triangle TABS to be accessed in its entirety, is detected by the control circuit 101, with the aid of the (4x4) interleaving pattern.
Thus, in the triangle T~~, if each interleaving pattern on the memory bank [X] is indicated by P (pattern index in the x-direction and pattern index in the y-direction), a sum total of 20 interleaving patterns specified by P(x,y) - P(3,I), P(4,I), P(1,2), P(2,2), P(3,2), P(4,2), P(1,3), P(2,3), P(3,3), P(4,3), P(5,3), P(2,4), P(3,4), P(4,4), P(5,4), P(3,5), P(4,5), P(5,5), P(4,6), P(5,6) are detected, as shown in Fig.5.
The control circuit 101 routes the pattern information specifying the 20 interleaving patterns, detected as described above, to the selector 102 on the interleaving pattern basis. When performing memory accessing on the address basis, the control circuit 101 routes the mask information corresponding to the shape of the triangle TAH~ to the selector 102.
Based on the pattern information, supplied from the control circuit 101 on the interleaving patten basis, the selector 102 designates the address corresponding to the (4x4) interleaving pattern P to be accessed for the MUX/DMUX I03a, 103b, 103c and 103d.
If fed with the mask information from the control circuit 101, the selector 102 designates for MUX/DMUX 103a to 103d the accessing addresses obtained as a result of masking performed in the (4x4) interleaving patterns P, on the basis of the masking information, as shown in Fig.6. Thus, of the addresses Ao to A15 in the interleaving pattern specified by P(4,1) shown in Fig.6, the addresses to be accessed, obtained as the result of masking, are A4, A5, A6, A8, A9, A10, A13, A14 and A15, shown shaded in Fig.7.
The MUX/DMUX 103a, 103b, 103c and 103d access the addressees Ao to A15 on the memory bank [X] designated by the selector 102.
The pixel engines 33DX1, 33Dx2, 33DX3 and 33DX4 output pixel data to the MUX/DMUX 103a, 103b, 103c and 103d, respectively, as explained previously.
Thus the MUX/DMUX 103a accesses the address designated by the selector 102 to write pixel data from the pixel engine Xa, via one of the input/output ports Po to P15 corresponding to the address designated by the selector 102, in an area on the memory bank [X]
designated by the above address.
The MUX/DMUX 103a accesses the address designated by the selector 102 to read out data written in an area designated by the address on the memory bank [X] via one of the input/output ports Po to P15 corresponding to the above address. The MUX/DMUX 103a performs pre-set processing on the data read out from the memory bank [X].
Since the operation of the MUX/DMUX 103b to 103d is similar to the above-described operation of the MUX/DMUX 103a, detailed description therefor is omitted for clarity.
The method for changing over the interleaving patterns in the above-described control circuit 101 is now specifically explained.
First, the number of times of accessing the inside of a transversely elongated triangle TpEF (shape of a second polygon) as the shape of a polygon drawn on the memory bank [X] shown in Fig.8 with a (4x4) interleaving pattern P is explained.
In this case, the interleaving patterns to be accessed are:
P(x,y) - P(1,1), P(2,1), P(3,1), P(4,1), P(5,1), P(0,2), P(1,2), P(2,2), P(3,2), P(4,2), P(5,2), P(6,2), P(7,2), P(8,2), P(7,3), P(8,3), P(9,3), totaling at 17, as shown in Fig.9.
That is, for accessing the inside of the triangle TDEF with the (4x4) interleaving pattern, the number of times of accessing for accessing the inside of the triangle TDSF in its entirety is 17.
In case of accessing on the address basis, only the required memory addresses can be accessed by carrying out the masking in the (4X4) interleaving pattern P, as in case of accessing the above-mentioned triangle TABS, as shown in Fig.lO.
Then, if the inside of the triangle TDEF is accessed with an (8X2) interleaving pattern, as shown in Fig.ll, the interleaving patterns to be accessed are P1(x,Y) - P1(1,2), P1(2,2), P1(0,3), P1(1,3), P1(2,3), P1(0,4), P1(1,4), P1(2,4), P1(3,4), P1(1,5), P1(2,5), P1(3,5), P1(4,5), P1(3,6), P1(4, 6) , totaling at 15, as shown in Fig. l2.
That is, if the inside of the triangle TDEF is accessed with the (8X2) interleaving pattern, the number of times of accessing required for accessing the entire inside of the triangle TDEF is 15.
In case of accessing on the address basis, masking is performed within the (8X2) interleaving pattern P1 as in case of accessing the triangle TAB as described above, as shown in Fig. l3, for accessing only the needed memory address.
Then, if the inside of the triangle TDEF is accessed with a (16X1) interleaving pattern, as shown in Fig. l4, the interleaving patterns to be accessed are PZ(X~Y) - PZ(0~~5) ~ PZ(1~5) PZ(0,6), PZ(1,6), PZ(0,7), PZ(1,7), PZ(0,8), PZ(1,8), PZ(0,9), PZ(1,9), PZ(0,10), PZ(1,10), PZ(2,10), PZ(1,11), PZ(2, 11) , PZ(1, 12) , PZ(2, 12) , PZ(2, 13)' totaling at 18, as shown in Fig. l5.
That is, if the inside of the triangle TpEF is accessed with the (16x1) interleaving pattern, the number of times of accessing required for accessing the entire inside of the triangle TDEF is 18.
In case of accessing on the address basis, masking is performed within the (8x2) interleaving pattern PZ as in case of accessing the triangle TABS as described above, as shown in Fig. l6, for accessing only the needed memory address.
As described above, the number of times of accessing the inside of the triangle TDEF with the (4x4) interleaving pattern P is 17, while that of accessing the inside of the triangle TDEF with the (8x2) interleaving pattern P1 is 15 and that of accessing the inside of the triangle TDEF with the (16x1) interleaving pattern P2 is 18. Thus, the number of times of accessing the inside of the triangle TDEF with the (8x2) interleaving pattern P1 represents the minimum number of times of accessing. Thus it is seen that a proper interleaving pattern for the triangle TpEF is the (8x2) interleaving pattern P1.
Thus, for switching the interleaving pattern used for accessing the memory bank [X] to a proper interleaving pattern in meeting with the shape of the polygon to be accessed, the control circuit 101 executes the following processing operations.
If, for example, the shape of a polygon drawn on the memory bank [X] is a triangle THZa, the control information for pixel interleaving is supplied from the pre-processor 32 to the control circuit 101, as described above. For example, the control information for pixel interleaving is such information as xy coordinates H (Xh, Yh), I (Xi, Yi) or J (Xj, Yj) of three apex points of the triangle THIJ.
The control circuit 101 then finds, using the control information for pixel interleaving from the pre-processor 32, the aspect ratio R of the triangle THrJ, bY calculations:
R = dy/dx - (MAXx - MINx)/(MAXy - MINy) where MAXx and MINx are maximum and minimum values in the X-direction, respectively, and MAXy and MINy are maximum and minimum values in the Y-direction, respectively, as shown in Fig. l7.
In the triangle THIJ, MAXx = Xj MINx = Xi MAXy = Yh MINy = Yi.
Depending on the aspect ratio R, thus found, the control circuit 101 selects one of five interleaving patterns Pa to Pe of (1x16), (2X8), (4X4), (8x2) and (16x1), as shown in Fig.l8, and switches the interleaving pattern used in accessing the inside of the triangle THia to the selected interleaving pattern.
The control circuit 101 has a table for the aspect ratio R and interleaving patterns (Table 1). In this table are pre-set proper interleaving patterns associated with various values of the aspect ratio R, that is such an interleaving pattern as minimizes the number of times of accessing. Thus the control circuit 101 selects, using the above table, a proper interleaving pattern associated with the aspect ratio R found as described above.
aspect ratio interleaving R pattern - 0.1 Pa (16x1) 0.1 ~ 0.5 Pb (8 X2) 0.5 - 2.0 Pc (4 X4) 2.0 - 8.0 Pd (2 X8) 8.0 ~ Pe (1 x16) In the second bus switcher 33E, a proper one of five interleaving patterns Pa to Pe shown in Fig. l8 is selected responsive to the shape of the polygon to be drawn on the memory bank [X], which is then accessed with the selected interleaving pattern, so that the polygon can be drawn on the memory bank [X]
with the minimum number of accessing operations. Thus it is possible for the second bus switcher 33E to effect memory accessing efficiently.
The GPU 15 accesses the frame buffer 18 by the second bus switcher 33E aimed at raising the memory accessing efficiency, for performing various data processing operations, as described above, for realizing efficient data processing operations.
A video game machine embodying the present invention is configured as shown for example in a plan view of Fig. l9, a front view of Fig.20 and in a side view of Fig.2l.
That is, the present video game machine 201 is basically made up of a main body member 202 and an operating device 217 connected to the main body member 202 via a cable 227, as shown in Fig.l9. At a mid portion on the upper surface of the main body member 202 is mounted a disc loading unit 203 within which is loaded a CD-ROM 251 shown in Fig.22. On the left side of the disc loading unit 203 are mounted a power source switch 205 operated for turning on or off the device and a reset switch 204 operated for transiently resetting the game. On the right side of the disc loading unit 203 is mounted a disc actuating switch 206 operated for mounting or dismounting the CD-ROM 251 with respect to the disc loading unit 203.
On the front side of the main body member 202 are mounted connecting portions 207A, 207B, as shown in Fig.20. These connecting portions 207A, 207B are provided with a connection terminal 226 provided on the foremast part of the cable 227 derived from the operating device 217 and a connection terminal inserting portion 212 for connecting a recording device 228, such as a memory card, and a recording/inserting portion 208. That is, two each of the operating devices 217 and recording devices 228 can be connected to the main body member 202.
The front view of Fig.20 shows the state in which the connection terminal portion 226 and the recording device 228 are loaded on the right side connecting portion 207B with none of the connecting terminal portion 226 nor the recording device 228 being loaded on the left side connecting portion 207A. The recording inserting portion 208 for loading the recording device 228 thereon is provided with the shutter 209. When loading the recording device 228 on the main body member 202, the shutter 209 is thrust by the foremost part of the recording device 228 to effect loading.
The connecting terminal portion 226 has a knurled gripping part 231A for anti-slip effect. Similarly, the recording device 228 has a knurled gripping part 242A for anti-slip effect.
Referring to a side view of Fig.2l, the connecting terminal portion 226 has a length L substantially equal to a length of the recording device 228.
The operating device 27 has supports 220, 221 that can be gripped with left and right hands. The foremost parts of the supports 220, 221 are provided with operating parts 218, 219, respectively. The operating parts 224, 225 are operated with index fingers of both hands, while the operating parts 218, 219 are operated with thumbs of both hands.
Between the operating parts 218 and 219 are provided a select switch 222 that is actuated for selection during the game and a start switch 223 operated for starting the game.
With the present video game machine 201, the CD-ROM 251 loaded on the disc loading unit 203 is reproduced by the CD-ROM driver 30.
The operating device 217 is equivalent to the above-mentioned input device 28, while the recording device 228 is equivalent to the auxiliary storage device 27.
According to the present invention, as described above, the addresses for accessing plural addresses on the memory are switched depending on the shape on the memory of data desired to be accessed, for thereby decreasing the number of times of memory accessing operations even if the shape represented by plural simultaneously accessible address is not coincident with the shape on the memory of data desired to be accessed. Thus, the memory can be accessed with a smaller number of accessing operations, thus raising the memory accessing efficiency.
Also, according to the present invention, if the above data is picture data, the number of times of accessing the memory can be decreased even in case wherein the shape represented by plural simultaneously accessible addresses is not coincident with the picture drawn on a picture memory.
Also, according to the memory accessing method of the present invention, the addresses to be accessed can be switched depending on the aspect ratio of the above shape for selecting a proper address for accessing in meeting with the data desired to be accesses. The result is that the memory can be accessed with the minimum number of times of accessing operations.
In the memory accessing method according to the present invention, the addresses to be accessed may be selected from a plurality of patterns.
In another aspect, the present invention provides a data processing apparatus for performing pre-set data processing by simultaneously accessing a plurality of addresses on a memory including accessing means for simultaneously accessing a plurality of addresses on the memory, and control means for determining the addresses simultaneously accessed by the accessing means depending on the shape of input data.
In the data processing apparatus of the present invention, data is picture data.
In the data processing apparatus of the present invention, the control means determines the simultaneously accessed addresses depending on the aspect ratio of the shape of the input data.
In the data processing apparatus of the present invention, the control means selects the accessed addresses from plural patterns.
Brief Description of The Drawings Fig.l is a block diagram showing the structure of a video game machine employing a data processing device according to the present invention.
Fig.2 is a bock diagram showing the structure of a picture processing device of the video game machine and a frame buffer.
Fig.3 is a block diagram showing the structure of a second bus switcher of the picture processing device.
Fig.4 illustrates accessing the inside of a first polygon drawn on a memory bank of the frame buffer.
Fig.5 illustrates an interleaving pattern to be accessed when accessing the inside of a first polygon.
Fig.6 illustrates masking processing in case of accessing the inside of the first polygon on the address basis.
Fig.7 illustrates an accessing address obtained by the masking processing.
Fig.8 illustrates accessing the inside of the shape of a second polygon drawn on a memory bank of the frame buffer with a (4x4) interleaving pattern.
Fig.9 illustrates an interleaving pattern to be accessed when having access to the inside of the second polygon with the (4x4) interleaving pattern.
Fig.lO illustrates masking processing when having access to the inside of the shape of the second polygon on the basis of the (4x4) interleaving pattern.
Fig.ll illustrates accessing the inside of the shape of the second polygon with a (8x2) interleaving pattern.
Fig. l2 illustrates an interleaving pattern to be accessed when having access to the inside of of the shape of the second polygon with the (8x2) interleaving pattern.
Fig.l3 illustrates masking processing when having access to the inside of the shape of the second polygon on the address basis within the (8X2) interleaving pattern.
Fig.l4 illustrates accessing the inside of the shape of the second polygon with a (16X1) interleaving pattern.
Fig. l5 illustrates an interleaving pattern to be accessed when accessing the inside of the shape of the second polygon with a (16X1) interleaving pattern.
Fig.l6 illustrates masking processing when having access to the inside of the shape of the second polygon on the address basis within the (16X1) interleaving pattern.
Fig. l7 illustrates processing for computing the aspect ratio of the shape of the polygon drawn on a memory bank of the above frame buffer.
Fig. l8 is a pattern diagram showing five interleaving patterns each having 16 addresses.
Fig. l9 is a plan view showing a video game machine according to the present invention.
Fig.20 is a back side view of the video game machine.
Fig.21 is a side view showing the video game machine.
Fig.22 is a plan view of a CD-ROM loaded on the video game machine.
Best Mode for Carrying Out the Invention Referring to the drawings, preferred embodiments of the present invention will be explained in detail.
The memory accessing method according to the present invention is carried out by a video game machine configured as shown in Fig.l. The video game machine is an apparatus employing a data processing device according to the present invention.
The video game machine executes a game in accordance with instructions by the user by reading and executing a game program stored in an auxiliary memory device such as an optical disc, and has two sorts of buses, namely a main bus 1 and a sub-bus 2. The main bus 1 and the sub-bus 2 are interconnected via a bus controller 16.
To the main bus 1 are connected a central processing unit (CPU) 11, made up of a micro-processor, a main memory 12, made up of a random access memory (RAM), a main dynamic memory access controller or main DMAC 13, a MPEG decoder 14 and a picture processing unit or graphic processing unit (GPU) 15.
To the sub-bus 2 are connected a subsidiary central processing unit or sub-CPU 21, made up of a micro-processor, a subsidiary memory 22, made up of a random access memory (RAM), a subsidiary dynamic memory accessing controller or sub DMAC 23, a read-only memory (ROM) 24, having stored therein a program, such as an operating system, a sound processing unit (SPU) 25, a communication controller or asynchronous transmission mode (ATM) 26, an auxiliary storage device 27, an input device 28 and a CD-ROM driver 30.
First, on the side of the main bus 1, the bus controller 16 is a device on the main bus 1 for switching between the main bus 1 and the sub-bus 2, and is opened in an initial state.
The main CPU 11 is a device on the main bus 1 operating by a program on the main memory 12. Since the bus controller 16 is open on start-up, the Main CPU 11 reads in a boot program from the ROM
24 on the sub-bus 2 in order to load an aplication program and necessary data from the auxiliary storage device 27 on the main memory 12 or on devices on the sub-bus 2.
On the main CPU 11 is loaded a geometry transfer engine (GTE) 17 for performing processing such as coordinate transformation.
This GTE 17 has a parallel computing mechanism for carrying ut plural computing processing operations in parallel and is responsive to a request for computing processing from the CPU 11 in order to carry out fast processing operations, such as coordinate transformation, light source calculations, matrix or vector operations. Based on the results of computing processing operations by the GTE 17, the main CPU 11 defines a three-dimensional model as a combination of basic unit figures, such as triangles or quadrangles, formulates a drawing command associated with each polygon for drawing a three-dimensional picture and packetizes the drawing command in order to route the resulting command packet to the GPU 15.
The main DMAC 13 is a device on the main bus 1 for performing control such as DMA transfer on the devices on the main bus 1. If the bus controller 16 is open, the main DMAC 13 also controls the devices on the sub-bus 2.
The CPU 15 is a device on the main bus 1 functioning as a rendering processor. This GPU 15 interprets the drawing command sent from the main CPU 11 or main DMAC 13 as command packet and performs rendering processing of calculating Z-values and colors of all pixels making up a polygon for writing pixel data in the frame buffer 18.
The GPU 15 will be explained subsequently in detail.
The MDEC 14 is an I/0 connection device operable in parallel with the main CPU 11 and is a device functioning as a picture expansion engine. The MDEC 14 decodes picture data compressed and encoded by orthogonal transform, such as discrete cosine transform.
On the sub-bus 2, the sub-CPU 21 is a device on the sub-bus 2 operating in accordance with a program on the sub-memory 22.
The sub-DMAC 23 is a device on the sub-bus 2 for performing control such as DMAC transfer for devices on the sub-bus 2. This sub-DMAC 23 can acquire bus rights only when the bus controller 16 is closed.
The SPU 25 is a device on the sub-bus 2 functioning as a sound processor. This SPU 25 is responsive to a sound command sent as a command packet from the sub-CPU 21 or sub-DMAC 23 as a command packet to read out sound source data from the sound memory 29 to output the read-out data.
The ATM 26 s a communication device on the sub-bus 2.
The auxiliary storage device 27 is a data input/output device on the sub-bus 2 and is made up of a non-volatile memory, such as a flash memory. This auxiliary storage device 27 temporarily holds on memory data such as game progress or scores.
The input device 28 is an input device from other equipments, such as a control pad on the sub-bus 2, man-machine interface, picture input or speech input.
The CD-ROM driver 30 is an input device on the sub-bus 2 and reproduces an application program and necessary data from the CD-ROM.
That is, in the above-described video game machine, the geometry processing system, executing geometry processing, such as coordinate transformation, clipping or light source calculations, formulating a drawing command for defining a three-dimensional model as combination of basic unit figures (polygons) such as triangles or quadrangles for drawing a three-dimensional picture, and sending out the drawing command associated with each polygon as command packet to the main bus 1, is made up of the main CPU 11 and the GTE 17 on the main bus 1. Also, in the video game machine, the rendering processing system for formulating pixel data of each polygon based on the drawing command from the geometry processing system for writing a figure in the frame buffer 18 by way of rendering processing for drawing a figure in the frame buffer 18 is constituted by the GPU 15.
The above-mentioned GPU 15 is explained in detail.
Referring to Fig.2, the GPU 15 includes a packet engine 31 connected to the main bus 1 shown in Fig.l and performs rendering processing of writing pixel data of each polygon in the frame buffer 18 by the pre-processor 32 and the drawing engine 33 in accordance with the drawing command sent as a command packet from the main CPU 11 or main DMAC 13 shown in Fig.l over the main bus 1 to the packet engine 31, reading out pixel data of the picture drawn in the frame buffer 18 and furnishing the read-out pixel data via CRT controller 34 as video signals to a television receiver or a monitor receiver, not shown.
The packet engine 31 develops the command packet sent from the main CPU 11 or main DMAC 13 shown in Fig.l over the main bus 1 on a register, not shown.
The pre-processor 32 generates polygon data in accordance with the drawing command sent to the packet engine 31 as command packet and performs pre-set pre-processing, such as polygon division as later explained, on the polygon data, while generating various data such as apex point coordinate information for the respective polygons required by the drawing engine 33, address information such as texture or MIP map texture, or control information, such as pixel interleaving.
The drawing engine 33 includes N polygon engines 33A1, 33A2, ..., 33AN, connected to the pre-processor 32, N texture engines 33B1, 33B2, ..., 33BN, connected to the polygon engines 33A1, 33A2, ..., 33AN, a first bus switcher 33C, connected to the texture engines 33B1, 33B2, . . . , 33BN, M pixel engines 33D1, 33D2, . . . , 33DM, connected to the first bus switcher 33C, a second bus switcher 33E, connected to the pixel engines 33D1, 33D2, ..., 33DM, a texture cache 33F connected to the second bus switcher 33E, and a GLUT cache 33G connected to the texture cache 33F.
In the drawing engine 33, the N polygon engines 33A1, 33A2, ..., 33AN sequentially generate polygons in accordance with the drawing command on the basis of the polygon data pre-processed by the pre-processor 32 for performing parallel shading processing from one polygon to another.
The N texture engines 33B1, 33B2,..., 33BN perform texture mapping or MIP map processing in parallel, based on the texture data supplied from the texture cache 33F via color lookup table (CLUT) cache 33G, on the polygons generated by the polygon engines 33A1, 33A2, ..., 33AN.
The pre-processor 32 previously furnishes the address information, such as texture or MIP map texture, bonded to the polygons processed by the N texture engines 33B1, 33B2, ..., 33BN, to the texture cache 33F. Based on the above address information, the necessary texture data is transferred from the texture area on the frame buffer 18. To the GLUT cache 33G CLUT data to be referred to during texture drawing is transferred from the CLUT
area on the frame buffer 18.
The polygon data, processed with texture mapping or MIP map processing by the N texture engines 33B1, 33B2, ..., 33BN, are transferred via first bus switcher 33C to M pixel engines 33D1, 33D2, ..., 33DM.
The M pixel engines 33D1, 33D2, ..., 33DM perform various picture processing operations, such as Z-buffer processing or anti-aliasing processing, in parallel, for generating M pixel data.
The M pixel data, generated by the M pixel engines 33D1, 33D2, ..., 33DM, are written in the frame buffer 18 via second bus switcher 33E.
The second bus switcher 33E is fed with the pixel interleaving control information from the pre-processor 32. The second bus switcher 33E as a function of performing pixel interleaving processing of selecting L pixel data from the M pixel data generated by the M pixel engines 33D1, 33D2, ..., 33DM in accordance with the above control information for writing M pixel data using the M storage locations conforming to the shape of the polygon drawn on the frame buffer 18 as accessing unit.
The pixel interleaving processing performed by the second bus switcher 33E will be explained subsequently.
The drawing engine 33 generates and writes all pixel data of each polygon in the frame buffer 18, based on the polygon data pre-processed by the pre-processor 32, for drawing a picture defined as the combination of the polygons by the drawing command on the frame buffer 18.
Thus the pixel data of the picture drawn on the frame buffer 18 is read out by the second bus switcher 33E so as to be furnished via CRTC 34 as video signals to a television receiver or to a monitor receiver, not shown.
The pixel interleaving processing performed by the above-mentioned second bus switcher 33E is now specifically explained.
Referring to Fig.3, the second bus switcher 33E includes a control circuit 101 fed with an output of the pre-processor 32 shown in Fig.2, a selector 102 fed with an output of the control circuit 101 and plural multiplexer/demultiplexers (MUX/DMUX) 103a, 103b, 103c, 103d, ... each fed with an output of the selector 102.
The MUX/DMUX 103a, 103b, 103c, 103d, ... are connected to the frame buffer 18 and to the drawing engine 33 shown in Fig.2.
The frame buffer 18 is made up of plural memory banks [1] , [2] , . . . , [X] , . . . , [L] , as shown in Fig.2. Each of the memory banks [1], [2], ..., [X], ..., [L] is made up of a rectangular area represented by 16 addresses (interleaving patterns), so that the 16 addresses can be accessed simultaneously.
Therefore, the memory bank [X], for example, of the frame buffer 18, has 16 input/output ports Po to P15 for accessing the addresses Ao to A15. Of the MUX/DMUX 103a, 103b, 103c, 103d, ... , the four MUX/DMUX 103a, 103b, 103c, 103d are each connected to 16 input/output ports Po to P15.
Also, the four MUX/DMUX 103a, 103b, 103c, 103d are connected in association with four pixel engines 33DX1, 33DX2, 33DX3 and 33DX4 of the drawing engine 33.
Since the memory banks other than the memory bank [X] are configured similarly to the above-mentioned memory bank [X], the detailed description therefor is not made for simplicity. The accessing operation performed by the second bus switcher 33E on the other memory banks is similar to that performed by the second bus switcher 33E on the memory bank [X] as later explained. Therefore, in the following description, only the accessing operation performed by the second bus switcher 33E on the memory bank [X] is explained.
First, a series of operations by the second bus switcher 33E
is explained.
If, for example, the shape of a polygon drawn on the memory bank [X] is a triangle TAHC (the shape of the first polygon) as shown in Fig.4, the control circuit 101 is first fed from the pre-processor 32 with the pixel interleaving control information.
Based on the pixel interleaving control information from the pre-processor 32, the control circuit 101 changes over an interleaving pattern, used for accessing the inside of the triangle TABS, to, for example, a (4X4) interleaving pattern.
The method for changing over the interleaving pattern in the control circuit 101 will be later explained in detail.
Of plural interleaving patterns formed on the memory bank [X], such interleaving pattern to be accessed, that is, such interleaving pattern as permits the inside of the triangle TABS to be accessed in its entirety, is detected by the control circuit 101, with the aid of the (4x4) interleaving pattern.
Thus, in the triangle T~~, if each interleaving pattern on the memory bank [X] is indicated by P (pattern index in the x-direction and pattern index in the y-direction), a sum total of 20 interleaving patterns specified by P(x,y) - P(3,I), P(4,I), P(1,2), P(2,2), P(3,2), P(4,2), P(1,3), P(2,3), P(3,3), P(4,3), P(5,3), P(2,4), P(3,4), P(4,4), P(5,4), P(3,5), P(4,5), P(5,5), P(4,6), P(5,6) are detected, as shown in Fig.5.
The control circuit 101 routes the pattern information specifying the 20 interleaving patterns, detected as described above, to the selector 102 on the interleaving pattern basis. When performing memory accessing on the address basis, the control circuit 101 routes the mask information corresponding to the shape of the triangle TAH~ to the selector 102.
Based on the pattern information, supplied from the control circuit 101 on the interleaving patten basis, the selector 102 designates the address corresponding to the (4x4) interleaving pattern P to be accessed for the MUX/DMUX I03a, 103b, 103c and 103d.
If fed with the mask information from the control circuit 101, the selector 102 designates for MUX/DMUX 103a to 103d the accessing addresses obtained as a result of masking performed in the (4x4) interleaving patterns P, on the basis of the masking information, as shown in Fig.6. Thus, of the addresses Ao to A15 in the interleaving pattern specified by P(4,1) shown in Fig.6, the addresses to be accessed, obtained as the result of masking, are A4, A5, A6, A8, A9, A10, A13, A14 and A15, shown shaded in Fig.7.
The MUX/DMUX 103a, 103b, 103c and 103d access the addressees Ao to A15 on the memory bank [X] designated by the selector 102.
The pixel engines 33DX1, 33Dx2, 33DX3 and 33DX4 output pixel data to the MUX/DMUX 103a, 103b, 103c and 103d, respectively, as explained previously.
Thus the MUX/DMUX 103a accesses the address designated by the selector 102 to write pixel data from the pixel engine Xa, via one of the input/output ports Po to P15 corresponding to the address designated by the selector 102, in an area on the memory bank [X]
designated by the above address.
The MUX/DMUX 103a accesses the address designated by the selector 102 to read out data written in an area designated by the address on the memory bank [X] via one of the input/output ports Po to P15 corresponding to the above address. The MUX/DMUX 103a performs pre-set processing on the data read out from the memory bank [X].
Since the operation of the MUX/DMUX 103b to 103d is similar to the above-described operation of the MUX/DMUX 103a, detailed description therefor is omitted for clarity.
The method for changing over the interleaving patterns in the above-described control circuit 101 is now specifically explained.
First, the number of times of accessing the inside of a transversely elongated triangle TpEF (shape of a second polygon) as the shape of a polygon drawn on the memory bank [X] shown in Fig.8 with a (4x4) interleaving pattern P is explained.
In this case, the interleaving patterns to be accessed are:
P(x,y) - P(1,1), P(2,1), P(3,1), P(4,1), P(5,1), P(0,2), P(1,2), P(2,2), P(3,2), P(4,2), P(5,2), P(6,2), P(7,2), P(8,2), P(7,3), P(8,3), P(9,3), totaling at 17, as shown in Fig.9.
That is, for accessing the inside of the triangle TDEF with the (4x4) interleaving pattern, the number of times of accessing for accessing the inside of the triangle TDSF in its entirety is 17.
In case of accessing on the address basis, only the required memory addresses can be accessed by carrying out the masking in the (4X4) interleaving pattern P, as in case of accessing the above-mentioned triangle TABS, as shown in Fig.lO.
Then, if the inside of the triangle TDEF is accessed with an (8X2) interleaving pattern, as shown in Fig.ll, the interleaving patterns to be accessed are P1(x,Y) - P1(1,2), P1(2,2), P1(0,3), P1(1,3), P1(2,3), P1(0,4), P1(1,4), P1(2,4), P1(3,4), P1(1,5), P1(2,5), P1(3,5), P1(4,5), P1(3,6), P1(4, 6) , totaling at 15, as shown in Fig. l2.
That is, if the inside of the triangle TDEF is accessed with the (8X2) interleaving pattern, the number of times of accessing required for accessing the entire inside of the triangle TDEF is 15.
In case of accessing on the address basis, masking is performed within the (8X2) interleaving pattern P1 as in case of accessing the triangle TAB as described above, as shown in Fig. l3, for accessing only the needed memory address.
Then, if the inside of the triangle TDEF is accessed with a (16X1) interleaving pattern, as shown in Fig. l4, the interleaving patterns to be accessed are PZ(X~Y) - PZ(0~~5) ~ PZ(1~5) PZ(0,6), PZ(1,6), PZ(0,7), PZ(1,7), PZ(0,8), PZ(1,8), PZ(0,9), PZ(1,9), PZ(0,10), PZ(1,10), PZ(2,10), PZ(1,11), PZ(2, 11) , PZ(1, 12) , PZ(2, 12) , PZ(2, 13)' totaling at 18, as shown in Fig. l5.
That is, if the inside of the triangle TpEF is accessed with the (16x1) interleaving pattern, the number of times of accessing required for accessing the entire inside of the triangle TDEF is 18.
In case of accessing on the address basis, masking is performed within the (8x2) interleaving pattern PZ as in case of accessing the triangle TABS as described above, as shown in Fig. l6, for accessing only the needed memory address.
As described above, the number of times of accessing the inside of the triangle TDEF with the (4x4) interleaving pattern P is 17, while that of accessing the inside of the triangle TDEF with the (8x2) interleaving pattern P1 is 15 and that of accessing the inside of the triangle TDEF with the (16x1) interleaving pattern P2 is 18. Thus, the number of times of accessing the inside of the triangle TDEF with the (8x2) interleaving pattern P1 represents the minimum number of times of accessing. Thus it is seen that a proper interleaving pattern for the triangle TpEF is the (8x2) interleaving pattern P1.
Thus, for switching the interleaving pattern used for accessing the memory bank [X] to a proper interleaving pattern in meeting with the shape of the polygon to be accessed, the control circuit 101 executes the following processing operations.
If, for example, the shape of a polygon drawn on the memory bank [X] is a triangle THZa, the control information for pixel interleaving is supplied from the pre-processor 32 to the control circuit 101, as described above. For example, the control information for pixel interleaving is such information as xy coordinates H (Xh, Yh), I (Xi, Yi) or J (Xj, Yj) of three apex points of the triangle THIJ.
The control circuit 101 then finds, using the control information for pixel interleaving from the pre-processor 32, the aspect ratio R of the triangle THrJ, bY calculations:
R = dy/dx - (MAXx - MINx)/(MAXy - MINy) where MAXx and MINx are maximum and minimum values in the X-direction, respectively, and MAXy and MINy are maximum and minimum values in the Y-direction, respectively, as shown in Fig. l7.
In the triangle THIJ, MAXx = Xj MINx = Xi MAXy = Yh MINy = Yi.
Depending on the aspect ratio R, thus found, the control circuit 101 selects one of five interleaving patterns Pa to Pe of (1x16), (2X8), (4X4), (8x2) and (16x1), as shown in Fig.l8, and switches the interleaving pattern used in accessing the inside of the triangle THia to the selected interleaving pattern.
The control circuit 101 has a table for the aspect ratio R and interleaving patterns (Table 1). In this table are pre-set proper interleaving patterns associated with various values of the aspect ratio R, that is such an interleaving pattern as minimizes the number of times of accessing. Thus the control circuit 101 selects, using the above table, a proper interleaving pattern associated with the aspect ratio R found as described above.
aspect ratio interleaving R pattern - 0.1 Pa (16x1) 0.1 ~ 0.5 Pb (8 X2) 0.5 - 2.0 Pc (4 X4) 2.0 - 8.0 Pd (2 X8) 8.0 ~ Pe (1 x16) In the second bus switcher 33E, a proper one of five interleaving patterns Pa to Pe shown in Fig. l8 is selected responsive to the shape of the polygon to be drawn on the memory bank [X], which is then accessed with the selected interleaving pattern, so that the polygon can be drawn on the memory bank [X]
with the minimum number of accessing operations. Thus it is possible for the second bus switcher 33E to effect memory accessing efficiently.
The GPU 15 accesses the frame buffer 18 by the second bus switcher 33E aimed at raising the memory accessing efficiency, for performing various data processing operations, as described above, for realizing efficient data processing operations.
A video game machine embodying the present invention is configured as shown for example in a plan view of Fig. l9, a front view of Fig.20 and in a side view of Fig.2l.
That is, the present video game machine 201 is basically made up of a main body member 202 and an operating device 217 connected to the main body member 202 via a cable 227, as shown in Fig.l9. At a mid portion on the upper surface of the main body member 202 is mounted a disc loading unit 203 within which is loaded a CD-ROM 251 shown in Fig.22. On the left side of the disc loading unit 203 are mounted a power source switch 205 operated for turning on or off the device and a reset switch 204 operated for transiently resetting the game. On the right side of the disc loading unit 203 is mounted a disc actuating switch 206 operated for mounting or dismounting the CD-ROM 251 with respect to the disc loading unit 203.
On the front side of the main body member 202 are mounted connecting portions 207A, 207B, as shown in Fig.20. These connecting portions 207A, 207B are provided with a connection terminal 226 provided on the foremast part of the cable 227 derived from the operating device 217 and a connection terminal inserting portion 212 for connecting a recording device 228, such as a memory card, and a recording/inserting portion 208. That is, two each of the operating devices 217 and recording devices 228 can be connected to the main body member 202.
The front view of Fig.20 shows the state in which the connection terminal portion 226 and the recording device 228 are loaded on the right side connecting portion 207B with none of the connecting terminal portion 226 nor the recording device 228 being loaded on the left side connecting portion 207A. The recording inserting portion 208 for loading the recording device 228 thereon is provided with the shutter 209. When loading the recording device 228 on the main body member 202, the shutter 209 is thrust by the foremost part of the recording device 228 to effect loading.
The connecting terminal portion 226 has a knurled gripping part 231A for anti-slip effect. Similarly, the recording device 228 has a knurled gripping part 242A for anti-slip effect.
Referring to a side view of Fig.2l, the connecting terminal portion 226 has a length L substantially equal to a length of the recording device 228.
The operating device 27 has supports 220, 221 that can be gripped with left and right hands. The foremost parts of the supports 220, 221 are provided with operating parts 218, 219, respectively. The operating parts 224, 225 are operated with index fingers of both hands, while the operating parts 218, 219 are operated with thumbs of both hands.
Between the operating parts 218 and 219 are provided a select switch 222 that is actuated for selection during the game and a start switch 223 operated for starting the game.
With the present video game machine 201, the CD-ROM 251 loaded on the disc loading unit 203 is reproduced by the CD-ROM driver 30.
The operating device 217 is equivalent to the above-mentioned input device 28, while the recording device 228 is equivalent to the auxiliary storage device 27.
According to the present invention, as described above, the addresses for accessing plural addresses on the memory are switched depending on the shape on the memory of data desired to be accessed, for thereby decreasing the number of times of memory accessing operations even if the shape represented by plural simultaneously accessible address is not coincident with the shape on the memory of data desired to be accessed. Thus, the memory can be accessed with a smaller number of accessing operations, thus raising the memory accessing efficiency.
Also, according to the present invention, if the above data is picture data, the number of times of accessing the memory can be decreased even in case wherein the shape represented by plural simultaneously accessible addresses is not coincident with the picture drawn on a picture memory.
Also, according to the memory accessing method of the present invention, the addresses to be accessed can be switched depending on the aspect ratio of the above shape for selecting a proper address for accessing in meeting with the data desired to be accesses. The result is that the memory can be accessed with the minimum number of times of accessing operations.
Claims (10)
1. A memory accessing method for simultaneously accessing a plurality of addresses of a memory (18) for data storage, a plurality of predetermined interleaving patterns (Pa, Pb, Pc, Pd, Pe) being provided for use in accessing the memory, the addresses simultaneously accessed being dependent on the predetermined interleaving pattern, the method comprising the steps of:
a) determining a polygon shape (T ABC; T DEF; T HIJ) encompassing a portion of data to be accessed;
b) selecting one of said predetermined Interleaving patterns from said plurality based on the polygon shape determined at said step (a); and c) accessing the portion of data using a plurality of identical interleaving patterns corresponding to the Interleaving pattern selected at said step (b) to encompass co-ordinates of the portion of data to be accessed.
a) determining a polygon shape (T ABC; T DEF; T HIJ) encompassing a portion of data to be accessed;
b) selecting one of said predetermined Interleaving patterns from said plurality based on the polygon shape determined at said step (a); and c) accessing the portion of data using a plurality of identical interleaving patterns corresponding to the Interleaving pattern selected at said step (b) to encompass co-ordinates of the portion of data to be accessed.
2. The method of claim 1 wherein said data is picture data and said step (a) comprises determining a polygon shape encompassing a portion of picture data to be accessed.
3. The method of claim 1, comprising the step of:
d) determining an aspect ratio of the polygon shape encompassing the portion of data to be accessed; and wherein step (b) comprises selecting one of said predetermined interleaving patterns from said plurality based on said aspect ratio of said polygon shape determined at said step (d).
d) determining an aspect ratio of the polygon shape encompassing the portion of data to be accessed; and wherein step (b) comprises selecting one of said predetermined interleaving patterns from said plurality based on said aspect ratio of said polygon shape determined at said step (d).
4. The method of claim 1, wherein said data is picture data for drawing a picture having a three-dimensional appearance, and said step (a) comprises determining a two-dimensional polygon shape encompassing a portion of the picture data to be accessed.
5. The method of claim 1, comprising the step of:
(d) determining an aspect ratio of the polygon shape from the co-ordinates of the portion of data to be accessed encompassed by said polygon shape;
wherein said provided plurality of interleaving patterns correspond respectively to a plurality of ranges of aspect ratios, and said step (b) comprises the step of selecting one of said predetermined interleaving patterns from said plurality such that the number of interleaving patterns required to encompass said portion of data to be accessed is minimized.
(d) determining an aspect ratio of the polygon shape from the co-ordinates of the portion of data to be accessed encompassed by said polygon shape;
wherein said provided plurality of interleaving patterns correspond respectively to a plurality of ranges of aspect ratios, and said step (b) comprises the step of selecting one of said predetermined interleaving patterns from said plurality such that the number of interleaving patterns required to encompass said portion of data to be accessed is minimized.
6. A memory accessing apparatus (15) for simultaneously accessing a plurality of addresses of a memory (18) for data storage, a plurality of predetermined interleaving patterns (Pa, Pb, Pc, Pd, Pe) being provided for use in accessing the memory, the addresses simultaneously accessed being dependent on the predetermined interleaving pattern, the apparatus comprising:
- inputting means (32) operable to determine a polygon shape (T ABC; T DEF; T HIJ) encompassing a portion of data to be accessed;
- control means (101, 102) operable to select one of said predetermined interleaving patterns from said plurality based on the determined polygon shape; and - accessing means (33E, 103a, 103b, 103c, 103d) operable to access the portion of data using a plurality of identical interleaving patterns corresponding to the interleaving pattern selected by the control means to encompass co-ordinates of the portion of data to be accessed.
- inputting means (32) operable to determine a polygon shape (T ABC; T DEF; T HIJ) encompassing a portion of data to be accessed;
- control means (101, 102) operable to select one of said predetermined interleaving patterns from said plurality based on the determined polygon shape; and - accessing means (33E, 103a, 103b, 103c, 103d) operable to access the portion of data using a plurality of identical interleaving patterns corresponding to the interleaving pattern selected by the control means to encompass co-ordinates of the portion of data to be accessed.
7. The apparatus of claim 6, wherein said data is picture data and said inputting means is operable to determine a polygon shape encompassing a portion of picture data to be accessed.
8. The apparatus of claim 6, wherein the control means (101, 102) is operable to determine an aspect ratio of the polygon shape encompassing the portion of data to be accessed; and is further operable to select one of said predetermined interleaving patterns from said plurality based on said aspect ratio of said polygon shape.
9. The apparatus of claim 6, wherein said data is picture data for drawing a picture having a three-dimensional appearance, and said inputting means is operable to determine a two-dimensional polygon shape encompassing a portion of the picture data to be accessed.
10. The apparatus of claim 6, wherein the control means (101, 102) is operable to determine an aspect ratio of the polygon shape from the co-ordinates of the portion of data to be accessed encompassed by said polygon shape, and wherein said provided plurality of interleaving- patterns correspond respectively to a plurality of ranges of aspect ratios, said control means (101, 102) further being operable to select one of said predetermined interleaving patterns from said plurality such that the number of interleaving patterns required to encompass said portion of data to be accessed is minimized.
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JPP8-020330 | 1996-02-06 | ||
JP8020330A JPH09212412A (en) | 1996-02-06 | 1996-02-06 | Memory access method and data processor |
PCT/JP1997/000295 WO1997029427A1 (en) | 1996-02-06 | 1997-02-06 | Memory access method and data processor |
Publications (2)
Publication Number | Publication Date |
---|---|
CA2216698A1 CA2216698A1 (en) | 1997-08-14 |
CA2216698C true CA2216698C (en) | 2005-08-30 |
Family
ID=12024135
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CA002216698A Expired - Fee Related CA2216698C (en) | 1996-02-06 | 1997-02-06 | Method and apparatus for simultaneous shape-dependent access to picture data stored at a plurality of addresses |
Country Status (9)
Country | Link |
---|---|
US (1) | US6172670B1 (en) |
EP (1) | EP0820014B1 (en) |
JP (1) | JPH09212412A (en) |
KR (1) | KR100471905B1 (en) |
CN (1) | CN1094612C (en) |
CA (1) | CA2216698C (en) |
DE (1) | DE69720873T2 (en) |
MX (1) | MX9707534A (en) |
WO (1) | WO1997029427A1 (en) |
Families Citing this family (14)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP0952673B1 (en) * | 1997-11-10 | 2017-05-17 | Ntt Mobile Communications Network Inc. | Interleaving method, interleaving apparatus, and recording medium in which interleave pattern generating program is recorded |
JP2003323339A (en) * | 2002-03-01 | 2003-11-14 | Sony Computer Entertainment Inc | Memory access device, semiconductor device, memory access control method, computer program and recording medium |
US7286134B1 (en) * | 2003-12-17 | 2007-10-23 | Nvidia Corporation | System and method for packing data in a tiled graphics memory |
US7420568B1 (en) | 2003-12-17 | 2008-09-02 | Nvidia Corporation | System and method for packing data in different formats in a tiled graphics memory |
US8269769B1 (en) * | 2003-12-22 | 2012-09-18 | Nvidia Corporation | Occlusion prediction compression system and method |
US8390619B1 (en) | 2003-12-22 | 2013-03-05 | Nvidia Corporation | Occlusion prediction graphics processing system and method |
US8878849B2 (en) * | 2007-12-14 | 2014-11-04 | Nvidia Corporation | Horizon split ambient occlusion |
US8330766B1 (en) | 2008-12-19 | 2012-12-11 | Nvidia Corporation | Zero-bandwidth clears |
US8319783B1 (en) | 2008-12-19 | 2012-11-27 | Nvidia Corporation | Index-based zero-bandwidth clears |
US8326074B2 (en) * | 2009-06-19 | 2012-12-04 | Ricoh Co., Ltd. | Method and apparatus for FIR filtering using space-varying rotation |
US8116587B2 (en) * | 2010-02-16 | 2012-02-14 | Ricoh Co., Ltd. | Method and apparatus for high-speed and low-complexity piecewise geometric transformation of signals |
KR101931566B1 (en) * | 2012-06-07 | 2018-12-21 | 삼성전자주식회사 | Interface circuit, interface system and interfacing method |
US10008029B2 (en) | 2013-05-31 | 2018-06-26 | Nvidia Corporation | Updating depth related graphics data |
US9418400B2 (en) | 2013-06-18 | 2016-08-16 | Nvidia Corporation | Method and system for rendering simulated depth-of-field visual effect |
Family Cites Families (15)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4283724A (en) * | 1979-02-28 | 1981-08-11 | Computer Operations | Variable size dot matrix character generator in which a height signal and an aspect ratio signal actuate the same |
US4484187A (en) * | 1982-06-25 | 1984-11-20 | At&T Bell Laboratories | Video overlay system having interactive color addressing |
JPS60221848A (en) * | 1984-04-18 | 1985-11-06 | Matsushita Electric Ind Co Ltd | Data storage device |
JPH061449B2 (en) * | 1985-03-04 | 1994-01-05 | 富士ゼロックス株式会社 | Image memory for image editing |
US4864629A (en) * | 1985-12-31 | 1989-09-05 | Schlumberger Technologies, Inc. | Image correlation system |
US4882683B1 (en) * | 1987-03-16 | 1995-11-07 | Fairchild Semiconductor | Cellular addrssing permutation bit map raster graphics architecture |
GB2207840B (en) * | 1987-08-07 | 1991-09-25 | Philips Electronic Associated | Method of and apparatus for modifying data stored in a random access memory |
US4935880A (en) * | 1987-12-24 | 1990-06-19 | Digital Equipment Corporation | Method of tiling a figure in graphics rendering system |
US5387945A (en) * | 1988-07-13 | 1995-02-07 | Seiko Epson Corporation | Video multiplexing system for superimposition of scalable video streams upon a background video data stream |
GB2229059B (en) * | 1989-03-07 | 1993-08-04 | Sony Corp | Obtaining access to a two-dimensional portion of a digital picture signal |
US5208875A (en) * | 1989-03-07 | 1993-05-04 | Sony Corporation | Digital picture signal processing apparatus |
US5251296A (en) * | 1990-03-16 | 1993-10-05 | Hewlett-Packard Company | Methods and apparatus for generating arbitrarily addressed, arbitrarily shaped tiles in computer graphics systems |
JPH04200070A (en) | 1990-11-29 | 1992-07-21 | Sharp Corp | Method of forming picture |
US5533148A (en) * | 1993-09-30 | 1996-07-02 | International Business Machines Corporation | Method for restructuring physical design images into hierarchical data models |
US5488385A (en) * | 1994-03-03 | 1996-01-30 | Trident Microsystems, Inc. | Multiple concurrent display system |
-
1996
- 1996-02-06 JP JP8020330A patent/JPH09212412A/en active Pending
-
1997
- 1997-02-06 KR KR1019970707012A patent/KR100471905B1/en not_active IP Right Cessation
- 1997-02-06 EP EP97902598A patent/EP0820014B1/en not_active Expired - Lifetime
- 1997-02-06 CA CA002216698A patent/CA2216698C/en not_active Expired - Fee Related
- 1997-02-06 MX MX9707534A patent/MX9707534A/en unknown
- 1997-02-06 WO PCT/JP1997/000295 patent/WO1997029427A1/en active IP Right Grant
- 1997-02-06 CN CN97190107A patent/CN1094612C/en not_active Expired - Lifetime
- 1997-02-06 DE DE69720873T patent/DE69720873T2/en not_active Expired - Lifetime
- 1997-02-06 US US08/930,384 patent/US6172670B1/en not_active Expired - Lifetime
Also Published As
Publication number | Publication date |
---|---|
US6172670B1 (en) | 2001-01-09 |
MX9707534A (en) | 1997-11-29 |
CA2216698A1 (en) | 1997-08-14 |
WO1997029427A1 (en) | 1997-08-14 |
JPH09212412A (en) | 1997-08-15 |
EP0820014B1 (en) | 2003-04-16 |
CN1180431A (en) | 1998-04-29 |
CN1094612C (en) | 2002-11-20 |
KR100471905B1 (en) | 2005-07-05 |
EP0820014A4 (en) | 1998-09-16 |
DE69720873T2 (en) | 2004-02-26 |
DE69720873D1 (en) | 2003-05-22 |
EP0820014A1 (en) | 1998-01-21 |
KR19980703613A (en) | 1998-12-05 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CA2216915C (en) | Picture drawing apparatus and picture drawing method | |
CA2216442C (en) | Image generating apparatus with fifo memory and cache memory | |
CA2216698C (en) | Method and apparatus for simultaneous shape-dependent access to picture data stored at a plurality of addresses | |
EP0821339B1 (en) | Address generating apparatus, picture display apparatus, address generation method and picture display method | |
US6364770B1 (en) | Image creating apparatus, displayed scene switching method for the image creating apparatus, computer-readable recording medium containing displayed scene switching program for the image creating apparatus, and video game machine | |
EP1312047B1 (en) | Apparatus and method for rendering antialiased image | |
US6992673B2 (en) | Memory access device, semiconductor device, memory access method, computer program and recording medium | |
US7015916B2 (en) | Draw processing device and drawing method for drawing image on two-dimensional screen | |
EP1081654A2 (en) | Method and apparatus for providing depth blur effects within a 3d videographics system | |
JP3548648B2 (en) | Drawing apparatus and drawing method | |
CA2371367A1 (en) | Method and apparatus for generating images | |
JP3934111B2 (en) | Drawing apparatus and drawing method | |
JP3971448B2 (en) | Drawing apparatus and drawing method | |
MXPA97007540A (en) | Apparatus and method to draw image | |
MXPA97007536A (en) | Apparatus for general directions, apparatus for exhibiting images, method for generating addresses and method for exhibiting image |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
EEER | Examination request | ||
MKLA | Lapsed |
Effective date: 20170206 |