WO2002019095A2 - Method of running an algorithm and a scalable programmable processing device - Google Patents

Method of running an algorithm and a scalable programmable processing device Download PDF

Info

Publication number
WO2002019095A2
WO2002019095A2 PCT/EP2001/009691 EP0109691W WO0219095A2 WO 2002019095 A2 WO2002019095 A2 WO 2002019095A2 EP 0109691 W EP0109691 W EP 0109691W WO 0219095 A2 WO0219095 A2 WO 0219095A2
Authority
WO
WIPO (PCT)
Prior art keywords
algorithm
complexity
function
scalable
modes
Prior art date
Application number
PCT/EP2001/009691
Other languages
French (fr)
Other versions
WO2002019095A3 (en
Inventor
Christian Hentschel
Shaomin Peng
Cornelis C. A. M. Van Zon
Maria Gabrani
Elisabeth F. M. Steffens
Reinder J. Bril
Original Assignee
Koninklijke Philips Electronics N.V.
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
Priority claimed from US09/649,777 external-priority patent/US6674800B1/en
Priority claimed from US09/759,036 external-priority patent/US20020129080A1/en
Priority claimed from US09/872,931 external-priority patent/US20030058942A1/en
Application filed by Koninklijke Philips Electronics N.V. filed Critical Koninklijke Philips Electronics N.V.
Priority to KR1020027005513A priority Critical patent/KR20020064893A/en
Priority to JP2002523147A priority patent/JP2004507957A/en
Priority to EP01967293A priority patent/EP1316218A2/en
Publication of WO2002019095A2 publication Critical patent/WO2002019095A2/en
Publication of WO2002019095A3 publication Critical patent/WO2002019095A3/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/10Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
    • H04N19/134Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or criterion affecting or controlling the adaptive coding
    • H04N19/156Availability of hardware or computational resources, e.g. encoding based on power-saving criteria
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/42Methods or arrangements for coding, decoding, compressing or decompressing digital video signals characterised by implementation details or hardware specially adapted for video compression or decompression, e.g. dedicated software implementation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/44Decoders specially adapted therefor, e.g. video decoders which are asymmetric with respect to the encoder
    • H04N19/45Decoders specially adapted therefor, e.g. video decoders which are asymmetric with respect to the encoder performing compensation of the inverse transform mismatch, e.g. Inverse Discrete Cosine Transform [IDCT] mismatch
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/60Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding
    • H04N19/61Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding in combination with predictive coding
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/90Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using coding techniques not provided for in groups H04N19/10-H04N19/85, e.g. fractals
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/41Structure of client; Structure of client peripherals
    • H04N21/4104Peripherals receiving signals from specially adapted client devices
    • H04N21/4113PC
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/44Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream, rendering scenes according to MPEG-4 scene graphs
    • H04N21/4402Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream, rendering scenes according to MPEG-4 scene graphs involving reformatting operations of video signals for household redistribution, storage or real-time display
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/44Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream, rendering scenes according to MPEG-4 scene graphs
    • H04N21/4402Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream, rendering scenes according to MPEG-4 scene graphs involving reformatting operations of video signals for household redistribution, storage or real-time display
    • H04N21/440218Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream, rendering scenes according to MPEG-4 scene graphs involving reformatting operations of video signals for household redistribution, storage or real-time display by transcoding between formats or standards, e.g. from MPEG-2 to MPEG-4
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/442Monitoring of processes or resources, e.g. detecting the failure of a recording device, monitoring the downstream bandwidth, the number of times a movie has been viewed, the storage space available from the internal hard disk
    • H04N21/4424Monitoring of the internal components or processes of the client device, e.g. CPU or memory load, processing speed, timer, counter or percentage of the hard disk space used
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/45Management operations performed by the client for facilitating the reception of or the interaction with the content or administrating data related to the end-user or to the client device itself, e.g. learning user preferences for recommending movies, resolving scheduling conflicts
    • H04N21/462Content or additional data management, e.g. creating a master electronic program guide from data received from the Internet and a Head-end, controlling the complexity of a video stream by scaling the resolution or bit-rate based on the client capabilities
    • H04N21/4621Controlling the complexity of the content stream or additional data, e.g. lowering the resolution or bit-rate of the video stream for a mobile client with a small screen
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/60Network structure or processes for video distribution between server and client or between remote clients; Control signalling between clients, server and network components; Transmission of management data between server and client, e.g. sending from server to client commands for recording incoming content stream; Communication details between server and client 
    • H04N21/61Network physical structure; Signal processing
    • H04N21/6106Network physical structure; Signal processing specially adapted to the downstream path of the transmission network
    • H04N21/6112Network physical structure; Signal processing specially adapted to the downstream path of the transmission network involving terrestrial transmission, e.g. DVB-T
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2209/00Indexing scheme relating to G06F9/00
    • G06F2209/50Indexing scheme relating to G06F9/50
    • G06F2209/504Resource capping
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
    • Y02D10/00Energy efficient computing, e.g. low power processors, power management or thermal management

Definitions

  • the invention relates to a method of running an algorithm wherein the algorithm comprises a first function and a second function.
  • the invention relates to scalable systems and more particularly to scalable multimedia communications systems such as an ATSC compliant video decoder.
  • Scalable Video Decoder and its Application to Multi-channel Multicast system (IEEE 19th International conference on consumer electronics, year 2000, Page 232 to 233.
  • a scalable algorithm is described to be used within real time systems that have limited resources and time critical algorithms.
  • An example of a real time system with these characteristics is a video decoder to be used vifiiin a multi-channel multicast system and examples of limited resources are a physical memory, a main processor, and an input/output device.
  • the scalable algorithm for example a decoding algorithm for video, comprises a plurality of functions like, for example low pass filtering and upsampling.
  • each function the resource requirement in terms of CPU load is determined per number of video channels, for example 1, 4, or 8 channels, that can be decoded simultaneously.
  • the functions that can be used within the algorithm are derived from the allowed CPU load and the budget each function is allowed to use must be allocated to each function individually.
  • the current approach for measuring complexity-distortion in a given system is to measure the operational curves for a particular data model (algorithm).
  • algorithm assumes that all the data inside each 8x8 block is in use. The total number of multipliers and adders is a fixed number.
  • the output distortion is also different, i.e. different operational points 202 are utilized. The corresponding operational curve for this algorithm can be measured.
  • scalability deals with the tradeoff of function complexity and distortion via information rate and resource constraints.
  • computational resources decrease, the computing or processing power for performing the original amount of function complexity is decreased, thereby forcing the scalable algorithm to retreat to a lower level of function complexity.
  • DTV Digital Television
  • the processing capability of the decoder is practically limited by the constraints of the decoder's processor, e.g. available computing resources.
  • the decoder's processing capabilities may be limited to the point where it is insufficient for processing the received bitstream for displaying at an accepted quality standard.
  • one way to enable the processor to decode the bitstream is to lower the quality of one of the functions.
  • the quality displayed in a Picture-In-Picture (PIP) window may be set lower (still acceptable) than the quality of the main channel being displayed by lowering the processing complexity of the windowed bitstream without altering the decoding quality of the main bitstream corresponding to the main channel.
  • PIP Picture-In-Picture
  • different processing complexities can be used for different bitstreams depending upon a respective modes of operations. This in turn permits the limited processing capabilities of the decoder to be better utilized to enable multiple bitstreams to be simultaneously processed.
  • the Information-Based Complexity theory shows that there is a minimal Complexity-Distortion (C-D) bound 100 for each given system.
  • C-D Complexity-Distortion
  • the rate distortion bound 100 is a convex function.
  • This curve 100 precisely defines the theoretical boundary between achievable function complexity-distortion (region 102) and non-achievable function-complexit distortion (region 104).
  • IT Information Theory
  • RDT Rate Distortion Theory
  • RDT is concerned with representing a source with the fewest number of bits possible for a given reproduction quality.
  • the tradeoff encountered in RDT is between information rate and output distortion. It should be recognized though that in RDT, there are typically no computational constraints on what the output decoding system can do.
  • IBC Information-Based-Complexity
  • the region 102 above the curve 100 is theoretically algorithm achievable, while the region 104 underneath is non-achievable.
  • the complexity is limited.
  • the complexity of the system has a boundary in order to let the system perform normally.
  • the boundary of the complexity is described as [C m i n , C m ax].
  • the output quality also has limitations, i.e. the distortion range [D m j n , D m ax].
  • D m i n means the best result the system can provide, while D max means the worst result that the user could tolerate.
  • the workable region of a realistic system is the region 106.
  • each set of test data will give a quality distortion rate.
  • each point of complexity and distortion pair derived from a practical system is called an operational point 202.
  • a group of operational points 202 compose an operational curve, e.g. 204 or 206.
  • operational curves e.g. 204 or 206.
  • Scalability can be defined as a transition between two operating points 202 with different complexity coordinates in the achievable region 106.
  • the best scalable algorithm has an operational curve which closely approximates the lowest C-D bound 100.
  • a first given system and data model i.e. algorithm, gives a first complexity- distortion curve 204, while a second provides curve 206.
  • the distance of operational curves 204, 206 from theoretical lowest complexity-distortion bound 100 illustrates how good each system design is. Often in a real design situation, the lowest bound 100 is not available and the operational curves 204, 206 are not parallel.
  • FIG. 3 illustrates a conventional video decoder 300 block diagram suitable for use in an ATSC DTV compliant system as taught by GUIDE TO THE USE OF THE ATSC DIGITAL TELEVISION STANDARD, ATSC Doc. A/54, October 4, 1995.
  • the decoder 300 includes a channel buffer 302 which receives a coded video bitstream signal A and outputs a signal B .
  • a Variable Length Decoder (VLD) 304 receives signal B and reconstructs 8x8 arrays of quantized Discrete Cosine Transform (DCT) coefficients to provide DCT coefficients in quantized form as signal C and motion vectors as signal H.
  • Motion Compensator 306 receives signals H and I, which includes data for anchor frames stored in memory 308 and provides motion compensated predicted pixel values as signal G.
  • Inverse quantizer 310 receives signal C and dequantizes it to provide signal D which includes quantized prediction error DCT coefficients in standard form.
  • ICT Inverse Discrete Cosine Transform
  • DCT Inverse Discrete Cosine Transform
  • Adder 314 receives signals E and G and sums them to provide reconstructed pixel values which are degraded by quantization as signal F which is provided as decoded video data and also to memory 308.
  • the method according to the invention comprises the following steps: a first step of requesting an algorithm resource by the algorithm to provide a plurality of output quality levels, a second step of determining that the first function provides a first plurality of quality levels and the second function provides a second plurality of quality levels, a third step of allocating a budget to the algorithm to enable operating the algorithm at a output quality level, said output quality level being one of the plurality of output quality levels, a fourth step of assigning a first quality level of the first plurality of quality levels to the first function and of assigning a second quality level of the second plurality of quality levels to the second function.
  • a budget manager, or overall system control does not need to know that the algorithm comprises of a plurality of functions.
  • the overall system control can therefore be used for the general purpose of allocating a budget to algorithms that run on the system simultaneously.
  • the budget is based upon the requested algorithm resources.
  • the overall system control can set an output quality level to the algorithm as a whole.
  • the output quality level can be chosen from the plurality of output quality levels the algorithm can provide.
  • Each function of the algorithm can provide a plurality of quality levels.
  • the corresponding quality level or setting is chosen from the plurality of quality levels that can be provided by a function.
  • the quality level of the function that provides the highest output quality level of the algorithm for the allocated budget can be the preferred choice from the plurality of quality levels that can be provided by a function.
  • the quality control distributes implicitly its allocated budget over the functions the algorithm comprises by the assignment of a corresponding quality level or setting to each function.
  • the assigned quality level per function is based upon the budget that is allocated to the algorithm.
  • a function can provide a quality level for a plurality of levels of complexity wherein a level of complexity for example is determined by a number of mathematical operations a function can perform, an amount of memory the function requires or communication means, like bandwidth, the function requires.
  • a level of complexity for example is determined by a number of mathematical operations a function can perform, an amount of memory the function requires or communication means, like bandwidth, the function requires.
  • a quality control can perform these combinations and can decide upon these combinations which quality level to assign to a function.
  • Each function can operate at its own quality level.
  • a combination of the first function and the second function can lead to one algorithm that can provide a plurality of output quality levels.
  • the same algorithm can be operated again, by allocating new quality levels to the first and second function as previously described.
  • a number of algorithms providing a same functionality but at a different output quality level that can, for example, be operated in parallel, can be limited this way.
  • a quality control for example can choose for each function the lowest complexity for the highest quality level from the plurality of combinations of complexity and quality level per function.
  • the algorithm does not use substantially more than its allocated budget. This prevents budget-overrun by the algorithm which may cause budget shortage of other algorithms or algorithms that can result in missing deadlines of these other algorithms or algorithms and degradation of an overall output quality.
  • the output quality levels that can be provided by an algorithm can depend upon a hardware platform that the algorithm is operated upon.
  • the first function of the algorithm has specific hardware requirements, like for example the availability of a harddisk, the first function may be omitted when the hardware is not available.
  • the output quality levels that can be provided by an algorithm can depend upon a software platform that the algorithm can access.
  • the first function of the algorithm has specific software platform requirements, like for example the availability of a linear interpolation algorithm, the first function may be operated differently when the linear interpolation algorithm is not available, for example by using an available cubic interpolation algorithm.
  • a further object of the invention is to provide a method for operating a programmable processing device to reduce distortion in an outputted signal, that allocates the resources in an improved way.
  • this method comprises the following steps: a first step of providing data indicative of a plurality of operational states, each of said states being associated with at least one of a plurality of operational modes of said device, a complexity of operations (C) and a distortion level (D); a second step of selecting one of said states for each of said complexities using said data and based upon said distortion levels; a third step of determining an operating status of said device; and, a fourth step of selecting which of said operational modes to operate said device in for each of said complexities responsively to said determined status using said selected states.
  • Embodiments of the method for operating a programmable processing device to reduce distortion in an outputted signal according to the invention are described in claims 10 to 15.
  • a further object of the invention is to provide a scalable programmable processing device that allocates the resources in an improved way.
  • this device comprises: at least one scalable application operable in plurality of modes each having a different complexity of operations characteristic; a QOS resource manager for tracking how much computing resources are available for use by said at least one scalable application; a strategy manager for determining whether said available resources are suitable for operation of said scalable application in a given one of said modes; and, a local resource control responsive to said strategy manager and for selecting, in response to a determination by said strategy manager that said available resources are not suitable for operation of said at least one application in said given mode to select another of said modes for said at least one application; wherein, said QOS manager and strategy manager are mutually responsive to one another and said at least one scalable application is responsive to said local resource control.
  • Figure 1 illustrates a theoretical lowest attainable complexity - distortion bound
  • Figure 2 illustrates two operational modes of a system and the theoretical lowest attainable bound
  • Figure 3 illustrates a conventional video decoder block diagram for an ATSC compliant DTV system
  • Figure 4 illustrates an embodiment of the main steps of the method according to the invention
  • Figure 5 illustrates an example of an algorithm that comprises a plurality of functions
  • Figure 6 illustrates an example of a diagram in which the complexity of the algorithm is set against the output quality level that can be provided by the algorithm
  • Figure 7 illustrates a storage device in a schematic way that comprises an embodiment of a storage device comprising a computer program product arranged to perform the method according to the invention
  • Figure 8 illustrates a block diagram of a control system used according an embodiment of the present invention
  • Figure 9 illustrates a scalable video decoder block diagram for an ATSC compliant DTV system according to an embodiment of the present invention
  • Figure 10 illustrates a lowest C-D approach among various algorithms according to an embodiment of the present invention
  • Figure 11 illustrates a scalable video decoder block diagram for an ATSC compliant DTV system according to another embodiment of the present invention.
  • Figure 12 illustrates the most important parts of an embodiment of the system according to the invention in a schematic way
  • Figure 13 illustrates a television set in a schematic way that contains an embodiment of the system according to the invention
  • Figure 14 illustrates a set-top box in a schematic way that contains an embodiment of the system according to the invention.
  • Figure 4 illustrates an embodiment of the main steps of the method according to the invention.
  • Programmable components rather than dedicated single-function components can perform continuous media processing. Those single-function components are used in traditional television receivers in which some of those single-function components could be combined to perform for example color decoding for NTSC or PAL systems, noise reduction or frame rate up-conversion.
  • continuous media processing algorithms can be implemented in software instead of hardware.
  • the software implementation of the media processing algorithms must run within the real-time environment in which system resources are finite and sufficient system resources may not be reserved for a particular processing algorithm, which can lead to changes in the output quality provided by the particular processing algorithm.
  • Output quality levels can be measured by perception measurements, or objectively by available measurement means.
  • a system running the processing algorithms is able to provide high-quality audio and video that has a relatively high frame rate above 50 Hz, almost no tolerance for frame rate fluctuations and a low tolerance for frame skips.
  • the system is also able to provide low frame rates with a maximum of 30 Hz, a high tolerance for frame rate fluctuations and a high tolerance for frame skips.
  • Algorithms can be allocated budget explicitly or implicitly by setting an output quality level of the algorithm.
  • One of the objectives of an overall system control is to optimize the total output quality provided by the total system while making efficient use of all the available resources.
  • the total output quality provided by the system depends amongst others upon the number of algorithms operating concurrently and the data an algorithm processes.
  • the system may be, for example, a television, a PC, a display, a set-top box, or a VCR. In order to achieve this objective, the main steps below are performed.
  • step 400 is an initialization step in which an overall system control, for example a budget manager accesses the contents of a first lookup table as illustrated in Table 1.
  • a first lookup table as illustrated in Table 1.
  • CPU central processing unit
  • co-processor co-processor
  • memory requirements are examples of resources that an algorithm can use.
  • quality number indicates a better output quality level perceived by a user.
  • the algorithm or a quality control, which is part of the algorithm, can have access to the contents of Table 1 too.
  • Algorithms are started implicitly when a user switches to another channel for a main window and the, analog, source of the new channel is different from the, digital, source of the old channel.
  • Other examples of starting algorithms or changing the resource requirement of an algorithm are: when a user exchanges the contents of a main window and a picture in picture window by for example viewing the re-play after a goal, when the size of a video conferencing window changes, or when a new application, for example a video conferencing application when a call arrives, is started in an additional window.
  • the resource requirement of an algorithm changes too when the media data the algorithm processes changes.
  • a change in the media data can be caused by the service provider that may transmit sources with different input parameters, for example when a movie which can be a 24 Hz film is interrupted by a commercial which can be a 60 Hz camera or it can be caused by motion or scene changes.
  • the functions a media processing algorithm comprises is determined by, for example, reading this information from some configuration file.
  • This file describes that, for example, an algorithm for edge or sharpness enhancement comprises the functions as is illustrated in a schematic way in Figure 5.
  • a detail filter 512, a non-linear function 502, a gain 504, an adder 506, and noise measurement 508, is shown.
  • the detail filter extracts higher frequency components from an input signal containing a video signal.
  • Those components can be added to the input signal to increase the overall sharpness impression of the video signal.
  • the non-linear function and following gain can reduce artifacts like clipping caused by the detail filter whereas the noise measurement function can adapt the sharpness enhancement dependent upon the noise level contained within the input signal.
  • the requested resources and the quality level per function are determined.
  • a quality control 510 see Figure 5, shields the overall system control from the functions an algorithm comprises and is part of the algorithm.
  • the detail filter varies its requested resources for, for example, number of CPU cycles or number of bytes. The variation of requested resources is determined by the quality levels described by the coefficients for the filter and the type of filter: horizontal, vertical, or both.
  • the non-linear function varies its requested resources for, for example, CPU cycles and is determined by the quality levels described by the quantization of the non-linear function, which can differ for the input signal and output signal.
  • the gain varies its requested resources for, for example, a multiplier, shift and adder operations dependent upon whether it is stored as fixed values in a lookup table contained in memory, it is calculated by a multiplier or is calculated by shift and adder operations.
  • the noise measurement varies its requested resources for, for example CPU cycles, because it can, for example, be switched on or off.
  • the adder operation can vary its requested amount of resources by for example doing less precise additions.
  • the mentioned parameters are not limiting, for example, store operations or communication means like bandwidth and cache can be used as parameters concerning the complexity of the algorithm.
  • the numbers used for the quality and complexity within Table 2 are absolute, but may be normalized to operations per pixel within video independently from the chosen format. With this concept, a media algorithm designer designs the functions the media algorithm comprises to provide the correct functionality at different output quality levels.
  • step 406 the contents of the table is updated for the available software platform the algorithm has access to. For example, when the software platform does not support "temporal processing", this column is removed from the table and the effectuated rows are updated correspondingly. When for example "horizontal processing" is not supported, the corresponding column and the rows which do not lead to any processing at all, like row 6 and N, are removed from the table. It is also possible to instantiate a run-time lookup table containing a mapping from software functions available within the software platform to software functions required by the algorithm instead of updating Table 2.
  • step 408 the contents of the table is updated for the available hardware platform the algorithm must be operated upon. For example, when the hardware platform does not provide a co-processor, this column is removed from the table and all rows are removed that only used a co-processor. It is also possible to instantiate a run-time lookup table containing a mapping from hardware available within the hardware platform to hardware required by the algorithm instead of updating Table 2.
  • the functions an algorithm comprises, the plurality of quality levels the different functions provide, the plurality of output quality levels the algorithm provides and the hardware and software the algorithm requires from the hardware platform and software are known to the quality control.
  • the overall system control only needs to know about the algorithm, the resources the algorithm requests, the hardware it requires and the plurality of output quality levels the algorithm provides.
  • the overall system control allocates a resource budget to the algorithm in accordance with a best overall system's output quality level.
  • a best overall system's output quality level can be achieved when the system is in a steady state in which all algorithms that are running provide a predefined output quality level and the system is fully loaded. This means that additional algorithms can not be started without adjusting the output quality levels of the running algorithms.
  • the budget that is allocated is substantially equal to the resources requested by the algorithm to provide a predefined output quality level.
  • the algorithm may not provide the predefined output quality level and when the algorithm gets allocated more budget than requested, the algorithm may not use all resources.
  • the overall system control 512 see Figure 5, allocates the budget to the algorithm based upon the contents of Table 1.
  • the overall system control 512 can allocate the budget to the algorithm based upon the contents of Table 2. In the latter case, the overall system control decides upon a more smooth transition of the output quality level provided by the algorithm. As is shown in Table 2, an abrupt transition of the output quality level provided by the algorithm is likely from version 2 to version 6, or from version 5 to version 6, because the processing changes in two dimensions.
  • a more smooth transition is expected from version 2 to version 3, because the processing changes only in one dimension.
  • the other "quality" parameters like the quality number or PSNR also provide information about the smoothness of transitions.
  • the information about the hardware platform and software platform as derived in steps 406 and 408, can also be accessed by the overall system control. Selection of the output quality level provided by the algorithm is then based upon for example the available hardware. This is shown in Table 2, where version 1 and version 2 provide the same output quality level because their quality numbers are equal, but they distribute the required resources differently between the CPU and co-processors.
  • the quality control can use this knowledge of distribution between CPU and co-processors to deal, amongst others at run-time, with overload situations in which the quality control can change the distribution, while the algorithm still provides the same output quality.
  • the quality control translates the allocated budget, or output quality level, to the algorithm as a whole into a quality level allocation to the different functions the algorithm comprises.
  • This translation is based upon the contents of Table 2 and takes the combination of all settings for requested resources and quality level per function into account.
  • the combination of all settings for requested resources determines the complexity of the algorithm, a function of the algorithm and a combination of the functions of the algorithm.
  • the complexity is expressed with a number. This number is weighted to get a single number for a specific hardware or software platform.
  • Figure 6 shows an example of the combination of the complexity and provided output quality level. Useful combinations are achieved at the highest output quality for the lowest complexity as is indicated by the drawn curve in Figure 6.
  • Each dot implies different quality settings or quality levels for the functions an algorithm comprises.
  • the information about the hardware platform and software platform as derived in steps 406 and 408 is accessed by the quality control.
  • the quality control uses this information to choose the best combination of the complexity and provided output quality level, because the best combination and the number of combinations can depend upon the hardware and/or software platform the functions must run upon. Changing the resolution of video data by for example sub-sampling the video data or deleting entire frames, lines or pixels is prevented by interpretation of the contents of Table 1 and Table 2 as previously described.
  • the quality control also maximizes the perceptual quality because a user perceives a low output quality provided by the system, when the quality of, for example a movie, is changed continuously. Therefore quality levels are sparingly adjusted.
  • the quality control re-allocates the translated allocated budget to the functions the algorithm comprises implicitly, by assigning the corresponding quality level to the functions.
  • step 416 the functions and therefore the algorithm as a whole start operating using their allocated budget and set quality level.
  • step 400 can be performed again or the final step 418 is reached.
  • Figure 7 illustrates, in a schematic way, a storage device that comprises a computer program product arranged to perform the method according to the invention.
  • 700 is a compact-disk comprising code 702.
  • the present invention involves comparing different C-D curves that achieve the same task, so that an algorithm which is more efficient regarding the tradeoff of the complexity and the quality distortion at certain complexity levels than available alternatives can be identified. Therefore the best algorithm which gives the minimal quality distortion at certain complexity can be selected, and the global optimal approach can be achieved for the given set of algorithms under assumed complexity and distortion ranges.
  • the scalable video algorithm design control system made according to the concepts of the present invention preferably includes four elements: a Quality Of Service (QOS) resource manager 800; a strategy manager 802; a local resource control 804; and scalable algorithms 806.
  • the QOS resource manager 800 oversees resource usage within an entire system, or grouped subsystems. It sends out control commands to the strategy manager 802 when system resources vary, and receives feedback from the strategy manager 802 when subsystems are scaled.
  • the strategy manager 802 serves as an envoy for the QOS manager 800 which has the power to command different scalable algorithms' 806 via local controller 804 to scale up or down in order to adapt to the resource level change.
  • the strategy manager 802 controls the overall scaling of levels of different applications, it does not control the detail of the scalability of a specific algorithm 806. For example, it controls the total complexity level of the MPEG2 decoder, but it does not have the control about which algorithm of the MPEG2 decoder should be scaled down to what level. This is the work of the local resource control 804.
  • the local resource control 804 also known as decoding resource control or complexity switching control
  • the scalable algorithms 806 are the keys that fulfill the scalability job.
  • the QOS manager 800 basically manages the use of computing resources, e.g. in use, not in use, monitors information flow, and responds to requests from applications that demand or are using resources.
  • the strategy manager 802 satisfies a need for communication between the QOS manager 800 and scalable applications which use the scalable algorithms 806, such as the scalable MPEG2 decoder of Figures 9 or 11.
  • the strategy manager 802 handles and controls the resource uses of each individual scalable application and coordinates these applications.
  • the local resource control 804 serves as a local office manager for a particular scalable application.
  • a scalable ATSC compliant DTV video decoder for example, and referring now to Figure 9, therein is illustrated a scalable ATSC compliant DTV video decoder according to the present invention.
  • the elements designated with a ' designate like elements to those of Figure 3, except that they are scalable in accordance with the present invention.
  • more than one functional block within the decoder 300' of Figure 9 is scalable.
  • the IDCT is one functional block for example.
  • the local resource manager 804 (also referred to as Decoding Resource Control) coordinates the activities and scalable levels of these blocks, e.g. how much each individual functional block should be scaled.
  • scalable algorithms 806 are available for a particular functional block, e.g. an IDCT, in order to achieve minimal distortion, when and where the switching of multiple algorithms, e.g. 204, 206, should apply, these control tasks are performed by the local resource manager 804.
  • DTV video decoder 300" which includes a scalable IDCT functional block 312, 312', 312".
  • IDCT functional block 312, 312', 312 of MPEG2 decoder 300"
  • this approach proposes to use multiple Discrete Cosine Transform (DCT) algorithms to achieve an optimal scalability of the decoder with regards to the computation complexity and the quality. For a given complexity level, a DCT algorithm that is chosen to give the minimal distortion level.
  • DCT Discrete Cosine Transform
  • FIG. 11 therein is illustrated a video decoder 300" block diagram for an ATSC compliant DTV system according to another form of the present invention.
  • the decoder 300" incorporates many of the same elements as the decoder 300 of Figure 1, therefore a discussion of these like elements will not be repeated.
  • the decoder 300" includes multiple IDCT's 312, 312, 312 and complexity switch 804 while the decoder 300' includes an IDCT 312' which can implement multiple algorithms and switch 804.
  • the complexity switch 804 is responsive to signal J which originates from strategy manager 802.
  • the switch control 804 outputs signal K in response to signal J which selectively activates ones of IDCT's 312,312, 312 .
  • IDCTs 312, 312', 312
  • one or more IDCT's which are selectably activatable to use different algorithms can be used such as is illustrated in Figure 9.
  • the QOS 800 determines how much, or what percentage of Central Processing Unit (CPU) cycles, i.e. processing power, the MPEG2 decoder 300" is entitled to use. This may or may not be enough for full power MPEG2 decoding, i.e. non-scalable.
  • the strategy manager 802 receives this budget, together with other budgets for other applications.
  • the strategy manager 802 determines if this budgeted amount of computing or processing power is sufficient for full decoding. If the budgeted amount of computing power is not sufficient for a non-scalable decoding, it will either inform the local resource control 804 to activate a scalable algorithm 806, or request more resources from QOS manager 800 for robustly maintaining a suitable output quality.
  • the local resource manager 804 of the MPEG2 decoder 300" receives the reduced budget, based on statistics gathered in advance, by using one or more look-up tables for example, a determination is made as to which scalable algorithm 204 will be activated at what level of available processing power. Assuming the global optimal IDCT algorithm according to the present invention is activated, and since the complexity versus distortion relationship is determined off-line in advance, at each complexity level the local resource manager 804 has a well defined algorithm to call and use, as corresponding to a particular operational point. For different algorithms, the complexity stretch is different. Not all the available algorithms will provide the same range of complexity-distortion measurement and range. The operational points for different algorithms may offset each other.
  • the metric for complexity measurement for different algorithms should be universal, or scaled to the comparable level.
  • the total number of machine cycles running the algorithm can be defined as the complexity level of the algorithm.
  • the multiplication reduction ratio can be used as a complexity measurement.
  • a procedure to obtain an operational C-D curve is as follows: Step 1. The operational points of available algorithms are measured under different complexity levels; Step 2. Scale the operational points of different algorithms to the same scale and draw the operational curves on the same plot; Step 3. Find the switching points (cross points) of the operational curves; and, Step 4.
  • the global optimal operational curve 1010 is decided by selecting each operation curve portion which is nearest to the C-D curve 100 between each of the switching points.
  • the disclosed method proposes a way to better approach the global optimal complexity-distortion bound 100 for a given system using multiple schemes, e.g. algorithms or modes.
  • This method is based on the information-based complexity theory and is practically achievable. It can be used in scalable multimedia / communication system design and scalability analysis.
  • FIG 12 illustrates the most important parts of an embodiment of the system according to the invention in a schematic way.
  • the system, 1200 comprises a first memory 1202 that contains per resource an amount of that resource an algorithm requests to provide a predefined output quality level.
  • a CPU and a co-processor are examples of resources of which cycles can be requested.
  • a second memory 1204 contains a module to perform a first function of the algorithm, while a third memory 1206, contains a module to perform a second function of the algorithm.
  • the edge or sharpness enhancement algorithm 514 as described in Figure 5.
  • the second memory 1204 contains the module that performs detail filtering 500, while the third memory 1206 contains the module that performs noise measurement 508.
  • the system may also contain more memories containing modules that perform all the functions of the edge or sharpness enhancement algorithm as described in Figure 5.
  • the fourth memory, 1208 contains a lookup table containing per quality level of a first plurality of quality levels the first function can provide, the amount of resources it requires.
  • the fifth memory, 1210 contains a lookup table containing per quality level of a second plurality of quality levels the second function can provide, the amount of resources the second function requires.
  • the sixth memory 1212 contains per resource the amount of budget allocated to the algorithm.
  • the overall system control can also assign the output quality level of the algorithm as a whole, thereby implicitly allocating a budget per resource to the algorithm.
  • the memories 1214 and 1216 contain the quality levels provided by the first and second function of the algorithm respectively.
  • Memory 1218 contains a plurality of complexity numbers indicating a plurality of levels of complexity of operation of the first function of the algorithm.
  • Memory 1220 contains a complexity number indicating the least complex level of operation of the first function of the algorithm.
  • the quality control has access to the contents of memory 1218 and 1220.
  • the contents of memories 1202, 1208, and 1210, 1218, 1220 can also be combined into one lookup table as illustrated in Table 2. This combined lookup table can then be stored into one memory instead of more separate memories.
  • the memories 1212, 1214 and 1216 may be omitted.
  • the quality control accesses the contents of memory 1226 that contains a configuration file containing information about the available hardware within the system and it accesses the contents of memory 1228 that contains a configuration file containing information about the available software algorithms within the system.
  • the quality control has access to all previously described memories, whereas the overall system control only requires access to memories 1202, 1212, 1226 and 1228. However, when the overall system control has access to more memories, the output quality level transitions provided by the algorithm can become smoother.
  • the system also comprises a first co-processor, 1222, on which the first function of the algorithm can run and a second co-processor, 1224, which on which the second function of the algorithm can run.
  • An, optional, CPU, 1230 operates the algorithm as a whole, because there needs to be some inter-process communication between the first and second function.
  • the system does not contain co-processors, the functions and therefore, the algorithm run on the CPU.
  • the first function can be operated at a plurality of levels of complexity, the first function runs at the least complex level on a dedicated co-processor 1232, while the more complex level is run on the co-processor 1222.
  • the first function runs at each of the plurality of levels of complexity on either 1232 or 1222 or that the first function runs at each of the plurality of levels of complexity on CPU 1230.
  • This system can be realised in software intended to be operated as an application by a computer or any other standard architecture able to operate software.
  • the system can be used to operate a digital television set 1234.
  • the system can also be realised in silicon wherein the mentioned lookup tables are replaced by logical building blocks that are hard-wired to each other and the mentioned processors and co-processors are omitted.
  • Figure 13 illustrates, in a schematic way, the most important parts of a television set that comprises an embodiment of the system according to the invention.
  • an antenna, 1300 receives a television signal.
  • the antenna may also be for example a satellite dish, cable, storage device, internet, Ethernet or any other device able to receive a television signal.
  • a receiver, 1302 receives the signal.
  • the signal may be for example digital, analog, RGB or YUV.
  • the television set contains a programmable component, 1304, for example a programmable integrated circuit.
  • This programmable component contains a system according to the invention 1306.
  • a television screen 1308 shows images that are received by the receiver 1302 and are processed by the programmable component 1304, the system according to the invention 1306 and other parts that are normally contained in a television set, but are not shown here.
  • Figure 14 illustrates, in a schematic way, the most important parts of a set-top box that comprises an embodiment of the system according to the invention.
  • an antenna 1400 receives a television signal.
  • the antenna may also be for example a satellite dish, cable, storage device, internet, Ethernet or any other device able to receive a television signal.
  • a set-top box 1402 receives the signal.
  • the signal may be for example digital, analogue, RGD or YUV.
  • the set-top box contains a system according to the invention 1404.
  • the television set 1406 can show the output signal generated from a received signal by the set-top box 1402 together with the system according to the invention 1404.
  • the output signal may also be directed to a storage device like a VCR, DVD-RW or a harddisk or they may be directed to an internet link in stead of being directed to the television set.

Abstract

Nowadays, programmable components (1304), rather than dedicated single-function components can perform continuous media processing in consumer devices, like digital television sets (1310), set-top boxes, PCs, or VCRs. The media processing algorithms that are written for those programmable components (1304), must be designed to provide a plurality of output quality levels in exchange for required processing resources. Since resources are finite, the media processing algorithms must be controlled in their resource usage and the output quality level they provide. Users of consumer devices do not like to see major changes in the quality of, for example, a video they are watching. Therefore, typical algorithm characteristics like the functions an algorithm comprises, the resource usage per function and the quality level per function are used to provide smoother quality transitions.

Description

Method of running an algorithm and a scalable programmable processing device
The invention relates to a method of running an algorithm wherein the algorithm comprises a first function and a second function.
Furthermore the invention relates to scalable systems and more particularly to scalable multimedia communications systems such as an ATSC compliant video decoder.
An embodiment of the method and the system of the kind set forth above is known from Scalable Video Decoder and its Application to Multi-channel Multicast system (IEEE 19th International conference on consumer electronics, year 2000, Page 232 to 233. Here, a scalable algorithm is described to be used within real time systems that have limited resources and time critical algorithms. An example of a real time system with these characteristics is a video decoder to be used vifiiin a multi-channel multicast system and examples of limited resources are a physical memory, a main processor, and an input/output device. The scalable algorithm, for example a decoding algorithm for video, comprises a plurality of functions like, for example low pass filtering and upsampling. For each function the resource requirement in terms of CPU load is determined per number of video channels, for example 1, 4, or 8 channels, that can be decoded simultaneously. The functions that can be used within the algorithm are derived from the allowed CPU load and the budget each function is allowed to use must be allocated to each function individually.
Furthermore, it is generally known that the current approach for measuring complexity-distortion in a given system is to measure the operational curves for a particular data model (algorithm). Using a generic IDCT algorithm of an MPEG2 decoder as an example, the algorithm assumes that all the data inside each 8x8 block is in use. The total number of multipliers and adders is a fixed number. However, with one particular algorithm, if the data pattern changes, the number of computational steps can be changed, hence the complexity regarding the computation time of the algorithm is different, see Figure 2. With the change of complexity levels, the output distortion is also different, i.e. different operational points 202 are utilized. The corresponding operational curve for this algorithm can be measured. If a different IDCT algorithm is adopted for the decoder, then a different operational curve can be drawn, e.g. curves 204, 206. Rapid development in the multimedia processing industry has promoted programmable multimedia processing devices instead of traditional dedicated hardware solutions, e.g. Application Specific Integrated Circuits (ASICs). The programmable functionality of software-oriented devices has tremendously increased the flexibility of these types of multimedia and communication systems. Programmable devices are commonly used for adjusting or scaling functions complexity to certain levels according to available computational resources. This provides system scalability. However, when function complexity is scaled down, the performance of the system often degrades as compared to conventional dedicated hardware solutions. Therefore it is desirable to minimize performance degradation or distortion, at each function complexity level to maintain the overall performance of the system.
In theory, scalability deals with the tradeoff of function complexity and distortion via information rate and resource constraints. When computational resources decrease, the computing or processing power for performing the original amount of function complexity is decreased, thereby forcing the scalable algorithm to retreat to a lower level of function complexity.
One example of where a scalable design can be utilized is in a Digital Television (DTV) video decoder adapted to receive and decode information streams, e.g. television signals. The processing capability of the decoder is practically limited by the constraints of the decoder's processor, e.g. available computing resources. The decoder's processing capabilities may be limited to the point where it is insufficient for processing the received bitstream for displaying at an accepted quality standard. Hence, one way to enable the processor to decode the bitstream is to lower the quality of one of the functions. For example, the quality displayed in a Picture-In-Picture (PIP) window may be set lower (still acceptable) than the quality of the main channel being displayed by lowering the processing complexity of the windowed bitstream without altering the decoding quality of the main bitstream corresponding to the main channel. Accordingly, different processing complexities can be used for different bitstreams depending upon a respective modes of operations. This in turn permits the limited processing capabilities of the decoder to be better utilized to enable multiple bitstreams to be simultaneously processed.
Referring now to Figure 1, the Information-Based Complexity theory (IBC) shows that there is a minimal Complexity-Distortion (C-D) bound 100 for each given system. Figure 1 shows that the rate distortion bound 100 is a convex function. This curve 100 precisely defines the theoretical boundary between achievable function complexity-distortion (region 102) and non-achievable function-complexit distortion (region 104). For purposes of background, C. E. Shannon published his work on Information Theory (IT) in 1948. As a branch of IT, Rate Distortion Theory (RDT) comes under the umbrella of source coding and compression, which is concerned with the tasks of maximally stripping redundancy from a source, subject to a quality criterion. In other words, RDT is concerned with representing a source with the fewest number of bits possible for a given reproduction quality. The tradeoff encountered in RDT is between information rate and output distortion. It should be recognized though that in RDT, there are typically no computational constraints on what the output decoding system can do.
To extend RDT to get complexity-distortion tradeoff and scalability issues investigated, the Information-Based-Complexity (IBC) theory was developed. IBC is a branch of computational complexity that studies problems for which the information is partial, contaminated, and priced. IBC claims that the computation of an algorithm could be scaled down by limiting the amount of input information to be processed. The complexity of an algorithm can be generalized to a function of the amount of information processed to generate an output sequence.
As indicated, the region 102 above the curve 100 is theoretically algorithm achievable, while the region 104 underneath is non-achievable. For a particular system, the complexity is limited. In other words, the complexity of the system has a boundary in order to let the system perform normally. The boundary of the complexity is described as [Cmin, Cmax]. Furthermore, the output quality also has limitations, i.e. the distortion range [Dmjn, Dmax]. Dmin means the best result the system can provide, while Dmax means the worst result that the user could tolerate. Hence, the workable region of a realistic system is the region 106.
Theoretically, an optimal design is achieved if the performance curve of a designed system achieves the lowest C-D bound 100. However, it is not realistic to achieve the theoretical bound 100 perfectly with a practical system. For a given system and a given data model (algorithm), each set of test data will give a quality distortion rate. Referring also to Figure 2, for such a system model, each point of complexity and distortion pair derived from a practical system is called an operational point 202. A group of operational points 202 compose an operational curve, e.g. 204 or 206. For different data models, e.g. algorithms, there will be different operational curves. Each operational point 202 on the operational curve, e.g. 204 or 206, is achievable by the system with a chosen implementation and given test data. Scalability can be defined as a transition between two operating points 202 with different complexity coordinates in the achievable region 106. The best scalable algorithm has an operational curve which closely approximates the lowest C-D bound 100. In Figure 2, a first given system and data model, i.e. algorithm, gives a first complexity- distortion curve 204, while a second provides curve 206. Theoretically, the distance of operational curves 204, 206 from theoretical lowest complexity-distortion bound 100 illustrates how good each system design is. Often in a real design situation, the lowest bound 100 is not available and the operational curves 204, 206 are not parallel.
The MPEG2 video decoder used in the above example is commonly employed in Advanced Television Systems Committee (ATSC) compliant Digital Television (DTN) systems. In particular Figure 3 illustrates a conventional video decoder 300 block diagram suitable for use in an ATSC DTV compliant system as taught by GUIDE TO THE USE OF THE ATSC DIGITAL TELEVISION STANDARD, ATSC Doc. A/54, October 4, 1995.
Briefly, the decoder 300 includes a channel buffer 302 which receives a coded video bitstream signal A and outputs a signal B . A Variable Length Decoder (VLD) 304 receives signal B and reconstructs 8x8 arrays of quantized Discrete Cosine Transform (DCT) coefficients to provide DCT coefficients in quantized form as signal C and motion vectors as signal H. Motion Compensator 306 receives signals H and I, which includes data for anchor frames stored in memory 308 and provides motion compensated predicted pixel values as signal G. Inverse quantizer 310 receives signal C and dequantizes it to provide signal D which includes quantized prediction error DCT coefficients in standard form. Inverse Discrete Cosine Transform (IDCT) 312 receives signal D and transforms it to obtain pixel values or prediction errors as signal E. Adder 314 receives signals E and G and sums them to provide reconstructed pixel values which are degraded by quantization as signal F which is provided as decoded video data and also to memory 308.
It is an object of the current invention to provide a method as set forth above that allocates the resources in an improved way. To achieve this object, the method according to the invention comprises the following steps: a first step of requesting an algorithm resource by the algorithm to provide a plurality of output quality levels, a second step of determining that the first function provides a first plurality of quality levels and the second function provides a second plurality of quality levels, a third step of allocating a budget to the algorithm to enable operating the algorithm at a output quality level, said output quality level being one of the plurality of output quality levels, a fourth step of assigning a first quality level of the first plurality of quality levels to the first function and of assigning a second quality level of the second plurality of quality levels to the second function. By allocating a budget to an algorithm as a whole, a budget manager, or overall system control does not need to know that the algorithm comprises of a plurality of functions. The overall system control can therefore be used for the general purpose of allocating a budget to algorithms that run on the system simultaneously. The budget is based upon the requested algorithm resources. Instead of allocating a budget to the algorithm, the overall system control can set an output quality level to the algorithm as a whole. The output quality level can be chosen from the plurality of output quality levels the algorithm can provide. Each function of the algorithm can provide a plurality of quality levels. When an algorithm gets allocated a budget or is assigned an output quality, a quality control can assign a corresponding quality level or setting to each function. The corresponding quality level or setting is chosen from the plurality of quality levels that can be provided by a function. The quality level of the function that provides the highest output quality level of the algorithm for the allocated budget can be the preferred choice from the plurality of quality levels that can be provided by a function. The quality control distributes implicitly its allocated budget over the functions the algorithm comprises by the assignment of a corresponding quality level or setting to each function. The assigned quality level per function is based upon the budget that is allocated to the algorithm.
An embodiment of the method according to the invention is described in claim
2. A function can provide a quality level for a plurality of levels of complexity wherein a level of complexity for example is determined by a number of mathematical operations a function can perform, an amount of memory the function requires or communication means, like bandwidth, the function requires. When the algorithm consists of a plurality of functions, each function providing a plurality of quality levels, there are a lot of combinations of level of complexity and quality level possible. A quality control can perform these combinations and can decide upon these combinations which quality level to assign to a function.
Furthermore, the knowledge about the complexity of a function while providing the same quality level can lead to more smooth output quality transitions of the algorithm as a whole. An embodiment of the method according to the invention is described in claim
3. Each function can operate at its own quality level. A combination of the first function and the second function can lead to one algorithm that can provide a plurality of output quality levels. When a new budget is allocated to an algorithm which leads to a different output quality level, the same algorithm can be operated again, by allocating new quality levels to the first and second function as previously described. A number of algorithms providing a same functionality but at a different output quality level that can, for example, be operated in parallel, can be limited this way.
An embodiment of the method according to the invention is described in claim
4. A quality control, for example can choose for each function the lowest complexity for the highest quality level from the plurality of combinations of complexity and quality level per function.
An embodiment of the method according to the invention is described in claim
5. When the allocated budget is substantially equal to the requested algorithm resource, the algorithm does not get allocated substantially more than its requested algorithm resource. This prevents resources being not used by the algorithm, which can cause rejection of other algorithms to operate because their requested resource is already allocated to the algorithm. An embodiment of the method according to the invention is described in claim
6. When the first amount of resources in addition to the second amount of resources is substantially equal to the allocated budget, the algorithm does not use substantially more than its allocated budget. This prevents budget-overrun by the algorithm which may cause budget shortage of other algorithms or algorithms that can result in missing deadlines of these other algorithms or algorithms and degradation of an overall output quality.
An embodiment of the method according to the invention is described in claim
7. The output quality levels that can be provided by an algorithm can depend upon a hardware platform that the algorithm is operated upon. When, for example, the first function of the algorithm has specific hardware requirements, like for example the availability of a harddisk, the first function may be omitted when the hardware is not available.
An embodiment of the method according to the invention is described in claim
8. The output quality levels that can be provided by an algorithm can depend upon a software platform that the algorithm can access. When, for example, the first function of the algorithm has specific software platform requirements, like for example the availability of a linear interpolation algorithm, the first function may be operated differently when the linear interpolation algorithm is not available, for example by using an available cubic interpolation algorithm. A further object of the invention is to provide a method for operating a programmable processing device to reduce distortion in an outputted signal, that allocates the resources in an improved way. To achieve this object, this method according to the invention comprises the following steps: a first step of providing data indicative of a plurality of operational states, each of said states being associated with at least one of a plurality of operational modes of said device, a complexity of operations (C) and a distortion level (D); a second step of selecting one of said states for each of said complexities using said data and based upon said distortion levels; a third step of determining an operating status of said device; and, a fourth step of selecting which of said operational modes to operate said device in for each of said complexities responsively to said determined status using said selected states.
Embodiments of the method for operating a programmable processing device to reduce distortion in an outputted signal according to the invention are described in claims 10 to 15.
A further object of the invention is to provide a scalable programmable processing device that allocates the resources in an improved way. To achieve this object, this device according to the invention comprises: at least one scalable application operable in plurality of modes each having a different complexity of operations characteristic; a QOS resource manager for tracking how much computing resources are available for use by said at least one scalable application; a strategy manager for determining whether said available resources are suitable for operation of said scalable application in a given one of said modes; and, a local resource control responsive to said strategy manager and for selecting, in response to a determination by said strategy manager that said available resources are not suitable for operation of said at least one application in said given mode to select another of said modes for said at least one application; wherein, said QOS manager and strategy manager are mutually responsive to one another and said at least one scalable application is responsive to said local resource control.
Embodiments of the scalable programmable processing device according to the invention are described in claims 17 to 19. Various objects, features and advantages of the invention will become more apparent by reading the following detailed description in conjunction with the drawings, which are shown by way of example only, wherein:
Figure 1 illustrates a theoretical lowest attainable complexity - distortion bound;
Figure 2 illustrates two operational modes of a system and the theoretical lowest attainable bound;
Figure 3 illustrates a conventional video decoder block diagram for an ATSC compliant DTV system; Figure 4 illustrates an embodiment of the main steps of the method according to the invention,
Figure 5 illustrates an example of an algorithm that comprises a plurality of functions,
Figure 6 illustrates an example of a diagram in which the complexity of the algorithm is set against the output quality level that can be provided by the algorithm,
Figure 7 illustrates a storage device in a schematic way that comprises an embodiment of a storage device comprising a computer program product arranged to perform the method according to the invention,
Figure 8 illustrates a block diagram of a control system used according an embodiment of the present invention;
Figure 9 illustrates a scalable video decoder block diagram for an ATSC compliant DTV system according to an embodiment of the present invention;
Figure 10 illustrates a lowest C-D approach among various algorithms according to an embodiment of the present invention; and, Figure 11 illustrates a scalable video decoder block diagram for an ATSC compliant DTV system according to another embodiment of the present invention.
Figure 12 illustrates the most important parts of an embodiment of the system according to the invention in a schematic way,
Figure 13 illustrates a television set in a schematic way that contains an embodiment of the system according to the invention,
Figure 14 illustrates a set-top box in a schematic way that contains an embodiment of the system according to the invention. Figure 4 illustrates an embodiment of the main steps of the method according to the invention. Programmable components, rather than dedicated single-function components can perform continuous media processing. Those single-function components are used in traditional television receivers in which some of those single-function components could be combined to perform for example color decoding for NTSC or PAL systems, noise reduction or frame rate up-conversion. With the introduction of programmable components, continuous media processing algorithms can be implemented in software instead of hardware. Some of the expected advantages of the software implementation of media processing algorithms are: reduced time to market, re-use of hardware, re-use of software algorithms, portability, and flexibility. The software implementation of the media processing algorithms must run within the real-time environment in which system resources are finite and sufficient system resources may not be reserved for a particular processing algorithm, which can lead to changes in the output quality provided by the particular processing algorithm. Output quality levels can be measured by perception measurements, or objectively by available measurement means. A system running the processing algorithms is able to provide high-quality audio and video that has a relatively high frame rate above 50 Hz, almost no tolerance for frame rate fluctuations and a low tolerance for frame skips. Preferably, the system is also able to provide low frame rates with a maximum of 30 Hz, a high tolerance for frame rate fluctuations and a high tolerance for frame skips. Algorithms can be allocated budget explicitly or implicitly by setting an output quality level of the algorithm. One of the objectives of an overall system control is to optimize the total output quality provided by the total system while making efficient use of all the available resources. The total output quality provided by the system depends amongst others upon the number of algorithms operating concurrently and the data an algorithm processes. The system may be, for example, a television, a PC, a display, a set-top box, or a VCR. In order to achieve this objective, the main steps below are performed.
Here, step 400 is an initialization step in which an overall system control, for example a budget manager accesses the contents of a first lookup table as illustrated in Table 1. In this table, "CPU", "co-processor" and "memory requirements" are examples of resources that an algorithm can use. Furthermore, a higher number that is denoted in the column named "quality number" indicates a better output quality level perceived by a user. By accessing the contents of this first lookup table, the overall system control determines the predefined amount of resources, for example CPU cycles, an algorithm requests to provide a predefined output quality level.
Figure imgf000011_0001
Table 1
The algorithm, or a quality control, which is part of the algorithm, can have access to the contents of Table 1 too. Algorithms are started implicitly when a user switches to another channel for a main window and the, analog, source of the new channel is different from the, digital, source of the old channel. Other examples of starting algorithms or changing the resource requirement of an algorithm are: when a user exchanges the contents of a main window and a picture in picture window by for example viewing the re-play after a goal, when the size of a video conferencing window changes, or when a new application, for example a video conferencing application when a call arrives, is started in an additional window. The resource requirement of an algorithm changes too when the media data the algorithm processes changes. A change in the media data can be caused by the service provider that may transmit sources with different input parameters, for example when a movie which can be a 24 Hz film is interrupted by a commercial which can be a 60 Hz camera or it can be caused by motion or scene changes. Within step 402 the functions a media processing algorithm comprises is determined by, for example, reading this information from some configuration file. This file describes that, for example, an algorithm for edge or sharpness enhancement comprises the functions as is illustrated in a schematic way in Figure 5. Within this Figure, a detail filter 512, a non-linear function 502, a gain 504, an adder 506, and noise measurement 508, is shown. The detail filter extracts higher frequency components from an input signal containing a video signal. Those components can be added to the input signal to increase the overall sharpness impression of the video signal. The non-linear function and following gain can reduce artifacts like clipping caused by the detail filter whereas the noise measurement function can adapt the sharpness enhancement dependent upon the noise level contained within the input signal. Within step 404 the requested resources and the quality level per function are determined. In order to separate concerns, a quality control 510, see Figure 5, shields the overall system control from the functions an algorithm comprises and is part of the algorithm. Within the algorithm for edge or sharpness enhancement, the detail filter varies its requested resources for, for example, number of CPU cycles or number of bytes. The variation of requested resources is determined by the quality levels described by the coefficients for the filter and the type of filter: horizontal, vertical, or both. The non-linear function varies its requested resources for, for example, CPU cycles and is determined by the quality levels described by the quantization of the non-linear function, which can differ for the input signal and output signal. The gain varies its requested resources for, for example, a multiplier, shift and adder operations dependent upon whether it is stored as fixed values in a lookup table contained in memory, it is calculated by a multiplier or is calculated by shift and adder operations. The noise measurement varies its requested resources for, for example CPU cycles, because it can, for example, be switched on or off. The adder operation can vary its requested amount of resources by for example doing less precise additions. However, adder operations that cannot vary their requested amount of resources but provide a predefined quality level for a predefined amount of resources, for example CPU cycles, can be used too. The combination of all settings for requested resources and quality level per function, results in a large design space in which the complexity of the algorithm, or of a function of the algorithm, or of a combination of functions of the algorithm is set against its quality level. The result is summarized into, for example, a second lookup table as illustrated in Table 2. In this table, there are three main columns: "version", which assigns a unique number to a row, "quality", which groups all parameters concerning the output quality level a algorithm can provide, and "complexity", which groups all parameters concerning the complexity of the algorithm. The mentioned parameters are not limiting, for example, store operations or communication means like bandwidth and cache can be used as parameters concerning the complexity of the algorithm. Furthermore, the numbers used for the quality and complexity within Table 2 are absolute, but may be normalized to operations per pixel within video independently from the chosen format. With this concept, a media algorithm designer designs the functions the media algorithm comprises to provide the correct functionality at different output quality levels.
Figure imgf000013_0001
Table 2
Within step 406 the contents of the table is updated for the available software platform the algorithm has access to. For example, when the software platform does not support "temporal processing", this column is removed from the table and the effectuated rows are updated correspondingly. When for example "horizontal processing" is not supported, the corresponding column and the rows which do not lead to any processing at all, like row 6 and N, are removed from the table. It is also possible to instantiate a run-time lookup table containing a mapping from software functions available within the software platform to software functions required by the algorithm instead of updating Table 2.
Within step 408 the contents of the table is updated for the available hardware platform the algorithm must be operated upon. For example, when the hardware platform does not provide a co-processor, this column is removed from the table and all rows are removed that only used a co-processor. It is also possible to instantiate a run-time lookup table containing a mapping from hardware available within the hardware platform to hardware required by the algorithm instead of updating Table 2.
After these steps, the functions an algorithm comprises, the plurality of quality levels the different functions provide, the plurality of output quality levels the algorithm provides and the hardware and software the algorithm requires from the hardware platform and software are known to the quality control. The overall system control only needs to know about the algorithm, the resources the algorithm requests, the hardware it requires and the plurality of output quality levels the algorithm provides. Within step 410 the overall system control allocates a resource budget to the algorithm in accordance with a best overall system's output quality level. A best overall system's output quality level can be achieved when the system is in a steady state in which all algorithms that are running provide a predefined output quality level and the system is fully loaded. This means that additional algorithms can not be started without adjusting the output quality levels of the running algorithms. The budget that is allocated is substantially equal to the resources requested by the algorithm to provide a predefined output quality level. When the algorithm gets allocated less budget than requested, the algorithm may not provide the predefined output quality level and when the algorithm gets allocated more budget than requested, the algorithm may not use all resources. The overall system control 512, see Figure 5, allocates the budget to the algorithm based upon the contents of Table 1. The overall system control 512 can allocate the budget to the algorithm based upon the contents of Table 2. In the latter case, the overall system control decides upon a more smooth transition of the output quality level provided by the algorithm. As is shown in Table 2, an abrupt transition of the output quality level provided by the algorithm is likely from version 2 to version 6, or from version 5 to version 6, because the processing changes in two dimensions. A more smooth transition is expected from version 2 to version 3, because the processing changes only in one dimension. The other "quality" parameters like the quality number or PSNR also provide information about the smoothness of transitions. The information about the hardware platform and software platform as derived in steps 406 and 408, can also be accessed by the overall system control. Selection of the output quality level provided by the algorithm is then based upon for example the available hardware. This is shown in Table 2, where version 1 and version 2 provide the same output quality level because their quality numbers are equal, but they distribute the required resources differently between the CPU and co-processors. The quality control can use this knowledge of distribution between CPU and co-processors to deal, amongst others at run-time, with overload situations in which the quality control can change the distribution, while the algorithm still provides the same output quality.
Within step 412 the quality control translates the allocated budget, or output quality level, to the algorithm as a whole into a quality level allocation to the different functions the algorithm comprises. This translation is based upon the contents of Table 2 and takes the combination of all settings for requested resources and quality level per function into account. The combination of all settings for requested resources determines the complexity of the algorithm, a function of the algorithm and a combination of the functions of the algorithm. The complexity is expressed with a number. This number is weighted to get a single number for a specific hardware or software platform. Figure 6 shows an example of the combination of the complexity and provided output quality level. Useful combinations are achieved at the highest output quality for the lowest complexity as is indicated by the drawn curve in Figure 6. Each dot implies different quality settings or quality levels for the functions an algorithm comprises. The information about the hardware platform and software platform as derived in steps 406 and 408 is accessed by the quality control. The quality control uses this information to choose the best combination of the complexity and provided output quality level, because the best combination and the number of combinations can depend upon the hardware and/or software platform the functions must run upon. Changing the resolution of video data by for example sub-sampling the video data or deleting entire frames, lines or pixels is prevented by interpretation of the contents of Table 1 and Table 2 as previously described. The quality control also maximizes the perceptual quality because a user perceives a low output quality provided by the system, when the quality of, for example a movie, is changed continuously. Therefore quality levels are sparingly adjusted. Within step 414, the quality control re-allocates the translated allocated budget to the functions the algorithm comprises implicitly, by assigning the corresponding quality level to the functions.
Within step 416 the functions and therefore the algorithm as a whole start operating using their allocated budget and set quality level. After completion of the algorithm, step 400 can be performed again or the final step 418 is reached.
Figure 7 illustrates, in a schematic way, a storage device that comprises a computer program product arranged to perform the method according to the invention. Here, 700 is a compact-disk comprising code 702. Furthermore, the present invention involves comparing different C-D curves that achieve the same task, so that an algorithm which is more efficient regarding the tradeoff of the complexity and the quality distortion at certain complexity levels than available alternatives can be identified. Therefore the best algorithm which gives the minimal quality distortion at certain complexity can be selected, and the global optimal approach can be achieved for the given set of algorithms under assumed complexity and distortion ranges.
Referring now to Figure 8, the scalable video algorithm design control system made according to the concepts of the present invention preferably includes four elements: a Quality Of Service (QOS) resource manager 800; a strategy manager 802; a local resource control 804; and scalable algorithms 806. The QOS resource manager 800 oversees resource usage within an entire system, or grouped subsystems. It sends out control commands to the strategy manager 802 when system resources vary, and receives feedback from the strategy manager 802 when subsystems are scaled. The strategy manager 802 serves as an envoy for the QOS manager 800 which has the power to command different scalable algorithms' 806 via local controller 804 to scale up or down in order to adapt to the resource level change. Although the strategy manager 802 controls the overall scaling of levels of different applications, it does not control the detail of the scalability of a specific algorithm 806. For example, it controls the total complexity level of the MPEG2 decoder, but it does not have the control about which algorithm of the MPEG2 decoder should be scaled down to what level. This is the work of the local resource control 804. The local resource control 804 (also known as decoding resource control or complexity switching control) knows exactly how each functional block inside of the MPEG2 decoder is scaled and to what level. Ultimately, the scalable algorithms 806 are the keys that fulfill the scalability job.
In other words, it should be understood that in general QOS is well understood by those possessing an ordinary skill in computer quality control/information management. The QOS manager 800 basically manages the use of computing resources, e.g. in use, not in use, monitors information flow, and responds to requests from applications that demand or are using resources. The strategy manager 802 satisfies a need for communication between the QOS manager 800 and scalable applications which use the scalable algorithms 806, such as the scalable MPEG2 decoder of Figures 9 or 11. The strategy manager 802 handles and controls the resource uses of each individual scalable application and coordinates these applications.
The local resource control 804 serves as a local office manager for a particular scalable application. For example, and referring now to Figure 9, therein is illustrated a scalable ATSC compliant DTV video decoder according to the present invention. Therein, the elements designated with a ' designate like elements to those of Figure 3, except that they are scalable in accordance with the present invention. Hence, more than one functional block within the decoder 300' of Figure 9 is scalable. In the MPEG2 decoder 300' the IDCT is one functional block for example. The local resource manager 804 (also referred to as Decoding Resource Control) coordinates the activities and scalable levels of these blocks, e.g. how much each individual functional block should be scaled. If multiple scalable algorithms 806 are available for a particular functional block, e.g. an IDCT, in order to achieve minimal distortion, when and where the switching of multiple algorithms, e.g. 204, 206, should apply, these control tasks are performed by the local resource manager 804.
As discussed above, the fundamental research proves that the lowest complexity-distortion (C-D) bound 100 in a C-D plane exists. However, to design a system which is ideally on this bound 100 is not practical. In order to best achieve/approach this theoretical lowest bound 100, system designers usually search for the single best algorithm that can approach the bound 100 for different complexity levels. Usually a single algorithm is selected from a group of algorithms for the best match. But as is clearly illustrated in Figure 2 for example, the operational 204, 206 curves of different algorithms may cross each other. This implies that one algorithm has a lower complexity level than the other at one distortion rate, but does not necessarily result in a lower complexity level at a different distortion rate.
Referring now to Figure 10, in order to better approach the global optimal C-D bound 100, and according to a preferred form of the present invention: the operational curves of available algorithms are measured; then for a possible given data set, the algorithm which yields the lowest distortion rate for each complexity level within the operational curves is selected; finally, switch points on different operational curves are selected which results in a new global optimal operational curve. In other words, according to the present invention, switches between different algorithms 1002, 1004, 1006, 1008 are advantageously utilized to provide a better operational curve 1010 than any of the individually tested algorithms 1002, 1004, 1006, 1008. Referring now also to Figure 11, therein is illustrated another ATSC compliant
DTV video decoder 300" according to the present invention which includes a scalable IDCT functional block 312, 312', 312". Using the IDCT functional block 312, 312', 312" of MPEG2 decoder 300" as an embodiment of the disclosure, this approach proposes to use multiple Discrete Cosine Transform (DCT) algorithms to achieve an optimal scalability of the decoder with regards to the computation complexity and the quality. For a given complexity level, a DCT algorithm that is chosen to give the minimal distortion level.
It should be recognized that theoretically, if an infinite number of algorithms are available the lowest C-D bound 100 could be approached or nearly achieved by performing all the comparisons therebetween and selecting the best fit at each complexity. Practically however, the number of available algorithms and the comparison time are limited by design criteria, and the number of operational switching points is also limited as will be discussed. Therefore the approach of the present invention is to get the lowest possible quality distortion under certain given complexity using a certain number of available algorithms.
Referring still to Figure 11, therein is illustrated a video decoder 300" block diagram for an ATSC compliant DTV system according to another form of the present invention. As can be readily ascertained, the decoder 300" incorporates many of the same elements as the decoder 300 of Figure 1, therefore a discussion of these like elements will not be repeated. Referring now also to Figures 3 and 9, in contrast to the decoder 300 though, the decoder 300" includes multiple IDCT's 312, 312, 312 and complexity switch 804 while the decoder 300' includes an IDCT 312' which can implement multiple algorithms and switch 804. The complexity switch 804 is responsive to signal J which originates from strategy manager 802. The switch control 804 outputs signal K in response to signal J which selectively activates ones of IDCT's 312,312, 312 . In the illustrated case of Figure 11, there are n IDCTs, 312, 312', 312" which are switched between to provide n different algorithms. Alternatively, one or more IDCT's which are selectably activatable to use different algorithms can be used such as is illustrated in Figure 9.
Referring again to Figure 8 also, the QOS 800 determines how much, or what percentage of Central Processing Unit (CPU) cycles, i.e. processing power, the MPEG2 decoder 300" is entitled to use. This may or may not be enough for full power MPEG2 decoding, i.e. non-scalable. The strategy manager 802 receives this budget, together with other budgets for other applications. The strategy manager 802 determines if this budgeted amount of computing or processing power is sufficient for full decoding. If the budgeted amount of computing power is not sufficient for a non-scalable decoding, it will either inform the local resource control 804 to activate a scalable algorithm 806, or request more resources from QOS manager 800 for robustly maintaining a suitable output quality. Assuming the local resource manager 804 of the MPEG2 decoder 300" receives the reduced budget, based on statistics gathered in advance, by using one or more look-up tables for example, a determination is made as to which scalable algorithm 204 will be activated at what level of available processing power. Assuming the global optimal IDCT algorithm according to the present invention is activated, and since the complexity versus distortion relationship is determined off-line in advance, at each complexity level the local resource manager 804 has a well defined algorithm to call and use, as corresponding to a particular operational point. For different algorithms, the complexity stretch is different. Not all the available algorithms will provide the same range of complexity-distortion measurement and range. The operational points for different algorithms may offset each other. The metric for complexity measurement for different algorithms should be universal, or scaled to the comparable level. The total number of machine cycles running the algorithm can be defined as the complexity level of the algorithm. However, in high level simulation of the scalable algorithms, it may not be realistic to measure the machine cycles as machine cycles are platform and CPU dependent. In such a case, the multiplication reduction ratio can be used as a complexity measurement. According to one embodiment of the present invention, a procedure to obtain an operational C-D curve is as follows: Step 1. The operational points of available algorithms are measured under different complexity levels; Step 2. Scale the operational points of different algorithms to the same scale and draw the operational curves on the same plot; Step 3. Find the switching points (cross points) of the operational curves; and, Step 4. The global optimal operational curve 1010 is decided by selecting each operation curve portion which is nearest to the C-D curve 100 between each of the switching points.
To summarize, the disclosed method proposes a way to better approach the global optimal complexity-distortion bound 100 for a given system using multiple schemes, e.g. algorithms or modes. This method is based on the information-based complexity theory and is practically achievable. It can be used in scalable multimedia / communication system design and scalability analysis.
The order in the described embodiments of the methods of the current invention is not mandatory, a person skilled in the art may change the order of steps or perform steps concurrently using threading models, multi-processor systems or multiple processes without departing from the concept as intended by the current invention.
Furthermore, the introduced quality control and overall system control express roles or concepts that can be used within the methods of the current invention.
Figure 12 illustrates the most important parts of an embodiment of the system according to the invention in a schematic way. The system, 1200, comprises a first memory 1202 that contains per resource an amount of that resource an algorithm requests to provide a predefined output quality level. A CPU and a co-processor are examples of resources of which cycles can be requested. A second memory 1204, contains a module to perform a first function of the algorithm, while a third memory 1206, contains a module to perform a second function of the algorithm. Consider the edge or sharpness enhancement algorithm 514, as described in Figure 5. The second memory 1204 contains the module that performs detail filtering 500, while the third memory 1206 contains the module that performs noise measurement 508. The system may also contain more memories containing modules that perform all the functions of the edge or sharpness enhancement algorithm as described in Figure 5. The fourth memory, 1208 contains a lookup table containing per quality level of a first plurality of quality levels the first function can provide, the amount of resources it requires. The fifth memory, 1210 contains a lookup table containing per quality level of a second plurality of quality levels the second function can provide, the amount of resources the second function requires. After the overall system control allocates a budget per resource, as previously described, the sixth memory 1212 contains per resource the amount of budget allocated to the algorithm. The overall system control can also assign the output quality level of the algorithm as a whole, thereby implicitly allocating a budget per resource to the algorithm. Furthermore, the memories 1214 and 1216 contain the quality levels provided by the first and second function of the algorithm respectively. Memory 1218 contains a plurality of complexity numbers indicating a plurality of levels of complexity of operation of the first function of the algorithm. Memory 1220 contains a complexity number indicating the least complex level of operation of the first function of the algorithm. In order to determine the content of memories 1214 and 1216 as previously described the quality control has access to the contents of memory 1218 and 1220. The contents of memories 1202, 1208, and 1210, 1218, 1220 can also be combined into one lookup table as illustrated in Table 2. This combined lookup table can then be stored into one memory instead of more separate memories. Furthermore, when the system is realised in silicon in which the functions and lookup table are hard-wired to eachother, the memories 1212, 1214 and 1216 may be omitted. The quality control accesses the contents of memory 1226 that contains a configuration file containing information about the available hardware within the system and it accesses the contents of memory 1228 that contains a configuration file containing information about the available software algorithms within the system. The quality control has access to all previously described memories, whereas the overall system control only requires access to memories 1202, 1212, 1226 and 1228. However, when the overall system control has access to more memories, the output quality level transitions provided by the algorithm can become smoother. The system also comprises a first co-processor, 1222, on which the first function of the algorithm can run and a second co-processor, 1224, which on which the second function of the algorithm can run. An, optional, CPU, 1230, operates the algorithm as a whole, because there needs to be some inter-process communication between the first and second function. When the system does not contain co-processors, the functions and therefore, the algorithm run on the CPU. When the first function can be operated at a plurality of levels of complexity, the first function runs at the least complex level on a dedicated co-processor 1232, while the more complex level is run on the co-processor 1222. It is also possible that the first function runs at each of the plurality of levels of complexity on either 1232 or 1222 or that the first function runs at each of the plurality of levels of complexity on CPU 1230. This system can be realised in software intended to be operated as an application by a computer or any other standard architecture able to operate software. The system can be used to operate a digital television set 1234. The system can also be realised in silicon wherein the mentioned lookup tables are replaced by logical building blocks that are hard-wired to each other and the mentioned processors and co-processors are omitted. Figure 13 illustrates, in a schematic way, the most important parts of a television set that comprises an embodiment of the system according to the invention. Here an antenna, 1300 receives a television signal. The antenna may also be for example a satellite dish, cable, storage device, internet, Ethernet or any other device able to receive a television signal. A receiver, 1302 receives the signal. The signal may be for example digital, analog, RGB or YUV. Besides the receiver 1302, the television set contains a programmable component, 1304, for example a programmable integrated circuit. This programmable component contains a system according to the invention 1306. A television screen 1308 shows images that are received by the receiver 1302 and are processed by the programmable component 1304, the system according to the invention 1306 and other parts that are normally contained in a television set, but are not shown here.
Figure 14 illustrates, in a schematic way, the most important parts of a set-top box that comprises an embodiment of the system according to the invention. Here, an antenna 1400 receives a television signal. The antenna may also be for example a satellite dish, cable, storage device, internet, Ethernet or any other device able to receive a television signal. A set-top box 1402, receives the signal. The signal may be for example digital, analogue, RGD or YUV. Besides the usual parts that are contained in a set-top box, but are not shown here, the set-top box contains a system according to the invention 1404. The television set 1406 can show the output signal generated from a received signal by the set-top box 1402 together with the system according to the invention 1404. The output signal may also be directed to a storage device like a VCR, DVD-RW or a harddisk or they may be directed to an internet link in stead of being directed to the television set.

Claims

CLAIMS:
1. A method of running an algorithm wherein the algorithm comprises a first function and a second function, the method comprising the following steps: a first step of requesting an algorithm resource by the algorithm to provide a plurality of output quality levels, a second step of determining that the first function provides a first plurality of quality levels and the second function provides a second plurality of quality levels, a third step of allocating a budget to the algorithm to enable operating the algorithm at a output quality level, said output quality level being one of the plurality of output quality levels, a fourth step of assigning a first quality level of the first plurality of quality levels to the first function and of assigning a second quality level of the second plurality of quality levels to the second function.
2. A method of running an algorithm according to claim 1, further comprising a fifth step of determining that the first function, while providing the first quality level, can be operated at a plurality of levels of complexity.
3. A method of running an algorithm according to claim 1, further comprising the following steps: a sixth step of operating the algorithm at the output quality level. a seventh step of operating the first function at the first quality level while consuming a first amount of resources by the first function and operating the second function at the second quality level while consuming a second amount of resources by the second function.
4. A method of running an algorithm according to claim 3, further comprising an eighth step of operating the first function at a least complex level of the plurality of levels of complexity.
5. A method of running an algorithm according to claim 1 , wherein the allocated budget is substantially equal to the requested algorithm resource.
6. A method of running an algorithm according to claim 3 , wherein the first amount of resources in addition to the second amount of resources is substantially equal to the allocated budget.
7. A method of running an algorithm according to claim 1, further comprising a ninth step of determining a hardware platform operating said method to determine the algorithm resource and the plurality of output quality levels.
8. A method of running an algorithm according to claim 1, further comprising an tenth step of determining a software platform operating said method to determine the algorithm resource and the plurality of output quality levels.
9. A method for operating a programmable processing device to reduce distortion in an outputted signal, the method comprising the following steps: a first step of providing data indicative of a plurality of operational states (202), each of said states (202) being associated with at least one of a plurality of operational modes (1002, 1004, 1006, 1008) of said device, a complexity of operations (C) and a distortion level (D); a second step of selecting one of said states for each of said complexities using said data and based upon said distortion levels; a third step of determining an operating status of said device; and, a fourth step of selecting which of said operational modes to operate said device in for each of said complexities responsively to said determined status using said selected states.
10. A method for operating a programmable processing device to reduce distortion in an outputted signal according to claim 9, wherein said selected operational mode for a first determined status is different from said selected operational mode for a second determined status.
11. A method for operating a programmable processing device to reduce distortion in an outputted signal according to claim 9, wherein said second step is based upon minimizing said distortion level for said complexity.
12. A method for operating a programmable processing device to reduce distortion in an outputted signal according to claim 9, wherein said first step comprises using at least one lookup table.
13. A method for operating a programmable processing device to reduce distortion in an outputted signal according to claim 9, wherein said programmable device is a multimedia communications device.
14. A method for operating a programmable processing device to reduce distortion in an outputted signal according to claim 9, wherein said device is an ATSC compliant digital television decoder including at least one IDCT, and each of said modes corresponds to a different mode of operation of said at least one IDCT.
15. A method for operating a programmable processing device to reduce distortion in an outputted signal according to claim 9, wherein said selecting comprises determining which of said modes provides a complexity-distortion characteristic desirable to those of said other modes for performing said task using said available amount of computing resources.
16. A scalable programmable processing device comprising: at least one scalable application (300') operable in plurality of modes each having a different complexity of operations characteristic; a QOS resource manager (800) for tracking how much computing resources are available for use by said at least one scalable application (300'); a strategy manager (802) for determining whether said available resources are suitable for operation of said scalable application (300') in a given one of said modes; and, a local resource control (804) responsive to said strategy manager (802) and for selecting, in response to a determination by said strategy manager (802) that said available resources are not suitable for operation of said at least one application (300') in said given mode to select another of said modes for said at least one application (300'); wherein, said QOS manager (800) and strategy manager (802) are mutually responsive to one another and said at least one scalable application (300') is responsive to said local resource control (804).
17. A scalable programmable processing device according to claim 16, further comprising a memory accessible to said local resource control.
18. A scalable programmable processing device according to claim 17, wherein said memory includes a data being indicative of complexity-distortion characteristics of each of said modes for a plurality of amounts of available system resources.
19. A scalable programmable processing device according to claim 16, wherein said device is an ATSC compliant digital television decoder including at least one IDCT, and each of said modes corresponds to a different mode of operation of said at least one IDCT.
20. A scalable MPEG2 compatible video decoder comprising: at least one variable length decoder (304'); at least one inverse quantizer (310') coupled to said variable length decoder (300'); at least one inverse discrete cosine transform (312') coupled to said inverse quantizer (310'); at least one motion compensator (306) coupled to said variable length decoder (304'); a summing junction (314) coupled to said inverse discrete cosine transform (312') and motion compensator (306); and, a controller (804); wherein at least one of said variable length decoder (304'), inverse quantizer (310'), inverse discrete cosine transform (312') and motion compensator (306) is coupled to said controller and responsive thereto to operate in one of a plurality of modes each having a given complexity characteristic for an acceptable distortion level of an output of said decoder; and, wherein said controller selects said one of said modes based upon said given complexity characteristics.
21. A scalable MPEG2 compatible video decoder according to claim 20, wherein said controller selects said one of said modes further based upon an available amount of computing resources for operating at least one of said variable length decoder (304'), inverse quantizer (310'), inverse discrete cosine transform (312') and motion compensator (306').
22. A scalable MPEG2 compatible video decoder according to claim 20, wherein said at least one inverse discrete cosine transform (312') includes a plurality of inverse discrete cosine transforms (312, 312', 312") which is selectively operable in response to said controller (804).
23. A scalable MPEG2 compatible video decoder according to claim 22, wherein said selectively operated inverse discrete cosine transform (312, 312', 312") implements said selected one of said modes.
24. A scalable MPEG2 compatible video decoder according to claim 23, wherein said complexity-distortion characteristic of said selected one of said modes is more efficient than those of the others of said plurality of modes.
25. A computer program product arranged to perform the method according to any of the claims 1 to 15.
26. A storage device (700) comprising a computer program product according to claim 25.
PCT/EP2001/009691 2000-08-29 2001-08-22 Method of running an algorithm and a scalable programmable processing device WO2002019095A2 (en)

Priority Applications (3)

Application Number Priority Date Filing Date Title
KR1020027005513A KR20020064893A (en) 2000-08-29 2001-08-22 Method of running an algorithm and a scalable programmable processing device
JP2002523147A JP2004507957A (en) 2000-08-29 2001-08-22 Algorithm execution method and scalable programmable processing device
EP01967293A EP1316218A2 (en) 2000-08-29 2001-08-22 Method of running an algorithm and a scalable programmable processing device

Applications Claiming Priority (6)

Application Number Priority Date Filing Date Title
US09/649,777 US6674800B1 (en) 2000-08-29 2000-08-29 Method and system for utilizing a global optimal approach of scalable algorithms
US09/649,777 2000-08-29
US09/759,036 US20020129080A1 (en) 2001-01-11 2001-01-11 Method of and system for running an algorithm
US09/759,036 2001-01-11
US09/872,931 2001-06-01
US09/872,931 US20030058942A1 (en) 2001-06-01 2001-06-01 Method of running an algorithm and a scalable programmable processing device

Publications (2)

Publication Number Publication Date
WO2002019095A2 true WO2002019095A2 (en) 2002-03-07
WO2002019095A3 WO2002019095A3 (en) 2002-06-13

Family

ID=27417828

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/EP2001/009691 WO2002019095A2 (en) 2000-08-29 2001-08-22 Method of running an algorithm and a scalable programmable processing device

Country Status (5)

Country Link
EP (1) EP1316218A2 (en)
JP (1) JP2004507957A (en)
KR (1) KR20020064893A (en)
CN (1) CN1265645C (en)
WO (1) WO2002019095A2 (en)

Cited By (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2004001597A2 (en) * 2002-06-20 2003-12-31 Matsushita Electric Industrial Co., Ltd. Multitask control device and music data reproduction device
WO2004075558A1 (en) 2003-02-06 2004-09-02 Koninklijke Philips Electronics, N.V. Optimizing scaleable video algorithm asset distribution utilizing quality indicators
EP1581007A2 (en) * 2004-03-25 2005-09-28 Sony Corporation Image decoding
EP1987674A1 (en) * 2006-02-24 2008-11-05 Microsoft Corporation Accelerated video encoding
WO2009132140A1 (en) * 2008-04-23 2009-10-29 Qualcomm Incorporated Coordinating power management functions in a multi-media device
WO2010022189A1 (en) * 2008-08-19 2010-02-25 Qualcomm Incorporated Power and computational load management techniques in video processing
US8908763B2 (en) 2008-06-25 2014-12-09 Qualcomm Incorporated Fragmented reference in temporal compression for video coding
US8948270B2 (en) 2008-08-19 2015-02-03 Qualcomm Incorporated Power and computational load management techniques in video processing
US8953685B2 (en) 2007-12-10 2015-02-10 Qualcomm Incorporated Resource-adaptive video interpolation or extrapolation with motion level analysis

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1713291A (en) * 2004-06-22 2005-12-28 皇家飞利浦电子股份有限公司 Method and device for optimizing CD brewser
US8928678B2 (en) * 2012-08-02 2015-01-06 Intel Corporation Media workload scheduler

Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5640208A (en) * 1991-06-27 1997-06-17 Sony Corporation Video signal encoding in accordance with stored parameters
US5818967A (en) * 1995-06-12 1998-10-06 S3, Incorporated Video decoder engine
WO1999012126A1 (en) * 1997-09-04 1999-03-11 Electronics And Telecommunications Research Institute Computational graceful degradation method using priority information in multiple objects case
US5925104A (en) * 1995-10-18 1999-07-20 U.S. Philips Corporation Method for making a multimedia application executable on hardware platforms with various different resource levels, a physical record containing such application, and an apparatus for executing such application
EP0939545A2 (en) * 1998-02-27 1999-09-01 Hitachi, Ltd. Video service system
US6014694A (en) * 1997-06-26 2000-01-11 Citrix Systems, Inc. System for adaptive video/audio transport over a network
US6049629A (en) * 1992-03-23 2000-04-11 Canon Kabushiki Kaisha Coding apparatus for coding image data using one of an interpicture coding method and an interpicture motion-compensated coding method

Patent Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5640208A (en) * 1991-06-27 1997-06-17 Sony Corporation Video signal encoding in accordance with stored parameters
US6049629A (en) * 1992-03-23 2000-04-11 Canon Kabushiki Kaisha Coding apparatus for coding image data using one of an interpicture coding method and an interpicture motion-compensated coding method
US5818967A (en) * 1995-06-12 1998-10-06 S3, Incorporated Video decoder engine
US5925104A (en) * 1995-10-18 1999-07-20 U.S. Philips Corporation Method for making a multimedia application executable on hardware platforms with various different resource levels, a physical record containing such application, and an apparatus for executing such application
US6014694A (en) * 1997-06-26 2000-01-11 Citrix Systems, Inc. System for adaptive video/audio transport over a network
WO1999012126A1 (en) * 1997-09-04 1999-03-11 Electronics And Telecommunications Research Institute Computational graceful degradation method using priority information in multiple objects case
EP0939545A2 (en) * 1998-02-27 1999-09-01 Hitachi, Ltd. Video service system

Non-Patent Citations (7)

* Cited by examiner, † Cited by third party
Title
LEE C ET AL: "A scalable solution to the multi-resource QoS problem" REAL-TIME SYSTEMS SYMPOSIUM, 1999. PROCEEDINGS. THE 20TH IEEE PHOENIX, AZ, USA 1-3 DEC. 1999, LOS ALAMITOS, CA, USA,IEEE COMPUT. SOC, US, 1 December 1999 (1999-12-01), pages 315-326, XP010366925 ISBN: 0-7695-0475-2 *
LOFTUS C ET AL: "Engineering for quality of service" GLOBAL CONVERGENCE OF TELECOMMUNICATIONS AND DISTRIBUTED OBJECT COMPUTING, 1997. PROCEEDINGS., TINA 97 SANTIAGO, CHILE 17-20 NOV. 1997, LOS ALAMITOS, CA, USA,IEEE COMPUT. SOC, US, 17 November 1997 (1997-11-17), pages 271-277, XP010271660 ISBN: 0-8186-8335-X *
RAJKUMAR R ET AL: "Practical solutions for QoS-based resource allocation problems" REAL-TIME SYSTEMS SYMPOSIUM, 1998. PROCEEDINGS. THE 19TH IEEE MADRID, SPAIN 2-4 DEC. 1998, LOS ALAMITOS, CA, USA,IEEE COMPUT. SOC, US, 2 December 1998 (1998-12-02), pages 296-306, XP010318786 ISBN: 0-8186-9212-X *
ROSU D ET AL: "FARACost: an adaptation cost model aware of pending constraints" REAL-TIME SYSTEMS SYMPOSIUM, 1999. PROCEEDINGS. THE 20TH IEEE PHOENIX, AZ, USA 1-3 DEC. 1999, LOS ALAMITOS, CA, USA,IEEE COMPUT. SOC, US, 1 December 1999 (1999-12-01), pages 224-233, XP010366903 ISBN: 0-7695-0475-2 *
SANG HWAN KUNG ET AL: "QoS based resources management model for supporting multimedia services" INFORMATION NETWORKING, 1998. (ICOIN-12). PROCEEDINGS., TWELFTH INTERNATIONAL CONFERENCE ON TOKYO, JAPAN 21-23 JAN. 1998, LOS ALAMITOS, CA, USA,IEEE COMPUT. SOC, US, 21 January 1998 (1998-01-21), pages 184-187, XP010265300 ISBN: 0-8186-7225-0 *
SILVA M L ET AL: "An object-oriented approach to a parallel tabu search algorithm for the task scheduling problem" COMPUTER SCIENCE SOCIETY, 1999. PROCEEDINGS. SCCC '99. XIX INTERNATIONAL CONFERENCE OF THE CHILEAN TALCA, CHILE 11-13 NOV. 1999, LOS ALAMITOS, CA, USA,IEEE COMPUT. SOC, US, 11 November 1999 (1999-11-11), pages 105-111, XP010365277 ISBN: 0-7695-0296-2 *
ZHAO SONGSHENG ET AL: "Dynamic quality of session control of real-time video multicast" INTELLIGENT PROCESSING SYSTEMS, 1997. ICIPS '97. 1997 IEEE INTERNATIONAL CONFERENCE ON BEIJING, CHINA 28-31 OCT. 1997, NEW YORK, NY, USA,IEEE, US, 28 October 1997 (1997-10-28), pages 1737-1741, XP010276324 ISBN: 0-7803-4253-4 *

Cited By (18)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2004001597A3 (en) * 2002-06-20 2004-07-08 Matsushita Electric Ind Co Ltd Multitask control device and music data reproduction device
WO2004001597A2 (en) * 2002-06-20 2003-12-31 Matsushita Electric Industrial Co., Ltd. Multitask control device and music data reproduction device
WO2004075558A1 (en) 2003-02-06 2004-09-02 Koninklijke Philips Electronics, N.V. Optimizing scaleable video algorithm asset distribution utilizing quality indicators
EP1581007A3 (en) * 2004-03-25 2012-11-21 Sony Corporation Image decoding
EP1581007A2 (en) * 2004-03-25 2005-09-28 Sony Corporation Image decoding
EP1987674A1 (en) * 2006-02-24 2008-11-05 Microsoft Corporation Accelerated video encoding
EP1987674A4 (en) * 2006-02-24 2012-08-08 Microsoft Corp Accelerated video encoding
US8654842B2 (en) 2006-02-24 2014-02-18 Microsoft Corporation Accelerated video encoding
US8953685B2 (en) 2007-12-10 2015-02-10 Qualcomm Incorporated Resource-adaptive video interpolation or extrapolation with motion level analysis
US9426414B2 (en) 2007-12-10 2016-08-23 Qualcomm Incorporated Reference selection for video interpolation or extrapolation
WO2009132140A1 (en) * 2008-04-23 2009-10-29 Qualcomm Incorporated Coordinating power management functions in a multi-media device
US8948822B2 (en) 2008-04-23 2015-02-03 Qualcomm Incorporated Coordinating power management functions in a multi-media device
US8908763B2 (en) 2008-06-25 2014-12-09 Qualcomm Incorporated Fragmented reference in temporal compression for video coding
WO2010022189A1 (en) * 2008-08-19 2010-02-25 Qualcomm Incorporated Power and computational load management techniques in video processing
US8948270B2 (en) 2008-08-19 2015-02-03 Qualcomm Incorporated Power and computational load management techniques in video processing
US8964828B2 (en) 2008-08-19 2015-02-24 Qualcomm Incorporated Power and computational load management techniques in video processing
US9462326B2 (en) 2008-08-19 2016-10-04 Qualcomm Incorporated Power and computational load management techniques in video processing
US9565467B2 (en) 2008-08-19 2017-02-07 Qualcomm Incorporated Power and computational load management techniques in video processing

Also Published As

Publication number Publication date
CN1265645C (en) 2006-07-19
EP1316218A2 (en) 2003-06-04
KR20020064893A (en) 2002-08-10
CN1394443A (en) 2003-01-29
WO2002019095A3 (en) 2002-06-13
JP2004507957A (en) 2004-03-11

Similar Documents

Publication Publication Date Title
US6704362B2 (en) Resource scalable decoding
EP1805995B1 (en) Method for generating multiple transcoded outputs based on a single video input
JP4344472B2 (en) Allocating computational resources to information stream decoder
JP4187405B2 (en) Object-based rate control apparatus and method in coding system
US6980695B2 (en) Rate allocation for mixed content video
JP4900976B2 (en) Method for switching compression level in an image streaming system, and system, server, and computer program
US8395634B2 (en) Method and apparatus for processing information
US20020059627A1 (en) Agent-enabled real-time quality of service system for audio-video media
JP2002517109A5 (en)
JP2015519016A (en) Encoding and reconstruction of residual quantity data based on support information
KR20010021879A (en) Apparatus and method for macroblock based rate control in a coding system
WO2002019095A2 (en) Method of running an algorithm and a scalable programmable processing device
US20040205217A1 (en) Method of running a media application and a media system with job control
US20160360231A1 (en) Efficient still image coding with video compression techniques
US20030058942A1 (en) Method of running an algorithm and a scalable programmable processing device
Bril et al. Multimedia QoS in consumer terminals
JP2004514352A (en) Dynamic adaptation of complexity in MPEG-2 scalable decoder
US20020129080A1 (en) Method of and system for running an algorithm
JP2007505545A (en) Scalable signal processing method and apparatus
Tagliasacchi et al. Minimum variance optimal rate allocation for multiplexed H. 264/AVC bitstreams
US10356439B2 (en) Flexible frame referencing for display transport
US6674800B1 (en) Method and system for utilizing a global optimal approach of scalable algorithms
JPH07303252A (en) Picture encoding/decoding method
Akramullah et al. Software-based H. 263 video encoder using a cluster of workstations
Carreira et al. 360° Video Coding using Adaptive Tile Partitioning

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A2

Designated state(s): CN IN JP KR

AL Designated countries for regional patents

Kind code of ref document: A2

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

ENP Entry into the national phase

Ref document number: 2002 523147

Country of ref document: JP

Kind code of ref document: A

WWE Wipo information: entry into national phase

Ref document number: 2001967293

Country of ref document: EP

Ref document number: 1020027005513

Country of ref document: KR

Ref document number: IN/PCT/2002/626/CHE

Country of ref document: IN

121 Ep: the epo has been informed by wipo that ep was designated in this application
AK Designated states

Kind code of ref document: A3

Designated state(s): CN IN JP KR

AL Designated countries for regional patents

Kind code of ref document: A3

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

WWE Wipo information: entry into national phase

Ref document number: 018032818

Country of ref document: CN

WWP Wipo information: published in national office

Ref document number: 1020027005513

Country of ref document: KR

WWP Wipo information: published in national office

Ref document number: 2001967293

Country of ref document: EP

WWW Wipo information: withdrawn in national office

Ref document number: 2001967293

Country of ref document: EP