WO2000062255A1 - Method and apparatus for performing perspective transformation - Google Patents

Method and apparatus for performing perspective transformation Download PDF

Info

Publication number
WO2000062255A1
WO2000062255A1 PCT/JP2000/002280 JP0002280W WO0062255A1 WO 2000062255 A1 WO2000062255 A1 WO 2000062255A1 JP 0002280 W JP0002280 W JP 0002280W WO 0062255 A1 WO0062255 A1 WO 0062255A1
Authority
WO
WIPO (PCT)
Prior art keywords
points
thing
point
values
perspective
Prior art date
Application number
PCT/JP2000/002280
Other languages
French (fr)
Inventor
Masaaki Oka
Original Assignee
Sony Computer Entertainment Inc.
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Sony Computer Entertainment Inc. filed Critical Sony Computer Entertainment Inc.
Priority to KR1020017012835A priority Critical patent/KR20010113781A/en
Priority to MXPA01010150A priority patent/MXPA01010150A/en
Priority to CNB008060614A priority patent/CN100392678C/en
Priority to CA002369879A priority patent/CA2369879A1/en
Priority to EP00915421A priority patent/EP1181669A1/en
Priority to JP2000611248A priority patent/JP3643036B2/en
Priority to BR0011156-2A priority patent/BR0011156A/en
Priority to AU36739/00A priority patent/AU3673900A/en
Publication of WO2000062255A1 publication Critical patent/WO2000062255A1/en
Priority to HK02103613.9A priority patent/HK1041959A1/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T17/00Three dimensional [3D] modelling, e.g. data description of 3D objects
    • G06T17/10Constructive solid geometry [CSG] using solid primitives, e.g. cylinders, cubes
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T3/00Geometric image transformations in the plane of the image
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T15/003D [Three Dimensional] image rendering
    • G06T15/10Geometric effects
    • G06T15/20Perspective computation

Definitions

  • the present invention relates to a computer graphic process and, more particularly, to a method and apparatus for perspective-transforming a three-dimensional thing on a virtual two-dimensional screen.
  • the present invention has been made in consideration of the above problem, relates to a computer graphic process, and has as its object to provide a novel method and apparatus for perspective-transforming a three-dimensional thing on a virtual two-dimensional screen.
  • An apparatus for perspective-transforming a thing placed in a three-dimensional space has means in which, when the coordinate values of a plurality of points for specifying the thing are localized with respect to a certain direction in the three-dimensional space, by using the coordinate values of a typical point selected from the plurality of points, perspective transformation of the other points is approximated, and calculation for graphics is performed at a high speed.
  • this direction of the line of sight is a Z-axis direction in an XYZ coordinate system specified around the point of view.
  • the typical point is determined by a replacing method on the basis of the coordinate values of the plurality of points. For example, as the typical point, an average value of Z values, the Z value of the first selected point, or a point selected last can be set.
  • the coordinate values can also be calculated by a linear approximation, a quadratic approximation, or a higher-order approximation.
  • Kl is, e.g., 0.1.
  • Kl may be changed depending on an application program to be applied, a scene to be applied, and the like.
  • K2 I minZM - maxZM
  • ⁇ K2 it is determined that the Z values are localized in units of things. In this case, approximate calculates are performed in units of things.
  • the value of K2 is, e.g.,
  • an apparatus for perspective-transforming a thing placed in a three-dimensional space on a virtual two-dimensional screen has means in which, when the coordinate values of a plurality of points for specifying things on the same scene are localized with respect to a certain direction in units of things, by using the coordinate values of a typical point selected for the respective things, perspective transformation of the other points for specifying the things is approximated.
  • the typical points may be selected by a replacing method, a linear approximation, a quadratic approximation, or a higher-order approximation.
  • an entertainment system including a control system, a graphic system, a sound system, an optical disk control unit, and a bus for connecting these systems and the unit to each other, and wherein the graphic system has a geometry transfer engine, and when the coordinate values of a plurality of points for specifying the thing are localized with respect to a certain direction in the three-dimensional space, by using the coordinate values of a typical point selected from the plurality of points, the graphic system approximates perspective transformation of the other points.
  • a method of perspective-transforming a thing placed in a three-dimensional space includes the steps of: checking whether the coordinate values of a plurality of points for specifying the thing are localized with respect to a certain direction in the three-dimensional space or not; and, if the coordinate values are localized, approximating perspective transformation of the other points by using the coordinate values of a typical point selected from the plurality of points.
  • FIG. 1 is a perspective view showing the appearance of a video game apparatus serving as an example of an entertainment system for realizing the present invention.
  • FIG. 2 is a perspective view showing the front surface of the video game apparatus in FIG. 1.
  • FIG. 3 is a perspective view showing the video game apparatus in FIG. 1 when a portable electronic device is inserted into the video game apparatus.
  • FIG. 4 is a block diagram showing an example of a schematic circuit configuration of a main part of the video game apparatus in FIG. 1.
  • FIG. 5 is a diagram for explaining perspective transformation for, when an object (thing) is viewed from a point of view, calculating the position of one point for specifying the object on a screen.
  • FIG. 6 is a diagram for explaining perspective transformation for, when an object is viewed from a point of view, calculating the positions of a plurality of points for specifying the object on a screen.
  • FIG. 7 is a diagram for explaining perspective transformation for, when a plurality of objects are present in the same scene, calculating the positions of a plurality of points for specifying the objects on a screen.
  • FIG. 8 is a diagram for explaining perspective transformation performed by approximating the object (thing) in FIG. 6.
  • FIG. 9 is a diagram for explaining perspective transformation performed by approximating the plurality of objects (things) in FIG. 7 in units of objects. DESCRIPTION OF THE PREFERRED EMBODIMENT
  • FIG. 1 shows the appearance of a video game apparatus as an example an entertainment system.
  • This video game apparatus 1 is to read a game program recorded on, e.g., an optical disk or the like to execute the game program according to an instruction from a user (game player).
  • Execution of the game mainly means the progress of a game and control of a display or sound.
  • a main body 2 of the video game apparatus 1 comprises a disk loading unit 3 on which an optical disk such as a CD-ROM serving as a recording medium for supplying an application program such as a video game to the central unit is loaded, a reset switch 4 for arbitrarily resetting the game, a power switch 5, a disk operation switch for operating loading of the optical disk, and, e.g., two slot units 7A and 7B.
  • Two operation devices 20 can be connected to the slot units 7A and 7B, so that two users can perform a match-up game or the like.
  • a memory card device in which game data can be saved (stored) or read or a portable electronic device in which a game can be executed independently of the main body can also be connected to the slot units 7A and 7B.
  • the operation device 20 (to be referred to as a "controller” hereinafter) 20 has first and second operation units 21 and 22, an L button 23L, an R button 23R, a start button 24, and a selection button 25.
  • the controller further has operation units 31 and 32 which can be analogously operated, a mode selection switch 33 for selecting one of the operation modes of the operation units 31 and 32, and a display unit 34 for displaying a selected operation mode.
  • FIG. 2 shows the aspects of the two slot units 7A and 7B arranged on the front surface of the main body 2 of the video game apparatus 1.
  • Each of the two slot units 7A and 7B has two stages. On the upper stages, memory card insertion units 8A and 8B into which a memory card 10 or a portable electronic device 100 (not shown) is inserted are formed. On the lower stages, controller connection units (jacks) 9A and 9B to which a connection terminal unit (connector) 26 of the controller 20 is connected are formed.
  • Each of the insertion holes (slots) of the memory card insertion units 8A and 8B is asymmetrically formed somewhat such that a memory card cannot erroneously inserted into the corresponding memory card insertion unit in reverse.
  • each of the controller connection units 9A and 9B is asymmetrically formed somewhat such that the connection terminal unit 26 cannot be erroneously connected to the corresponding controller connection unit in reverse.
  • Each of the controller connection units 9A and 9B has a shape different from that of each of the memory card insertion units 8A and 8B such that a memory card cannot be erroneously inserted into the corresponding the controller connection unit.
  • FIG. 3 shows the vide game device 1 in a state in which the portable electronic device 100 is inserted into the memory card insertion unit 8 A of the slot unit 7 A on the front surface of the video game device 1.
  • FIG. 4 is a block diagram showing an example of a schematic circuit configuration of a main part of the video game device 1.
  • the video game device 1 comprises a control system 50 constituted by a central processing unit (CPU) 51 and its peripheral unit and the like, a graphic system 60 constituted by an image processing unit (GPU: Graphic Processing Unit) 62 or the like for drawing a picture in a frame buffer 63, a sound system 70 constituted by a sound processing unit (SPU) or the like for generating sound, sound effect, or the like, an optical disk control unit 80 for controlling an optical disk on which an application program is recorded, a communication control unit 90 for controlling an input/output operation of a signal from the controller 20 in which an instruction from a user is input and data from the memory card 10 or the portable electronic device 100 for storing settings of a game, and a bus BUS or the like to which the above units are connected.
  • a control system 50 constituted by a central processing unit (CPU) 51 and its peripheral unit and the like
  • a graphic system 60 constituted by an image processing unit (GPU: Graphic Processing Unit) 62 or the like for drawing a picture in a
  • the control system 50 has the CPU 51, a peripheral device control unit 52 for performing interrupt control or control or the like of direct memory access (DMA: Dynamic Memory Access) transfer, a main memory (main storage unit) 53 constituted by a random access memory (RAM), and a read-only memory (ROM) 54 in which a program such as a so-called operating system for managing the main memory 53, the graphic system 60, the sound system 70, and the like.
  • the main memory 53 is a memory on which a program can be executed.
  • the CPU 51 executes the operating system stored in the ROM 54 to control the video game device 1 as a whole, and is constituted by a 32-bit RISC (reduced instruction set computer) - CPU.
  • the CPU 51 of the control system 50 executes the operating system stored in the ROM 54, so that the CPU 51 performs control of the graphic system 60, the sound system 70, and the like.
  • the CPU 51 performs initialization such as an operation check of the video game device 1 as a whole and then controls the optical disk control unit 80 to execute an application program such as a game recorded on the optical disk.
  • the CPU 51 controls the graphic system 60, the sound system 70, and the like according to an input by a user to control display of an image and generation of sound effect and sound.
  • the graphic system 60 comprises a graphic data generation processor or a geometry transfer engine (GTE) 61 for performing a process such as coordinate conversion, the graphic processing unit (GPU) 62 for drawing a picture according to a drawing instruction from the CPU 51, a frame buffer 63 for storing the image drawn by the GPU 62, and an image decoder 64 for decoding image data which is compressed by orthogonal transformation such as discrete cosine conversion.
  • GTE geometry transfer engine
  • the GTE 61 functions as a co-processor 51.
  • the GTE 61 comprises a parallel arithmetic operation mechanism for executing a plurality of arithmetic operations in parallel, so that arithmetic operations such as coordinate transformation, light source calculations, matrixes, or vectors can be performed at a high speed according to an arithmetic request from the CPU 51. More specifically, calculations of vertex coordinates of polygons according to the present invention are performed by the GTE 61.
  • the GTE 61 can perform coordinate operations of a maximum of about 1.5 million polygons for one second in arithmetic operations for performing flat shooting for drawing, e.g., one triangular polygon in the same color. In this manner, in the video game apparatus, a load on the CPU 51 can be reduced, and a high-speed coordinate operation can be performed.
  • the GPU 62 operates according to a polygon drawing instruction from the CPU 51.
  • the GPU 62 has a two-dimensional address space which is independent of the CPU 51 to draw polygons and the like in the frame buffer 63 serving as the address space.
  • the GPU 62 is designed such that a maximum of about 360 thousand polygons for one second.
  • the frame buffer 63 is constituted by a so-called dual port RAM, and is designed such that drawing from the GPU 62 or transfer from the main memory 53 and reading for a display can be simultaneously performed.
  • the frame buffer 63 has, e.g., a 1-Mbyte capacity, and is handled as 16-bit matrixes each of which has 1,024 pixels in width and 512 pixels in length.
  • a CULT region in which a color look up table (CLUT) which is referred to when the GPU 62 draws polygons or the like, and a texture region in which materials (textures) inserted (mapped) in the polygons or the like subjected to coordinate transformation in drawing and drawn by the GPU 62 are stored are formed.
  • CLUT region and texture region are dynamically changed according to a change of the display region or the like.
  • the GPU 62 is designed such that, in addition to the flat shading, gouraud shading for determining the colors of the polygons by interpolating the colors of vertexes of the polygons and texture mapping for pasting the textures stored in the texture region on the polygons can be performed.
  • gouraud shading or the texture mapping is performed, the GTE 61 can perform coordinate operations of a maximum of about 500 thousand polygons for one second.
  • the image decoder 64 is controlled by the CPU 51 and decodes image data of a static image or a moving picture to store the decoded data in the main memory 53.
  • the reproduced image data is stored in the frame buffer 63 through the main body 2, so that the image data can be used as a background of an image drawn by the GPU 62.
  • the sound system 70 comprises an SPU 71 for generating sound, sound effect, and the like on the basis of an instruction from the CPU 51, a sound buffer 72 in which waveform data or the like is recorded, and a loudspeaker 73 for outputting the sound, sound effect, and the like generated by the SPU 71.
  • the SPU 71 comprises an ADPCM decoding function for reproducing audio data obtained by performing adaptive differential PCM (ADPCM) to, e.g., 16-bit audio data as a 4-bit differential signal, a reproducing function for reproducing the waveform data stored in the sound buffer 72 to generate sound effect or the like, a modulating function for modulating and reproducing the waveform data stored in the sound buffer 72, and the like.
  • ADPCM adaptive differential PCM
  • the sound system 70 comprises these functions, the sound system 70 can be used as a so-called sampling sound source for generating sound, sound effect, and the like on the basis of the waveform data recorded on the sound buffer 72 according to an instruction from the CPU 51.
  • the optical disk control unit 80 comprises an optical disk device 81 for generating a program, data, or the like recorded on an optical disk, a decoder 82 for decoding a program, data, or the like recorded with an error correction code (ECC), and a buffer 83 for temporarily storing data from the optical disk device 81 to make the reading speed of the data from the optical disk high.
  • a sub-CPU 84 is connected to the decoder 82.
  • Audio data which is recorded as ADPCM data such that the difference of, e.g.,
  • 16-bit digital data is expressed by 4 bits is decoded by the decoder 82, supplied to the SPU 71, and subjected to a process such as digital/analog conversion by the SPU 71, and used to drive the loudspeaker 73.
  • Audio data which is recorded as PCM data, e.g., 16-bit digital data is decoded by the decoder 82 and then used to drive the loudspeaker 73.
  • the communication control unit 90 has a communication controller 91 for controlling communication with the CPU 51 through the bus BUS.
  • a controller connection unit 12 to which the controller 20 for inputting an instruction from a user is connected and memory card insertion units 8 A and 8B to which a memory card 10 serving as an auxiliary storage device for storing setting data or the like of a game or a portable electronic device 100 (to be described later) is connected are arranged on the communication controller 91.
  • the controller 20 connected to the controller connection unit 12 has, e.g., 16 instruction keys to input an instruction from a user, and transmits the state of the instruction keys to the communication controller 91 by synchronous communication about 60 times according to the instruction from the controller 20.
  • the communication controller 91 transmits the state of the instruction keys of the controller 20 to the CPU 51.
  • this video game apparatus is designed to perform so-called DMA transfer in which data is directly transferred among the main memory 53, the GPU 62, the image decoder 64, the decoder 82, and the like under the control of the peripheral device control unit 52 without passing through the CPU 51. In this manner, a load on the CPU 51 generated by the data transfer can be reduced, and high-speed data transfer can be performed.
  • the CPU 51 transmits the data to be stored to the communication controller 91, and the communication controller 91 writes the data from the CPU 51 in the memory card 10 or the portable electronic device 100 which is inserted into the slot of the memory card insertion unit 8A or the memory card insertion unit 8B.
  • a protection circuit for preventing electric breakdown is incorporated in the communication controller 91.
  • the memory card 10 and the portable electronic device 100 are separated from the bus BUS, and can be attached to or detached from the slot while the main body of the apparatus is powered on. Therefore, when the memory capacity of the memory card 10 or the portable electronic device 100 is short, a new memory card 10 can be inserted without cutting the power supply of the main body of the apparatus. For this reason, without losing game data which must be backup, the new memory card 10 can be inserted to write necessary data in the new memory card 10.
  • a parallel I/O interface (PIO) 96 and a serial I/O interface (SIO) 97 are interfaces for connecting the memory card 10 or the portable electronic device 100 to the video game device 1.
  • Three-dimensional graphics are techniques in which, when an object placed in a three-dimensional space is viewed from a certain point of view, the perspective position of the object on a screen supposed to be set a certain position.
  • a series of processes i.e., the process of performing a geometry operation by using a plurality of polygons of one screen as a unit, the process of performing sorting by Z values, and the process of performing drawing are performed. More specifically, The processes from the process of performing a geometry operation to the process of performing drawing are performed step by step to a set of polygons of one screen.
  • the GTE 61 of the graphic system 60 functions as a co-processor for performing the geometry operation at a high speed.
  • a typical geometry operation is provided to, e.g., a game programmer as the form of a library.
  • An approximation of perspective transformation to be described below can be prepared as, e.g., a basic geometry library, and can be provided to a game programmer.
  • a calculation of perspective transformation is expressed as, e.g., Equations (1) and (2):
  • Equations (1) and (2) are equations for, when an object OB is viewed from a point of view VP set at a certain point as shown in FIG. 5, calculating the position of a projected image of the object OB on a virtual screen 200.
  • a point of view VP is set as a coordinate origin A
  • a line of sight is pointed in the plus side of the Z axis
  • the upper direction in FIG. 5 is defined as the Y axis.
  • the X axis is omitted.
  • an arrow-like object OB is arranged on the Z axis.
  • the summit of the project of the arrow reflected on the screen 200 is represented by coordinates Ps (Sx,Sy).
  • a triangle ABC is similar to a triangle ADE.
  • the distance from the point of view VP to the object OB is represented by Z
  • the distance from the point of view VP to the screen 200 is represented by h.
  • scale factors (segment factors) of the two triangles which are similar to each other are represented by (h/Z). For this reason, the coordinate values of the summit coordinates Ps on the screen 200 can be expressed by Equations (1) and (2) described above.
  • the summit coordinates Ps (Sx,Sy) calculated by Equations (1) and (2) correspond to summit coordinates on the screen on which a basic figure (polygon) constituting an object of, e.g., a three-dimensional image. This relationship can also be satisfied with respect to the X-axis direction omitted in FIG. 5. Perspective transformation must be performed to all the points constituting a three-dimensional object.
  • FIG. 6 illustrates this case.
  • FIG. 6 as typical points constituting an object OB which is similar to a Christmas tree, four points PI (X1,Y1), P2 (X2,Y2), P3 (X3 . Y3), and P4 (X4,Y4) are specified.
  • the distances from a point of view VP to the four points PI, P2, P3, and P4 of the object OB are represented by Zl, Z2, Z3, and Z4, respectively, and the distance from the point of view VP to a screen 200 is represented by h.
  • FIG. 7 is a diagram showing this case.
  • three Christmas-tree-like objects OB each of which is the same as that shown in FIG. 6 are arranged with different distances from a point of view VP.
  • These objects are represented by OBI, OB2, and OB3 in order of increasing the distance from the point of view VP.
  • each of the three objects OBI to OB3 in FIG. 7 is constituted by four points as in FIG. 6.
  • calculation for scale factors (h/Z) must be performed times the number of which is the number of distances in the Z direction of each object, i.e., four times. Therefore, calculation must be performed 12 times in all the objects OBI to OB3.
  • M objects are constituted by Nl points, N2 points,..., Nm points, respectively.
  • calculation for scale factors (h/Z) must be performed times the number of which is the number of distances, i.e., (Nl + N2 +...+ Nm) times.
  • minZ min(Zj, Z2,..., ZN) is satisfied, i.e., minZ represents the minimum value of the values (Zj, Z2,..., Zj f) of the distances from the point of view VP to the points constituting the objects
  • maxZ max(Zj, Z2,-, ZJSJ) is satisfied, i.e., maxZ represents the maximum value of the values (Zj, Z2,..., ZN) of the distances from the point of view VP to the points constituting the objects
  • represents that the value of the left member is considerably smaller than that of the right member.
  • an average value meanZ (Z ⁇ , Z2,—, Zjj)/N of the Z values (Z ⁇ , Z2,—, ZN) of n points constituting the object is defined as the typical value typZ, and the Z values of the object can be approximated by using the typical value typz.
  • division for calculating scale factors is basically performed by repeating subtraction. For this reason, when calculation for a scale factor is satisfactorily performed once an object, the number of times of arithmetic operation can be considerably reduced.
  • OBI2,..., OBINI of the first object OBI are represented by Zli, ZI2,—, Zl ⁇ i, respectively. It is assumed that the distances from the point of view VP to points
  • OB2 ⁇ , OB22,..-, OB2N2 of the second object OB2 are represented by Z2 ⁇ , Z22,.» .
  • minZ min(Zl; ,..., ZMNM) * S satisfied, i.e., minZ represents the minimum value of the values (Z ⁇ ,..., ZMNM) °f me distances from the point of view VP to the points constituting all the objects OBI to OBM
  • maxZ max(Zl ⁇ ,..., ZMJ ⁇ M) ⁇ s satisfied, i.e., maxZ represents the maximum value of the values (Zlj,..., ZMJ ⁇ M) ° me distances from the point of view VP to the points constituting all the objects OBI to OBM
  • the points constituting a specific object are sufficiently spaced apart from the points constituting the other objects.
  • the points constituting the specific object are also sufficiently spaced apart from the points constituting the objects adjacent to the specific object.
  • minZi min(Zl ⁇ , ZI2,..., Zljsjl) is satisfied, i.e., minZi represents the minimum value of the values (Zli, ZI2,— , ZINI) of the distances from the point of view VP to Nl points constituting the first object OBI
  • minZ2 min(Z2 ⁇ , Z22,.» > 22 ⁇ 2) is satisfied, i.e., minZ2 represents the minimum value of the values (Z2 , Z22 > — .
  • minZM min(ZM ⁇ , ZM2,— , ZMJNJM) * S satisfied, i.e., minZi represents the minimum value of the values (ZMi, ZM2,—, ZMJ ⁇ M) °f tne distances from the point of view VP to NM points constituting the Mth object OBM.
  • maxZl max(Zl ⁇ , ZI2,..., Zlj ⁇ i) is satisfied, i.e., maxZl represents the maximum value of the values (Zli, Zl2 > — .
  • meanZ2 mean(Z2 ⁇ , Z22,— > 2jsf2) i satisfied
  • meanZM mean(ZM ⁇ , ZM2,-, ZMISJM) * S sat i s fi e ⁇ ' i- e -> nieanZ
  • the differences between the Z values of points constituting a specific object when a plurality of objects are drawn are considerably smaller than the differences between the Z values of points constituting objects adjacent to the specific objects. It is understood that an image is slightly influenced even if the differences are neglected.
  • an average value meanZM (ZM + ZM2 +...+ ZMJNJMVNM of the Z values (ZMi, ZM2,—. ZMNM) °f NM points constituting a specific object (e.g., the Mth object) is defined as a typical value typZM, and the Z values of an object can be approximated by using the typical value typZM.
  • the first object OBI is constituted by Nl points, and the Z values of all the points can be approximated by the typical value typZl. For this reason, a scale factor can be approximated by calculating (h/typZl).
  • the second object OB2 is constituted by N2 points, and the Z values of all the points can be approximated by the typical value typZ2. For this reason, a scale factor can be approximated by calculating (h/typZ2).
  • the Mth object OBM is constituted by NM points, and the Z values of all the points can be approximated by the typical value typZM. For this reason, a scale factor can be approximated by calculating (h/typZM).
  • the plurality of objects OBI to OBM are constituted by Nl to NM points, respectively, and the M objects OBI to OBM can be approximated by using the typical values typZl to typZM of the Z values.
  • the scale factors can be perspective-transformed by performing approximation of (h/typZl), (h/typZ2),..., (h/typZM).
  • the present inventor uses the following values as criterions for deciding whether Expressions (7) to (9) are satisfied, i.e., all points constituting the object are independently calculated by changing the Z values of the scale factor (h/Z) or can be approximated by using the typical value typZ (meanZ in the above case) of the Z values:
  • Expressions (23) to (25) are Kl or less, it is determined that the objects can be approximated.
  • Expressions (23) to (25) mean that the ratios of the differences between the minimum value minZ and the maximum value maxZ of the points constituting the object to the typical values minZ, maxZ, and meanZ are the predetermined value Kl or less.
  • the absolute value of the difference between the minimum value and the maximum value of the Z values of the object OB is equal to or smaller than 1/10 of the absolute value of the typical value (minimum value minZ, maximum value maxZ, or average value meanZ) of the Z values of the object, and it is determined that all the Z values of the object can be approximated by the typical value typZ of one Z value.
  • the value of Kl can be arbitrarily set depending on an application program to be applied, a scene to be applied, or the like.
  • Kl need not be always a constant value, and may be changed depending on the application program to be applied, the scene to be applied, or the like.
  • a specific object can be approximated by a typical value, and the other objects can also be calculated such that the values of the objects are calculated.
  • criterions for deciding whether it is regarded that all objects are localized in a space and localized in the space in units of objects will be described below.
  • the present inventor uses the following values as criterions for deciding whether it can be regarded that all the objects are localized as in Expressions (23) to (25).
  • the following values are used as the criterions of decision to satisfy Expressions (14) to (16).
  • Expressions (26) to (28) are Kl or less, it is determined that the objects can be approximated.
  • the contents of Expressions (26) to (28) and the predetermined value Kl are as described above.
  • Expressions (29) to (34) mean that the ratio of the difference (
  • a specific object e.g., OP2
  • the ratio of the difference between the distance from the point of view to a specific object (e.g., OP2) and the distance from the point of view to an object (e.g., OP3) adjacent to the specific object to the difference between the minimum value and the maximum value of the distances from the point of view VP to a plurality of points constituting the specific object is 1/10 or less. It is determined that the Z values of all the points of the object (e.g., OP2) can be approximated by one typical value (e.g., typZ2) of Z values.
  • K2 can be changed depending on an application program to be applied, a scene to be applied, or the like.
  • the value of K2 need not be always a constant value, and may be changed depending on the application program to be applied, the scene to be applied, or the like.
  • a specific object can be approximated by a typical value, and the other objects can also be calculated such that the Z values of the respective points of the objects are calculated. (Selection of typical value typZ)
  • Equation (35) the average value of points (Z0 + Zl + Z2 +...+ Zn) constituting one object as in the above embodiment is set as the distance of a typical point (typical value of Z values).
  • Equation (36) the first Z value of Z values (Zl, Z2,..., Zn) of the points constituting the object is set as the distance of the typical point.
  • the scale factor (h/Z) is given by (h/Zn).
  • typZ Zn ...(37)
  • the last (i.e., the Nth) Z value of the Z values (Zl, Z2,..., Zn) of the points constituting the object is set as the distance of the typical value.
  • the scale factor (h/Z) is given by (h/Zn).
  • Equations (35) to (37) are also called replacing methods.
  • Expression (38) a value h/Z of the typical point of the Z values are linearly approximated (primarily approximated) by using h/maxZ obtained by the maximum value maxZ and h/minZ obtained by the minimum value minZ.
  • Expression (38) is also called a linear (primary) approximation.
  • midZ (maxZ + minZ)/2 is satisfied, i.e., midZ is the average value of maxZ and minZ.
  • the scale factors can be calculated by performing division once in Equations (35), (36), and (37) according to the replacing method.
  • a scale factor can be calculated by performing division twice.
  • a scale factor can be calculated by performing division three times.
  • the present invention relates to a computer graphic process, and can provide a novel method and apparatus for perspective-transforming a three-dimensional thing on a virtual two-dimensional screen.

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Geometry (AREA)
  • Computer Graphics (AREA)
  • Computing Systems (AREA)
  • Software Systems (AREA)
  • Processing Or Creating Images (AREA)
  • Image Generation (AREA)
  • Image Processing (AREA)

Abstract

The present invention relates to a computer graphic process, and has as its object to make it possible to perform high-speed processing when a three-dimensional thing is perspective-transformed on a two-dimensional screen. An apparatus for performing perspective transformation according to the present invention is an apparatus for perspective transforming a thing placed in a three-dimensional space on a virtual two-dimensional screen. The apparatus has a device in which when a plurality of things exist in the same scene, and when the coordinate values of a plurality of points for specifying the things are localized with respect to a certain direction in units of things, by using the coordinate values of typical points selected in units of things, perspective transformation of other points for specifying the things is approximated.

Description

DECRIPTION
METHOD AND APPARATUS FOR PERFORMING PERSPECTIVE TRANSFORMATION
BACKGROUND OF THE INVENTION Field of the Invention
The present invention relates to a computer graphic process and, more particularly, to a method and apparatus for perspective-transforming a three-dimensional thing on a virtual two-dimensional screen. Description of the Related Art
In a conventional technique, when a three-dimensional object (thing) is perspective-transformed on a virtual two-dimensional screen, points for specifying the thing are respectively calculated in accordance with ratios of distances between a point of view and the points to a distance between the point of view and the screen to perform perspective transformation.
However, since the distances between the point of view and the respective points for specifying the thing are different from each other, very large amounts of calculation for the distances are loaded on the CPU (Central Processing Unit) or another device of a computer. In other words, in an entertainment system such as a video game apparatus, the heavy load on the CPU or the like is posed as a problem when high-speed processing for an object image which continuously changes is performed.
SUMMARY OF THE INVENTION The present invention has been made in consideration of the above problem, relates to a computer graphic process, and has as its object to provide a novel method and apparatus for perspective-transforming a three-dimensional thing on a virtual two-dimensional screen.
An apparatus for perspective-transforming a thing placed in a three-dimensional space according to the present invention has means in which, when the coordinate values of a plurality of points for specifying the thing are localized with respect to a certain direction in the three-dimensional space, by using the coordinate values of a typical point selected from the plurality of points, perspective transformation of the other points is approximated, and calculation for graphics is performed at a high speed.
When a plurality of things are localized in a three-dimensional space, approximation is performed in units of things. As the certain direction, the direction of a line of sight extending from a point of view to the thing is frequently used. For example, this direction of the line of sight is a Z-axis direction in an XYZ coordinate system specified around the point of view.
As the plurality of points, vertex coordinates obtained when a thing is drawn with polygons are frequently used. The typical point is determined by a replacing method on the basis of the coordinate values of the plurality of points. For example, as the typical point, an average value of Z values, the Z value of the first selected point, or a point selected last can be set.
The coordinate values can also be calculated by a linear approximation, a quadratic approximation, or a higher-order approximation.
In this case, whether the coordinate values of a plurality of points for specifying the thing are localized with respect to a certain direction in the three-dimensional space or not is determined in the following manner. That is, it is assumed that the minimum value of the Z values of the thing in the Z-axis direction is represented by minZ, that the maximum value of the Z values of the thing is represented by maxZ, and that the average value of the Z values of the thing is represented by meanZ. In this case, when expressions: I minZ - maxZ | ÷ | minZ | ≤ Kl,
| minZ - maxZ| ÷ | maxZ| ≤ Kl, or
I minZ - maxZ | ÷ | meanZ | ≤ Kl are satisfied, it is determined that the Z values of the thing are localized. The value of Kl is, e.g., 0.1.
However, the value of Kl may be changed depending on an application program to be applied, a scene to be applied, and the like.
In addition, whether the coordinate values of the plurality of points for specifying a plurality of things are localized with respect to a certain direction in the three-dimensional space in units of things or not is determined in the following manner. That is, it is assumed that the minimum value of the Z values of the ith thing (i = 1, 2,..., M) in the Z-axis direction is represented by minZi, that the maximum value of the Z values of the ith thing is represented by maxZi, and that the average value of the Z values of the ith thing is represented by meanZi. In this case, when expressions:
I minZi - maxZl | ÷ | meanZi - meanZ21 ≤ K2,
I minZ2 - maxZ21 ÷ | meanZi - meanZ21 ≤ K2,
I minZ2 - maxZ21 ÷ | meanZ2 - meanZ31 ≤ K2,
I minZ3 - maxZ3 1 ÷ | meanZ2 - meanZ31 ≤ K2,
| minZM-l - maxZM-l | ÷ | meanZM-l - meanZM | ≤ K2, and
I minZM - maxZM | ÷ | meanZM-1 - meanZM | ≤ K2 are satisfied, it is determined that the Z values are localized in units of things. In this case, approximate calculates are performed in units of things. The value of K2 is, e.g.,
0.1. However, the value of K2 may be changed depending on an application program to be applied, a scene to be applied, and the like. The method may be selectively applied to only a thing in which the expressions are satisfied. In addition, an apparatus for perspective-transforming a thing placed in a three-dimensional space on a virtual two-dimensional screen has means in which, when the coordinate values of a plurality of points for specifying things on the same scene are localized with respect to a certain direction in units of things, by using the coordinate values of a typical point selected for the respective things, perspective transformation of the other points for specifying the things is approximated.
The typical points may be selected by a replacing method, a linear approximation, a quadratic approximation, or a higher-order approximation.
In addition, an entertainment system according to the present invention including a control system, a graphic system, a sound system, an optical disk control unit, and a bus for connecting these systems and the unit to each other, and wherein the graphic system has a geometry transfer engine, and when the coordinate values of a plurality of points for specifying the thing are localized with respect to a certain direction in the three-dimensional space, by using the coordinate values of a typical point selected from the plurality of points, the graphic system approximates perspective transformation of the other points.
Here, when a plurality of things exist, and when the things are localized in units of things, approximation is performed in units of things.
In addition, a method of perspective-transforming a thing placed in a three-dimensional space according to the present invention includes the steps of: checking whether the coordinate values of a plurality of points for specifying the thing are localized with respect to a certain direction in the three-dimensional space or not; and, if the coordinate values are localized, approximating perspective transformation of the other points by using the coordinate values of a typical point selected from the plurality of points.
Here, when a plurality of things exist, and when the things are localized in units of things, approximation is performed in units of things. In this manner, when the plurality of points are perspective-transformed, the Z values of several points can be arithmetically operated with approximate values. For this reason, a load on a CPU and other arithmetic operation means is reduced, and a high-speed perspective transformation can be achieved.
BRIEF DESCRIPTION OF THE DRAWINGS FIG. 1 is a perspective view showing the appearance of a video game apparatus serving as an example of an entertainment system for realizing the present invention. FIG. 2 is a perspective view showing the front surface of the video game apparatus in FIG. 1.
FIG. 3 is a perspective view showing the video game apparatus in FIG. 1 when a portable electronic device is inserted into the video game apparatus.
FIG. 4 is a block diagram showing an example of a schematic circuit configuration of a main part of the video game apparatus in FIG. 1. FIG. 5 is a diagram for explaining perspective transformation for, when an object (thing) is viewed from a point of view, calculating the position of one point for specifying the object on a screen.
FIG. 6 is a diagram for explaining perspective transformation for, when an object is viewed from a point of view, calculating the positions of a plurality of points for specifying the object on a screen.
FIG. 7 is a diagram for explaining perspective transformation for, when a plurality of objects are present in the same scene, calculating the positions of a plurality of points for specifying the objects on a screen.
FIG. 8 is a diagram for explaining perspective transformation performed by approximating the object (thing) in FIG. 6.
FIG. 9 is a diagram for explaining perspective transformation performed by approximating the plurality of objects (things) in FIG. 7 in units of objects. DESCRIPTION OF THE PREFERRED EMBODIMENT
An embodiment according to the present invention will be described below in detail with reference to the accompanying drawings. [Entertainment System]
First, an entertainment system, according to the present invention, being capable of executing three-dimensional graphics will be simply described with reference to the drawings.
FIG. 1 shows the appearance of a video game apparatus as an example an entertainment system. This video game apparatus 1 is to read a game program recorded on, e.g., an optical disk or the like to execute the game program according to an instruction from a user (game player). Execution of the game mainly means the progress of a game and control of a display or sound.
A main body 2 of the video game apparatus 1 comprises a disk loading unit 3 on which an optical disk such as a CD-ROM serving as a recording medium for supplying an application program such as a video game to the central unit is loaded, a reset switch 4 for arbitrarily resetting the game, a power switch 5, a disk operation switch for operating loading of the optical disk, and, e.g., two slot units 7A and 7B.
Two operation devices 20 can be connected to the slot units 7A and 7B, so that two users can perform a match-up game or the like. A memory card device in which game data can be saved (stored) or read or a portable electronic device in which a game can be executed independently of the main body can also be connected to the slot units 7A and 7B.
The operation device (to be referred to as a "controller" hereinafter) 20 has first and second operation units 21 and 22, an L button 23L, an R button 23R, a start button 24, and a selection button 25. The controller further has operation units 31 and 32 which can be analogously operated, a mode selection switch 33 for selecting one of the operation modes of the operation units 31 and 32, and a display unit 34 for displaying a selected operation mode.
FIG. 2 shows the aspects of the two slot units 7A and 7B arranged on the front surface of the main body 2 of the video game apparatus 1. Each of the two slot units 7A and 7B has two stages. On the upper stages, memory card insertion units 8A and 8B into which a memory card 10 or a portable electronic device 100 (not shown) is inserted are formed. On the lower stages, controller connection units (jacks) 9A and 9B to which a connection terminal unit (connector) 26 of the controller 20 is connected are formed. Each of the insertion holes (slots) of the memory card insertion units 8A and 8B is asymmetrically formed somewhat such that a memory card cannot erroneously inserted into the corresponding memory card insertion unit in reverse. On the other hand, each of the controller connection units 9A and 9B is asymmetrically formed somewhat such that the connection terminal unit 26 cannot be erroneously connected to the corresponding controller connection unit in reverse. Each of the controller connection units 9A and 9B has a shape different from that of each of the memory card insertion units 8A and 8B such that a memory card cannot be erroneously inserted into the corresponding the controller connection unit.
FIG. 3 shows the vide game device 1 in a state in which the portable electronic device 100 is inserted into the memory card insertion unit 8 A of the slot unit 7 A on the front surface of the video game device 1.
FIG. 4 is a block diagram showing an example of a schematic circuit configuration of a main part of the video game device 1.
The video game device 1 comprises a control system 50 constituted by a central processing unit (CPU) 51 and its peripheral unit and the like, a graphic system 60 constituted by an image processing unit (GPU: Graphic Processing Unit) 62 or the like for drawing a picture in a frame buffer 63, a sound system 70 constituted by a sound processing unit (SPU) or the like for generating sound, sound effect, or the like, an optical disk control unit 80 for controlling an optical disk on which an application program is recorded, a communication control unit 90 for controlling an input/output operation of a signal from the controller 20 in which an instruction from a user is input and data from the memory card 10 or the portable electronic device 100 for storing settings of a game, and a bus BUS or the like to which the above units are connected. The control system 50 has the CPU 51, a peripheral device control unit 52 for performing interrupt control or control or the like of direct memory access (DMA: Dynamic Memory Access) transfer, a main memory (main storage unit) 53 constituted by a random access memory (RAM), and a read-only memory (ROM) 54 in which a program such as a so-called operating system for managing the main memory 53, the graphic system 60, the sound system 70, and the like. The main memory 53 is a memory on which a program can be executed.
The CPU 51 executes the operating system stored in the ROM 54 to control the video game device 1 as a whole, and is constituted by a 32-bit RISC (reduced instruction set computer) - CPU.
When the video game device 1 is powered on, the CPU 51 of the control system 50 executes the operating system stored in the ROM 54, so that the CPU 51 performs control of the graphic system 60, the sound system 70, and the like. When the operating system is executed, the CPU 51 performs initialization such as an operation check of the video game device 1 as a whole and then controls the optical disk control unit 80 to execute an application program such as a game recorded on the optical disk. When the execution of the program for a game or the like, the CPU 51 controls the graphic system 60, the sound system 70, and the like according to an input by a user to control display of an image and generation of sound effect and sound.
The graphic system 60 comprises a graphic data generation processor or a geometry transfer engine (GTE) 61 for performing a process such as coordinate conversion, the graphic processing unit (GPU) 62 for drawing a picture according to a drawing instruction from the CPU 51, a frame buffer 63 for storing the image drawn by the GPU 62, and an image decoder 64 for decoding image data which is compressed by orthogonal transformation such as discrete cosine conversion.
The GTE 61 functions as a co-processor 51. The GTE 61 comprises a parallel arithmetic operation mechanism for executing a plurality of arithmetic operations in parallel, so that arithmetic operations such as coordinate transformation, light source calculations, matrixes, or vectors can be performed at a high speed according to an arithmetic request from the CPU 51. More specifically, calculations of vertex coordinates of polygons according to the present invention are performed by the GTE 61. The GTE 61 can perform coordinate operations of a maximum of about 1.5 million polygons for one second in arithmetic operations for performing flat shooting for drawing, e.g., one triangular polygon in the same color. In this manner, in the video game apparatus, a load on the CPU 51 can be reduced, and a high-speed coordinate operation can be performed.
The GPU 62 operates according to a polygon drawing instruction from the CPU 51. The GPU 62 has a two-dimensional address space which is independent of the CPU 51 to draw polygons and the like in the frame buffer 63 serving as the address space. The GPU 62 is designed such that a maximum of about 360 thousand polygons for one second.
In addition, the frame buffer 63 is constituted by a so-called dual port RAM, and is designed such that drawing from the GPU 62 or transfer from the main memory 53 and reading for a display can be simultaneously performed. The frame buffer 63 has, e.g., a 1-Mbyte capacity, and is handled as 16-bit matrixes each of which has 1,024 pixels in width and 512 pixels in length.
In the frame buffer 63, in addition to a display region output as a video output, a CULT region in which a color look up table (CLUT) which is referred to when the GPU 62 draws polygons or the like, and a texture region in which materials (textures) inserted (mapped) in the polygons or the like subjected to coordinate transformation in drawing and drawn by the GPU 62 are stored are formed. These CLUT region and texture region are dynamically changed according to a change of the display region or the like.
The GPU 62 is designed such that, in addition to the flat shading, gouraud shading for determining the colors of the polygons by interpolating the colors of vertexes of the polygons and texture mapping for pasting the textures stored in the texture region on the polygons can be performed. When the gouraud shading or the texture mapping is performed, the GTE 61 can perform coordinate operations of a maximum of about 500 thousand polygons for one second.
In addition, the image decoder 64 is controlled by the CPU 51 and decodes image data of a static image or a moving picture to store the decoded data in the main memory 53.
The reproduced image data is stored in the frame buffer 63 through the main body 2, so that the image data can be used as a background of an image drawn by the GPU 62.
The sound system 70 comprises an SPU 71 for generating sound, sound effect, and the like on the basis of an instruction from the CPU 51, a sound buffer 72 in which waveform data or the like is recorded, and a loudspeaker 73 for outputting the sound, sound effect, and the like generated by the SPU 71.
The SPU 71 comprises an ADPCM decoding function for reproducing audio data obtained by performing adaptive differential PCM (ADPCM) to, e.g., 16-bit audio data as a 4-bit differential signal, a reproducing function for reproducing the waveform data stored in the sound buffer 72 to generate sound effect or the like, a modulating function for modulating and reproducing the waveform data stored in the sound buffer 72, and the like.
Since the sound system 70 comprises these functions, the sound system 70 can be used as a so-called sampling sound source for generating sound, sound effect, and the like on the basis of the waveform data recorded on the sound buffer 72 according to an instruction from the CPU 51.
The optical disk control unit 80 comprises an optical disk device 81 for generating a program, data, or the like recorded on an optical disk, a decoder 82 for decoding a program, data, or the like recorded with an error correction code (ECC), and a buffer 83 for temporarily storing data from the optical disk device 81 to make the reading speed of the data from the optical disk high. A sub-CPU 84 is connected to the decoder 82.
As the audio data read by the optical disk device 81 and recorded on the optical disk, the ADPCM data and so-called PCM data obtained by analog/digital-converting audio signal recorded on the optical disk is known. Audio data which is recorded as ADPCM data such that the difference of, e.g.,
16-bit digital data is expressed by 4 bits is decoded by the decoder 82, supplied to the SPU 71, and subjected to a process such as digital/analog conversion by the SPU 71, and used to drive the loudspeaker 73.
Audio data which is recorded as PCM data, e.g., 16-bit digital data is decoded by the decoder 82 and then used to drive the loudspeaker 73.
In addition, the communication control unit 90 has a communication controller 91 for controlling communication with the CPU 51 through the bus BUS. A controller connection unit 12 to which the controller 20 for inputting an instruction from a user is connected and memory card insertion units 8 A and 8B to which a memory card 10 serving as an auxiliary storage device for storing setting data or the like of a game or a portable electronic device 100 (to be described later) is connected are arranged on the communication controller 91. The controller 20 connected to the controller connection unit 12 has, e.g., 16 instruction keys to input an instruction from a user, and transmits the state of the instruction keys to the communication controller 91 by synchronous communication about 60 times according to the instruction from the controller 20. The communication controller 91 transmits the state of the instruction keys of the controller 20 to the CPU 51.
In this manner, the instruction from the user is input to the CPU 51, and the CPU 51 performs a process according to the instruction from the user on the basis of the game program or the like being in execution. Here, in reading a program, display of an image, image drawing, or the like, a large amount of image data must be transferred at a high speed among the main memory 53, the GPU 62, the image decoder 64, the decoder 82, and the like. Therefore, this video game apparatus, as described above, is designed to perform so-called DMA transfer in which data is directly transferred among the main memory 53, the GPU 62, the image decoder 64, the decoder 82, and the like under the control of the peripheral device control unit 52 without passing through the CPU 51. In this manner, a load on the CPU 51 generated by the data transfer can be reduced, and high-speed data transfer can be performed.
When setting data or the like of a game being in execution must be stored, the CPU 51 transmits the data to be stored to the communication controller 91, and the communication controller 91 writes the data from the CPU 51 in the memory card 10 or the portable electronic device 100 which is inserted into the slot of the memory card insertion unit 8A or the memory card insertion unit 8B.
Here, a protection circuit for preventing electric breakdown is incorporated in the communication controller 91. The memory card 10 and the portable electronic device 100 are separated from the bus BUS, and can be attached to or detached from the slot while the main body of the apparatus is powered on. Therefore, when the memory capacity of the memory card 10 or the portable electronic device 100 is short, a new memory card 10 can be inserted without cutting the power supply of the main body of the apparatus. For this reason, without losing game data which must be backup, the new memory card 10 can be inserted to write necessary data in the new memory card 10.
In addition, a parallel I/O interface (PIO) 96 and a serial I/O interface (SIO) 97 are interfaces for connecting the memory card 10 or the portable electronic device 100 to the video game device 1.
In the entertainment system described above, when perspective transformation according to this embodiment is executed, high-speed processing is executed by using approximate calculation.
[Three-dimensional Graphics]
Three-dimensional graphics are techniques in which, when an object placed in a three-dimensional space is viewed from a certain point of view, the perspective position of the object on a screen supposed to be set a certain position. In the entertainment system described above, in order to draw polygons, a series of processes, i.e., the process of performing a geometry operation by using a plurality of polygons of one screen as a unit, the process of performing sorting by Z values, and the process of performing drawing are performed. More specifically, The processes from the process of performing a geometry operation to the process of performing drawing are performed step by step to a set of polygons of one screen.
The GTE 61 of the graphic system 60 functions as a co-processor for performing the geometry operation at a high speed. Of the high-speed operations, a typical geometry operation is provided to, e.g., a game programmer as the form of a library. An approximation of perspective transformation to be described below can be prepared as, e.g., a basic geometry library, and can be provided to a game programmer. A calculation of perspective transformation is expressed as, e.g., Equations (1) and (2):
Sx = X x (h/Z) ...(1)
Sy = Y x (h/Z) ...(2) Equations (1) and (2) are equations for, when an object OB is viewed from a point of view VP set at a certain point as shown in FIG. 5, calculating the position of a projected image of the object OB on a virtual screen 200.
In FIG. 5, a point of view VP is set as a coordinate origin A, a line of sight is pointed in the plus side of the Z axis, and the upper direction in FIG. 5 is defined as the Y axis. At this time, the X axis is omitted. In such a coordinate system, it is assumed that an arrow-like object OB is arranged on the Z axis.
When the coordinates of the summit of the arrow of the object OB is defined as P (X,Y), the summit of the project of the arrow reflected on the screen 200 is represented by coordinates Ps (Sx,Sy). Referring to FIG. 5, a triangle ABC is similar to a triangle ADE. The distance from the point of view VP to the object OB is represented by Z, and the distance from the point of view VP to the screen 200 is represented by h. In this case, scale factors (segment factors) of the two triangles which are similar to each other are represented by (h/Z). For this reason, the coordinate values of the summit coordinates Ps on the screen 200 can be expressed by Equations (1) and (2) described above.
The summit coordinates Ps (Sx,Sy) calculated by Equations (1) and (2) correspond to summit coordinates on the screen on which a basic figure (polygon) constituting an object of, e.g., a three-dimensional image. This relationship can also be satisfied with respect to the X-axis direction omitted in FIG. 5. Perspective transformation must be performed to all the points constituting a three-dimensional object. Here, the case in which one single object is placed in the same scene is considered. FIG. 6 illustrates this case. In FIG. 6, as typical points constituting an object OB which is similar to a Christmas tree, four points PI (X1,Y1), P2 (X2,Y2), P3 (X3.Y3), and P4 (X4,Y4) are specified. The distances from a point of view VP to the four points PI, P2, P3, and P4 of the object OB are represented by Zl, Z2, Z3, and Z4, respectively, and the distance from the point of view VP to a screen 200 is represented by h. At this time, coordinates Psl (Sxl,Syl), Ps2 (Sx2,Sy2), Ps3 (Sx3,Sy3), and Ps4 (Sx4,Sy4) on the screen obtained by perspective-transforming the four points PI to P4 can be expressed by the following equations, respectively: Sxl = XI x (h/Zl), Syl = Yl x (h/Zl) ...(3) Sx2 = X2 x (h/Z2), Sy2 = Y2 x (h/Z2) ...(4) Sx3 = X3 x (h/Z3), Sy3 = Y3 x (h/Z3) ...(5)
Sx4 = X4 x (h/Z4), Sy4 = Y4 x (h/Z4) ...(6).
These calculations are performed for the following reason. That is, although the distance from the point of view VP to the screen 200 is constant, i.e., h, since the distances from the point of view VP to the four points PI to P4 are different from Zl, Z2, Z3, and Z4, respectively, the scale factors of the similar figures are different from (h/Zl), (h/Z2), (h/Z3), and (h/Z4), respectively. For this reason, in order to perspective-transforming the four specific points PI to P4, scale factors (h/Zl), (h/Z2), to (h/Z4) the number of which is proportional to the number of points must be calculated. In general, if the object OB is constituted by N points, scale factors (h/Z) must be calculated times the number of which is proportional to the number of points N. A case in which a plurality of objects are placed on the same scene will be considered. FIG. 7 is a diagram showing this case. In FIG. 7, three Christmas-tree-like objects OB each of which is the same as that shown in FIG. 6 are arranged with different distances from a point of view VP. These objects are represented by OBI, OB2, and OB3 in order of increasing the distance from the point of view VP.
It is assumed that each of the three objects OBI to OB3 in FIG. 7 is constituted by four points as in FIG. 6. In this case, according to Equations (3) to (6), calculation for scale factors (h/Z) must be performed times the number of which is the number of distances in the Z direction of each object, i.e., four times. Therefore, calculation must be performed 12 times in all the objects OBI to OB3. In general, it is assumed that M objects are constituted by Nl points, N2 points,..., Nm points, respectively. In this case, according to Equations (3) to (6), calculation for scale factors (h/Z) must be performed times the number of which is the number of distances, i.e., (Nl + N2 +...+ Nm) times.
More specifically, it is assumed that the Z values of Nl points constituting the first object OBI are represented by ZOBli, ZOBI2,..., ZOBINI, tnat the z values of N2 points constituting the second object OB2 are represented by ZOB2ι, ZOB22,..., ZOB2N2, and, similarly, that the Z values of Nm points constituting the Mth object OBM are represented by ZOBMi, ZOBM2,..., ZOBMNm. In this case, (h/ZOBi), (I1/ZOBI2),..., (h/ZOBMNm) must De calculated. In this manner, amounts of calculation of these scale factors (h/Z) are enormous.
(Case in which it is regarded that object is localized in space)
However, it may be regarded that a single object is sufficiently spaced apart from a point of view, and that the object is localized in the space. It is assumed that the object is constituted by N points. The distances from the point of view VP to points ?ι, P2,— , ?N are represented by Z , Tq.,—, Z^j, respectively.
In such a case, the differences between the Z values of the distances __\, Z2,—> ZN from the point of view VP to the points constituting the objects are relatively considerably smaller than the Z values of the distances from the point of view VP to the points constituting the objects. As described above, when it can be regarded that the points constituting the objects are localized in the space, the following expressions are satisfied:
| minZ - maxZ| < | minZ| ...(7), I minZ - maxZ | < | maxZ | —(8), or
| minZ - maxZ| < | meanZ| ...(9) where, minZ = min(Zj, Z2,..., ZN) is satisfied, i.e., minZ represents the minimum value of the values (Zj, Z2,..., Zj f) of the distances from the point of view VP to the points constituting the objects, maxZ = max(Zj, Z2,-, ZJSJ) is satisfied, i.e., maxZ represents the maximum value of the values (Zj, Z2,..., ZN) of the distances from the point of view VP to the points constituting the objects, meanZ = mean(Zj, Z2,..., Zjsj) is satisfied, i.e., meanZ represents an average value meanZ = (Z\ + Z2 + ... + ZN)/N of the values (Z\, Z2,..., Zjvj) of the distances from the point of view VP to the points constituting the objects, and
<: represents that the value of the left member is considerably smaller than that of the right member. When the equations are satisfied, the distances of the Z values of the points constituting the object are considerably smaller than the Z values of the points constituting the object. For this reason, it is understood that an image is slightly influenced even if the differences are neglected when the object is drawn. Therefore, as shown in FIG. 8, the Z values of all the points constituting the object are approximated by a typical value typZ, an influence on an image can be almost neglected. For example, an average value meanZ = (Z\, Z2,—, Zjj)/N of the Z values (Z\, Z2,—, ZN) of n points constituting the object is defined as the typical value typZ, and the Z values of the object can be approximated by using the typical value typz.
For example, when each Z value is approximated by using the typical value typZ to perform perspective transformation, the coordinates of the object on the screen can be expressed by the following equations:
Sxl = XI x (h/typZ), Syl = Yl x (h/typZ) ...(10) Sx2 = X2 x (h/typZ), Sy2 = Y2 x (h/typZ) ...(11) Sx3 = X3 x (h/typZ), Sy3 = Y3 x (h/typZ) ...(12)
SxN = XN x (h/typZ), SyN = YN x (h/typZ) ...(13) In calculations of Equation (10) to (13), a calculation for a scale factor (h/Z) of one object is completed by calculating (h/typZ) only once. More specifically, in perspective transformation of all the points constituting the object, an approximate scale factor (h/typ) can be used.
In a computer, division for calculating scale factors is basically performed by repeating subtraction. For this reason, when calculation for a scale factor is satisfactorily performed once an object, the number of times of arithmetic operation can be considerably reduced.
(Case in which it is regarded that a plurality of objects are localized in units of objects in space) The case in which a plurality of objects OBI to OBM are placed on the same scene will be considered. It may be regarded that all these objects OBI to OBM are sufficiently spaced apart from a point of view VP, and that the objects are localized in units of objects in the space. In other words, the later condition indicates that the objects are sufficient spaced apart from each other. It is assumed that the first object OBI is constituted by Nl points, that the second object OB2 is constituted by N2 points, ...., and that the Mth object OBM is constituted by NM points.
It is assumed that the distances from the point of view VP to points OBlj,
OBI2,..., OBINI of the first object OBI are represented by Zli, ZI2,—, Zl^i, respectively. It is assumed that the distances from the point of view VP to points
OB2χ, OB22,..-, OB2N2 of the second object OB2 are represented by Z2ι , Z22,.».
Z2N2> respectively. Similarly, it is assumed that the distances from the point of view VP to points OBM}, OBM2,..., OBM^M of the Mm object OBM are represented by ZMj, ZM2,-, ZM_VJM> resPectively.
In such a case, since all these objects are sufficiently spaced apart from the point of view VP, relationships which are similar to the relationships expressed by Expressions (7) to (9):
| minZ - maxZ| < | minZ| ...(14),
| minZ - maxZ| < | maxZ| ...(15), or
| minZ - maxZ| C | meanZ| ...(16) where, minZ = min(Zl; ,..., ZMNM) *S satisfied, i.e., minZ represents the minimum value of the values (Z\\,..., ZMNM) °f me distances from the point of view VP to the points constituting all the objects OBI to OBM, maxZ = max(Zlι,..., ZMJ^M) ιs satisfied, i.e., maxZ represents the maximum value of the values (Zlj,..., ZMJ^M) ° me distances from the point of view VP to the points constituting all the objects OBI to OBM, meanZ = mean(Zlj,..., ZMNM) *S satisfied, i.e., meanZ represents the average value meanZi = (Zli +...+ ZMNMV(N1 +•••+ NM) of the values (Zli ,..., ZMNM) of the distances from the point of view VP to the points constituting all the objects OBI to OBM, and < : represents that the value of the left member is considerably smaller than that of the right member.
Since the plurality of objects OBI to OBM are localized in the space in units of objects, the points constituting a specific object are sufficiently spaced apart from the points constituting the other objects. In particular, the points constituting the specific object are also sufficiently spaced apart from the points constituting the objects adjacent to the specific object.
When it can be regarded that the points constituting the objects in the space are localized in units of objects, the following expressions are satisfied:
I minZi - maxZl | ≤ | meanZi - meanZ21 ...(17)
I minZ2 - maxZ21 ≤ | meanZi - meanZ21 ...(18)
| minZ2 - maxZ2 | ≤ | meanZ2 - meanZ31 ...(19) | minZ3 - maxZ3 | ≤ | meanZ2 - meanZ31 ...(20)
I minZM-1 - maxZM-1 1 ≤ | meanZM-1 - meanZM | ...(21)
I minZM - maxZM | ≤ | meanZM-1 - meanZM | ...(22) where, minZi = min(Zlι, ZI2,..., Zljsjl) is satisfied, i.e., minZi represents the minimum value of the values (Zli, ZI2,— , ZINI) of the distances from the point of view VP to Nl points constituting the first object OBI, minZ2 = min(Z2ι, Z22,.»> 22^2) is satisfied, i.e., minZ2 represents the minimum value of the values (Z2 , Z22>— . 2]sj2) °f e distances from the point of view VP to N2 points constituting the second object OB2, and similarly, minZM = min(ZMι, ZM2,— , ZMJNJM) *S satisfied, i.e., minZi represents the minimum value of the values (ZMi, ZM2,—, ZMJ^M) °f tne distances from the point of view VP to NM points constituting the Mth object OBM. Next, maxZl = max(Zlι, ZI2,..., Zlj^i) is satisfied, i.e., maxZl represents the maximum value of the values (Zli, Zl2>. ZINI) of the distances from the point of view VP to Nl points constituting the first object OBI, maxZ2 = max(Z2 , Z22,—> i satisfied, i.e., maxZ2 represents the maximum value of the values (Z2ι, Z22,.-. Z2_NJ2) °f tne distances from the point of view VP to N2 points constituting the second object OB2, and similarly, maxZM = max(ZM , ZM2,—> ZMJSJM) S satisfied, i.e., maxZl represents the maximum value of the values (ZMi, ZM2,—. ZMJSJM) of the distances from the point of view VP to NM points constituting the Mth object OBM.
Furthermore, meanZi = mean(Zl , Zl2,.--> Z1]SJI) is satisfied, i.e., meanZi represents the average value meanZi = mean(Zlι + ZI2 +...+ Z1]SJI)/N1 of the values (Zli, ZI2,—, ZINI) of the distances from the point of view VP to Nl points constituting the first object OBI, meanZ2 = mean(Z2ι, Z22,—> 2jsf2) i satisfied, i.e., meanZ2 represents the average value meanZ2 = mean(Z2ι + Z22 +...+ Z2N2) N2 of the values (Z2ι, Z22,..., Z2N2) of e distances from the point of view VP to N2 points constituting the second object OB2, and similarly, meanZM = mean(ZMι, ZM2,-, ZMISJM) *S satisfie^' i-e-> nieanZl represents the average value meanZ2 = mean(ZMι + ZM2 +—+ ZMNM)/NM of the values (ZMi, ZM2. ., ZMNM) °f tne distances from the point of view VP to NM points constituting the Mth object OBM. < : represents that the value of the left member is considerably smaller than that of the right member.
When the equations are satisfied, the differences between the Z values of points constituting a specific object when a plurality of objects are drawn are considerably smaller than the differences between the Z values of points constituting objects adjacent to the specific objects. It is understood that an image is slightly influenced even if the differences are neglected.
For example, an average value meanZM = (ZM + ZM2 +...+ ZMJNJMVNM of the Z values (ZMi, ZM2,—. ZMNM) °f NM points constituting a specific object (e.g., the Mth object) is defined as a typical value typZM, and the Z values of an object can be approximated by using the typical value typZM.
For this reason, as shown in FIG. 9, even if the Z values of all points constituting a plurality of objects are respectively approximated by typical values typZl, typZ2,..., TypZM in units of objects, an influence on an image can be almost neglected.
The first object OBI is constituted by Nl points, and the Z values of all the points can be approximated by the typical value typZl. For this reason, a scale factor can be approximated by calculating (h/typZl). The second object OB2 is constituted by N2 points, and the Z values of all the points can be approximated by the typical value typZ2. For this reason, a scale factor can be approximated by calculating (h/typZ2).
The Mth object OBM is constituted by NM points, and the Z values of all the points can be approximated by the typical value typZM. For this reason, a scale factor can be approximated by calculating (h/typZM).
In this manner, the plurality of objects OBI to OBM are constituted by Nl to NM points, respectively, and the M objects OBI to OBM can be approximated by using the typical values typZl to typZM of the Z values. For this reason, the scale factors can be perspective-transformed by performing approximation of (h/typZl), (h/typZ2),..., (h/typZM).
When a plurality of objects exist, a calculation for a scale factor (h/Z) of each object is completed by calculating (h/typZ) once for the corresponding object. More specifically, in perspective transformation of all the points constituting the plurality of objects, approximate scale factors (h/typZ) can be used in units of objects. In a computer, division for calculating scale factors is basically performed by repeating subtraction. For this reason, when calculation for a scale factor is satisfactorily performed once an object, the number of times of arithmetic operation can be considerably reduced. (Criterion of decision) First, criterions for deciding whether it can be regarded that a single object is localized in a space will be described below.
The present inventor uses the following values as criterions for deciding whether Expressions (7) to (9) are satisfied, i.e., all points constituting the object are independently calculated by changing the Z values of the scale factor (h/Z) or can be approximated by using the typical value typZ (meanZ in the above case) of the Z values: | minZ - maxZ| ÷ |minZ| ≤ Kl ...(23),
| minZ - maxZ| ÷ | maxZ | ≤ Kl ...(24), or
| minZ - maxZ| ÷ | meanZ| ≤ Kl ...(25).
The values of the left members of Expressions (23) to (25) are Kl or less, it is determined that the objects can be approximated. Expressions (23) to (25) mean that the ratios of the differences between the minimum value minZ and the maximum value maxZ of the points constituting the object to the typical values minZ, maxZ, and meanZ are the predetermined value Kl or less.
It is assumed that the value Kl of Expressions (23) to (25) is a predetermined value, e.g., Kl = 0.1. In this case, the absolute value of the difference between the minimum value and the maximum value of the Z values of the object OB is equal to or smaller than 1/10 of the absolute value of the typical value (minimum value minZ, maximum value maxZ, or average value meanZ) of the Z values of the object, and it is determined that all the Z values of the object can be approximated by the typical value typZ of one Z value. As a matter of course, the value of Kl can be arbitrarily set depending on an application program to be applied, a scene to be applied, or the like. The value of Kl need not be always a constant value, and may be changed depending on the application program to be applied, the scene to be applied, or the like. When a plurality of objects exist in the same scene, a specific object can be approximated by a typical value, and the other objects can also be calculated such that the values of the objects are calculated. Second, criterions for deciding whether it is regarded that all objects are localized in a space and localized in the space in units of objects will be described below.
The present inventor uses the following values as criterions for deciding whether it can be regarded that all the objects are localized as in Expressions (23) to (25). The following values are used as the criterions of decision to satisfy Expressions (14) to (16).
|minZ-maxZ| ÷ |minZ| ≤ Kl ...(26),
|minZ-maxZ| ÷ |maxZ| ≤ Kl ...(27), or
|minZ-maxZ| ÷ |meanZ| ≤ Kl ...(28).
The values of Expressions (26) to (28) are Kl or less, it is determined that the objects can be approximated. The contents of Expressions (26) to (28) and the predetermined value Kl are as described above.
Since Expressions (17) to (22) are satisfied, the present inventor uses the following values as criterions for deciding whether a plurality of objects are localized in a space in units of objects: |minZl-maxZl| ÷ | meanZi - meanZ21 ≤ K2 ...(29)
I minZ2 - maxZ21 |meanZl-meanZ2| ≤ K2 ...(30) |minZ2-maxZ2| |meanZ2-meanZ3| ≤ K2 ...(31) minZ3-maxZ3| ÷ | meanZ2 - meanZ31 ≤ K2 ...(32)
|minZM-l-maxZM-l| ÷ | meanZM- 1 -meanZM | ≤ K2 ...(33)
|minZM-maxZM| ÷ | meanZM- 1 - meanZM | ≤ K2 ...(34). If the values of Expressions (29) and (30) are K2 or less, it can be determined that the first object OB is sufficiently spaced apart from the second object OB2. If the values of Expressions (31) and (32) are K2 or less, it can be determined that the second object OB2 is sufficiently spaced apart from the third object OB3. Similarly, if the values of Expressions (33) and (34) are K2 or less, it can be determined that the (M-l)th object OBM-1 is sufficiently spaced apart from the Mth object OBM. Expressions (29) to (34) mean that the ratio of the difference ( | meanZ2 - meanZ31 ) between the distance from the point of view to a specific object (e.g., OP2) and the distance from the point of view to an object adjacent to the specific object to the difference ( | minZ2 - max Z21 ) between the minimum value and the maximum value of the distances from the point of view VP to a plurality of points constituting the specific object is a predetermined value K2 or less.
When the value K2 of Expressions (29) to (34) is a predetermined value, e.g., K2 = 0.1, the ratio of the difference between the distance from the point of view to a specific object (e.g., OP2) and the distance from the point of view to an object (e.g., OP3) adjacent to the specific object to the difference between the minimum value and the maximum value of the distances from the point of view VP to a plurality of points constituting the specific object is 1/10 or less. It is determined that the Z values of all the points of the object (e.g., OP2) can be approximated by one typical value (e.g., typZ2) of Z values. As a matter of course, the value of K2 can be changed depending on an application program to be applied, a scene to be applied, or the like. The value of K2 need not be always a constant value, and may be changed depending on the application program to be applied, the scene to be applied, or the like. When a plurality of objects exist in the same scene, a specific object can be approximated by a typical value, and the other objects can also be calculated such that the Z values of the respective points of the objects are calculated. (Selection of typical value typZ)
A method of selecting a typical value tpyZ of the Z values will be described below. The scale factor changes depending on the selection of the typical value. Firs, in the embodiment described above, as a typical value of Z values, the average value meanZ of the Z values of points constituting the object is set. For example, as the typical value typZ, a value given by the following equations: typZ = meanZ = (Zl + Z2 +...+ Zn)/N ...(35).
In Equation (35), the average value of points (Z0 + Zl + Z2 +...+ Zn) constituting one object as in the above embodiment is set as the distance of a typical point (typical value of Z values). In this case, the scale factor (h/Z) is given by (h/meanZ). typZ = Zl ...(36)
In Equation (36), the first Z value of Z values (Zl, Z2,..., Zn) of the points constituting the object is set as the distance of the typical point. In this case, the scale factor (h/Z) is given by (h/Zn). typZ = Zn ...(37) In Equation (37), the last (i.e., the Nth) Z value of the Z values (Zl, Z2,..., Zn) of the points constituting the object is set as the distance of the typical value. In this case, the scale factor (h/Z) is given by (h/Zn).
The methods expressed by Equations (35) to (37) are also called replacing methods. Second, a method of calculating a scale factor by a primary (linear) approximation is known.
{(maxZ - Z)/(maxZ - minZ)} x (h/minZ) + {(Z - minZ)/(maxZ - minZ)} x (h/maxZ) ...(38)
In Expression (38), a value h/Z of the typical point of the Z values are linearly approximated (primarily approximated) by using h/maxZ obtained by the maximum value maxZ and h/minZ obtained by the minimum value minZ. Expression (38) is also called a linear (primary) approximation.
Third, a method of calculating a scale factor (h/Z) by a quadratic approximation is known. {h/(minZ x maxZ x midZ)} x [(Z x Z) - 3.0 x midZ x Z + 0.5 x {(minZ x minZ)
+ (maxZ x maxZ) + 4.0(minZ x maxZ)}] ...(39) where midZ = (maxZ + minZ)/2 is satisfied, i.e., midZ is the average value of maxZ and minZ.
In Expression (39), a value (h/Z) of the typical point of the Z values is calculated by a quadratic approximation.
This quadratic approximation is concretely performed by the following method. When the scale factor (h/Z) is approximated by a quadratic curve, a quadratic equation f(Z) = A-Z2 + B Z + C is given. When Z = minZ, f(Z) = h/minZ is satisfied. When Z = maxZ, f(Z) = h/maxZ is satisfied. When Z = midZ, f(Z) = h/midZ is satisfied. These relationships, the three following equations are satisfied: A minZ2 + B minZ + C = h/minZ ...(40) A maxZ2 + B maxZ + C = h/maxZ ...(41)
A midZ2 + B midZ + C = h/midZ ...(42)
Since three variables A, B, and C are used, and three quadratic equations are satisfied, the solutions of these variables can be calculated. When Equations (40) to (42) are solved, the following solutions are obtained: A = h/(minZ x maxZ x midZ) ...(43)
B = A (-3.0 x midZ) ...(44)
C = A [(0.5 x {(minZ x minZ) + (maxZ x maxZ) + 4.0(minZ x maxZ)}]
...(45) When the values of A, B, and C are substituted in the quadratic equation f(Z) = A-Z2 + B Z + C, Expression (39) is obtained. Expression (39) is also called a quadratic approximation.
In the approximation of these scale factors, the scale factors can be calculated by performing division once in Equations (35), (36), and (37) according to the replacing method. In Expression (38) according to the linear approximation, a scale factor can be calculated by performing division twice. In Expression (39) according to the quadratic approximation, a scale factor can be calculated by performing division three times. Although the numbers of times of addition and multiplication is increased in the linear approximation and the quadratic approximation, in general computer processing, addition and multiplication can be processed at a speed higher than that of division. Therefore, even in the linear approximation and the quadratic approximation, processing can be performed at a speed higher than that in the case in which the scale factors of points constituting an object are respectively calculated.
The replacing method, the linear approximation, and the quadratic approximation have been described above. When the order is increased, i.e., a tertiary approximation, a quaternary approximation, or a higher-order approximation is performed, scale factors can be approximated at a more precision.
The present invention relates to a computer graphic process, and can provide a novel method and apparatus for perspective-transforming a three-dimensional thing on a virtual two-dimensional screen.

Claims

CLAIMSWHAT IS CLAIMED IS:
1. An apparatus for perspective-transforming a thing placed in a three-dimensional space on a virtual two-dimensional screen, comprising means in which, when the coordinate values of a plurality of points for specifying the thing are localized with respect to a certain direction in the three-dimensional space, by using the coordinate values of a typical point selected from the plurality of points, perspective transformation of the other points is approximated, and wherein calculation for graphics is performed at a high speed.
2. An apparatus for perspective-transforming a plurality of things placed in a three-dimensional space on a virtual two-dimensional screen, comprising means in which, when the coordinate values of a plurality of points for specifying the things are localized with respect to a certain direction in the three-dimensional space, by using the coordinate values of typical points of the things selected from the plurality of points for specifying the things, perspective transformation of the other points is approximated, and wherein calculation for graphics is performed at a high speed.
3. An apparatus for perspective-transforming a thing according to claim 1 or 2, wherein the certain direction is the direction of a line of sight extending from a point of view to the thing
4. An apparatus for perspective-transforming a thing according to claim 3, wherein the direction of the line of sight is a Z-axis direction in an XYZ coordinate system specified around the point of view.
5. An apparatus for perspective-transforming a thing according to claim 1 or 2, wherein the plurality of points are vertex coordinates obtained when a thing is drawn with polygons.
6. An apparatus for perspective-transforming a thing according to claim 1 or 2, wherein the typical point is determined by a replacing method on the basis of the coordinate values of the plurality of points.
7. An apparatus for perspective-transforming a thing according to claim 1 or 2, wherein the typical point is determined by averaging the plurality of points, and the distances from the point of view to the other points or the Z values of the other points are approximated on the basis of the average value of the distances from the point of view or the average value of the Z values.
8. An apparatus for perspective-transforming a thing according to claim 1 or 2, wherein the typical point is set as the first selected point of the plurality of points, and the distances from the point of view to the other points or the Z values of the other points are approximated on the basis of the distance from the point of view to the first point or the Z value of the first point.
9. An apparatus for perspective-transforming a thing according to claim 1 or 2, wherein the typical point is set as the last selected point of the plurality of points, and the distances from the point of view to the other points or the Z values of the other points are approximated on the basis of the distance from the point of view to the last point or the Z value of the last point.
10. An apparatus for perspective-transforming a thing according to claim 1 or 2, wherein, as the typical point, one point is selected from the plurality of points by an arbitrary method, and the distances from the point of view to the other points or the Z values of the other points are approximated on the basis of the distance from the point of view to the selected point or the Z value of the selected point.
11. An apparatus for perspective-transforming a thing according to claim 1 or 2, wherein when the distances from the point of view to the plurality of points or the Z values of the points are represented by Z, when the maximum value of the distances from the point of view to the plurality of points or the maximum value of Z is represented by maxZ, when the minimum value of the distances from the point of view to the points or the minimum value of Z is represented by minZ, and when the distance from the point of view to the virtual screen is represented by h, h/Z is approximated on the basis of a value calculated by a linear approximate expression: {(maxZ - Z)/(maxZ - minZ)} x (h/minZ) + {(Z - minZ)/(maxZ - minZ)} x (h/maxZ).
12. An apparatus for perspective-transforming a thing according to claim 1 or 2, wherein when the distances from the point of view to the plurality of points or the Z values of the points are represented by Z, when the maximum value of the distances from the point of view to the plurality of points or the maximum value of Z is represented by maxZ, when the minimum value of the distances from the point of view to the points or the minimum value of Z is represented by minZ, when the average value of the minimum value and the maximum value of Z is represented by midZ, and when the distance from the point of view to the virtual screen is represented by h, h/Z is approximated on the basis of a value calculated by a quadratic approximate expression: {h/(minZ x maxZ x midZ)} x [(Z x Z) - 3.0 x midZ x Z + 0.5 x {(minZ x minZ) + (maxZ x maxZ) + 4.0(minZ x maxZ)}].
13. An apparatus for perspective-transforming a thing according to claim 1, wherein, whether the coordinate values of a plurality of points for specifying the thing are localized with respect to a certain direction in the three-dimensional space or not is determined in such a manner that, when the minimum value of the Z values of the thing in a Z-axis direction is represented by minZ, when the maximum value of the Z values of the thing is represented by maxZ, when the average value of the Z values of the thing is represented by meanZ, and when expressions:
| minZ - maxZ| ÷ | minZ| ≤ Kl, | minZ - maxZ| ÷ | maxZ| ≤ Kl, or
| minZ - maxZ| ÷ | meanZ| ≤ Kl are satisfied, it is determined that the Z values of the thing are localized.
14. An apparatus for perspective-transforming a thing according to claim 13, wherein the Kl is a number which is smaller than 1.0.
15. An apparatus for perspective-transforming a thing according to claim 13, wherein the Kl is changed depending on an application program to be applied.
16. An apparatus for perspective-transforming a thing according to claim 13, wherein the Kl is changed depending on a scene to be applied.
17. An apparatus for perspective-transforming a thing according to claim 2, wherein, whether the coordinate values of the plurality of points for specifying the plurality of things are localized with respect to a certain direction in the three-dimensional space in units of things or not is determined in such a manner that, when the minimum value of the Z values of the ith thing (i = 1, 2,..., M) in a Z-axis direction is represented by minZi, when the maximum value of the Z values of the ith thing is represented by maxZi, when the average value of the Z values of the ith thing is represented by meanZi, and when expressions:
I minZi - maxZl | ÷ | meanZi - meanZ21 ≤ K2,
| minZ2 - maxZ2| ÷ | meanZi - meanZ21 ≤ K2,
| minZ2 - maxZ2 | ÷ | meanZ2 - meanZ31 ≤ K2,
|minZ3 - maxZ3 | ÷ | meanZ2 - meanZ31 ≤ K2,
I minZM-1 - maxZM-11 ÷ | meanZM- 1 - meanZM | ≤ K2, and I minZM - maxZM l ÷ | meanZM-1 - meanZM | ≤ K2 are satisfied, it is determined that the Z values are localized in units of things.
18. An apparatus for perspective-transforming a thing according to claim 17, wherein the K2 is a number which is smaller than 1.0.
19. An apparatus for perspective-transforming a thing according to claim 17, wherein the K2 is changed depending on an application program to be applied.
20. An apparatus for perspective-transforming a thing according to claim 17, wherein the K2 is changed depending on a scene to be applied.
21. An apparatus for perspective-transforming a thing according to claim 17, wherein the apparatus is selectively applied to only a thing, which satisfies the expressions, of the plurality of things.
22. An apparatus for perspective-transforming a thing according to claim 1 or 2, wherein the apparatus for perspective transformation is a geometry transfer engine.
23. An entertainment system comprising: a control system; a graphic system; a sound system; an optical disk control unit; and a bus for connecting these systems and the unit to each other, and wherein the graphic system has a geometry transfer engine, and when the coordinate values of a plurality of points for specifying the thing are localized with respect to a certain direction in the three-dimensional space, by using the coordinate values of a typical point selected from the plurality of points, the graphic system approximates perspective transformation of the other points.
24. An entertainment system comprising: a control system; a graphic system; a sound system; an optical disk control unit; and a bus for connecting these systems and the unit to each other, and wherein the graphic system has a geometry transfer engine, and when the coordinate values of a plurality of points for specifying a plurality of things are localized with respect to a certain direction in the three-dimensional space, by using the coordinate values of typical points selected from the plurality of points for specifying the things in units of things, the graphic system approximates perspective transformation of the other points.
25. A method of perspective-transforming a thing placed in a three-dimensional space, comprising the steps of: checking whether the coordinate values of a plurality of points for specifying the thing are localized with respect to a certain direction in the three-dimensional space or not; and if the coordinate values are localized, approximating perspective transformation of the other points by using the coordinate values of a typical point selected from the plurality of points.
26. A method of perspective-transforming a plurality of things placed in a three-dimensional space, comprising the steps of: checking whether the coordinate values of a plurality of points for specifying the things are localized with respect to a certain direction in the three-dimensional space in units of things; and if the coordinate values are localized, approximating perspective transformation of the other points by using the coordinate values of typical points selected from the plurality of points in units of things.
27. A method of perspective-transforming a thing according to claim 25, wherein, whether the coordinate values of a plurality of points for specifying the thing are localized with respect to a certain direction in the three-dimensional space or not is determined in such a manner that, when the minimum value of the Z values of the thing in a Z-axis direction is represented by minZ, when the maximum value of the Z values of the thing is represented by maxZ, when the average value of the Z values of the thing is represented by meanZ, and when expressions: | minZ - maxZ| ÷ | minZ| ≤ Kl,
| minZ - maxZ| ÷ | maxZ| ≤ Kl, or |minZ - maxZ| ÷ |meanZ| ≤ Kl are satisfied, it is determined that the thing is localized.
28. A method of perspective-transforming a thing according to claim 26, wherein, whether the coordinate values of the plurality of points for specifying the plurality of things are localized with respect to a certain direction in the three-dimensional space in units of things or not is determined in such a manner that, when the minimum value of the Z values of the ith thing (i = 1, 2,..., M) in a Z-axis direction is represented by minZi, when the maximum value of the Z values of the ith thing is represented by maxZi, when the average value of the Z values of the ith thing is represented by meanZi, and when expressions:
I minZi - maxZl | ÷ | meanZi - meanZ21 ≤ K2,
| minZ2 - maxZ2 | ÷ | meanZi - meanZ21 ≤ K2,
I minZ2 - maxZ21 ÷ | meanZ2 - meanZ31 ≤ K2,
|minZ3 - maxZ3 | ÷ I meanZ2 - meanZ31 ≤ K2,
I minZM-1 - maxZM-1 1 ÷ | meanZM-1 - meanZM | ≤ K2, and | minZM - maxZM | ÷ | meanZM- 1 - meanZM | ≤ K2 are satisfied, it is determined that the Z values are localized in units of things.
29. A recording medium which stores a program comprising the steps of: when a thin placed in a three-dimensional space is perspective-transformed, checking whether the coordinate values of a plurality of points for specifying the thing are localized with respect to a certain direction in the three-dimensional space or not; and if the coordinate values are localized, approximating perspective transformation of the other points by using the coordinate values of a typical point selected from the plurality of points.
30. A recording medium which stores a program comprising the steps of: when a thin placed in a three-dimensional space is perspective-transformed, checking whether the coordinate values of a plurality of points for specifying the things are localized with respect to a certain direction in the three-dimensional space in units of things; and if the coordinate values are localized, approximating perspective transformation of the other points by using the coordinate values of typical points selected from the plurality of points in units of things.
PCT/JP2000/002280 1999-04-09 2000-04-07 Method and apparatus for performing perspective transformation WO2000062255A1 (en)

Priority Applications (9)

Application Number Priority Date Filing Date Title
KR1020017012835A KR20010113781A (en) 1999-04-09 2000-04-07 Method and apparatus for performing perspective transformation
MXPA01010150A MXPA01010150A (en) 1999-04-09 2000-04-07 Method and apparatus for performing perspective transformation.
CNB008060614A CN100392678C (en) 1999-04-09 2000-04-07 Method and apparatus for performing perspective transformation
CA002369879A CA2369879A1 (en) 1999-04-09 2000-04-07 Method and apparatus for performing perspective transformation
EP00915421A EP1181669A1 (en) 1999-04-09 2000-04-07 Method and apparatus for performing perspective transformation
JP2000611248A JP3643036B2 (en) 1999-04-09 2000-04-07 Apparatus and method for perspective transformation
BR0011156-2A BR0011156A (en) 1999-04-09 2000-04-07 Apparatus and method for performing the transformation in perspective, entertainment system and recording media
AU36739/00A AU3673900A (en) 1999-04-09 2000-04-07 Method and apparatus for performing perspective transformation
HK02103613.9A HK1041959A1 (en) 1999-04-09 2002-05-13 Method and apparatus for performing perspective transformation

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
JP11/102655 1999-04-09
JP10265599 1999-04-09
JP16174299 1999-06-08
JP11/161742 1999-06-08

Publications (1)

Publication Number Publication Date
WO2000062255A1 true WO2000062255A1 (en) 2000-10-19

Family

ID=26443338

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/JP2000/002280 WO2000062255A1 (en) 1999-04-09 2000-04-07 Method and apparatus for performing perspective transformation

Country Status (13)

Country Link
US (2) US6590576B1 (en)
EP (1) EP1181669A1 (en)
JP (1) JP3643036B2 (en)
KR (1) KR20010113781A (en)
CN (1) CN100392678C (en)
AU (1) AU3673900A (en)
BR (1) BR0011156A (en)
CA (1) CA2369879A1 (en)
HK (1) HK1041959A1 (en)
MX (1) MXPA01010150A (en)
RU (1) RU2001130343A (en)
TW (1) TW540009B (en)
WO (1) WO2000062255A1 (en)

Families Citing this family (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
FR2799558B1 (en) * 1999-10-08 2002-02-08 Thomson Marconi Sonar Sas METHOD FOR AUTOMATICALLY PLACING THE TASKS OF AN APPLICATION IN A SIGNAL PROCESSING MACHINE
US7664338B2 (en) * 2004-09-28 2010-02-16 Qualcomm Incorporated Perspective transformation of two-dimensional images
JP4487188B2 (en) * 2004-10-25 2010-06-23 ソニー株式会社 Information processing apparatus and method, program, and navigation apparatus
TWI386841B (en) * 2008-08-22 2013-02-21 Acer Inc Method and system for generating a three-dimensional graphic user interface, and computer program product
CN104537712B (en) * 2015-01-04 2017-04-19 成都思达特电器有限公司 Method for establishing three-dimensional spray nodes of workpiece to be sprayed
CN108984262B (en) * 2018-07-12 2021-04-13 宁波视睿迪光电有限公司 Three-dimensional pointer creating method and device and electronic equipment

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0549944A2 (en) * 1992-01-02 1993-07-07 International Business Machines Corporation Multi-resolution graphic representation for interactive visualization applications
EP0642102A1 (en) * 1993-08-31 1995-03-08 Kabushiki Kaisha Toshiba Apparatus and method for image processing
US5841442A (en) * 1996-12-30 1998-11-24 Cirrus Logic, Inc. Method for computing parameters used in a non-homogeneous second order perspective texture mapping process using interpolation

Family Cites Families (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS61210395A (en) 1985-03-14 1986-09-18 ソニー株式会社 Image processor
JP2604710B2 (en) 1985-08-26 1997-04-30 ソニー株式会社 Image conversion device
US5283859A (en) * 1986-09-03 1994-02-01 International Business Machines Corporation Method of and system for generating images of object transforms
US5420979A (en) * 1989-12-22 1995-05-30 Eastman Kodak Company Method and apparatus for using composite transforms to form intermediary image data metrics which achieve device/media compatibility for subsequent imaging applications
GB2270243B (en) * 1992-08-26 1996-02-28 Namco Ltd Image synthesizing system
JP2807608B2 (en) 1992-12-29 1998-10-08 株式会社ナムコ Sorting processing apparatus, image synthesizing apparatus using the same, and sorting processing method
JPH06348861A (en) 1993-04-15 1994-12-22 Sony Corp Method and device for generating picture and household game machine
JP3647487B2 (en) 1994-12-02 2005-05-11 株式会社ソニー・コンピュータエンタテインメント Texture mapping device
JP3578498B2 (en) 1994-12-02 2004-10-20 株式会社ソニー・コンピュータエンタテインメント Image information processing device
JP3442183B2 (en) 1995-02-28 2003-09-02 株式会社ナムコ 3D game device and image composition method
TW346611B (en) * 1996-03-28 1998-12-01 Sega Enterprises Kk An image processor, a game machine using the image processor, a method of image processing and a medium
JPH09305792A (en) 1996-05-17 1997-11-28 Sony Corp Hidden surface processing method

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0549944A2 (en) * 1992-01-02 1993-07-07 International Business Machines Corporation Multi-resolution graphic representation for interactive visualization applications
EP0642102A1 (en) * 1993-08-31 1995-03-08 Kabushiki Kaisha Toshiba Apparatus and method for image processing
US5841442A (en) * 1996-12-30 1998-11-24 Cirrus Logic, Inc. Method for computing parameters used in a non-homogeneous second order perspective texture mapping process using interpolation

Also Published As

Publication number Publication date
US20030189569A1 (en) 2003-10-09
CN100392678C (en) 2008-06-04
KR20010113781A (en) 2001-12-28
AU3673900A (en) 2000-11-14
CA2369879A1 (en) 2000-10-19
US6590576B1 (en) 2003-07-08
RU2001130343A (en) 2003-08-20
CN1346478A (en) 2002-04-24
US6900806B2 (en) 2005-05-31
BR0011156A (en) 2002-02-26
MXPA01010150A (en) 2002-06-21
JP3643036B2 (en) 2005-04-27
JP2002541600A (en) 2002-12-03
EP1181669A1 (en) 2002-02-27
TW540009B (en) 2003-07-01
HK1041959A1 (en) 2002-07-26

Similar Documents

Publication Publication Date Title
US6618048B1 (en) 3D graphics rendering system for performing Z value clamping in near-Z range to maximize scene resolution of visually important Z components
US7002591B1 (en) Method and apparatus for interleaved processing of direct and indirect texture coordinates in a graphics system
US6466218B2 (en) Graphics system interface
JP3637031B2 (en) GAME DEVICE AND GAME PROGRAM
US7522170B2 (en) Graphics system interface
US6411301B1 (en) Graphics system interface
JP2002074390A (en) Shadow mapping in inexpensive graphics system
US20040186631A1 (en) Storage medium storing a shadow volume generation program, game device, and shadow volume generation method
US6900806B2 (en) Method and apparatus for performing perspective transformation
US20030148802A1 (en) Recording medium which stores 3D image processing program, 3D image processor, 3D image processing method, and video game machine
JP3602835B2 (en) VIDEO GAME DEVICE, ITS CONTROL METHOD, AND GAME PROGRAM
JP2000113226A (en) Video game device, model displaying method in video game and readable recording medium with model displaying program in video game recorded therein.
EP1190392B1 (en) Method and apparatus for generating images
JP3839355B2 (en) GAME DEVICE AND GAME PROGRAM
US6831639B2 (en) Computer readable storage medium storing 3-D game image processing program, 3-D game image processing method, video game machine, and 3-D game image processing program
JP4740490B2 (en) Clamping Z values in the Z neighborhood to maximize the accuracy of visually important Z components in graphics rendering systems and avoid Z neighborhood clipping

Legal Events

Date Code Title Description
WWE Wipo information: entry into national phase

Ref document number: 00806061.4

Country of ref document: CN

AK Designated states

Kind code of ref document: A1

Designated state(s): AU BR CA CN JP KR MX NZ RU SG

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE

121 Ep: the epo has been informed by wipo that ep was designated in this application
DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
WWE Wipo information: entry into national phase

Ref document number: 36739/00

Country of ref document: AU

WWE Wipo information: entry into national phase

Ref document number: 2000915421

Country of ref document: EP

ENP Entry into the national phase

Ref document number: 2000 611248

Country of ref document: JP

Kind code of ref document: A

ENP Entry into the national phase

Ref document number: 2369879

Country of ref document: CA

Ref document number: 2369879

Country of ref document: CA

Kind code of ref document: A

WWE Wipo information: entry into national phase

Ref document number: PA/a/2001/010150

Country of ref document: MX

Ref document number: 1020017012835

Country of ref document: KR

WWE Wipo information: entry into national phase

Ref document number: 514927

Country of ref document: NZ

WWP Wipo information: published in national office

Ref document number: 1020017012835

Country of ref document: KR

WWP Wipo information: published in national office

Ref document number: 2000915421

Country of ref document: EP

WWR Wipo information: refused in national office

Ref document number: 2000915421

Country of ref document: EP

WWW Wipo information: withdrawn in national office

Ref document number: 2000915421

Country of ref document: EP

WWR Wipo information: refused in national office

Ref document number: 1020017012835

Country of ref document: KR