[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

CN102693207B - Reconfigurable device and method, information processing apparatus, and control method therefor - Google Patents

Reconfigurable device and method, information processing apparatus, and control method therefor Download PDF

Info

Publication number
CN102693207B
CN102693207B CN201210027897.8A CN201210027897A CN102693207B CN 102693207 B CN102693207 B CN 102693207B CN 201210027897 A CN201210027897 A CN 201210027897A CN 102693207 B CN102693207 B CN 102693207B
Authority
CN
China
Prior art keywords
data flow
structural detail
distribution
configuration
change
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Fee Related
Application number
CN201210027897.8A
Other languages
Chinese (zh)
Other versions
CN102693207A (en
Inventor
谷内出悠介
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Canon Inc
Original Assignee
Canon Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Priority claimed from JP2011120990A external-priority patent/JP5798378B2/en
Priority claimed from JP2012003497A external-priority patent/JP5832311B2/en
Priority claimed from JP2012003035A external-priority patent/JP5907607B2/en
Application filed by Canon Inc filed Critical Canon Inc
Publication of CN102693207A publication Critical patent/CN102693207A/en
Application granted granted Critical
Publication of CN102693207B publication Critical patent/CN102693207B/en
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

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]
    • G06F9/5061Partitioning or combining of resources
    • G06F9/5066Algorithms for mapping a plurality of inter-dependent sub-tasks onto a plurality of physical CPUs
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2209/00Indexing scheme relating to G06F9/00
    • G06F2209/50Indexing scheme relating to G06F9/50
    • G06F2209/502Proximity

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Stored Programmes (AREA)
  • Logic Circuits (AREA)

Abstract

The invention relates to a reconfigurable device and method, an information processing apparatus and a control method therefor. According to the present invention, in changing the circuit configuration of a reconfigurable device, a circuit configuration change period is shortened while avoiding a dependency on processing contents without increasing the size of a circuit due to addition of a mechanism. Considering an execution order relation between a plurality of data flows, a setting change count necessary for changing the circuit configuration in changing processing is decreased within a constraint range, thereby shortening the circuit configuration change period.

Description

Reconfigurable device and method, messaging device and control method thereof
Technical field
The present invention relates to a kind of reconfigurable device, process distribution method, processing configuration method, messaging device and control method thereof.
Background technology
Traditionally, a kind of that comprise manufactured LSI circuit arrangement, the contents processing performed by this circuit can be changed by changing internal circuit configuration reconfigurable device is proposed.Due to the process of manufactured LSI circuit arrangement can be changed, thus again LSI need not be manufactured along with the change of specification.Due to manufacturing cost can be reduced or shorten the construction cycle, thus currently use this kind of reconfigurable device in various field.
Representational reconfigurable device is provided with many LUT (look-up table) perhaps multiprocessing element.Each element is all connected with the switching device of such as multiplexer etc.Note, the setting being used for making each structural detail of such as LUT, treatment element or switching device etc. carry out action is referred to as circuit structure information.Be used for the various methods of generative circuit structural information although exist, the many methods in these methods perform (1) in turn and are called as the step of the assignment of logical process of technology-mapped, (2) in each structural detail physically to processing the step that is configured and (3) carry out the step of route to each structural detail.By performing this three steps, final generative circuit structural information.
In logical process allocation step (1), structural detail is distributed in process.More specifically, when logical organization element being distributed in each process without the need to specifying when physical arrangement element.Change the index of operation as order, usually use the area of circuit, operating rate or power consumption.In configuration step (2), determine to perform the structural detail in physical allocation, the i.e. reconfigurable device of each process.According to the distance between the treatment element being configured with the process with data I/O relation, the change of the quantity of time delay (maximum operation frequency) switching device involved by data communication and obviously changing.For shortening time delay, usually importantly will there is the processing configuration of I/O relation in mutually close as far as possible treatment element.In routing step (3), determine route by the switching device of the data communication between the treatment element with data communication I/O relation.Due to compared with configuration step, carry out more detailed route, thus important determination route is to shorten the time delay between treatment element.
In recent years, along with the raising of degree of integration, the scale of executable process in reconfigurable device increases.In addition, the requirement of process itself is become complicated and accurate, therefore, may be difficult to once perform all process in a reconfigurable device.For solving this problem, there is a kind of method also performing process for the time-division in a reconfigurable device in turn.More specifically, the process expected is split, and generate the circuit structure information corresponding with the process after segmentation.After this, based on this circuit structure information, perform change operation and the process of the circuit structure of reconfigurable device in turn.This makes it possible in reconfigurable device, perform large-scale process.But when each change circuit structure, total processing time extends, and thus makes speed ability deterioration.When processing dividing number and being large, this also makes processing speed deterioration.
As the method for solving this problem, there is a kind of multi-context reconfigurable device (multicontext reconfigurable device).Context represents circuit structure information, and multi-context reconfigurable device represents the reconfigurable device of the storer be provided with for storing multiple circuit structure information.When changing circuit structure, reconfiguration device can be carried out by switchable memory, and high speed switching can be carried out, thus significantly shorten the reconstitution time of circuit.But owing to needing the annex memory of mounting circuit structural information, thus circuit scale becomes large.
For solving this problem, No. 3558119, Jap.P. proposes a kind of method based on skeleton circuit engineering (skeleton circuit technique) as the method for shortening reconstitution time.In the method, in reconfigurable device, generate the circuit structure information be called as based on priority circuit in advance.Note, represent that circuit structure information below, this circuit structure information comprise the common circuit part of all multiple circuit structure information commons and is not that multiple circuit shares and on reconfigurable device, do not share the non-exclusive independent circuit portions of circuit structure information based on priority circuit.By only carrying out partial reconfiguration to the difference of the circuit of reconfigurable device, construct the circuit needed for processing.Compared with multi-context type, owing to not needing the annex memory configured, thus the method can not increasing circuit scale.
Reconfigurable device can perform various types of purposes usually, and due to the difference of purposes, common ground is few.The quantity of the circuit structure information reconstructed changes according to purposes.Described in No. 3558119, Jap.P. based on priority circuit generate in, the quantity of or circuit structure information few at common ground greatly and when significantly exceeding the circuit scale of reconfigurable device, be difficult to the time period effectively shortened for changing circuit structure.
Summary of the invention
The present invention considers the problems referred to above and makes, and provides and effectively shorten reconfigurable device, process distribution method, processing configuration method, messaging device and the control method thereof that circuit changes the time period by considering circuit structure change order when not increasing circuit scale.
According to a first aspect of the invention, a kind of process distribution method is provided, for for the reconfigurable device comprising multiple structural detail, to each structural detail allocation process, described process distribution method comprises the following steps: data flow input step, for inputting the execution sequence of at least two different data flows and data flow; Constraint step, for inputting the constraint of described structural detail; And process distributes determining step, for determining that process distributes, changing counting diminish to make being reconstructed required arranging based on the constraint of described structural detail and described execution sequence to described structural detail.
According to a second aspect of the invention, a kind of reconfigurable device is provided, it comprises multiple structural details that the process being used for realizing data flow can be dispensed to, described reconfigurable device also comprises: data flow input block, for inputting the execution sequence of at least two different data flows and data flow; Constraint input block, for inputting the constraint of described structural detail; And process distributes determining unit, for determining that process distributes, changing counting diminish to make being reconstructed required arranging based on the constraint of described structural detail and described execution sequence to described structural detail.
According to a third aspect of the invention we, a kind of messaging device is provided, it comprises multiple structural details that the process being used for realizing data flow can be dispensed to, described messaging device also comprises: input block, for inputting for being realized the configuration information of the first data flow and the configuration information of described multiple structural detail by described multiple structural detail; And controller, for based on described configuration information and described configuration information, described multiple structural detail is distributed in the process being used for realizing described first data flow, with make and for realize the second data flow setting between to carry out the structural detail changed quantity diminish.
According to a forth aspect of the invention, a kind of control method of messaging device is provided, multiple structural details that described messaging device comprises input block, controller and the process being used for realizing data flow can be dispensed to, described control method comprises the following steps: input step, for inputting for being realized the configuration information of the first data flow and the configuration information of described multiple structural detail by described multiple structural detail; And rate-determining steps, for based on described configuration information and described configuration information, described multiple structural detail is distributed in the process being used for realizing described first data flow, with make and for realize the second data flow setting between to carry out the structural detail changed quantity diminish.
According to a fifth aspect of the invention, a kind of processing configuration method is provided, for for the reconfigurable device comprising multiple structural detail, determine the structural detail of each process performing data flow, described processing configuration method comprises the following steps: input step, for inputting the processing sequence of at least two different data flows and data flow; Constraint step, for inputting the constraint of the described structural detail of described reconfigurable device; And determining step, for by use according to described data flow be reconstructed required arrange change counting and based on the dependence of the data I/O of described data flow each structural detail between distance determine the configuration of described structural detail, thus determine the structural detail performing required process.
According to a sixth aspect of the invention, provide a kind of reconfigurable device, for carrying out work based on the configuration information generated according to above-mentioned processing configuration method.
According to the present invention, can by generative circuit structural information to reduce the quantity of setting needed for reconstruct, when can not increasing circuit scale, the reconstitution time section of shortening reconfigurable device.
By following (with reference to the accompanying drawing) explanation to exemplary embodiments, further feature of the present invention will become obvious.
Accompanying drawing explanation
Fig. 1 is the figure of the example of the structure that the treatment facility comprising reconfigurable device is shown;
Fig. 2 is the figure of the example of the structure that reconfigurable device is shown;
Fig. 3 be reconfigurable device is shown element between the figure of example of data communication process;
Fig. 4 is the figure of the example of the structure that treatment element is shown;
Fig. 5 is the figure of the example of the form that configuration order is shown;
Fig. 6 is the figure of the overview that the setting be stored in the config memory for the treatment of element is shown;
Fig. 7 is the process flow diagram of the process illustrated for reading/writing setting;
Fig. 8 is the figure of the example of the structure that switching device is shown;
Fig. 9 is the figure of the overview that the setting be stored in the config memory of switching device is shown;
Figure 10 is the sequential chart performed in turn that multiple data flow is shown;
Figure 11 is the figure that the overview that process distributes is shown;
Figure 12 is the figure of the overview of the process distribution for performing data flow illustrated according to the first embodiment;
Figure 13 illustrates the process flow diagram for performing the process that process distributes according to the first embodiment;
Figure 14 is the figure of the overview of the process distribution for performing data flow illustrated according to the second embodiment;
Figure 15 is the figure of the overview of the process distribution for performing data flow illustrated according to the 3rd embodiment;
Figure 16 is the figure of the overview of the process distribution for performing data flow illustrated according to the 4th embodiment;
Figure 17 is the figure of the configuration example of the process illustrated according to the data flow in the treatment element of the 5th embodiment;
Figure 18 is the figure of the example model of the processing element array for the treatment of configuration illustrated according to the 5th embodiment;
Figure 19 is the figure of the overview of the processing configuration for performing multiple data flow illustrated according to the 5th embodiment;
Figure 20 is the process flow diagram of the process for performing processing configuration illustrated according to the 5th embodiment;
Figure 21 is the figure of the overview of the processing configuration for performing data flow illustrated according to the 6th embodiment;
Figure 22 is the figure of the overview of the processing configuration for performing data flow illustrated according to the 7th embodiment;
Figure 23 is the figure of the overview of the processing configuration for performing data flow illustrated according to the 8th embodiment;
Figure 24 is the figure of the overview of the process configurable range for restricting data flow process illustrated according to the 9th embodiment; And
Figure 25 is the block diagram of the structure of the equipment illustrated for creating circuit structure information.
Embodiment
Describe application the preferred embodiments of the present invention below with reference to the accompanying drawings in detail.
Fig. 1 illustrates the figure with the example of the general structure of the system of reconfigurable device according to the embodiment of the present invention.Circuit structure information 106 remains on wherein by external memory storage 101.Circuit structure information 106 comprises one group of setting for making the element of reconfigurable device 105 carry out action.Configuration Control Unit 102 via connecting line 104 from storer 101 acquisition cuicuit structural information 106.Via connecting line 103, obtained circuit structure information 106 is sent to reconfigurable device 105.Note, as the example of reconfigurable device 105, show processing element array.
The inside of processing element array will be described in detail below.But the present invention is not limited to the following structure of each treatment element or following routing infrastructure.
Fig. 2 illustrates the figure being used as the overview of the processing element array of reconfigurable device 105 according to the present embodiment.In reconfigurable device 105, with two-dimensional grid pattern arrangement separately as the switching device 201 with 8 inputs and 8 I/O processing element exported, and configure in the grid of switching device 201 separately as the treatment element 202 with 4 inputs and 4 computing parts exported.In switching device 201a ~ 201i separately 8 input and 8 outputs, by connecting line 203a and 203b, four groups of respective inputs and one are exported and is connected with other four switching devices 201 on east, west, Nan Hebei (right side, a left side, lower and upper) direction respectively.In addition, by connecting line 204a and 204b, other four groups respective inputs and an output are bi-directionally connected with northeast, the southeast, southwest and northwest other four treatment elements 202 upwards respectively.Switching device 201a ~ 201i and treatment element 202a ~ 202d is connected in series in one direction by connecting line 205.
Connecting line 203a, 203b, 204a are connected with 204b, to communicate to data to be processed between switching device 201 and treatment element 202.Connecting line 205 is used to provide setting to switching device 201 and treatment element 202.Arrange based on these, switching device 201 determines the input and output destination of data to be processed, and treatment element 202 determines contents processing and the input and output destination of data to be processed.Note, the direction of connecting line 203a, 203b, 204a, 204b in Fig. 2 and 205 respective arrows represents the direction of data.Switching device 201a ~ 201i has identical structure, and treatment element 202a ~ 202d has identical structure.
Fig. 3 illustrates the example using the TW two wire Handshake Protocol of useful signal and standby ready signal as connecting line 203a, 203b, 204a, 204b and 205 respective communication protocols.With reference to figure 3, between the modules A 301 as sender side and the module B 302 as receiver-side, be connected with data signal line 303, useful signal line 304 and standby ready signal line 305.Sender side uses useful signal, to represent transmission enable state via useful signal line 304 for receiver-side.Receiver-side uses standby ready signal, to represent data receiver enable state via standby ready signal line 305 for sender side.In this agreement, the useful signal line 304 of modules A 301 and module B302 both standby ready signal lines 305 effectively time the rising edge place of clock, the data of data signal line 303 are sent to module B302 from modules A 301.In the waveform shown in Fig. 3, respectively the moment 306a, 306b, 306c and 306d data A, B, C and D are sent to module B302 from modules A 301.
Fig. 4 illustrates the structure for the treatment of element 202.Treatment element 202 comprises dispensing unit 401, input block 402, computing unit 403, output unit 404 and temporary buffer 405.
The setting of dispensing unit 401 to the content of operation for determining treatment element 202 manages.Input block 402 arranges execution input processing based on dispensing unit 401.Computing unit 403 arranges execution computing based on dispensing unit 401.In addition, result can remain in temporary buffer 405 by computing unit 403, again to input to computing unit 403.Output unit 404 arranges execution output processing based on dispensing unit 401.
The operation for the treatment of element 202 will be illustrated in greater detail below.Input block 402 to be obtained from dispensing unit 401 by connecting line 406 and inputs the setting of destination for determining.Arranging of obtaining specifies the module be connected with outside to carry out the input port that will use that communicates.Based on this information, obtain data to be processed by connecting line 204a-ne, 204a-se, 204a-sw or 204a-nw.Note, Reference numeral ne, se, sw and nw represent all directions respectively.Connecting line 204a-ne is connected with the switching device that northeastward configures.Connecting line 204a-se is connected with the switching device configured in southeastern direction.Connecting line 204a-sw is connected with the switching device that southwestward configures.The switching device that connecting line 204a-nw and northwest upwards configure is connected.By connecting line 409, obtained data are sent to computing unit 403.
Computing unit 403 obtains setting for determining contents processing by connecting line 407 from dispensing unit 401.Based on obtained setting, computing unit 403 obtains the data sent from input block 402, and the process set by performing.Then, the data after process are sent to output unit 404 by connecting line 410 by computing unit 403.
Computing unit 403 has at least one calculating unit.Calculating unit comprises such as the calculating unit of such as addition/subtraction parts, comparer, multiplier, divider or logical calculated parts etc., the combination of these parts or the combination of these parts and other calculating unit.Assuming that as concrete instance, computing unit 403 can perform sum computing and comparison operation, and optionally can perform one of them process in a computing.In sum computing, unit 403 calculates ab+cd.In comparison operation, if a > is b, then unit 403 exports c; Otherwise unit 403 exports d.Also computing unit 403 is configured to reuse calculating unit for an input.When reusing calculating unit, by connecting line 412, the result used in calculating unit being kept in temporary buffer temporarily, then by connecting line 411, it being inputed to computing unit 403 again.Unit 403 performs process to the data again inputted in calculating unit.As will be described in detail after a while, above-mentioned setting will specify the type of computing, re-treatment and each value referenced by variable a, b, c and d needed for process or variable a, b, c and d value when it is fixed value.
Output unit 404 obtains the setting of the output destination of the data after representing process by connecting line 408.The appointment that arranges obtained carries out with switching device the output port that will use that communicates.Based on this information, by connecting line 204b-ne, 204b-se, 204b-sw or 204b-nw, data are exported to switching device.Note, connecting line 204b-ne is connected with the switching device that northeastward configures.Connecting line 204b-se is connected with the switching device that southeastern direction configures.Connecting line 204b-sw is connected with the switching device that southwestward configures.The switching device that connecting line 204b-nw and northwest upwards configure is connected.
Then the operation of dispensing unit 401 will be described.Dispensing unit 401 keeps unique ID of each treatment element 202.Dispensing unit obtains the setting sent from the connecting line 205 of input side, processes in self to these settings, and exports these settings by the connecting line 205 of outgoing side.Dispensing unit 401 has the config memory 413 for storing the setting corresponding with the ID of himself.
Fig. 5 illustrates and is sent to dispensing unit/from the configuration order 501 of the setting received by dispensing unit.Configuration order 501 comprises reading/WriteMode 502, ID503, configuration address 504 and settings 505.Reading/WriteMode 502 is signals of the reading/writing process for determining configuration order.ID503 is the signal for determining treatment element 202 to be processed.Configuration address 504 is the signals of the address be used to specify in the storer of the setting keeping dispensing unit 401.Settings 505 are the signals representing actual settings.Bit width M, N, O and the P in Fig. 5 is determined based on practical basis framework.
Setting based on said structure will be illustrated in greater detail below.With reference to figure 6, Reference numeral 601 represents the address of the config memory 413 corresponding with the address specified by the configuration address 504 of Fig. 5.Reference numeral 602 represents the actual settings corresponding with the settings 505 of Fig. 5.In the present embodiment, each value is all called setting.But the present invention is not limited to said units.In figure 6, the setting be associated with input block 402, computing unit 403 and output unit 404 is remained in config memory 413.
Use the settings at address 0x0000_0000 (" 0x " represents sexadecimal number) place to determine the input destination of input block 402, and determine predetermined input destination based on this value.The iterations at use 0x0000_0004 place, address determines the calculating iteration count in computing unit 403, and determines to calculate iteration count based on this value.In the present embodiment, assuming that nearly calculate for four times.
Use the operation setting at 0x0000_0008 place, address to determine the type of the computing performed in first time calculating, and judge perform sum computing or perform comparison operation based on this value.
The variable set up at 0x0000_000c place, address is used to determine the reference destination of the value of the variable a in first time calculating.The example of reference destination comprises the value of the temporary buffer from the fixed value kept in the input value of input port, config memory 413 and the result of calculation before keeping.According to the value at this address place, in these values is inputed to variable a.Be similar to address 0x0000_000c, use the variable set up at 0x0000_0010,0x0000_0014 and 0x0000_0018 place, address to determine the reference destination of the value of variable b, c and d in first time calculating respectively.In calculating in first time, when the reference destination that 0x0000_000c place, address specifies is fixed value, the parameter at 0x0000_001c place, address has the fixed value for variable a.Be similar to address 0x0000_001c, in first time calculates, for variable b, c and d, use the fixed value at 0x0000_0020,0x0000_0024 and 0x0000_0028 place, address.
Be similar to 0x0000_0008 ~ 0x0000_0028 place, address and calculate with first time the setting be associated, the value at 0x0000_002c ~ 0x0000_0094 place, address represents second time calculating, third time calculating and the settings in calculating for the 4th time respectively.Finally, the output selective value at 0x0000_0098 place, address is the settings of the output destination for determining output unit 404, and determines predetermined output destination based on this value.
Fig. 7 illustrates the processing procedure performed in dispensing unit.In step S701, input configuration order 501.In step S702, dispensing unit 401 judges that whether the ID503 specified by configuration order 501 inputted is consistent with the ID of itself.If in step S702, unit 401 is judged as that ID503 and the ID of self is inconsistent, then the configuration order 501 of input is exported when not performing any process in step S711 and S712; Otherwise in step S703, unit 401 judges whether the value of reading/WriteMode 502 represents read mode.If this value does not represent read mode, then in step S707, unit 401 judges whether this value represents WriteMode.If all do not represent this two patterns, then unit 401 exports order 501 in step S711 and S712 when not performing any process.If be judged as that this value represents read mode, then unit 401 reads the data specified by configuration address 504 in step S704 from config memory 413.Then, the data read write in the settings 505 of the configuration order 501 of input in step S705 by unit 401, and export configuration order 501 in step S706.If be judged as that this value represents WriteMode, then the settings 505 of the configuration order 501 of input write in the config memory 413 specified by configuration address 504 in step S708 by unit 401.Unit 401 does not change the value of the configuration order 501 of input in step S709, and exports this configuration order in step S710 former state.Settings 505 can be changed for a configuration order.By sending configuration order in turn, and changing the settings be necessary, achieving the process of expectation.That is, the switching time of contents processing is determined based on the quantity arranged.
Fig. 8 illustrates the structure of switching device 201.Switching device 201 comprises dispensing unit 801 and cross bar switch 802.Dispensing unit 801 is to for determining that the settings of the connection destination that data are sent to manage.Cross bar switch 802, based on the setting of dispensing unit 801, connects input and output with one-to-one relationship.Be similar to the dispensing unit 401 for the treatment of element 202, dispensing unit 801 keeps unique ID of each switching device 201.Dispensing unit 801 obtains the settings sent from the connecting line 205 of input side, in dispensing unit, perform process, and exports settings by the connecting line 205 of outgoing side.Obtained setting remains in config memory 804 by dispensing unit 801.The configuration order of dispensing unit 801 is identical with processing procedure with the configuration order shown in Fig. 5 with 7 respectively with processing procedure.Cross bar switch 802 obtains setting for determining data input and output destination by connecting line 803 from dispensing unit 801.Switching device 201, based on obtained settings, obtains data by connecting line 203a-w, 203a-s, 203b-e, 203b-n, 204b-ne, 204b-se, 204b-sw or 204b-nw.Pass through connected connecting line 203a-e, 203a-n, 203b-w, 203b-s, 204a-ne, 204a-se, 204a-sw or 204a-nw and transmit the data obtained.
Note, connecting line 203a-w and 203a-s represents and the connecting line of west to the switching device upwards configured with south respectively.Connecting line 203b-e and 203b-n represents and the connecting line of east to the switching device upwards configured with the north respectively.
Connecting line 203a-e and 203a-n represents and the connecting line of east to the switching device upwards configured with the north respectively.Connecting line 203b-w and 203b-s represents and the connecting line of west to the switching device upwards configured with south respectively.
Connecting line 204a-ne, 204a-se, 204a-sw and 204a-nw represent the connecting line of the treatment element upwards configured with northeastward, southeastern direction, southwestward and northwest respectively.Connecting line 204b-ne, 204b-se, 204b-sw and 204b-nw represent the connecting line of the treatment element upwards configured with northeastward, southeastern direction, southwestward and northwest respectively.
Fig. 9 illustrates setting that keep in config memory 804, that be associated with the connecting line of the I/O of the cross bar switch 802 of switching device 201.Reference numeral 901 represents the storage address corresponding with the address specified by the configuration address 504 of Fig. 5; And Reference numeral 902 represents the settings corresponding with the settings 505 of Fig. 5.The connection at 0x0000_0000 place, address arranges the settings had for determining connecting line 203a-e, 203a-n, 203b-w, 203b-s, 204a-ne, 204a-se, 204a-sw or 204a-nw of being output to from the input of connecting line 203a-w.Be similar to address 0x0000_0000, use the settings at 0x0000_0004 place, address to determine the connecting line be output to from the input of connecting line 203a-s.Be similar to address 0x0000_0000, use the settings at 0x0000_0008 place, address to determine the connecting line be output to from the input of connecting line 203b-e.Be similar to address 0x0000_0000, use the settings at 0x0000_000c place, address to determine the connecting line be output to from the input of connecting line 203b-n.Be similar to address 0x0000_0000, use the settings at 0x0000_0010 place, address to determine the connecting line be output to from the input of connecting line 204b-ne.Be similar to address 0x0000_0000, use the settings at 0x0000_0014 place, address to determine the connecting line be output to from the input of connecting line 204b-se.Be similar to address 0x0000_0000, use the settings at 0x0000_0018 place, address to determine the connecting line be output to from the input of connecting line 204b-sw.Be similar to address 0x0000_0000, use the settings at 0x0000_001c place, address to determine the connecting line be output to from the input of connecting line 204b-nw.
Figure 10 illustrates that the structure for the multiple types by changing above-mentioned reconfigurable device realizes the sequential chart of expectation process.Figure 10 is the sequential chart that a reconfigurable device performs multiple different data flow A ~ Z in turn.In the present embodiment, execution data flow inputs the execution sequence with input traffic journey and data flow.Primary distribution can constitute the data flow processed in the present embodiment to the process unit of reconfigurable device.Generate the setting for the treatment of each data flow in advance.Reconfigurable device is reconstructed based on arranging of generating in advance for self, and utilize this structure to perform process.With the execution sequence expected to these process of data flow performing.
Tentation data flow process A have passed through process and distributes, and data flow B is process distribution object.More specifically, with reference to for performing the settings that have passed through the data flow A that process distributes, then determine that the process of data flow B distributes.After the process by reference to data flow A distributes and determines the process distribution of data flow B, think that data flow B have passed through process and distributes, and data flow C becomes process distribution object.More specifically, the determination that the process being similar to data flow B distributes, with reference to for performing the settings that have passed through the data flow B that process distributes, then determines that the process of data flow C distributes.Repeat said process, make it possible to that process is performed to data flow A ~ Z and distribute.
The distribution of the process of data flow to the treatment element of reconfigurable device is described.The process of data flow illustrates the method for each processing logic of data flow being distributed to treatment element to the distribution for the treatment of element.More specifically, as shown in figure 11, determine the treatment element performing the contents processing corresponding with each node 1105 of data flow, and determine execution sequence.In the left side of Figure 11, data flow A is shown.Illustrate that in the centre of Figure 11 process distributes example.On the right side of Figure 11, the setting shown in the Fig. 6 distributed based on process is shown.As mentioned above, as the function of the treatment element described in the present embodiment, assume process iteration count, each contents processing of process and the fixed value needed for contents processing, and determine that these are arranged practically.Assuming that maximum process iteration count is 4 in the present embodiment.Group 1101a ~ 1104a is distributed to different treatment elements 202 respectively in order.Based on group 1101a ~ 1104a, that determines treatment element 202-1 ~ 202-4 respectively arranges 1101b ~ 1104b.
According to the present invention, provide the process distribution method for reducing the quantity in the setting shown in required time hand-off process content (data flow) in a reconfigurable device, Figure 11 as shown in Figure 10.Figure 12 illustrates the overview arranging change of the treatment element 202-1 ~ 202-4 when the process in reconfigurable device is switched to data flow B from data flow A.The process of tentation data flow process 1204 corresponds to the process 1201 in sequential chart, and has distributed this process.Also the process of tentation data flow process 1205 corresponds to the process 1203 in sequential chart, and data flow 1205 is process distribution objects.The treatment element that data flow 1204 is identical with on treatment element 202-1 ~ 202-4 presentation logic of being assigned to of process of 1205.In the process of data flow A, 1101b ~ 1104b is set and is associated with treatment element 202-1 ~ 202-4 respectively.In the process of data flow B, arrange 1206 ~ 1209 and be associated with treatment element 202-1 ~ 202-4 respectively.In treatment element 202-1, change during the time period 1202 the arranging from data flow A to data flow B of this sequential chart, carry out from arrange 1101b to arrange 1206 change 1210 is set.In treatment element 202-2, change during the time period 1202 the arranging from data flow A to data flow B of this sequential chart, carry out from arrange 1102b to arrange 1207 change 1211 is set.In treatment element 202-3, change during the time period 1202 the arranging from data flow A to data flow B of this sequential chart, carry out from arrange 1103b to arrange 1208 change 1212 is set.In treatment element 202-4, change during the time period 1202 the arranging from data flow A to data flow B of sequential chart, carry out from arrange 1104b to arrange 1209 change 1213 is set.In the present embodiment, for the process performed for data flow B distributes, with reference to the data flow A that the process that have passed through in treatment element 202-1 ~ 202-4 distributes.Then, carry out the change that arranges arranged needed for change 1210,1211,1212 and 1213 be counted as object to reduce, process is performed for data flow B and distributes.
Figure 25 is the block diagram of the structure of the equipment illustrated for the generative circuit structural information 106 when data flow A being transformed into data flow B.With reference to Figure 25, Reference numeral 2501 represents the CPU of overall opertaing device; Reference numeral 2502 represents the ROM for storing boot and BIOS; Reference numeral 2503 represents the RAM for storing OS (operating system) and application program of the workspace being used as CPU2501; And Reference numeral 2504 represents for storing OS, hard disk drive (HDD) for the application program and various types of data that create circuit structure information 106.Keyboard 2505 and mouse 2506 are used as user interface separately.Reference numeral 2507 represents the display controller comprising video memory and display controller; And Reference numeral 2508 represents vision signal for receiving from display controller 2507 and carries out the display device that shows.Reference numeral 2509 represents the interface being used for carrying out with various types of external device (ED) communicating.Such as, if interface 2509 is connected with the external memory storage 101 shown in Fig. 1, then the circuit structure information 106 created by this equipment can be write in external memory storage 101.
When connection has the power supply of the equipment of said structure, CPU2501 performs the boot be stored in ROM2502, the OS be stored in HDD2504 is loaded into RAM, then start the application program for creating circuit structure information 106, thus make this equipment be used as circuit structure information creating device.
The processing procedure of the equipment as circuit structure information creating device is described below with reference to the process flow diagram shown in Figure 13.Although this process is the example of the process distribution method based on simulated annealing, the present invention is not limited to this.The approximate solution of such as genetic algorithm etc. and various numerical optimization method can be used.
With reference to Figure 12, the element for explaining needed for this process flow diagram is described.Assuming that i is the index representing each data flow, j is the index for the treatment of element, and k is the configuration address of the storer in the treatment element corresponding with the address 601 of Fig. 6.Then, u i, j, krepresent the settings in each storer.Tentation data flow process i0 have passed through process and distributes, and data flow i1 is process distribution object.In step S1301, input multiple data flow and their execution sequence relation (order of i).For the data flow that have passed through process distribution, same its settings u of input i0, j, k.In the present embodiment, data flow 1204 have passed through process and has distributed, and the settings be associated with data flow 1204 in the storer of each treatment element are fixed values.Data flow 1205 is process distribution objects.
In step S1302, the required specification of input and hardware constraints.Hardware constraints comprises the constraint of the hardware configuration of the type of accessible process iteration count and computing unit in the quantity of the treatment element in such as reconfigurable device, treatment element etc.What required specification comprised the type of the quantity of the treatment element such as used, process iteration count and spendable computing unit etc. should restricted item in hardware uses.Constraint also comprises: do not have contradiction and do not have deadlock in the ordinal relation between the input and output of process.For the data flow that have passed through process distribution, constraint comprises not changing to process and distributes.Note, the present invention is not limited to above-mentioned constraint.
In step S1303, process is performed for the data flow as process distribution object and distributes.As initial treatment distribution method, use and be used for the method for Random assignment process or the method for the depth direction order-assigned process according to data flow.But the present invention is not limited to this.Except in original allocation, also change process based on simulated annealing and distribute, thus Stochastic choice and exchange two configuration.In the present embodiment, initial treatment is performed for the data flow 1205 as process distribution object to distribute or process distribution change.For the data flow that have passed through process distribution, do not carry out process according to constraint and distribute change.
In step S1304, judge to process the required specification whether allocation result meets step S1302 input.
As shown in following equation (1), if meet constraint, then at punishment variable p 0in arrange 0; Otherwise, at punishment variable p 0in penalty value C is set p0.
Punishment variable
In the present embodiment, when violating constraint, by C p0be set to identical constant.But, C p0it can be the variate-value according to violating item.In step S1305, judge whether process allocation result meets the hardware constraints that step S1302 inputs.As shown in following equation (2), if meet constraint, then at punishment variable P 1in arrange 0; Otherwise, at punishment variable P 1in penalty value C is set p1.
Punishment variable
In the present embodiment, when violating constraint, by C p1be set to identical constant.But, C p1it can be the variate-value according to violating item.In step S1306, arranging when calculating object data flow changes changes counting, thus Calculation Estimation value.With reference to the example of Figure 12, evaluation of estimate represents in the quantity arranging in change 1210,1211,1212 and 1213 setting needing change.More specifically, if having passed through the settings u in the data flow i0 of process distribution i0, j, kbe not equal to the settings u as the identical address place in the data flow i1 of process distribution object i1, j, k, then by α 1be added to arrange and change counting; Otherwise, do not perform additive operation.All storer k for all treatment element j perform above-mentioned calculating.Above-mentioned setting can be provided by following equation and change counting.
Wherein, α 1normally 1.But, can change according to the structure of the config memory for the treatment of element the weight that stored each address is set.Can also assign weight for each data flow, to distribute the priority of switching time for each data flow.
As shown in Figure 7, settings can be changed for a configuration order.Therefore, if the quantity of order reduces, then the switching time of contents processing can be shortened.Based on above-mentioned equation, provided the equation for Calculation Estimation value in this step by following equation.
Evaluation of estimate=s+p0+p1 ... (4)
That is, when meeting required specification and hardware constraints, counting less owing to reconstructing the required change that arranges, thus going up evaluation values and become less.Finally, judge whether to reach target based on simulated annealing in step S1307.If the target of reaching, then terminate this process; Otherwise process turns back to step S1303 to repeat step S1303 ~ S1307.This means to repeat this process until obtain very good result or pass by predetermined computing time.
As a result, generative circuit structural information 106 in HDD2504.Therefore, only need this information to be write in the external memory storage 101 that will use via interface 2509, and this memory device is fitted on commodity.
Note, this example demonstrates external unit (Figure 25) and create the situation of circuit structure information 106.This is applicable to following other embodiments all.Configuration Control Unit 102 can perform the process shown in Figure 13, and creates circuit structure information 106.Such as, external memory storage 101 keeps the setting of each data flow in multiple data flow (quantity of required processor and the process parameter of each processor), and Configuration Control Unit 102 creates circuit structure information 106 based on arranging of multiple data flow.This is equally applicable to following other embodiments all.
Due to not considering to arrange for the method process of data flow being dispensed to treatment element and change counting in general reconfigurable device, thus need to change all settings when the process of data flow changes.The present invention has paid close attention to the processing sequence of data flow, and reduces total change counting of the level that arranges as least unit, thus makes it possible to effectively reduce to arrange change counting.
second embodiment
The second embodiment of the present invention will be described.Figure 14 illustrates the overview of distributing according to sequential chart and the process of the process of the second embodiment.Process when the present embodiment relates to below distributes: when by change reconfigurable device the process performing multiple data flow is set time, determine the contents processing of each data flow, but the execution sequence of data flow is uncertain, and this execution sequence changes according to situation or input data.More specifically, Figure 14 assumes situation below: as shown in sequential chart 1401, and the execution sequence of the process performed by reconfigurable device is not constant, but changes according to result or state.
During the time period 1402 of sequential chart 1401, perform the process be associated with data flow A.During the time period 1404 and 1408, perform the process be associated with data flow C.During the time period 1406, perform the process be associated with data flow B.During the time period 1403, carry out arranging change from data flow A to data flow C.During the time period 1405, carry out arranging change from data flow C to data flow B.During the time period 1407, carry out arranging change from data flow B to data flow C.In the present embodiment, the execution sequence due to data flow A, B and C is not constant, and thus to need to consider between data flow all arranges change to perform process and distribute.All data flow A, B and C are process distribution objects.
In fig. 14, Reference numeral 1409,1410 and 1411 represent respectively for data flow A, B and C PE202-1 ~ 202-4 example is set, and for all data flow A, B and C once seek unity of action process distribute.As in the first embodiment, example 1409,1410 and 1411 is set and corresponds to the setting shown in Fig. 6.Always arranging needed for the second embodiment data flow paid close attention in PE202-1 ~ 202-4 between data flow A and B, B and C and C and A changes changes counting.By calculating tale as evaluation of estimate, reducing arranging when reconfigurable device is reconstructed and changing counting.
Note, Reference numeral 1412,1415,1418 and 1421 represents that PE202-1 ~ 202-4's between data flow A and B arranges change respectively.Reference numeral 1413,1416,1419 and 1422 represents that PE202-1 ~ 202-4's between data flow B and C arranges change respectively.Reference numeral 1414,1417,1420 and 1423 represents that PE202-1 ~ 202-4's between data flow C and A arranges change respectively.
The difference of the second embodiment and the first embodiment is: perform to process for multiple data flow simultaneously and distribute.At the step S1301 of Figure 13, input multiple data flow, and input represents that execution sequence is arbitrary information.
The process all data flows 1409,1410 and 1411 as process distribution object being performed to the step S1303 of Figure 13 distributes.What the step S 1306 for Figure 13 used arranges change counting, compared with the first embodiment, exists following different.
If as the settings u in the data flow i0 of process distribution object i0, j, kbe not equal to the settings u as the identical address place in the data flow i1 of process distribution object i1, j, k, then by α 2be added to arrange and change counting.If as the settings u in the data flow i1 of process distribution object i1, j, kbe not equal to the settings u as the identical address place in the data flow i2 of process distribution object i2, j, k, then by β 2be added to arrange and change counting.In addition, if as the settings u in the data flow i2 of process distribution object i2, j, kbe not equal to the settings u as the identical address place in the data flow i0 of process distribution object i0, j, k, then by γ 2be added to arrange and change counting.Alternatively, if these settings are equal to each other, then additive operation is not performed.As shown in following equation (5), all storer k for all treatment element j perform above-mentioned calculating.
Wherein, i0 represents data flow A1409, and i1 represents data flow B1410, and i2 represents data flow C1411.Determine settings u i0, j, k, u i1, j, kand u i2, j, k, diminish to make the value represented by above-mentioned equation.In addition, α 2, β 2and γ 2be generally 1.But, can change according to the structure of the config memory for the treatment of element the weight that stored each address is set.Can also assign weight for each data flow, to distribute the priority of switching time for each data flow.
According to the second embodiment, by considering all data flows, following effect can be obtained: even if processing execution order is uncertain, also reducing to arrange to change counting fifty-fifty.
3rd embodiment
Then the third embodiment of the present invention is described.Figure 15 illustrates the overview of distributing according to sequential chart and the process of the process of the 3rd embodiment.3rd embodiment assumes following situation: the execution sequence of multiple data flow and the process of each data flow distribute to be determined.The present embodiment relates to the process of inserting the process corresponding with new data flow process between the process for the arbitrary data flow process when not changing the process before and after inserting and distributing, in above-mentioned execution sequence and distributes.
For the sequential chart 1501 shown in Figure 15, the execution sequence in reconfigurable device and process distribution are determined.In sequential chart 1501, after the process 1503 of data flow A, insert the time period 1504 setting of data flow A being changed over the setting of data flow C, then perform the process 1505 of data flow C.Sequential chart 1502 is obtained by data inserting flow process B new between data flow A and C of sequential chart 1501.After the process 1503 of data flow A, insert the time period 1506 setting of data flow A being changed over the setting of data flow B, then perform the process 1507 of the new data flow B inserted.Then, after the time period 1508 of the setting setting of data flow B being changed over data flow C, perform the process 1505 of data flow C.Owing to now determining when the process not changing data flow A and C distributes that the process of data flow B distributes, thus consider with insert before and after have passed through between the data flow that processes and distribute, knots modification is set.
At Figure 15, Reference numeral 1509,1510 and 1511 represents the setting of the PE202-1 ~ 202-4 of data flow A, B and C respectively.In the present embodiment, data flow A and C have passed through process and distributes, and will perform process distribution to data flow B.As in the first embodiment, arrange 1509,1510 and 1511 and correspond to the setting shown in Fig. 6.More specifically, in the third embodiment, the process determining data flow A and C distributes, and will perform process distribution to data flow B.
Now, pay close attention to from data flow A to data flow B and from data flow B to the PE202-1 ~ 202-4 of data flow C arrange needed for change always arranging change counting.By calculate tale as Figure 13 of the first embodiment Reference numeral S1306 represented by evaluation of estimate, reduce when reconfigurable device is reconstructed arranging change counting.
Note, Reference numeral 1512,1514,1516 and 1518 represents that PE202-1 ~ 202-4's between data flow A and B arranges change respectively.Reference numeral 1513,1515,1517 and 1519 represents that PE202-1 ~ 202-4's between data flow B and C arranges change respectively.3rd embodiment is from the different of the first embodiment: distribute, simultaneously with reference to other data flows multiple that have passed through process distribution for performing the process being used for a data flow.
Process data flow 1510 as process distribution object being performed to the step S1303 of Figure 13 distributes.Data flow 1509 and 1511 have passed through process and distributes, and does not carry out process distribution change.What the step S1306 for Figure 13 used arranges change counting, compared with the first embodiment, exists following different.
If have passed through the settings u of the data flow i0 that process distributes i0, j, kbe not equal to the settings u at the identical address place of the data flow i1 as process distribution object i1, j, k, then by α 3be added to arrange and change counting.If the settings u of the data flow i1 as process distribution object i1, j, kbe not equal to the settings u at the identical address place that have passed through the data flow i2 that process distributes i2, j, k, then by β 3be added to arrange and change counting.If these settings are equal to each other, then do not perform additive operation.All storer k for treatment element j perform above-mentioned calculating.Can represent that above-mentioned setting changes counting by following equation.
...(6)
Wherein, i0 represents data flow A1509, and i1 represents data flow B1510, and i2 represents data flow C1511.In these settings, settings u i0, j, kand u i2, j, khave passed through process to distribute, and to settings u i1, j, kdetermine, diminish to make the value represented by above-mentioned equation.In addition, α 3and β 3be generally 1.But, can change according to the structure of the config memory for the treatment of element the weight that stored each address is set.Can also assign weight for each data flow, to distribute the priority of switching time for each data flow.If insert new data flow process, then can obtain following effect: reduce and change counting relative to arranging of the data flow inserting front and back.
4th embodiment
The fourth embodiment of the present invention will be described.Figure 16 illustrates the overview of distributing according to sequential chart and the process of the process of the 4th embodiment.The process that 4th embodiment relates to when the data flow that then will perform after the process at the data flow as benchmark changes according to result distributes.
In the sequential chart 1601 shown in Figure 16, during the time period 1602, perform the process of the data flow X as benchmark, and according to result, carry out arranging change from data flow X to data flow A, B or C during the time period 1603.After completing this setting operation, during the time period 1604, perform the process of data flow A, B or C, and carry out during the time period 1605 from data flow A, B or C to data flow X arranging change using the process again performing the data flow X as benchmark.Although repeat above-mentioned execution sequence, perform in data flow A, B and C which be determined based on the result of data flow X.
In figure 16, Reference numeral 1606,1607,1608 and 1609 represents the setting of the PE 202-1 ~ 202-4 of data flow X, A, B and C respectively.In the fourth embodiment, process is all performed for all data flow X, A, B and C to distribute.As in the first embodiment, arrange 1606,1607,1608 and 1609 and correspond to the setting shown in Fig. 6.More specifically, in the fourth embodiment, perform process to data flow X, A, B and C to distribute.
Distributing for performing process, considering that always arranging needed for the data flow change in PE202-1 ~ 202-4 between data flow X and A, X and B and X and C changes counting.By calculate tale as Figure 13 of the first embodiment Reference numeral S1306 represented by evaluation of estimate, reduce when reconfigurable device is reconstructed arranging change counting.Note, Reference numeral 1610,1613,1616 and 1619 represents that PE202-1 ~ 202-4's between data flow X and A arranges change respectively.Reference numeral 1611,1614,1617 and 1620 represents that PE202-1 ~ 202-4's between data flow X and B arranges change respectively.Reference numeral 1612,1615,1618 and 1621 represents that PE202-1 ~ 202-4's between data flow X and C arranges change respectively.The present embodiment is from the different of the first embodiment: in execution sequence, occur branch, and performs process distribution for the data flow as branch destination and the data flow as branch source.
At the step S1301 of Figure 13, when inputting multiple data flow, any execution sequence in importation.The process all data flows 1606,1607,1608 and 1609 as process distribution object being performed to the step S1303 of Figure 13 distributes.Although describe situation about processing all data flows as process distribution object in the fourth embodiment, the present invention is not limited to this.4th embodiment has paid close attention to the execution sequence of data flow.Distribute if at least one data flow have passed through process, then process is performed for other data flow and distribute.
What the step S1306 for Figure 13 used arranges change counting, compared with the first embodiment, exists following different.If the settings u of the data flow i0 as process distribution object i0, j, kbe not equal to the settings u at the identical address place of the data flow i1 as process distribution object i1, j, k, then by α 4be added to arrange and change counting.If the settings u of the data flow i0 as process distribution object i0, j, kbe not equal to the settings u at the identical address place of the data flow i2 as process distribution object i2, j, k, then by β 4be added to arrange and change counting.In addition, if the settings u of the data flow i0 as process distribution object i, j, kbe not equal to the settings u at the identical address place of the data flow i3 as process distribution object i3, j, k, then by γ 4be added to arrange and change counting.Alternatively, if these settings are equal to each other, then additive operation is not performed.All storer k for all treatment element j perform above-mentioned calculating.This can be represented by following equation.
Wherein, i0 represents data flow X1606, and i1 represents data flow A1607, and i2 represents data flow B1608, and i3 represents data flow C1609.To settings u i0, j, k, u i1, j, k, u i2, j, kand u i3, j, karrange, diminish to make the value represented by above-mentioned equation.In addition, α 4, β 4and γ 4be generally 1.But, can change according to the structure of the config memory for the treatment of element the weight that stored each address is set.Can also assign weight for each data flow, to distribute the priority of switching time for each data flow.
According to the 4th embodiment, even if when there is branch in execution sequence when performing multiple data flow in turn, by being considered as the data flow in branch source and other data flows multiple as branch destination, the effect reducing and arrange and change counting also can be obtained.
Although describe method for routing for each service condition in above-described embodiment, the combination of these methods can also be used in the present invention.In addition, although describe treatment element as the structural detail of reconfigurable device, the present invention is not limited to this, and can use the combination of LUT or LUT and treatment element.Arrange and be not limited to the setting described in embodiment, and the setting used in the reconfigurable device based on LUT can be used.In these embodiments, although using all input traffic journeys as process distribution object, by designated treatment range of distribution, process can be performed to a part of data flow in data flow and distribute.In addition, in these embodiments, although the quantity for the treatment of element is constant for each data flow, the quantity processing the treatment element be allocated to also can be different.
5th embodiment
In the 5th embodiment and embodiment subsequently, change except the time period except shortening circuit structure as the first embodiment ~ the 4th embodiment, the treatment element also making to have data I/O relation mutually closer to, shorten total processing time section thus.
With reference to the overview of the configuration of the data flow in Figure 17 description architecture element.This configuration represents: treatment element that determine each process for performing data flow, that be limited to pre-position.With reference to Figure 17, the node 1702,1703,1704 or 1705 of data flow 1701 represents process performed in a treatment element.By with node 1702,1703,1704 and 1705 corresponding process are configured in treatment element 202-1,202-2,202-3 and 202-4 of reconfigurable device 105 respectively.Arrange 1706,1707,1708 or 1709 and comprise the address 601 corresponding with the contents processing of node 1702,1703,1704 or 1705 and settings 602.Assuming that be assigned with the contents processing performed by each node, and determine and arrange 1706,1707,1708 or 1709.Determining this configuration, making it possible to determine the ID 503 corresponding with arranging write treatment element.
The sequential chart of expectation process is realized as shown in Figure 10 for the polytype structure by changing above-mentioned reconfigurable device.Figure 10 is the sequential chart that a reconfigurable device performs multiple different data flow A ~ Z in turn.The data flow processed in the present embodiment is that in the treatment element by reconfigurable device, configurable unit is formed.Generate the setting for the treatment of each data flow in advance.Reconfigurable device is reconstructed based on arranging of generating in advance for self, and utilize this structure to perform process.According to predefined procedure to the process of data flow performing.
Assuming that be configured with data flow A, and want configuration data flow process B.More specifically, with reference to for performing the settings of configured data flow A, the processing configuration of data flow B is then determined.After determining the processing configuration of data flow B in the processing configuration by reference to data flow A, think and be configured with data flow B and want configuration data flow process C.More specifically, being similar to the determination of the processing configuration of data flow B, with reference to for performing the settings of the data flow B that have passed through processing configuration, then determining the processing configuration of data flow C.Repeat said process, make it possible to configuration data flow process A ~ Z.Usually, even if allocation problem only determines configuration, solution space is also larger.Therefore, if determine detailed route simultaneously, then not only become and cannot calculate good solution, even cannot calculate solution itself.In this collocation method, do not determine detailed routing iinformation, and use the approximate distance based on the allocation models shown in Figure 18 to determine configuration.In the 5th embodiment, use the Manhattan model of the position of the treatment element based on processing element array as allocation models.By the manhatton distance between treatment element is calculated solution as index.Note, in the present invention, approximate distance is not limited to manhatton distance.As index, detailed route can be performed simultaneously.Although use the allocation models based on Manhattan model in the present embodiment, the present invention is not limited to this.The model based on architecture or the model based on Euclidean space can be used.
As shown in figure 18, for the reconfigurable device 105 comprising switching device 201 and treatment element 202, definition allocation models 1801.Allocation models 1801 is only made up for the treatment of element 202.As the distance of index represented by the distance 1803 between the distance 1802 between the treatment element in horizontal direction and the treatment element in vertical direction.In the 5th embodiment, the distance in horizontal direction and vertical direction is equal to each other, but they also can be different from each other.Although distance handled in the present invention can be the time period needed for communication between physical length or element, the present invention is not limited to this.
By using the allocation models of Figure 18, the method being used for the process of configuration process element that the process shown in the sequential chart paying close attention to Figure 10 switches is described.
Figure 19 illustrates the overview of the configuration according to the 5th embodiment.Data flow A is consisted of process as node 1901,1902,1903 and 1904 represented by institute, and arranges the setting of the process performed by each node of 1905,1906,1907 or 1908 expression.Flow process 1909 represents the data I/O relation between node 1901 and 1902.Flow process 1910 represents the data I/O relation between node 1901 and 1903.Flow process 1911 represents the data I/O relation between node 1902 and 1904.Flow process 1912 represents the data I/O relation between node 1903 and 1904.
Data flow B by as node 1913,1914, the process institute shown in 1915 and 1916 forms, and arranges the setting that 1917,1918,1919 or 1920 represent the process performed by each node.Flow process 1921 represents the data I/O relation between node 1913 and 1915.Flow process 1922 represents the data I/O relation between node 1914 and 1915.Flow process 1923 represents the data I/O relation between node 1915 and 1916.
Assuming that by the processing configuration of data flow A and B in the region 1924 of the allocation models 1801 of processing element array.Although the configuration in a part for processing element array will be described in the 5th embodiment, the present invention is not limited to this.Configuration in multiple part or whole array is also fine.Reference numeral 1925 represents for the processing configuration in the region 1924 of data flow A, and Reference numeral 1926 represents for the processing configuration in the region 1924 of data flow B.Treatment element 1927,1928,1929 in processing configuration 1925 or 1926 represents treatment element identical physically with 1930.In processing configuration 1925, by the processing configuration of the node 1901 of data flow A in treatment element 1927.By the processing configuration of node 1902 in treatment element 1929.By the processing configuration of node 1903 in treatment element 1928.By the processing configuration of node 1904 in treatment element 1930.Distance 1931,1932,1933 and 1934 represents the data communication distance of the flow process 1909,1910,1911 and 1912 between treatment element respectively.
For data flow B, by the processing configuration of node 1913 in treatment element 1927.By the processing configuration of node 1914 in treatment element 1928.By the processing configuration of node 1915 in treatment element 1929.By the processing configuration of node 1916 in treatment element 1930.Distance 1935 represents the data communication distance of the flow process 1921 between treatment element, and distance 1936 and 1937 represents the data communication distance of flow process 1922, and distance 1938 represents the data communication distance of flow process 1923.
When process is switched to data flow B from data flow A, as arranged shown in change 1939, in treatment element 1927, setting being changed over arrange 1917 from arranging 1905.In treatment element 1928, as arranged shown in change 1941, setting is changed over arrange 1918 from arranging 1907.In treatment element 1929, as arranged shown in change 1940, setting is changed over arrange 1919 from arranging 1906.In treatment element 1930, as arranged shown in change 1942, setting is changed over arrange 1920 from arranging 1908.
In the 5th embodiment, for performing configuration, consider process switch time arranging change counting and based on the dependence between data flow structural detail between these two factors of distance.
In example shown in Figure 19 that the 5th embodiment uses, data flow A have passed through processing configuration, and the settings be associated with data flow A in the storer of each treatment element are fixed values.Data flow B is processing configuration object.That is, assuming that determine the processing sequence of data flow, and determine the configuration of then data flow to be processed based on the configuration information of the data flow that have passed through configuration.
Illustrate with reference to the process flow diagram shown in Figure 20 and be used for realizing process of the present invention.This procedural representation is based on the processing configuration method of simulated annealing.But the present invention is not limited to this.The various approximate solution of such as genetic algorithm etc. and the numerical optimization method of such as linear programming and nonlinear programming etc. can be used.Method can be changed according to the scale of allocation problem.
Assuming that i is the index representing each data flow shown in Figure 19, j is the index of node, and k is the configuration address of the storer in the element corresponding with the address 601 of Fig. 6 or the address 901 of Fig. 9.In addition, assuming that l is the index that the flow process between node j is associated.Then, u i, j, kthe settings in each storer can be represented.In addition, S i, 1represent the node of the side of setting out of the flow process 1 of the i-th data flow, and d i, 1represent the node of the arrival side of flow process 1.
As shown in figure 18, assuming that r is the index representing each treatment element.X can be passed through i, jand y i, jrepresent the allocation position of each node j of each data flow i.In the present embodiment, because the different disposal in a data flow is not configured in a treatment element, thus for each node j, x i, jand y i, jobvious difference.That is, different process is not configured in a treatment element.
Tentation data flow process i0 have passed through processing configuration, and data flow i1 is processing configuration object.In step S2001, input multiple data flow and the ordinal relation between them (order of i).For the data flow that have passed through processing configuration, with settings u i0, j, kinput configuration information x together i0, j, y i0, j.
In step S2002, the required specification of input and hardware constraints.Hardware constraints comprises the structural information that such as kept respectively by each treatment element with heterojunction structure and processes the constraint of hardware configuration of the thermal value that generates etc.The required specification Distance geometry comprised such as between treatment element distribute to the levels of priority (will be described in step S2006 below) that changes counting or distance etc. is set should restricted item in hardware uses.Note, the present invention is not limited to above-mentioned constraint.
In step S2003, processing configuration is performed to object data flow process.As initial treatment collocation method, use for random arrangement process method or for the input and output directional correlation of processing element array join on the depth direction of data flow the method for configuration process.But the present invention is not limited to these methods.Except except initial configuration, also change processing configuration based on simulated annealing.In the 5th embodiment, initial treatment configuration or processing configuration change are performed for the data flow B as processing configuration object.For the data flow A that have passed through processing configuration, processing configuration does not change according to constraint.
In step S2004, judge whether processing configuration result meets the required specification of step S2002 input.As shown in equation (1), if meet constraint, then at punishment variable p 0in arrange 0; Otherwise, at punishment variable p 0in penalty value C is set p0(see equation (1)).
In the 5th embodiment, when violating constraint, by C p0be set to identical constant.But, C p0it can be the variate-value according to violating item.In step S2005, judge whether processing configuration result meets the hardware constraints of step S2002 input.
As shown in equation (2), if meet constraint, then at punishment variable P 1in arrange 0; Otherwise, at punishment variable P 1in penalty value C is set p1.
In the 5th embodiment, when violating constraint, by C p1be set to identical constant.But, C p1it can be the variate-value according to violating item.In step S2006, arranging when calculating object data flow changes changes counting and the distance based on configuration, thus Calculation Estimation value.First the calculating arranging and change counting is described.With reference to the example shown in Figure 19, the count table that calculate is shown in the quantity arranging in change 1939,1940,1941 and 1942 and need the setting changed.
More specifically, if having passed through the settings u of the data flow i0 of processing configuration i0, j, kbe not equal to the settings u of the identical type of the treatment element be configured in as the same position place in the data flow i1 of processing configuration object i1, j, k, then by α 1be added to arrange and change counting; Otherwise, do not perform additive operation.
Note, j0 rrepresent the node j0 of the data flow i0 be configured in treatment element r, and j1 rrepresent the node j1 of data flow i1, wherein, as mentioned above, r representative represents the index of each treatment element.The change that arranges needed for change being obtained the contents processing of the node that same position place configures when data flow switches by following equation is counted.
Wherein, α 1be generally 1.But, can change according to the structure of the config memory for the treatment of element the weight that stored each address is set.Can also assign weight for each data flow, to distribute the priority of switching time for each data flow.As shown in Figure 7, settings can be changed for a configuration order.Therefore, if the quantity of order reduces, then can shorten and process switching time.
The calculating of distance is then described.Distance table is shown as the summation of the distance 1935,1936,1937 and 1938 in the data flow B into configuring object.Based on the configuration of step S2003 and the data I/O relation of data flow, distance can be represented by following equation.
Wherein, κ 1 1with λ 1 1represent x and the y weight separately of the distance between node respectively.Weight can be made to be constant, or individually can to change weight according to the architecture of the distance such as between node etc.Use above-mentioned equation, in this step, according to equation (10) Calculation Estimation value.
Evaluation of estimate=δ s+ (1-δ) d+p0+p1 ... (10)
Wherein, δ representative represents the index distributing to apart from or arrange the level of the priority changing counting given by step S2002.That is, due to when meeting required specification and hardware constraints, distance shortens and the change counting that arranges needed for reconstruct diminishes, and thus evaluation of estimate diminishes.
Finally, judge whether to reach target based on simulated annealing in step S2007.If the target of reaching, then terminate this process; Otherwise process turns back to step S2003 to repeat step S2003 ~ S2007.This means to repeat this process until obtain very good result or pass by the predetermined computation time.
Processing configuration method due to the data flow of the treatment element in general reconfigurable device is not considered to arrange change counting, thus needs to change all settings when the process of data flow changes.
In the 5th embodiment, pay close attention to the processing sequence of data flow.Except distance, also reduce always to arrange to change counting, this makes it possible to effectively reduce arrange and changes counting.
6th embodiment
The sixth embodiment of the present invention will be described.Figure 21 illustrates the sequential chart of process according to the 6th embodiment and the overview of processing configuration.But the 6th embodiment relates to when changing the arranging of reconfigurable device, determine the change order of the contents processing contents processing of each data flow uncertain and change according to situation or input data time processing configuration.
During time period 2102 in sequential chart 2101, perform the process be associated with data flow A.During the time period 2104 and 2108, perform the process be associated with data flow C.During the time period 2106, perform the process be associated with data flow B.During the time period 2103, carry out arranging change from data flow A to data flow C.During the time period 2105, carry out arranging change from data flow C to data flow B.During the time period 2107, carry out arranging change from data flow B to data flow C.In the present embodiment, because the process change order of data flow A, B and C is always not identical, thus to need to consider between data flow all arranges change to perform processing configuration.
In figure 21, Reference numeral 2109,2122 and 2131 represents the configuration of the treatment element of data flow A, B and C respectively, and once to seek unity of action processing configuration for all data flows.Note, the treatment element 2110,2111,2112 of configuration 2109,2122 or 2131 represents treatment element identical physically with 2113.
The setting that 2114,2115,2116 and 2117 represent the treatment element 2110,2111,2112 and 2113 in the configuration of data flow A is respectively set.The setting that 2123,2124,2125 and 2126 represent the treatment element 2110,2111,2112 and 2113 in the configuration of data flow B is respectively set.The setting that 2132,2133,2134 and 2135 represent the treatment element 2110,2111,2112 and 2113 in the configuration of data flow C is respectively set.As in the first embodiment, these arrange the setting corresponded to described in Fig. 6.Total distance that the connection changed between counting and treatment element is always set needed for the present embodiment data flow paid close attention in treatment element 2110,2111,2112 and 2113 between data flow A and B, B and C and C and A changes.
Add to arranging of evaluation of estimate by the step S2006 phase calculating the process flow diagram shown in Figure 20 based on above-mentioned tale and distance and change counting as evaluation of estimate (illustrating) below, consider that this distance changes counting to reduce arranging when reconfigurable device is reconstructed.
What Reference numeral 2139 represented treatment element 2110,2111,2112 and 2113 between data flow A and B arranges change; What Reference numeral 2140 represented treatment element 2110,2111,2112 and 2113 between data flow B and C arranges change; And Reference numeral 2141 represent treatment element 2110,2111,2112 and 2113 between data flow C and A change is set.
6th embodiment is from the different of the first embodiment: perform processing configuration for multiple data flow simultaneously.At the step S2001 of Figure 20, input multiple data flow, and input represents that processing sequence is arbitrary information.In the processing configuration of the step S2003 of Figure 20, processing configuration is performed to all data flow A, B and C as processing configuration object.For the process of the step S2006 of Figure 20, compared with the 5th embodiment, exist following different.
If as the settings u in the data flow i0 of processing configuration object i0, j, kbe not equal to the settings u of the identical type of the treatment element configured as the same position place in the data flow i1 of processing configuration object i1, j, k, then by α 2be added to arrange and change counting.If as the settings u in the data flow i1 of processing configuration object i1, j, kbe not equal to the settings u of the identical type of the treatment element configured as the same position place in the data flow i2 of processing configuration object i2, j, k, then by β 2be added to arrange and change counting.In addition, if as the settings u in the data flow i2 of processing configuration object i2, j, kbe not equal to the settings u of the identical type of the treatment element configured as the same position place in the data flow i0 of processing configuration object i0, j, k, then by γ 2be added to arrange and change counting.Alternatively, if these settings are equal to each other, then additive operation is not performed.
Note, j0 rrepresent the node j0 of the data flow i0 configured in treatment element r, j1 rrepresent the node j1 of data flow i1, and j2 rrepresent the node j2 of data flow i2, wherein, as mentioned above, r representative represents the index of each treatment element.
The change that arranges needed for change being obtained the contents processing of the node that the same position place when data flow switches configures by following equation is counted.
Wherein, α 2, β 2and γ 2be generally 1.But, can change according to the structure of the config memory for the treatment of element the weight that stored each address is set.Can also assign weight for each data flow, to distribute the priority of switching time for each data flow.
For distance, exist following different.In the example shown in Figure 21, distance is expressed as the summation of distance 2118,2119,2120,2121,2127,2128,2129,2130,2136,2137 and 2138.The configuration of the treatment element of Figure 21 is only example, and changes total distance by changing configuration.After configuration operation, following equation can be used to represent this distance based on the data I/O of configuration and data flow.
Wherein, κ 2 i, 1with λ 2 i, 1expression can be constant or the weight that individually can change according to the architecture of the distance between the node of such as each data flow etc.According to the 6th embodiment, by considering all data flows, even if processing execution order is uncertain, also can considers distance and obtaining the effect reducing fifty-fifty and arrange and change counting.
7th embodiment
The seventh embodiment of the present invention will be described.Figure 22 illustrates the sequential chart of process according to the 7th embodiment and the overview of processing configuration.7th embodiment supposition has determined the situation of the processing sequence of multiple data flow and the processing configuration of each data flow.The processing configuration of the process corresponding with new data flow process is inserted between the process of arbitrary data flow process when the 7th embodiment relates to for not changing processing configuration after before insertion, in above-mentioned processing sequence.
For the sequential chart 2201 shown in Figure 22, the processing sequence in reconfigurable device and processing configuration are determined.In sequential chart 2201, after the process 2203 of data flow A, insert the time period 2204 setting of data flow A being changed over the setting of data flow C, then perform the process 2205 of data flow C.Sequential chart 2202 is obtained by data inserting flow process B new between data flow A and C in sequential chart 2201.After the process 2203 of data flow A, insert the time period 2206 setting of data flow A being changed over the setting of data flow B, then perform the process 2207 of the new data flow B inserted.Then, after the time period 2208 of the setting setting of data flow B being changed over data flow C, perform the process 2205 of data flow C.Owing to now determining the processing configuration of data flow B when not changing the processing configuration of data flow A and C, thus consider and have passed through processing configuration insertion before and after data flow between knots modification is set.
In fig. 22, Reference numeral 2209,2222 and 2231 represents the configuration of the treatment element of data flow A, B and C respectively.In the present embodiment, data flow A and C have passed through processing configuration, and performs processing configuration to data flow B.Note, the treatment element 2210,2211,2212 in configuration 2209,2222 or 2231 represents identical treatment element with 2213.
The setting that 2214,2215,2216 and 2217 represent the treatment element 2210,2211,2212 and 2213 in the configuration of data flow A is respectively set.The setting that 2223,2224,2225 and 2226 represent the treatment element 2210,2211,2212 and 2213 in the configuration of data flow B is respectively set.The setting that 2232,2233,224 and 2235 represent the treatment element 2210,2211,2212 and 2213 in the configuration of data flow C is respectively set.As in the first embodiment, these arrange the setting corresponded to described in Fig. 6.Total distance that the connection changed between counting and these treatment elements is always set needed for the 7th embodiment data flow paid close attention in treatment element 2210,2211,2212 and 2213 between data flow A and B and B and C changes.
Note, what Reference numeral 2239 represented treatment element 2210,2211,2212 and 2213 when new data inserting flow process B between data flow A and B arranges change.What Reference numeral 2240 represented treatment element 2210,2211,2212 and 2213 between data flow B and C arranges change.
7th embodiment is from the 5th the different of embodiment: by reference to have passed through multiple data flows of processing configuration to perform the processing configuration of object data flow process.
Only data flow B is performed to the processing configuration in the step S2003 of Figure 20.Data flow A and C have passed through processing configuration, and does not change processing configuration.For the process of the step S2006 of Figure 20, compared with the 5th embodiment, exist following different.
If have passed through the settings u of the data flow i0 of processing configuration i0, j, kbe not equal to the settings u of the treatment element configured as the same position place in the data flow i1 of processing configuration object i1, j, k, then by α 3be added to arrange and change counting.If the settings u of the data flow i1 as processing configuration object i1, j, kbe not equal to the settings u of the treatment element that the same position place that have passed through in the data flow i2 of processing configuration configures i2, j, k, then by β 3be added to arrange and change counting.If these settings are equal to each other, then do not perform additive operation.
Note, j0 rrepresent the node j0 of the data flow i0 configured in treatment element r, j1 rrepresent the node j1 of data flow i1, and j2 rrepresent the node j2 of data flow i2, wherein, as mentioned above, r representative represents the index of each treatment element.
The change that arranges needed for change being obtained the contents processing of the node that the same position place when data flow switches configures by following equation is counted.
Wherein, α 3and β 3be generally 1.But, can change according to the structure of the config memory for the treatment of element the weight that stored each address is set.Can also assign weight for each data flow, to distribute the priority of switching time for each data flow.
For distance, exist following different.In the example shown in Figure 22, distance is expressed as the summation of distance 2227,2228,2229,2230.The configuration of the treatment element of Figure 22 is only example, and changes total distance by changing configuration.After configuration operation, following equation can be used to represent this distance based on the data I/O of configuration and data flow.
Wherein, κ 3 1with λ 3 1expression can be constant or the weight that individually can change according to the architecture of the distance between the node of such as each data flow etc.When new data inserting flow process, what can obtain the data flow before and after reducing and inserting arranges the effect changing and count.
8th embodiment
The eighth embodiment of the present invention will be described.Figure 23 illustrates the sequential chart of process according to the 8th embodiment and the overview of processing configuration.8th embodiment relates to processing configuration when changing the data flow that then will perform according to result after the process at the data flow as benchmark.
In the sequential chart 2301 shown in Figure 23, during the time period 2302, perform the process of the data flow X as benchmark, and carry out arranging change from data flow X to data flow A, B or C according to result during the time period 2303.After completing this setting operation, during the time period 2304, perform the process of data flow A, B or C, and carry out during the time period 2305 from data flow A, B or C to data flow X arranging change using the process again performing the data flow X as benchmark.Although repetition said sequence, perform in data flow A, B and C which be determined based on the result of data flow X.
In fig 23, Reference numeral 2306,2319,2328 and 2337 represents the configuration of data flow X, A, B and C respectively.In the present embodiment, processing configuration is performed to all data flow X, A, B and C.Note, the treatment element 2307,2308,2309 in configuration 2306 represents identical treatment element with 2310.
The setting that 2311,2312,2313 and 2314 represent the treatment element 2307,2308,2309 and 2310 in the configuration of data flow X is respectively set.The setting that 2320,2321,2322 and 2323 represent the treatment element 2307,2308,2309 and 2310 in the configuration of data flow A is respectively set.The setting that 2329,2330,2331 and 2332 represent the treatment element 2307,2308,2309 and 2310 in the configuration of data flow B is respectively set.The setting that 2338,2339,2340 and 2341 represent the treatment element 2307,2308,2309 and 2310 in the configuration of data flow C is respectively set.As in the first embodiment, these arrange the setting corresponded to described in Fig. 6.
More specifically, in the 8th embodiment, processing configuration is performed to data flow X, A, B and C.For performing processing configuration, the total distance that the connection changed between counting and treatment element is always set needed for the data flow paid close attention in treatment element 2307,2308,2309 and 2310 between data flow X and A, X and B and X and C changes.
Note, what Reference numeral 2345 represented treatment element 2307,2308,2309 and 2310 between data flow X and A arranges change; And what Reference numeral 2346 represented treatment element 2307,2308,2309 and 2310 between data flow X and B arranges change.
What Reference numeral 2347 represented treatment element 2307,2308,2309 and 2310 between data flow X and C arranges change.
8th embodiment is from the 5th the different of embodiment: in processing sequence, there is branch, and performs processing configuration for the data flow between branch destination and branch source.
At the step S2001 of Figure 20, when inputting multiple data flow, input comprises the processing sequence of part random order relation.Note, " part arbitrarily " in the present embodiment refers in execution sequence, to there is branch and only the execution sequence of branch source and branch destination is arbitrary.
All data flow X, A, B and C as processing configuration object are performed to the processing configuration of the step S2003 of Figure 20.Although present embodiment illustrates the situation all data flows being used as processing configuration object, the present invention is not limited to this.The present embodiment has paid close attention to processing sequence.If at least one data flow have passed through processing configuration, then processing configuration is performed to other data flow.
For the process of the step S2006 of Figure 20, compared with the first embodiment, exist following different.If the settings u of the data flow i0 as processing configuration object i0, j, kbe not equal to the settings u of the identical type of the treatment element configured as the same position place in the data flow i1 of processing configuration object i1, j, k, then by α 4be added to arrange and change counting.If the settings u of the data flow i0 as processing configuration object i0, j, kbe not equal to the settings u of the identical type of the treatment element configured as the same position place in the data flow i2 of processing configuration object i2, j, k, then by β 4be added to arrange and change counting.In addition, if the settings u of the data flow i0 as processing configuration object i0, j, kbe not equal to the settings u of the identical type of the treatment element configured as the same position place in the data flow i3 of processing configuration object i3, j, k, then by γ 4be added to arrange and change counting.Alternatively, if these settings are equal to each other, then additive operation is not performed.
Note, j0 rrepresent the node j0 of the data flow i0 configured in treatment element r, j1 rrepresent the node j1 of data flow i1, j2 rrepresent the node j2 of data flow i2, and j3 rrepresent the node j3 of data flow i3, wherein, as mentioned above, r representative represents the index of each treatment element.
The change that arranges needed for change being obtained the contents processing of the node that the same position place when data flow switches configures by following equation is counted.
Wherein, α 4, β 4and γ 4be generally 1.But, can change according to the structure of the config memory for the treatment of element the weight that stored each address is set.Can also assign weight for each data flow, to distribute the priority of switching time for each data flow.
For distance, exist following different.In the example shown in Figure 23, distance is expressed as the summation of distance 2315,2316,2317,2318,2324,2325,2326,2327,2333,2334,2335,2336,2342,2343 and 2344.The configuration of the treatment element of Figure 23 is only example, and changes total distance by changing configuration.After this configuration operation, following equation can be used to represent this distance based on the data I/O of configuration and data flow.
Wherein, κ 4 i, 1with λ 4 i, 1expression can be constant or the weight that individually can change according to the architecture of the distance between the node of such as each data flow etc.According to the present embodiment, even if there is branch in the execution sequence when performing multiple data flow in turn, by being considered as the data flow in branch source and other data flows multiple as branch destination, the effect reducing and arrange and change counting also can be obtained.
9th embodiment
The ninth embodiment of the present invention will be described.Figure 24 illustrates according to the data flow of the 9th embodiment and the method for limiting processing configuration.In many cases, processing configuration problem is usually very complicated, and needs the longer time to calculate solution.When configuring multiple data flow as the present invention simultaneously, problem becomes serious.Therefore, in the 9th embodiment, effectively shortened by restriction process configurable range and separate computing time.
Data flow 2419 comprises the node 2401 ~ 2418 corresponding with multiple process.Reference numeral 2420 represents the input media of processing element array 2426; And Reference numeral 2424 represents output unit.Processing element array 2426 is there is between input media and output unit.
In the 9th embodiment, when with the process of allocation models 1801 configuration data flow process 2419, by being associated with the depth direction of data flow by the i/o sites+of processing element array, effectively reduce solution space.More specifically, node 2401 ~ 2404 is arranged to only be configurable in the scope represented by Reference numeral 2421.Node 2405 ~ 2410 is arranged to only be configurable in the scope represented by Reference numeral 2422.Node 2411 ~ 2414 is arranged to only be configurable in scope 2422.Node 2415 ~ 2418 is arranged to only be configurable in the scope represented by Reference numeral 2423.
Assuming that limit in the step S2002 input of Figure 20.Although in the 9th embodiment, configurable range and the degree of depth of data flow and the I/O directional correlation of processing element array are joined, the present invention is not limited to this.
Although describe processing configuration method for each service condition in the above-described embodiments, the combination of these methods can be used in the present invention.In addition, although describe treatment element as the structural detail of reconfigurable device, the present invention is not limited to this, and can use the combination of LUT or LUT and treatment element.Arrange and be not limited to the setting described in these embodiments, and the setting used in the reconfigurable device based on LUT can be used in.Although in these embodiments all input traffic journeys are used as processing configuration object, by the processing configuration object range of specific data flow process, only processing configuration can be performed to a part of data flow in data flow.In addition, although always the quantity for the treatment of element is identical for each data flow in these embodiments, but the quantity of the treatment element of configuration process can be different.Although determine in these embodiments to be configured to make total distance diminish, can determine to be configured to the maximal value of each distance is diminished.Alternatively, can determine to be configured to make the mean value of distance to diminish.
In the above-described embodiments, assuming that with lattice configuration process element equably, and the connection distance between treatment element is constant.But the present invention is not limited to this.If connection handling element is to have tree construction, then can give weight according to this tree construction to each distance.That is, weight can be given according to the connection configuration for the treatment of element to each distance.
Program that memory device is set up can also be recorded in carry out computing machine devices such as (or) CPU or MPU of the system or equipment of the function of above-described embodiment and to realize each aspect of the present invention by method below by reading and performing, wherein, the computing machine of system or equipment is recorded in by such as reading and performing program that memory device is set up to carry out said method each step with the function of carrying out above-described embodiment.For this reason, such as, by network or by the various types of recording mediums (such as, computer-readable recording medium) being used as storage arrangement, this program is supplied to computing machine.
Although describe the present invention with reference to exemplary embodiments, should be appreciated that, the present invention is not limited to disclosed exemplary embodiments.The scope of appended claims meets the widest explanation, to comprise all this kind of amendments, equivalent structure and function.

Claims (16)

1. process a distribution method, for for the reconfigurable device comprising multiple structural detail, to each structural detail allocation process, described process distribution method comprises the following steps:
Data flow input step, for inputting the execution sequence of at least two different data flows and data flow;
Constraint step, for inputting the constraint of described structural detail; And
Process distributes determining step, for determining that process distributes, to make constraint based on described structural detail and described execution sequence, when switching between described at least two different data flows, required arranging is reconstructed to described structural detail and changes counting and diminish
It is characterized in that, described data flow input step also inputs the configuration information of described multiple structural detail, and
Described process distributes determining step and comprises:
First determining step, for based on described execution sequence, for described at least two different data flows, determines the distribution candidate to described structural detail allocation process;
Change counting calculation procedure, for based on described constraint and described configuration information, calculate the change counting of the distribution of each described distribution candidate; And
Second determining step, for determining that the process of described structural detail distributes, diminishes to make described change counting.
2. process distribution method according to claim 1, it is characterized in that, at least one data flow in the data flow inputted have passed through process and distributes, and by reference to have passed through the data flow of process distribution, performing to process distribute the data flow do not distributed through process.
3. process distribution method according to claim 1, is characterized in that, seeks unity of action to process distribute for the multiple data flows do not distributed through process in inputted data flow.
4. process distribution method according to claim 1, is characterized in that, for each data flow or the setting for the contents processing of determining described structural detail, described setting is changed to counting and is weighted.
5. a messaging device, for generating the structural information that will realize for device, described device has the reconfigurable arrays of multiple structural details that the process being used for realizing data flow can be dispensed to, and described messaging device comprises:
Input block, for inputting for realizing comprising the configuration information of multiple data flows of the first data flow and the second data flow and the configuration information of described multiple structural detail by described multiple structural detail; And
Controller, for based on described configuration information and described configuration information, described multiple structural detail is distributed in the process being used for realizing described first data flow, with make and for realize described second data flow setting between to carry out the structural detail changed quantity diminish
It is characterized in that, described input block also inputs the execution sequence of described first data flow and described second data flow, and
Described controller comprises:
Candidate's determining unit, for based on described execution sequence, for described first data flow and described second data flow, determines the distribution candidate to described structural detail allocation process;
Change counting computing unit, for based on described configuration information and described configuration information, calculate the change counting of the distribution of each described distribution candidate; And
Determining unit, for determining that the process of described structural detail distributes, diminishes to make described change counting.
6. messaging device according to claim 5, is characterized in that, described determining unit comprises:
Judging unit, for judge whether based on described configuration information can by described distribution candidate allocation give described structural detail;
Penalty value determining unit, during for being judged as when described judging unit distributing described distribution candidate, determines penalty value;
Evaluation of estimate computing unit, for based on described change counting and described penalty value, calculates for determining the evaluation of estimate of distributing; And
Evaluation of estimate judging unit, for judging, whether evaluation values is not more than threshold value,
Wherein, when when being judged as, evaluation values is not more than described threshold value, the process that described distribution candidate is defined as described structural detail distributes by described determining unit.
7. messaging device according to claim 5, it is characterized in that, when the process that at least one data flow in described multiple data flow have passed through described structural detail distributes, described change counting computing unit distributes with reference to this process, and for each described distribution candidate, that calculate the process distribution not carrying out described structural detail, that the process of next data flow that will perform distributes change counts.
8. messaging device according to claim 5, is characterized in that, described change counting computing unit is for each described distribution candidate, and the change that the process of the data flow that the process that described structural detail is not carried out in unified calculation distributes distributes counts.
9. messaging device according to claim 5, is characterized in that, described input block also inputs the insertion destination locations of data flow in described execution sequence of the process distribution not carrying out described structural detail, and
Handled by before and after the described process changing the data flow that the reference of counting computing unit will be inserted, to have passed through the data flow that process distributes process distributes, and for each described distribution candidate, the change counting that the process calculating the data flow of the process distribution not carrying out described structural detail distributes.
10. messaging device according to claim 5, is characterized in that, the described counting computing unit that changes gives weight by the process for each data flow or each structural detail, calculates described change counting.
The control method of 11. 1 kinds of messaging devices, multiple structural details that described messaging device comprises input block, controller and the process being used for realizing data flow can be dispensed to, described control method comprises the following steps:
Input step, for inputting for realizing comprising the configuration information of multiple data flows of the first data flow and the second data flow and the configuration information of described multiple structural detail by described multiple structural detail; And
Rate-determining steps, for based on described configuration information and described configuration information, described multiple structural detail is distributed in the process being used for realizing described first data flow, with make and for realize described second data flow setting between to carry out the structural detail changed quantity diminish
It is characterized in that, described input step also inputs the execution sequence of described first data flow and described second data flow, and
Described rate-determining steps comprises:
Candidate determining step, for based on described execution sequence, for described first data flow and described second data flow, determines the distribution candidate to described structural detail allocation process;
Change counting calculation procedure, for based on described configuration information and described configuration information, calculate the change counting of the distribution of each described distribution candidate; And
Determining step, for determining that the process of described structural detail distributes, diminishes to make described change counting.
12. 1 kinds of processing configuration methods, for for the reconfigurable device comprising multiple structural detail, determine the structural detail of each process performing data flow, described processing configuration method comprises the following steps:
Input step, for inputting the processing sequence of the different data flow of at least two of comprising the first data flow and the second data flow and data flow;
Constraint step, for inputting the constraint of the described structural detail of described reconfigurable device; And
Determining step, for when switching to described second data flow from described first data flow, by use according to described data flow be reconstructed required arrange change counting and based on the dependence of the data I/O of described data flow each structural detail between distance determine the configuration of described structural detail, thus determine the structural detail performing required process
It is characterized in that, described input step also inputs the configuration information of described multiple structural detail, and
Described determining step comprises:
First determining step, for based on described processing sequence, for described at least two different data flows, determines the distribution candidate to described structural detail allocation process;
Calculation procedure, for calculating the change counting of the distribution of each described distribution candidate based on described constraint and described configuration information, and calculates the distance between each structural detail in described first data flow and described second data flow; And
Second determining step, for determining that the process of described structural detail distributes, diminishes to make described change counting.
13. processing configuration methods according to claim 12, is characterized in that, described constraint comprises the constraint for carrying out each process restriction configurable range to described data flow according to the configuration of described data flow and the structure of described reconfigurable device.
14. processing configuration methods according to claim 12, is characterized in that, for each data flow or the setting for the contents processing of determining described structural detail, described setting are changed to counting and are weighted.
15. processing configuration methods according to claim 12, is characterized in that, based on described structural detail, are weighted the connection distance between described structural detail.
16. 1 kinds of reconfigurable devices, carry out work for the configuration information generated based on process distribution method according to claim 1.
CN201210027897.8A 2011-02-08 2012-02-08 Reconfigurable device and method, information processing apparatus, and control method therefor Expired - Fee Related CN102693207B (en)

Applications Claiming Priority (10)

Application Number Priority Date Filing Date Title
JP2011025284 2011-02-08
JP2011-025284 2011-02-08
JP2011031220 2011-02-16
JP2011-031220 2011-02-16
JP2011120990A JP5798378B2 (en) 2011-05-30 2011-05-30 Apparatus, processing method, and program
JP2011-120990 2011-05-30
JP2012003497A JP5832311B2 (en) 2011-02-08 2012-01-11 Reconfiguration device, process allocation method, and program
JP2012-003035 2012-01-11
JP2012003035A JP5907607B2 (en) 2011-02-16 2012-01-11 Processing arrangement method and program
JP2012-003497 2012-01-11

Publications (2)

Publication Number Publication Date
CN102693207A CN102693207A (en) 2012-09-26
CN102693207B true CN102693207B (en) 2015-04-01

Family

ID=46601558

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201210027897.8A Expired - Fee Related CN102693207B (en) 2011-02-08 2012-02-08 Reconfigurable device and method, information processing apparatus, and control method therefor

Country Status (2)

Country Link
US (1) US9116751B2 (en)
CN (1) CN102693207B (en)

Families Citing this family (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103810142B (en) * 2014-03-06 2017-04-12 中国人民解放军信息工程大学 Reconfigurable system and construction method thereof
US10108516B2 (en) 2015-01-29 2018-10-23 Knuedge Incorporated Affinity data collection in a computing system
US10331569B2 (en) 2016-01-05 2019-06-25 Friday Harbor Llc Packet router buffer management
JP6713410B2 (en) * 2016-11-21 2020-06-24 日立オートモティブシステムズ株式会社 Electronic control unit
JP7127018B2 (en) 2017-05-19 2022-08-29 株式会社半導体エネルギー研究所 Semiconductor device and integrated circuit

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1241275A (en) * 1996-10-30 2000-01-12 爱特梅尔股份有限公司 Method and system for configuring array of logic devices
CN101053158A (en) * 2005-10-05 2007-10-10 松下电器产业株式会社 Reconfigurable semiconductor integrated circuit and its processing allocation method

Family Cites Families (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
DE69737750T2 (en) 1997-12-17 2008-03-06 Hewlett-Packard Development Co., L.P., Houston First and second processors used method
JP3558119B2 (en) 1999-08-09 2004-08-25 富士ゼロックス株式会社 Information processing system, method for forming circuit information of programmable logic circuit, method for reconfiguring programmable logic circuit
JP2001202236A (en) * 2000-01-20 2001-07-27 Fuji Xerox Co Ltd Data processing method for programmable logic circuit device and the same device and information processing system and circuit reconstituting method for the same device
US6971004B1 (en) * 2001-11-19 2005-11-29 Cypress Semiconductor Corp. System and method of dynamically reconfiguring a programmable integrated circuit
US7941794B2 (en) * 2004-08-30 2011-05-10 Sanyo Electric Co., Ltd. Data flow graph processing method and processing apparatus provided with reconfigurable circuit
US8407429B2 (en) * 2006-06-21 2013-03-26 Element Cxi, Llc Multi-context configurable memory controller
US20100023736A1 (en) * 2007-11-12 2010-01-28 Takashi Morimoto Reconfigurable circuit, reset method, and configuration information generation device
JP5294304B2 (en) 2008-06-18 2013-09-18 日本電気株式会社 Reconfigurable electronic circuit device
JP5056644B2 (en) * 2008-07-18 2012-10-24 富士通セミコンダクター株式会社 Data conversion apparatus, data conversion method and program
JP2010114772A (en) * 2008-11-07 2010-05-20 Nec Electronics Corp Semiconductor device and method for executing differential program
US8407633B2 (en) * 2009-10-26 2013-03-26 International Business Machines Corporation Dynamically reconfigurable self-monitoring circuit
JP5504985B2 (en) * 2010-03-11 2014-05-28 富士ゼロックス株式会社 Data processing device
US8635571B1 (en) * 2012-10-19 2014-01-21 Altera Corporation Integrating multiple FPGA designs by merging configuration settings

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1241275A (en) * 1996-10-30 2000-01-12 爱特梅尔股份有限公司 Method and system for configuring array of logic devices
CN101053158A (en) * 2005-10-05 2007-10-10 松下电器产业株式会社 Reconfigurable semiconductor integrated circuit and its processing allocation method

Also Published As

Publication number Publication date
US20120204181A1 (en) 2012-08-09
US9116751B2 (en) 2015-08-25
CN102693207A (en) 2012-09-26

Similar Documents

Publication Publication Date Title
CN102693207B (en) Reconfigurable device and method, information processing apparatus, and control method therefor
US6871328B1 (en) Method for mapping logic design memory into physical memory device of a programmable logic device
CN101714247B (en) Single pass tessellation
CN101630275B (en) Realizing method of configuration information for generating cycle task and device thereof
EP3364306A1 (en) Parallel processing of reduction and broadcast operations on large datasets of non-scalar data
KR20160033695A (en) System level simulation in network on chip
Zahidi et al. Optimizing complex cluster formation in MANETs using SAT/ILP techniques
US20240345617A1 (en) Separate clocking for components of a graphics processing unit
CN106326987A (en) Multi-objective optimization method and multi-objective optimization device
Mundani et al. A sliding window technique for interactive high-performance computing scenarios
CN103793483A (en) Clock tree generating method and system based on clock node clusters
JP2012248114A (en) Information processing apparatus, method of controlling the same, and program
Shamieh et al. Transaction throughput provisioning technique for blockchain-based industrial IoT networks
CN107645400B (en) Tactful sending, receiving method, device and controller
CN109902821A (en) A kind of data processing method, device and associated component
Bahrami et al. Proposing an optimal structure for the architecture of wireless networks on chip
US10469337B2 (en) Cost management against requirements for the generation of a NoC
CN105097005A (en) Memory matrix
CN109783222A (en) A kind of method and apparatus for eliminating branch's disagreement
CN106293936A (en) A kind of determination method and device of the locally optimal solution of physical host virtual memory
JP5832311B2 (en) Reconfiguration device, process allocation method, and program
US20150178436A1 (en) Clock assignments for programmable logic device
JP2016213637A (en) Error verification method of programmable logic device, and circuit formation method of programmable logic device
Švogor et al. Multi-criteria software component allocation on a heterogeneous platform
Oliveira et al. Mapping wired links in a hybrid wired-wireless network-on-chip

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
C14 Grant of patent or utility model
GR01 Patent grant
CF01 Termination of patent right due to non-payment of annual fee
CF01 Termination of patent right due to non-payment of annual fee

Granted publication date: 20150401