WO2021234882A1 - ウェブコンテンツの自動高速表示制御方法 - Google Patents
ウェブコンテンツの自動高速表示制御方法 Download PDFInfo
- Publication number
- WO2021234882A1 WO2021234882A1 PCT/JP2020/020025 JP2020020025W WO2021234882A1 WO 2021234882 A1 WO2021234882 A1 WO 2021234882A1 JP 2020020025 W JP2020020025 W JP 2020020025W WO 2021234882 A1 WO2021234882 A1 WO 2021234882A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- user terminal
- data
- processing unit
- web content
- original data
- Prior art date
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/90—Details of database functions independent of the retrieved data types
- G06F16/95—Retrieval from the web
- G06F16/957—Browsing optimisation, e.g. caching or content distillation
- G06F16/9577—Optimising the visualization of content, e.g. distillation of HTML documents
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/90—Details of database functions independent of the retrieved data types
- G06F16/95—Retrieval from the web
- G06F16/957—Browsing optimisation, e.g. caching or content distillation
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/90—Details of database functions independent of the retrieved data types
- G06F16/95—Retrieval from the web
- G06F16/958—Organisation or management of web site content, e.g. publishing, maintaining pages or automatic linking
Definitions
- the present invention relates to an automatic high-speed display control method for web contents.
- a user terminal such as a personal computer (PC), smartphone, or tablet
- the user can search for the information he / she wants to know at any time, and the user can browse the web content displayed on the user terminal as a search result. ..
- the user usually wants the search results to be displayed quickly on the user terminal. For this reason, it is important to improve the speed at which web content is provided to users.
- Non-Patent Document 1 Non-Patent Document 1
- CDN CONTENT DELIVERY NETWORK
- the website operator can contract with the company that provides the CDN and use the method of the CDN provided by the company.
- the domain of the website published by the administrator may be the domain specified by the website operator, not the domain of the company that provides the CDN. This allows website operators to provide users with a powerful method of CDN while maintaining their domain.
- CDN In the case of CDN, multiple web server groups are prepared, and the same data is stored in each web server. Then, when the user uses the CDN method, data is transmitted from the web server closest to the user terminal of the user to the user terminal of the user.
- the processing load of the web server becomes large. Since the processing capacity of a web server per unit time is limited, if a certain amount of access is concentrated on one web server, the processing time of that web server tends to be delayed. According to the CDN method, even if access from a large number of user terminals is concentrated on one web server at one time, a web server with extra capacity can be utilized through a communication network formed by a group of multiple web servers. Therefore, it is possible to prevent a delay in the processing time of the web server and respond to many data requests from the user terminal of the user at high speed.
- Non-Patent Document 2 a method for keeping web contents up-to-date.
- GULP a method for keeping web contents up-to-date
- the original data constituting the web content is adjusted so that the web content is displayed at high speed on the user terminal of the user.
- an adjustment for example, if an element that hinders the high-speed display of the user terminal of the user exists in the original data, the element included in the original data is deleted, and the element processing included in the original data is postponed. How to do, etc. Examples thereof include a method of reducing the transfer time of the original data by reducing the capacity and compression of the original data transferred to the user terminal of the user. These adjustments are usually made by the administrator of the website that provides the web content. With these adjustments, the web content is displayed at high speed on the user terminal of the user.
- the web content is displayed at high speed on the user terminal of the user when these adjustments are completed.
- the speed at which the web content is displayed on the user terminal of the user tends to be slower with time after the above adjustment is completed.
- the web content is updated daily, but in the updated web content, in addition to the part of the web content that has been adjusted earlier, a new part of the web content is added and the adjustment is completed. This is because the portion of web content that is not available increases.
- each original data has different points to be improved, which are required for high-speed display of web contents.
- the points to be improved required for high-speed display of web contents differ depending on the type of user terminal. If the same adjustments are made uniformly to the original data, problems may occur when displaying the web content for each user terminal. Therefore, it is necessary to individually grasp the contents of each original data and then implement measures suitable for each web content according to the type of user terminal. As a result, the administrator of the website that provides the web content is often required to perform many process processes at all times in order to display the web content at high speed. And these adjustments may take several days or more for one process.
- An object of the present invention is for each user terminal from the time when a request is transmitted from the user terminal to the server until the web content before adjustment can be input and accepted on the user terminal.
- the processing of the original data for displaying the web content before adjustment is completed, and the adjusted web content is displayed on each user terminal within a time shorter than the time.
- the present invention [1] After a request is sent from the user terminal to one or more servers that can communicate via the network, the original data for displaying the web content on the user terminal is sent from the server to the user terminal.
- a step in which a request transmitted from a user terminal to a request processing unit installed in the server is received by the application processing unit and the artificial intelligence unit, and The step in which the application processing unit sends the original data for displaying the web content to the data acquisition / processing unit, and Steps for the artificial intelligence unit to formulate a strategy for displaying web content for each user terminal,
- the step in which the data acquisition / processing unit receives the original data for displaying the web content on the user terminal, and Based on the above strategy plan, the step of processing the original data by the data acquisition / processing unit and generating a plurality of processed data, A step of selecting processed data for displaying web content for each user terminal from at least one resource selected from the group consisting of the original data and a plurality of processed data
- the step of transmitting the processed data for displaying the web content for each user terminal to each user terminal and displaying the web content for each user terminal, and the step. was carried out,
- the server consists of at least one execution environment selected from the group consisting of one or more physical machines, one or more virtual machines, and one or more containers.
- the steps to formulate the above-mentioned strategy plan are Of at least one resource selected from the group consisting of the original data and a plurality of processed data.
- For each user terminal a step of processing the original data in the data acquisition / processing unit based on the attribute, and It is intended to provide an automatic high-speed display control method of web contents, which is characterized by including.
- the resource includes at least one data selected from a group consisting of original data and a plurality of processed data.
- the processed data contains the object replaced program
- the object-replaced program is executed on the browser installed in the user terminal for each user terminal,
- the steps in which an object contained in an object-replaced program identifies a resource by identification information and the resource is executed,
- the present invention provides the automatic high-speed display control method for the web content according to the above [1].
- one of the present inventions is [3]
- the step of processing the original data by the data acquisition / processing unit based on the attribute is A step of selecting a program to be executed from the programs included in the processed data.
- the step of selecting processed data for displaying web content for each user terminal from at least one resource selected from the group consisting of the original data and a plurality of processed data.
- the present invention provides the automatic high-speed display control method of the web content according to the above [1] or [2], which includes at least one step selected from the group consisting of.
- the original data includes at least one of program data and binary data.
- the program data contains code having at least one selected from the group consisting of a markup language, a programming language, a style sheet, and a scripting language.
- the binary data contains at least one of an image file, a sound file and a video file.
- the resource contains at least one selected from the original data as well as a group consisting of multiple processed data.
- the step in which the processed data is generated is (1) A step in which unnecessary parts are deleted for each display environment of the user terminal from the code having at least one selected from the group consisting of the markup language, the programming language, the style sheet and the script language included in the original data.
- Including at least one step selected from the group consisting of (1) to (5) of The step of displaying web content for each user terminal is The step in which the request is sent from the user terminal to the request processing unit via the network, A step to specify the display environment for each user terminal from the request received by the request processing unit, After the request is sent from the browser of the user terminal to the request processing unit, resources are transmitted from at least one of the application processing unit and the data acquisition / processing unit to each user terminal and displayed on the browser of each user terminal. Steps and The present invention provides the automatic high-speed display control method for the web content according to any one of the above [1] to [3], including the above.
- one of the present inventions is [5]
- the step in which the original data is processed and a plurality of processed data are generated is Including a step of generating a plurality of processed data for each user terminal based on the model information data about the user terminal stored in the storage area where the data acquisition / processing unit can communicate.
- the step of selecting the processed data for displaying the web content for each user terminal from at least one resource selected from the group consisting of the original data and a plurality of processed data is For each user terminal, a step to specify the display environment of the display screen of the user terminal based on the model information data, and For each user terminal, a step to specify the part of the web content that is displayed first according to the display environment of the display screen of the user terminal, and The step in which the processed data for displaying the web content for each user terminal is transmitted to each user terminal and the web content is displayed for each user terminal is the display of the user terminal among the web contents.
- the present invention provides the automatic high-speed display control method for the web content according to any one of the above [1] to [4], including the above.
- the step in which the web content is displayed for each user terminal is The step in which the data corresponding to the part of the web content that is first displayed on the screen of the user terminal is sent to the user terminal, Event information indicating that a certain period of time has passed since the part of the web content corresponding to the part initially displayed on the screen of the user terminal is displayed on the user terminal, and the user operates the user terminal.
- a step in which at least one event information of the event information indicating that the user terminal has taken an action to display additional information is detected by at least one of the server and the browser.
- the present invention provides the automatic high-speed display control method for the web content according to any one of the above [1] to [5], including the above.
- one of the present inventions is [7]
- the step in which the web content is displayed for each user terminal is A step in which resources for displaying the part of the web content that is first displayed on the screen of the user terminal are sent to the user terminal, and Of the web content, the step that the time until the part that is first displayed on the screen of the user terminal can accept input is expanded and contracted, and
- the present invention provides the automatic high-speed display control method for the web content according to the above [6].
- one of the present inventions is [8] A step of calculating the engagement score between the user and the web content based on the user experience of the user who browses the web content, and Based on the engagement score, the time until the part of the web content that is first displayed on the screen of the user terminal can be input is expanded or contracted for each user terminal.
- the present invention provides the automatic high-speed display control method for the web content according to the above [7].
- the present invention [9] A program for implementing the automatic high-speed display control method for web contents according to any one of the above [1] to [8]. After a request is sent from the user terminal to one or more servers that can communicate through the network, the original data for displaying web content on the user terminal is sent from the server to the user terminal, and the web. By the time the content can be input on the user terminal A means for the application processing unit and the artificial intelligence unit to receive a request transmitted from the user terminal to the request processing unit installed in the server.
- the server consists of at least one execution environment selected from the group consisting of one or more physical machines, one or more virtual machines, and one or more containers.
- the means of formulating the above-mentioned strategy plan is Of at least one resource selected from the group consisting of the original data and a plurality of processed data.
- the present invention provides a storage device that records an automatic high-speed display control program for the web content described in the above [9].
- the present invention [11] A system for implementing the automatic high-speed display control method for web contents according to any one of the above [1] to [8]. After a request is sent from the user terminal to one or more servers that can communicate through the network, the original data for displaying web content on the user terminal is sent from the server to the user terminal, and the web. By the time the content can be input on the user terminal A means for the application processing unit and the artificial intelligence unit to receive a request transmitted from the user terminal to the request processing unit installed in the server.
- the server consists of at least one execution environment selected from the group consisting of one or more physical machines, one or more virtual machines, and one or more containers.
- the means of formulating the above-mentioned strategy plan is Of at least one resource selected from the group consisting of the original data and a plurality of processed data.
- the web content is displayed on the user terminal after a request is sent from the user terminal to one or more servers that can communicate through the network.
- the processing of the original data for displaying the web content is completed for each user terminal and used.
- the processed data is transmitted to each user terminal and the web content is displayed on the user terminal. Therefore, according to the method according to the present invention, even if the first request is made from the user terminal that has not sent the request to the server so far, the web content based on the original data is the user terminal from the first time. It is possible to realize a state in which web contents based on processed data can be accepted for each user terminal in a shorter time than the time when input can be accepted in.
- the original data for displaying web contents can be crawled and monitored by a data acquisition / processing unit or the like. Therefore, if there is a change in the original data, processed data is generated in response to the change, and even if there is a request from the user terminal after the change in the original data, the processed data is supported from the first time. Can provide web content.
- the original data transmitted from the server is transmitted to the user terminal as it is, before the original data is transmitted to the user terminal. It is taken out from the application processing unit to the data acquisition / processing unit, and the original data is processed based on the strategy devised by the artificial intelligence unit. Then, the processed data is transmitted to each user terminal, and the web content based on the processed data is displayed on the user terminal for each user terminal. Therefore, it is not necessary for a human to visually check and edit the state of the original data and the state of the processed data, and automatic high-speed display of the web content is realized.
- the original data, the processed data and the like can be communicated with the user terminal through the request processing unit and the like. Therefore, the automatic high-speed display control method for the web content of the present invention can be implemented simply by installing a request processing unit on the server and by performing at least one of migration and DNS changes as necessary. It is possible to realize automatic high-speed display of web contents by operation.
- FIG. 1 is a schematic diagram for explaining an automatic high-speed display control system for implementing an automatic high-speed display control method for web contents according to the first embodiment of the present invention.
- FIG. 2 is a schematic diagram for explaining the application processing unit A used in the present invention.
- FIG. 3 is a schematic diagram for explaining the artificial intelligence unit used in the present invention.
- FIG. 4 is a schematic diagram for explaining the request processing unit used in the present invention.
- FIG. 5 is a schematic diagram for explaining the data acquisition / processing unit used in the present invention.
- FIG. 6 is a diagram for explaining an example of the hardware configuration of the user terminal 101 used in the automatic high-speed display control method of the web content according to the first embodiment of the present invention.
- FIG. 1 is a schematic diagram for explaining an automatic high-speed display control system for implementing an automatic high-speed display control method for web contents according to the first embodiment of the present invention.
- FIG. 2 is a schematic diagram for explaining the application processing unit A used in the present invention.
- FIG. 3 is
- FIG. 7 is a diagram for explaining a hardware configuration of an application execution server used in the automatic high-speed display control method for web contents according to the first embodiment of the present invention.
- FIG. 8 is a schematic diagram for explaining the details of the hardware configuration included in the storage device 1101 of the application execution server 103 used in the automatic high-speed display control method of the web content according to the first embodiment of the present invention. ..
- FIG. 9 is a schematic diagram for explaining how a request from a user is processed.
- FIG. 10 is a schematic diagram for explaining how a request from a user is processed.
- FIG. 11 is a schematic diagram for explaining how a request from a user is processed.
- FIG. 12 is a conceptual diagram for explaining how the original data 200 is processed.
- FIG. 13 is a conceptual diagram for explaining how the original data 200 is processed.
- FIG. 14 is a flowchart for explaining the relationship between the generation of processed data and the optimization of resources.
- FIG. 15 is a conceptual diagram showing an example of a model information file 1526 stored in the setting file storage unit 1523 of the data acquisition / processing unit D, which is used in the first embodiment of the present invention.
- FIG. 16 is a conceptual diagram for explaining the correspondence between the HTML file before processing and the optimized HTML file.
- FIG. 17 is a flowchart for explaining a step in which an unnecessary portion is deleted for each display environment of the user terminal.
- FIG. 18 is a flowchart for explaining a step in which a necessary portion is compressed for each display environment of a user terminal.
- FIG. 19 is a diagram for explaining a step in which the script language file portions 108a108d described in the HTML file 113 are executed in series.
- FIG. 20 is a diagram for explaining a step in which the script language file portion 108a108C and the script language file 108d described in the HTML file 113 are executed in parallel.
- FIG. 21 is a diagram for explaining a step in which the execution of the script language file 108d described in the HTML file 113 is postponed.
- FIG. 22 is a flowchart for explaining a step in which processed data is generated.
- FIG. 23 is a flowchart for explaining a step in which a signal notifying that the original data 200 has been modified such as addition, movement, deletion, or change is transmitted to the operation control unit.
- FIG. 24 is an automatic high-speed display control system for implementing the automatic high-speed display control method for web contents according to the second embodiment of the present invention, and is a schematic diagram describing a reverse proxy type configuration.
- FIG. 25 is a diagram for explaining the details of the hardware configuration included in the storage device 1701 of the reverse proxy server 1703 used in the automatic high-speed display control method of the web content according to the second embodiment of the present invention.
- FIG. 26 is a schematic diagram for explaining how a request from a user is processed.
- FIG. 27 is a schematic diagram for explaining how a request from a user is processed.
- FIG. 28 is a schematic diagram for explaining how a request from a user is processed.
- FIG. 29 is an automatic high-speed display control system for implementing the automatic high-speed display control method for web contents according to the third embodiment of the present invention, and is a schematic diagram describing a nanoagent type configuration.
- FIG. 30 is a schematic diagram for explaining how a request from a user is processed.
- FIG. 31 is a schematic diagram for explaining how a request from a user is processed.
- FIG. 32 is a schematic diagram for explaining how a request from a user is processed.
- FIG. 33 is an automatic high-speed display control system for implementing the automatic high-speed display control method for web contents according to the third embodiment of the present invention, and is a schematic diagram describing a SAAS type configuration.
- FIG. 34 is a schematic diagram for explaining how a request from a user is processed.
- FIG. 30 is a schematic diagram for explaining how a request from a user is processed.
- FIG. 31 is a schematic diagram for explaining how a request from a user is processed.
- FIG. 32 is a schematic diagram for
- FIG. 35 is a schematic diagram for explaining how a request from a user is processed.
- FIG. 36 is a schematic diagram for explaining how a request from a user is processed.
- FIG. 37 is a conceptual diagram for explaining a mechanism for displaying the web content 211 on the user terminal 101 at high speed.
- FIG. 38 is a flowchart for explaining how the user experience is reflected in the step of realizing the automatic high-speed display of the web content.
- the automatic high-speed display control system for implementing the automatic high-speed display control method for web contents according to the present invention includes at least an application processing unit A, an artificial intelligence unit B, a request processing unit C, and a data acquisition / processing unit D.
- the all-in-one type (Embodiment 1) and the reverse proxy type (Embodiment 1) can be configured by combining the four units A to D. It is roughly classified into four types: Embodiment 2), nano-agent type (Embodiment 3) and SassS type (Embodiment 4).
- Embodiment 2 Embodiment 2
- nano-agent type Embodiment 3
- SassS type Embodiment 4
- FIG. 1 is a schematic diagram for explaining an automatic high-speed display control system for implementing an automatic high-speed display control method for web contents according to the first embodiment of the present invention.
- the first embodiment of the present invention as an example, four units A to D are constructed in one execution environment.
- the application execution server 103 is adopted as an example of the execution environment.
- the user can operate the user terminal 101 to communicate with the application execution server 103 through the network 102.
- a request is transmitted from the user terminal 101 operated by the user to the request processing unit C through the network 102.
- This request requests the application execution server 103 to transmit data for displaying web contents on a browser or the like mounted on the user terminal 101.
- This request is first sent to the request processing unit C.
- the user terminal 101 used in the present invention is not limited to one, and two or more can be used. Further, it is sufficient that the user terminal 101 and the application execution server 103 can communicate with each other through the network 102.
- the mutual positional relationship between the user terminal 101 and the application execution server 103 is not particularly limited.
- the request processing unit C has a function of first receiving a request transmitted from the user terminal 101.
- the original data stored in the application processing unit A is processed based on the request transmitted from the user terminal 101.
- This original data is data for displaying the web content for each user terminal 101.
- the processing of the original data is carried out by the data acquisition / processing unit D based on the strategic plan drafted by the artificial intelligence unit B. First, these four units A to D will be described.
- FIG. 2 is a schematic diagram for explaining the application processing unit A used in the present invention.
- the application processing unit A used in the present invention stores the original data 200 and the like for displaying the web contents, and is included in the user terminal 101, the request from each user terminal 101 to each unit and the like, and the original data 200. Mainly responsible for the function of transmitting resources, etc.
- each file in the disclosure of the present invention is an example, and means that the data can be managed in a file format.
- humans can visually manage the data through CLI or the like.
- FIG. 2 schematically shows that data can be managed in a file format.
- the original data 200 includes, for example, an HTML file 113 necessary for displaying web contents on the user terminal 101, resources associated with the HTML file 113, and the like.
- the HTML file 113 is dynamically or statically generated, for example, by a program such as PHP105 associated with database 1106.
- resources such as a CSS file 107, a script language file 108, and an image file 109 referenced by the HTML file 113 are stored in the application processing unit A. These resources can be appropriately referenced and executed from the HTML file 113. It is also possible to execute a program such as a CSS style sheet or Javascript (registered trademark) directly described inside the HTML file 113.
- a program such as a CSS style sheet or Javascript (registered trademark) directly described inside the HTML file 113.
- the user terminal 101 receives the HTML file 113 or the like transmitted to the user terminal 101. Then, the HTML file 113 or the like received by the user terminal 101 is executed by the browser or the like mounted on the user terminal 101.
- resources such as the CSS file 107 which is a style sheet associated with the HTML file 113 and the like, the script language file 108 which is a program, and the like are executed along with the execution. By this execution, web contents and the like based on the original data 200 and the like can be displayed on the user terminal 101.
- FIG. 3 is a schematic diagram for explaining the artificial intelligence unit used in the present invention.
- the artificial intelligence unit B used in the present invention mainly has a function as a control tower, which gives a guideline for operation to each of the units A to D.
- the original data 200 stored in the application processing unit A is processed according to each display environment of the user terminal 101, and the processed data 201 is processed for each user terminal 101.
- Generate one or more strategic proposals such as selecting the most suitable one, determining the execution order, execution timing, etc. of the program included in the processed data 201.
- the artificial intelligence control unit 1410 of the artificial intelligence unit B generates a strategy file 1412 as a strategy plan in the artificial intelligence storage area 1430.
- a strategy plan for displaying the web content for each user terminal 101 until the web content is displayed on the user terminal 101 using the original data 200 and input can be accepted by the browser of the user terminal 101 or the like is proposed. Generated. Then, based on this strategic plan, the original data 200 is processed, selected, distributed, and the like. As a result, the web content is displayed on the user terminal 101 using the original data 200, and the web content is displayed for each user terminal 101 using the processed data until the input can be accepted by the user terminal 101. Will be realized.
- This strategy proposal can be stored, for example, as a strategy file 1412 in a storage area that can be used by the artificial intelligence unit B.
- the strategy file 1412 is not limited to the case where it is stored inside the artificial intelligence unit B, and for example, it can be stored outside the artificial intelligence unit B so that the artificial intelligence unit B can use it.
- the strategy plan is described as a strategy file 1412 as an example, but the strategy plan is not limited to the case where it is saved in a file format.
- the strategy plan may be saved in a format that can be executed by the artificial intelligence unit B, and can also be saved and utilized in a database or the like that can be used by the execution server 103.
- FIG. 4 is a schematic diagram for explaining the request processing unit used in the present invention.
- the request processing unit C used in the present invention serves as a so-called communication gate that first receives a request transmitted from a browser or the like of a user terminal 101 operated by a user. Mainly responsible for the function of.
- FIG. 4 illustrates a case where the application processing unit A, the artificial intelligence unit B, the request processing unit C, and the data acquisition / processing unit D are arranged on the application execution server 103 as an example.
- each of the application processing unit A, the artificial intelligence unit B, the request processing unit C, and the data acquisition / processing unit D used in the present invention is implemented under one execution environment.
- an execution environment is an environment constructed by at least one selected from a group consisting of one or more physical machines, one or more virtual machines, and one or more containers. say.
- the application execution server 103 which is one execution environment, is used.
- This execution environment can be operated as if one physical machine actually exists even when it is composed of, for example, a plurality of physical machines, a plurality of virtual machines, a plurality of containers, and the like.
- a request is transmitted from the browser or the like of the user terminal 101 operated by the user.
- This request is received by the application processing unit A, the artificial intelligence unit B, the data acquisition / processing unit D, and the like through the network 102 and the request processing unit C.
- the response corresponding to the request is transmitted from the application processing unit A, the artificial intelligence unit B, the data acquisition / processing unit D, and the like.
- the response is received by the user terminal 101 through the network 102.
- FIG. 5 is a schematic diagram for explaining the data acquisition / processing unit used in the present invention.
- the data acquisition / processing unit D used in the present invention has a function of acquiring original data 200 or the like from the application processing unit A through the request processing unit C and optimizing resources suitable for each user terminal 101. Mainly responsible for.
- the data acquisition / processing unit D includes, for example, an optimization unit d100, a crawler unit d200, a control unit d300, and the like.
- the optimization of the HTML file 113 stored in the application processing unit A, the CSS file 107, and the script language are based on the strategy file 1412 in which the strategy plan devised by the artificial intelligence unit B is described.
- Resources such as file 108 and image file 109 are optimized.
- resources such as HTML file 113, CSS file 107, script language file 108, and image file 109 stored in the application processing unit A are crawled, and their data acquisition, storage, monitoring, etc. I do.
- the user terminal 101 and the application execution server 103 can communicate with each other through the network 102 by a wired connection or a wireless connection.
- the user terminal 101 include mobile information terminals such as smartphones and feature phones, information display terminals such as PDAs (PERSONAL DIGITAL ASSISTANT) and tablets, wearable communication terminals such as smart watches and smart glasses, and PCs (PERSONAL). Computers such as COMPUTER) can be mentioned.
- PDAs PERSONAL DIGITAL ASSISTANT
- wearable communication terminals such as smart watches and smart glasses
- PCs PERSONAL
- Computers such as COMPUTER
- one user terminal 101 is illustrated in FIG. 4, one or more user terminals 101 can actually be used.
- Examples of the network 102 used in the first embodiment of the present invention include VPN (VIRTUAL PRIVATE NETWORK), LAN (LOCAL AREA NETWORK), WAN (WIDE AREA NETWORK), PSTN (PUBLIC SWITCHED TELEPHONE NETWORK), the Internet, and an intranet.
- VPN VIRTUAL PRIVATE NETWORK
- LAN LOCAL AREA NETWORK
- WAN WIDE AREA NETWORK
- PSTN PUBLIC SWITCHED TELEPHONE NETWORK
- the network 102 can provide an environment in which the user terminal 101, various execution environments, and the like can communicate with each other through a wire using an optical fiber, a communication wire, or the like, or a radio wave using an electromagnetic wave such as an infrared ray or a radio wave.
- the application execution server 103 has a function of providing the user terminal 101 with information such as a website including program data such as characters, symbols, and numbers in each country's language, and binary data such as images, videos, and sounds. ..
- the configuration of the application execution server 103 is not limited as long as it has a function of displaying web contents based on original data on the user terminal 101 through the network 102.
- the application execution server 103 is equipped with at least an application processing unit A, an artificial intelligence unit B, a request processing unit C, and a data acquisition / processing unit D.
- FIG. 6 is a diagram for explaining an example of the hardware configuration of the user terminal 101 used in the automatic high-speed display control method of the web content according to the first embodiment of the present invention.
- the user terminal 101 includes, for example, a hardware configuration such as a central processing unit 1000 (CPU, CENTRAL PROCESSING UNIT), a storage device 1001, a communication interface 1002, an input device 1003, and a display device 1004. Each of these hardware configurations is connected and can communicate with each other.
- the central processing unit 1000 is equipped with a circuit capable of executing the contents described in the program, and can execute various processes.
- the configuration of the central processing unit 1000 is not limited to one equipped with one microprocessor, and may include a multiprocessor equipped with two or more processors.
- the storage device 1001 can store data, programs, and the like necessary for the operation of the user terminal 101.
- the storage device 1001 includes, for example, a main storage unit 1001a and an auxiliary storage unit 1001b.
- a main storage unit for example, a volatile memory such as RAM is used.
- auxiliary storage unit for example, a non-volatile memory such as a hard disk, a solid state disk, or a flash memory is used.
- the storage device 1001 stores, for example, an application program for a browser that can be used in the user terminal 101. Web contents can be viewed on the user terminal 101 by this browser.
- the communication interface 1002 receives, for example, various data transmitted from the request processing unit C or the like via the network 102, and transfers the various data to the central processing unit 1000. Further, the communication interface 1002 transmits various data from the user terminal 101 to the request processing unit C or the like via the network 102.
- the input device 1003 is a device for inputting various operations to the user terminal 101.
- the input device 1003 for example, one integrated with the display device 1004 may be used, or one in which the input device 1003 and the display device 1004 are separated may be used.
- the input device 1003 can receive various data inputs from the user.
- the various received data are transferred to the central processing unit 1000.
- Examples of the input device 1003 include a touch panel, a touch pad, a mouse, a keyboard, a camera, a microphone, and the like.
- input of various data is accepted by an operation with a user's finger, an operation with a dedicated input tool such as a touch pen, or the like.
- keyboard for example, input of various data is accepted by selecting various keys mounted on the keyboard and operating various keys at the same time.
- the input of various data is accepted by analyzing the image taken by the camera and converting it into a signal that can be transferred to the central processing unit 1000.
- the display device 1004 can display various data processed by the central processing unit 1000. Examples of the display device 1004 include a liquid crystal panel, an LED panel, an organic EL panel, a liquid crystal monitor, an LED monitor, an organic EL monitor, and the like.
- the display device 1004 may be a touch panel that accepts input of various data.
- the configuration of the application execution server 103 is not particularly limited as long as it is constructed from one execution environment as a whole.
- a case where the hardware configuration of the application execution server 103 is configured by a physical machine will be described as an example.
- the configuration of the application execution server 103 is not limited to the case where the application execution server 103 is configured by a physical machine.
- An execution environment composed of one physical machine even if at least one execution environment selected from a group consisting of one or more physical machines, one or more virtual machines, one or more containers, etc. is selected. It is possible to construct an execution environment similar to that of the above and use it in the first embodiment of the present invention.
- FIG. 7 is a diagram for explaining a hardware configuration of an application execution server used in the automatic high-speed display control method for web contents according to the first embodiment of the present invention.
- the application execution server 103 includes, for example, hardware configurations such as a central processing unit 1100 (CPU, CENTRAL PROCESSING UNIT), a storage device 1101, a communication interface 1102, an input device 1103, and a display device 1104. Each of these hardware configurations is connected and can communicate with each other.
- the central processing unit 1100 is equipped with, for example, a circuit capable of executing a program stored in a storage area of the storage device 1101 or the like, and can execute various processes.
- the configuration of the central processing unit 1100 is not limited to one equipped with one microprocessor, and may include a multiprocessor equipped with two or more processors.
- the storage device 1101 can store, for example, data, programs, and the like necessary for the operation of the application processing unit A.
- the storage device 1101 includes, for example, a main storage unit 1101a and an auxiliary storage unit 1101b.
- a volatile memory such as RAM
- auxiliary storage unit for example, a non-volatile memory such as a hard disk, a solid state disk, or a flash memory is used.
- each unit such as the request processing unit C is installed inside the storage device 1101.
- the units A to D may be installed in one storage device 1101, or may be distributed and installed in different storage devices as long as the units A to D can communicate with each other.
- the communication interface 1102 receives various data transmitted from the user terminal 101 or the like through the network 102 and transfers various data to the central processing unit 1100 or the like. Further, various data are transmitted from the request processing unit C to the user terminal 101 through the network 102.
- the input device 1103 is a device for inputting data to each unit or the like from A to D.
- the input device 1103 for example, one integrated with the display device 1104 may be used, or one in which the input device 1103 and the display device 1104 are separated may be used.
- the input device 1103 can accept input of various data by the administrator of the application execution server 103.
- the various received data are transferred to the central processing unit 1100.
- Examples of the input device 1103 include a touch panel, a touch pad, a mouse, a keyboard, a camera, a microphone, and the like.
- the display device 1104 can display various data processed by the central processing unit 1100. Examples of the display device 1104 include a liquid crystal panel, an LED panel, an organic EL panel, a liquid crystal monitor, an LED monitor, an organic EL monitor, and the like.
- the display device 1104 may be a touch panel that accepts input of various data.
- the administrator of the application execution server 103 uses an input device 1103 such as CLI (COMMAND LINE INTERFACE) displayed on the display device 1104 to display, for example, characters, numbers, symbols, and the like. Enter the data and do it.
- CLI COMMAND LINE INTERFACE
- FIG. 8 is a schematic diagram for explaining the details of the hardware configuration included in the storage device 1101 of the application execution server 103 used in the automatic high-speed display control method of the web content according to the first embodiment of the present invention. ..
- OS OPERATING SYSTEM
- OS1105 is introduced in the storage device 1101 to control the central processing unit 1100, each storage area of the storage device 1101, each program, and the like.
- OS1105 is available from the market for a fee or for free.
- the storage device 1101 includes an original data storage area 104 and a database 1106.
- the original data 200 displayed on the user terminal 101 is stored in the original data storage area 104.
- the storage device 1101 is provided with an application processing unit A, an artificial intelligence unit B, a request processing unit C, and a data acquisition / processing unit D.
- the automatic high-speed display control method for web contents according to the first embodiment of the present invention operates, for example, a program included in each unit on the OS 1105 included in the operating environment by a central processing unit 1500. Will be realized.
- the application execution server 103 includes an application processing unit A.
- the application processing unit A includes a processed data storage area 130 in addition to the original data storage area 104 and the database 1106 for storing the original data 200.
- the processed data storage area 130 can be provided in, for example, the data acquisition / processing unit D in addition to the application processing unit A.
- the application processing unit A installed in the storage device 1101 of the application execution server 103 may include, for example, a monitoring control unit 1115, an operation control unit 1116, an operation control storage unit 1117, and the like, if necessary.
- the operation control storage unit 1117 of the application processing unit A is necessary for the operation control unit 1116 to operate together with data related to the type of OS1105, the execution environment, etc. so as to correspond to various applications described by the program. Data is stored.
- the monitoring control unit 1115 can automatically detect the modification.
- the signal notifying that the original data 200 has been modified is transmitted to at least one of the artificial intelligence unit B and the data acquisition / processing unit D.
- the monitoring control unit 1115 monitors the original data 200 stored in the application processing unit A. For example, in the case of FIG. 2, addition, movement, deletion, or change to any of the resources such as PHP file 105, HTML file 113, CSS file 107, script language file 108, and image file 109 included in the original data 200. If there is a modification such as, this modification can be detected.
- the monitoring control unit 1115 can be installed in the application processing unit A by using the function. If the OS 1105 of the application execution server 103 does not have a function that can realize the monitoring control unit 1115, a program having a function that can monitor the change of the original data 200 can be installed in the application processing unit A to handle the change. ..
- the monitoring control unit 1115 is not particularly limited to be installed in the application processing unit A, and may be installed in the data acquisition / processing unit D in place of the application processing unit A or together with the application processing unit A. It may be installed in at least one of the application processing unit A and the data acquisition / processing unit D.
- the application processing unit A installed in the storage device 1101 of the application execution server 103 may include, for example, a time execution control unit 1120.
- the time execution control unit 1120 of the application execution server 103 can obtain an accurate current time through the network 102.
- the time execution storage unit 1521 of the time execution control unit 1120 stores an execution program 1122 that describes information on when, at what timing, and what to execute.
- the time execution control unit 1120 can also be installed in the data acquisition / processing unit D.
- the time execution control unit 1120 can execute various steps that need to be executed at a specified time on a specified date and time.
- the artificial intelligence unit B installed in the storage device 1101 of the application execution server 103 includes an artificial intelligence control unit 1410.
- the artificial intelligence control unit B can execute, for example, a program or the like described in a programming language such as Python, C ++, or Javascript (registered trademark) in an execution environment including an OS or the like mounted on the application execution server 103.
- the artificial intelligence control unit 1410 can generate the strategy file 1412.
- the generated strategy file 1412 is stored in the artificial intelligence storage area 1430. Further, the strategy file 1412 can be saved in association with the database 1106 or the like.
- the request processing unit C has a function of enabling communication with the user terminal 101 and the like through the network 102 and communicating data between the units and the like. As shown in FIGS. 4 and 8, the request processing unit C installed in the storage device 1101 of the application execution server 103 inputs data through the network 102, for example, via the communication interface 1102 of the application execution server 103. It is provided with a communication data control unit 1510 capable of output.
- the communication data control unit 1510 can process a request from the outside to the application execution server 10, a request from each unit, and a response to these requests by a program such as Javascript (registered trademark).
- each of the application processing unit A, the artificial intelligence unit B, the data acquisition / processing unit D, and the like maintains a state in which they can communicate with the request processing unit C. be able to.
- the data acquisition / processing unit D installed in the storage device 1101 of the application execution server 103 can include, for example, an optimization unit d100, a crawler unit d200, and a control unit d300. ..
- the optimization unit d100, the crawler unit d200, and the control unit d300 can be executed on an execution environment including an OS mounted on the application execution server 10 by a programming language such as Python, C ++, or Javascript (registered trademark).
- the data processed by the data acquisition / processing unit D can be stored in the database 1106 or the like.
- optimization unit d100 the crawler unit d200, and the like are controlled by the program described in the control unit d300 of the data acquisition / processing unit D.
- the crawler configured by the program mounted on the crawler unit d200 can crawl, acquire, and store the original data 200 and the like stored in the original data storage area 104 of the application processing unit A. Further, the original data 200 and the like are monitored, and when the original data 200 and the like are changed, resources such as processed data corresponding to the change are generated by a program mounted on the optimization unit d100.
- control unit d300 of the data acquisition / processing unit D can also function as a web worker. It is also possible to independently execute various program processes in the background without being influenced by the execution of the application execution server 103.
- the original data 200 used in the present invention is dynamically or statically generated and stored in the original data storage area 104 in which the application processing unit A is installed.
- the original data 200 for displaying the web contents on the user terminal 101 is 200.
- it can be transmitted from the application execution server 103 to the user terminal 101 as it is, and the web content can be displayed on the user terminal 101.
- the case where the automatic high-speed display control method according to the present invention is implemented and the automatic high-speed display control method according to the present invention based on the original data 200 are used. Delivery of web content when not implemented can be switched between each other.
- Examples of the original data 200 used in the disclosure of the present invention include one or more of program data (1), binary data (2), and the like.
- program data (1) for example, Markup languages such as HTML and XML, Programming languages such as PHP, Perl, Java®, C, Lua, etc. Data including one or more of style sheets such as CSS and SCSS, script languages such as JavaScript (registered trademark), TypeScript (registered trademark), and Jquery (registered trademark) which is a library of Javascript (registered trademark).
- Examples include one or more data such as image files, sound files, video files, and the like.
- the program data (1) includes, for example, numerical data, symbol data, character data, and the like. Further, the binary data (2) includes data that can be perceived by the five human senses, such as sound data, image data, and moving image data.
- Markup languages are used for documents that describe the basic structure of websites, such as HTML and XML.
- programming languages such as PHP, Perl, Java (registered trademark), C, and Lua are languages that can actually operate the application execution server 103 and the like and display web contents for each user terminal 101.
- a style sheet such as CSS or SCSS is a program that mainly controls a design configuration such as a position, size, and type of characters, numbers, symbols, images, etc. displayed on a browser or the like of a user terminal 101.
- script languages such as JavaScript (registered trademark), TypeScript (registered trademark), and Jquery (registered trademark), which is a library of JavaScript (registered trademark), are mainly buttons by users such as websites displayed on the user terminal 101. It is a program that performs a wide variety of processes necessary for displaying web contents on the user terminal 101, including processes such as click operations and scroll operations.
- FIG. 2 described above shows the relationship between the original data storage area 104 of the storage device 1101 installed in the application processing unit A used in the first embodiment of the present invention and each file stored in the processed data storage area 130. It is a schematic diagram for demonstrating.
- the PHP programming language is stored in the original data storage area 104 as the data of the PHP file 105. Further, the database 1106 stores data necessary for displaying the PHP file 105.
- the PHP described in the PHP file 105 is used as an example as a programming language, but the programming language used in the present invention is PHP. It is not limited, and can be appropriately selected and used as long as it can realize the display of web contents such as Lua.
- the data about the CSS file 107, the script language file 108, and the image file 109 are stored in the original data storage area 104.
- the program described in the PHP file 105 or the like refers to the data necessary for displaying the web content on the browser or the like of the user terminal 101 from the database 1106.
- access information to the CSS file 107, the script language file 108, and the image file 109 is described in the PHP file 105 or the like, and the data of the CSS file 107, the script language file 108, and the image file 109 are used from the PHP file 105 or the like.
- Web content to be displayed on the user terminal 101 can be generated.
- the variables defined in the PHP file 105 etc. are stored in the database 1106.
- the database 1106 is provided with data reading means, data writing means, data storage means, data search means, and the like.
- the data corresponding to the variables described in the PHP file 105 or the like is written and saved in the database 1106 in advance. Then, the data stored in the database 1106 can be recalled based on the variables described in the PHP file 105 or the like.
- a browser or the like mounted on the user terminal 101 operated by the user can execute the program described in the PHP file 105 or the like to generate the HTML file 113, and the application processing unit A can generate the PHP file 105 or the like.
- the described program can also be executed to generate the HTML file 113.
- the HTML file 113 may be statically and pre-generated, or may be dynamically generated before or immediately after the request from the user terminal 101. Further, it may be dynamically generated each time the program described in the PHP file 105 or the like is executed. Normally, the HTML file 113 is dynamically generated. The same applies hereinafter.
- the CSS file 107 and the script language file 108 referenced by the HTML file 113 and the like may also be statically generated in advance, or may be stored in the PHP file 105 before or immediately after the request from the user terminal 101. It may be dynamically generated each time the described program is executed.
- FIGS. 9 to 11 are schematic diagram for explaining how a request from a user is processed.
- the vertical axis represents time and the horizontal axis represents data flow.
- the request transmitted from the browser or the like of the user terminal 101 operated by the user is transmitted to the request processing unit C through the network 102.
- the request processing unit C that has received the request sends the request to the application processing unit A.
- the application processing unit A transmits the original data 200 for displaying the web content on the user terminal 101 of the user to the request processing unit C as a response.
- this response is transmitted from the request processing unit C to the user terminal 101 through the network 102.
- the transmitted response is received by the user terminal 101.
- the web content based on the original data 200 is displayed on the user terminal 101 by a browser or the like mounted on the user terminal 101.
- the request transmitted from the browser or the like of the user terminal 101 operated by the user is transmitted to the request processing unit C through the network 102.
- the request processing unit C Upon receiving the request, transmits the request to the application processing unit A.
- the application processing unit A dynamically generates, for example, an HTML file 113 for displaying the web content on the user terminal 101 of the user.
- the HTML file 113 is an example of original data having a part that refers to a resource.
- Examples of the original data having a portion that refers to a resource include one type or two or more types such as an HTML file, an XML file, and a PHP file.
- the download can be waited for based on the strategy proposed by the artificial intelligence unit B.
- the resource referenced by the HTML file 113 stored in the original data storage area 104 of the application processing unit A is transmitted to the user terminal 101 through the network 102 via the application processing unit A and the request processing unit C. Means to be done.
- the request processing unit C interrupts the processing in which the download as a response is executed from the application processing unit A via the request processing unit C to the user terminal 101 through the network 102, and the data of the HTML file 113 is as shown in FIG. To get.
- the request transmitted from the browser or the like of the user terminal 101 is transmitted to the request processing unit C through the network 102.
- the request is transmitted from the request processing unit C to the application processing unit A.
- the application processing unit A Upon receiving the request, the application processing unit A transmits data such as an HTML file 113 to the request processing unit C as a response.
- the acquired data such as the HTML file 113 is transmitted from the request processing unit C in the order of the artificial intelligence unit B and the data acquisition / processing unit D. Based on the strategy plan drafted by the artificial intelligence unit B, the data acquisition / processing unit D optimizes the HTML file 113 and the like.
- the data about the optimized HTML file 113z is transmitted to the user terminal 101 of the user through the network 102 via the data acquisition / processing unit D, the artificial intelligence unit B, and the request processing unit C.
- the HTML file 113 which is one of the original data having a portion that refers to the resource, is referenced by the HTML file 113 and contains information about the resource for displaying the web content on the browser or the like of the user terminal 101. ing.
- the part that refers to the resource included in the HTML file 113 is replaced with the object of the program, and the optimized HTML file 113z is generated. Each of these objects is given identification information to identify the corresponding resource.
- the optimized HTML file 113z is an example of an object-replaced program.
- the network is based on the object described in the optimized HTML file 113z.
- a request is transmitted from the request processing unit C to the data acquisition / processing unit D through 102.
- the optimum resource is selected from the data acquisition / processing unit D that has received the request, and the optimum resource is transmitted to the user terminal 101 through the network 102 via the request processing unit C.
- the request processing unit C acquires the corresponding resource from the original data 200 stored in the application processing unit A, as shown in FIG.
- the acquired resource is transmitted from the application processing unit A to the user terminal 101 via the request processing unit C.
- the optimum resource does not exist, the corresponding resource from the original data 200 is used.
- the generation and selection of the optimum resource are advanced in the background.
- the optimum resource is generated, the optimum resource is transmitted from the data acquisition / processing unit D to the user terminal 101 via the request processing unit C and the network 102. Then, the resource used for each user terminal 101 is replaced with the optimum resource.
- the user terminal 101 and the application execution server 103 communicate with each other, for example, before a request is transmitted to the application execution server 103 from a browser or the like mounted on the user terminal 101 by the user.
- the crawl control unit 1510 of the crawler unit d200 installed in the data acquisition / processing unit D crawls the original data 200 or the like stored in the application execution server 103 when the data is not being executed.
- resources optimized by the control unit 1610 of the optimization unit d100 installed in the data acquisition / processing unit D are generated and stored in the database 1106.
- the crawler unit d200 installed in the data acquisition / processing unit D periodically crawls the original data 200 stored in the application processing unit A, automatically generates optimization resources, and has a step of accumulating in the database 1106. Will be implemented.
- the original data 200 is monitored by a program mounted on at least one of the data acquisition / processing unit D and the application processing unit A.
- the crawler unit d200 installed in the data acquisition / processing unit D crawls the original data 200, and an optimization resource is automatically generated.
- the optimization resource generated by crawling, monitoring, etc. is continuously downloaded from each user terminal 101 to the user terminal 101 every time there is a request.
- the reference portion of all the resources included in the program data in which at least one of the markup language and the programming language included in the original data 200 for displaying the web content on the user terminal 101 is described.
- the program data for displaying the web content on the user terminal 101 for example, at least one of markup languages such as HTML and XML, and programming languages such as PHP, Perl, Java (registered trademark), C, and Lua is described.
- the program data etc. that have been created can be mentioned.
- the HTML file 113 is exemplified as an example of data in which at least one of the markup language and the programming language included in the original data 200 for displaying the web content on the user terminal 101 is described.
- the HTML file 113 includes, for example, a head portion 113i, a body portion 113j, and the like.
- the head portion 113i is, for example, a style sheet such as CSS and SCSS necessary for executing the HTML file 113, JavaScript (registered trademark), TypeScript (registered trademark), and Jquery (registered trademark) which is a library of JavaScript (registered trademark).
- JavaScript registered trademark
- TypeScript registered trademark
- Jquery registered trademark
- a reference portion such as program data, an image file, a sound file, a binary data such as a moving image file, which is displayed on the browser of the user terminal 101 and read by the user who operates the user terminal 101, is provided.
- program data an image file
- a sound file a binary data such as a moving image file
- program data displayed on a browser or the like of the user terminal 101 and read by a user who operates the user terminal 101, and reference portions of various programs or the like necessary for controlling the browser or the like of the user terminal 101 are described. There is.
- the optimized HTML file 113z newly generated as the replaced program data is illustrated.
- the replaced program data includes, for example, data described in a markup language such as an HTML file and an XML file, and data described in a programming language such as a PHP file.
- all of the reference portions are converted into objects together with the identification information.
- the HTML file 113 includes a reference part, which is a reference part of a style sheet, a program, etc. directly described in the HTML file 113, and a style sheet, a program described outside the HTML file 113. There is a reference part such as.
- the rules applied when describing the reference part are predetermined in the markup language, etc. According to this rule, it is possible to distinguish which part corresponds to the reference part in the HTML file 113.
- the optimization unit d100 installed in the data acquisition / processing unit D replaces, for example, all of each reference portion with an object that can be handled by the program together with the identification information.
- this identification information defines the correspondence between the reference portion described in the markup language and the like and the object, and is unique information that can identify one object for one reference portion.
- the object in the disclosure of the present invention means an entity that can be handled by the execution environment including the user terminals 101, units A to D, and the like, and is, for example, a kind of variable, array, function, program, or the like. Refers to a concept that includes two or more types.
- each reference part described in the HTML file 113 is replaced by an object that can be handled by the program together with the identification information is to execute what the reference part actually is. It can be carried out without making a substantive examination such as how much time is required and how large the capacity is.
- the replacement location can be formally determined according to the rules from the contents of the HTML file 113 and the contents of the strategy file generated by the artificial intelligence unit B, and the optimized HTML file 113z can be simply replaced with an object together with the identification information. Can be generated at high speed.
- each reference portion of the HTML file 113 included in the original data is replaced by objects 113o 1 , 113o 2, and the like. ..
- Objects 113o 1 , 113o 2, etc. that are first executed by the browser or the like of the user terminal 101 operated by the user are inserted into the head portion 113i of the optimized HTML file 113z by replacement. Further, in the body portion 113j of the optimized HTML file 113z, an object 113o 10 for inserting an object together with identification information into the optimized HTML file 113z is described. In addition, in the body portion of the optimized HTML file 113z, a program executed by the browser of the user terminal 101 or the like is inserted as objects 113o 20 , 113o 21, or the like.
- Steps for generating optimal resources Next, a step of generating the optimum resource used in the first embodiment of the present invention will be described.
- the optimum resource include a resource obtained by processing at least one of the program data (1) and the binary data (2) described above.
- the HTML file 113 is adopted as an example.
- the HTML file 113 that is statically generated and stored in the application processing unit A or dynamically generated and stored in the application processing unit A is for displaying the web content on the user terminal 101.
- the CSS file 107, the script language file 108, the reference part to the image file 109, and the like, and the reference part to the resource are described.
- the web content received by the user terminal 101 is normally displayed on the user terminal 101.
- the web contents displayed by the program data such as the programming language described in the PHP file 105 and the HTML file 113 and the binary data such as the image data by the image file 109 are the CSS file 107, the script language file 108 and the like. Therefore, the display position, the display size, the display layout, and the like are specified according to the display environment of the user terminal 101.
- the original data 200 including the original data 200 can display web contents corresponding to the display environment of any user terminal 101 that is expected to access the application processing unit A, but is not required for the display environment of each user terminal 101.
- the part of the original data 200 is also included.
- the original data 200 required when the user terminal 101 is a PC also includes a portion of the original data 200 which is not required when the user terminal 101 is a smartphone.
- the original data 200 required when the user terminal 101 is a smartphone for example, also includes a portion of the original data 200 which is not required when the user terminal 101 is a PC.
- the part of the original data 200 required may be different between a plurality of different smartphones.
- the required original data 200 may differ depending on the type of browser installed in the user terminal 101.
- the original data 200 includes data that is not necessary for displaying the individual user terminals 101. Will result in
- the original data 200 acquires data in order to prevent data unnecessary for display of the individual user terminals 101 from being transmitted from the application processing unit A to the individual user terminals 101 and shorten the display completion time. -Processing is performed by the processing unit D, and a plurality of processed data 201 are generated.
- the original data 200 includes at least one of program data and binary data.
- the original data 200 includes data described in the markup language.
- the description of the markup language includes reference information such as a directly described style sheet, a programming language, and a script language.
- the description of the markup language includes reference information to an external style sheet, an external script language, an external binary data, and the like.
- the term "external” as used herein refers to content that is not directly described in the markup language description but can be used as web content by referring to the markup language description.
- the HTML file 113 which is one of the files in which the markup language is described
- a plurality of code portions of the HTML file directly described in the HTML file 113 and a plurality of codes of the CSS file 107 are included. It contains reference information such as parts and a plurality of code parts of the script language file 108.
- an external file portion of the plurality of CSS files 107 referenced by the HTML file 113, an external file portion of the plurality of script language files 108, and the like are included.
- a reference portion relating to one or more external files such as an image file, a sound file, and a moving image file is also described in the HTML file 113.
- the original data 200 can be transmitted to all user terminals 101 whose display environment is specified via the network 102. If the HTML file 113 is executed by the browser or the like of each user terminal 101 that has received the original data 200, the web content 211 based on the original data 200 is displayed.
- FIG. 14 is a flowchart for explaining the relationship between the generation of processed data and the optimization of resources.
- the original data 200 can normally be displayed on the user terminal 101 of all the users described in the model information file. This is because the original data 200 is usually created so that the display of the user terminal 101 does not have a problem. If there is a problem with the original data 200, for example, the problem is detected by an emulator such as a headless browser mounted on the data acquisition / processing unit D. Based on the information about the detected defect, the defect can be corrected individually.
- the program data and binary data included in the original data 200 are processed.
- the program data and binary data included in the original data 200 are transmitted in the order of the artificial intelligence unit B and the data acquisition / processing unit D.
- the program data and binary data received by the data acquisition / processing unit D can be stored in the original data storage area 1530 of the data acquisition / processing unit D.
- the program data includes, for example, one type or two or more types such as an HTML file 113, a CSS file 107, and a script language file 108.
- the binary data includes, for example, one type or two or more types of image files, sound files, video files, and the like.
- the HTML file 113 is adopted as an example of the file in which the markup language included in the program data is described.
- the web content displayed on the user terminal 101 by the original data 200 usually has a plurality of web pages. Each of these web pages corresponds to the HTML file 113 as a plurality of program data. In the case of FIG. 2, it is shown in HTML file 113.
- Each of the HTML files 113 is a unit that can be displayed on the browser of the user terminal 101 without requiring a reloading operation.
- step S1021 and S1022 all or part of the program data required for processing is transmitted to the data acquisition / processing unit D (steps S1021 and S1022).
- All or part of the program data transmitted to the data acquisition / processing unit D is processed by the data acquisition / processing unit D (step S1023).
- the processing of all or part of the program data by the data acquisition / processing unit D includes, for example, deletion of optional programs and the like included in the program data, compression of the programs and the like, change of the processing order, and processing timing. Changes etc. can be mentioned.
- the processing of all or part of the data related to the program data includes, for example, the case where each of the resources such as the program data and the binary data referred to by the HTML file 113 or the like is treated as an object.
- each of the resources such as the program data and the binary data referred to by the HTML file 113 or the like is treated as an object.
- the style sheet, script language, etc. referred to by the HTML file 113 or the like are also processed by the data acquisition / processing unit D (step S1023).
- step S1024 binary data or the like referenced by the HTML file 113 or the like is processed.
- step S1023 and step S1024 are performed in series, they can also be performed in parallel at the same time.
- the processes from step S1023 to step S1024 are processes for each resource included in the original content 200. That is, it is a process for program data and binary data included in the original content 200.
- the processing for each resource included in the original content 200 is performed once or a plurality of times for the same resource. Processed program data and processed binary data corresponding to the number of times processing is performed for each resource can be obtained.
- the processed data 210 that can be displayed on the user terminal 101 is selected from the plurality of processed data (step S1025).
- the previous steps S1023 and S1024 are processes for each resource included in the original data 200.
- one processed data 210 is generated by combining the processed resources.
- This one processed data 210 corresponds to one web page.
- a plurality of processed data 210s having different display completion times are generated for each user terminal 101.
- Each of the web pages is a unit displayed on the browser of the user terminal 101 without performing a reloading operation.
- a plurality of processed data 210 are generated for each web page included in all the original contents 200.
- Step S1026 From the original data 200 and the plurality of processed data 210, those that can be displayed on one type of user terminal 101 are ranked based on the display completion time for the user terminal 101.
- the "display completion time” is a web page corresponding to the request on the browser or the like mounted on the user terminal 101 after the request is transmitted from the user terminal 101. The time until the user can accept input. Further, “input acceptance possible” means that the browser installed in the user terminal 101 is in a state of reacting to operations such as tapping, clicking, dragging, dropping, and text input by the user. ..
- the display completion time can be estimated by analysis using a trained model such as a preliminary test described later and machine learning using the data obtained by the preliminary test. This estimate can be used to perform rankings based on display completion time.
- the processed data 210 corresponding to each user terminal 101 is prepared.
- the prepared processed data 210 can also be stored in the processed data storage area 130 inside the application processing unit A from the data acquisition / processing unit D via the request processing unit C.
- the web content to be displayed on the user terminal 101 is selected (S1027).
- the request processing unit C actually receives the request from the user terminal 101 of the user, the request is transmitted in the order of the artificial intelligence unit B and the data acquisition / processing unit D.
- the content of the request is analyzed by the control unit 1512 of the data acquisition / processing unit D. Web content to be displayed on each user terminal 101 is selected according to the content of the request.
- "immediately after the request processing unit C receives the request” means within 0.2 seconds after the request processing unit C receives the request from the user terminal 101, that is, within 200 msec. means. This time is preferably within 100 ms. Further, the time from when the request processing unit C receives the request until the user terminal 101 can receive the input is preferably within 200 msec, and more preferably within 100 msec. The time from when a human receives information through the five senses such as sight and hearing to when he / she actually takes action is usually about 0.2 seconds. If the request processing unit C or the like responds within 200 ms, the user who uses the user terminal 101 can feel that the web content is displayed on the browser or the like of the user terminal 101 in real time.
- the processed data 210 constituting the web content displayed on the user terminal 101 is selected (). S1027).
- An object is prepared in advance with identification information in the HTML file 113z optimized as an object-replaced program.
- the preparation of the optimized HTML file 113z is completed only by associating the processed data 210 with the object based on the identification information.
- the processed data 210 collectively or distributedly stored in at least one of the application processing unit A and the data acquisition / processing unit D is transmitted to the user terminal 101 through the network 102 and downloaded on the user terminal 101 side. NS.
- the optimized HTML file 113z When the optimized HTML file 113z is executed by the browser or the like of the user terminal 101, the resources or the like downloaded for each user terminal 101 can be executed. Further, even if the resource is not downloaded to the user terminal 101, a resource or the like that can be referred to through the network 102 from the browser or the like of the user terminal 101 can be executed by the browser or the like of the user terminal 101. Since these resources are managed by the HTML file 113z optimized by the object described above, the selection can be performed at high speed.
- the HTML file 113z optimized by the browser of the user terminal 101 is executed, and the web content based on the processed data 210 is displayed on each user terminal 101 (S1028).
- the automatic high-speed display control method for web content according to the first embodiment of the present invention can be implemented.
- Step to generate processed data Next, the step of generating the processed data 210 from the original data 200 will be described in detail.
- the steps for generating the processed data 210 are, for example, before the request processing unit C receives the request from the user terminal 101, immediately after the request processing unit C receives the request from the user terminal 101, and with the application execution server 103. It is carried out at least one timing after the communication with the user terminal 101 is completed.
- the markup language included in the program data includes a document having characters, numbers, symbols, etc. that is displayed on the user terminal 101 and can be read directly by the user.
- This document also includes DOM (DOCUMENTS OBJECT MODEL) and Node objects constituting the DOM tree structure, which are necessary for displaying on the user terminal 101.
- the Node object contains markup, which is a symbol that identifies paragraphs, headings, bullet points, and the like.
- HTML file directly described in the HTML file 113 including the markup language
- HTML file 113 which is one of the markup languages
- Each of the reference parts to the external binary data is an object together with the identification information. The objects that handle them are then used in the optimized HTML file 113z.
- Javascript registered trademark
- the program that handles the object is not particularly limited as long as it can achieve the above object.
- the optimized HTML file 113z is generated in which the reference part is replaced with the object of the program.
- a plurality of the optimized HTML files 113z are generated corresponding to each of the plurality of web pages constituting the web content 211 included in the original data 201.
- a plurality of optimized HTML files 113z may be statically generated or dynamically generated.
- Multiple optimized HTML files 113z exist for one or more corresponding to one web page displayed without reloading the browser. Further, there are one or two or more depending on the type of the user terminal 101.
- the objects used in the respective optimized HTML files 113z are assigned identification information and stored in the processed data storage area 130 of the data acquisition / processing unit D. With these identification information, a reference part such as a code part to be processed can be specified.
- binary data such as image files, sound files, and video files included in the original data 200 to be processed from the reference part to the external binary data described in the data as an object defined by the program. Can be identified.
- At least one resource of the original data 200 and the plurality of processed data 201 includes at least one of program data and binary data.
- the program data includes a program described in one or more kinds such as a markup language, a programming language, a style sheet, and a script language.
- binary data includes one or more types of files such as image files, sound files, and video files.
- the part of the program to be executed and the part of the program not to be executed are specified for each display environment of the user terminal 101.
- the display environment of the user terminal 101 is an environment that can be displayed on the display device 1104 of the user terminal 101, and the type of the user terminal 101, the type of the OS, the type of the browser, the size of the display device 1104, and the unit. It is determined for each user terminal 101 depending on the number of display pixels per area and the like.
- FIG. 15 is a schematic diagram for explaining the model information file 1526 stored in the setting file storage unit 1523 of the storage device 1501 of the data acquisition / processing unit D.
- the user terminal 101 there are differences in types depending on mobile information terminals such as smartphones and feature phones, information display terminals such as PDAs and tablets, wearable communication terminals such as smart watches and smart glasses, and computers such as PCs.
- the manufacturer and the like disclose the specifications for each user terminal 101. Based on this public information, the display environment for the user terminal 101 is organized. There are a plurality of these display environments for each user terminal 101.
- identification information that identifies the user terminal 101
- model information that indicates whether the user terminal 101 is a mobile information terminal, an information display terminal, a computer, or the like
- a user terminal Supports OS information about the type of OS installed in 101, browser information installed in user terminal 101, number of pixels on the display screen of user terminal 101, display environment information indicating the size of the display screen, etc.
- the information to be processed is stored in the model information file 1526 of the data acquisition / processing unit D.
- the data is schematically represented in a table format in FIG. 15 for convenience of explanation, the data is actually stored in a database format such as various file formats such as JSON, CSV, and TSV.
- the user terminal 101 is mass-produced and supplied to the market. Therefore, the display environment of the user terminal 101 is generally standardized.
- the information of the display environment stored in the model information file 526 in the setting file storage unit 523 of the data acquisition / processing unit D is not infinite, and can be organized with respect to the model information file 526 within a finite time.
- the model information file 526 may include information about all individual user terminals 101, or may group information about user terminals 101 belonging to a certain category and include the group information.
- the group information is particularly limited to the expression format as long as the display environment of the user terminal 101 can be specified based on the model information file 526 from the group information when any one user terminal 101 is selected. There is no.
- the control unit 1512 of the data acquisition / processing unit D is a part and execution of a program to be executed from the program and the file described above based on the display environment of all the user terminals 101 described in the model information file 1526.
- the part of the program to be prevented is specified for each display environment of the user terminal 101.
- Specific examples of the part of the program to be executed include the part of the program that contributes to the part displayed on the display device 1104 of the user terminal 101.
- Specific examples of the portion of the program that is not executed include the portion of the program that contributes to the portion that is not displayed on the display device 1104 of the user terminal 101.
- the part of the program used only by the smartphone is not used by the user terminal 101 other than the smartphone, the part of the program used only by the smartphone is not executed by the user terminal 101 other than the smartphone. Applicable.
- the part of the program to be executed and the part of the program not to be executed are usually different for each user terminal 101.
- the user terminal 101 is based on the information of all the user terminals 101 described in the model information file 1526.
- a preliminary test is actually conducted in advance to determine.
- a method of learning the data obtained by the implementation of the present invention, a preliminary test, or the like and determining according to the learned model obtained is adopted.
- a model can be formed by machine learning by the artificial intelligence unit D or the like.
- the predictions within the risk tolerance obtained from the formed trained model can be treated equivalent to the results of the preliminary test.
- the meaning of "in advance” means before the user actually sends a request to the request processing unit C from the user terminal 101.
- control unit 1512 of the data acquisition / processing unit D is equipped with an environment similar to the browser environment mounted on the user terminal 101 called an emulator such as a headless browser.
- an emulator such as a headless browser.
- a model can be formed by preliminary tests, machine learning, or the like.
- a problem occurs in the display of the user terminal 101.
- a problem for example, whether or not an error signal is generated by a preliminary test using an emulator such as a headless browser corresponding to the user terminal 101 mounted on the data acquisition / processing unit D is used as a clue. , Can be checked in advance.
- this error signal is detected by the control unit 112 of the data acquisition / processing unit 103, it is possible to specify at what stage the problem occurred when selecting the part of the program to be not executed.
- Preliminary tests etc. will reveal to some extent which part of the original data 200 has a part of the program that is not executed. However, in a situation where there is no preliminary information, such as when the program has never been executed, it is not known in detail which part of the original data 200 corresponds to the program that is not executed in the preliminary test.
- the operation of removing the part of the program that is not executed one by one from the program is repeated. Then, when it is first detected that the browser mounted on the user terminal 101 has issued an error signal, it can be seen that the part of the program that is removed last and is not executed corresponds to the part of the program that should be executed.
- the display content of the user terminal 101 reproduced in the emulator is used as a capture screen for a sequential image file. Repeat the operation to save to. Comparing the capture screen based on the original data 200 with the subsequent capture screen, it can be seen that the part of the program that is not executed last that was removed when the two do not match corresponds to the part of the program that should be executed. .. By forming a model of this operation through machine learning or the like, it is possible to detect a part of the program that causes a problem.
- a program that realizes this operation is stored in the control unit 1512 of the data acquisition / processing unit 103.
- the above operation is automatically performed by executing the program stored in the control unit 1512 of the data acquisition / processing unit 103.
- the above operation is repeated, and a preliminary test is actually performed in advance based on the information of the user terminal 101 described in the model information file 1526.
- a model is formed by a trained model through this preliminary test. From the results of this preliminary test and model formation, information on the part of the program to be executed and the part of the program not to be executed for each user terminal 101 is specified for all the user terminals 101.
- the specified information is associated with the model information file 1526, and is stored together with the identification information in the setting file storage unit 1523 of the data acquisition / processing unit D.
- the most important thing when a user browses a web page included in the web content 211 is the content included in the first view.
- the execution of the program portion not related to the display of the first view is postponed, and the execution is related to the first view. Prioritize the execution of the program to be executed. The execution timing of each program is also adjusted.
- the step in which the processed data 210 is generated is included in the resource included in the original data, that is, the program data having one or more kinds of markup language, programming language, style sheet, script language, etc., and the original data. It is carried out for each of one or more types of binary data such as image files, sound files, and video files.
- the part of the program included in the program data described by one or more types such as markup language, programming language, style sheet, script language, etc. included in the original data is optimized HTML.
- each object of the program is configured together with the identification information.
- the reference part related to one or more kinds of files such as an image file, a sound file, and a moving image file included in the original data referred to by the program part is also identified in the optimized HTML file 113z. Consists of the program's objects together with.
- FIG. 16 is a conceptual diagram for explaining the correspondence between the HTML file before processing and the optimized HTML file.
- FIG. 13 it has been described that the reference portion of the program data, binary data, etc. described in the HTML file 113 before processing is replaced with the object used for the function of the program.
- a reference portion such as program data and binary data described in the HTML file 113 before processing is specifically reflected in the optimized HTML file 113z.
- a plurality of processed data 201 composed of a plurality of processed resources are generated for each display environment of the user terminal 101.
- a plurality of processed data 201 are generated for one user terminal 101.
- To generate the processed data 201 specify identification information, call each program part from the object defined by the program, and add, move, delete, change, etc. to the called program part. It is carried out by modifying.
- the HTML file 113 included in the original data 200 is, for example, an HTML code portion 113a, 113b, 113c, a CSS code portion 10. 7a, 107b, 107c, script language code portions 108a, 108b, 108c and the like are included.
- Each of the CSS code portions 107a, 107b, 107c is defined as an object, together with identification information, in the objects F107a, F107b, F107c, etc., respectively.
- each of the script language code portions 108a, 108b, 108c is defined as an object, together with the identification information, in the objects F108a, F108b, F108c, etc., respectively.
- the steps in which the processed data 210 is generated include a step in which unnecessary parts are deleted from the program data, a step in which necessary parts are compressed, a step in which the execution order is changed, a step in which the execution timing is changed, and a duplicate execution time.
- One or more of the steps to be shortened, From binary data it includes one or more steps such as the number of display pixels per unit area, recording density per unit time, size of capacity, storage format, etc., or two or more conversion steps.
- FIG. 17 is a flowchart for explaining a step in which an unnecessary portion is deleted for each display environment of the user terminal. If the corresponding process cannot be executed even after performing the process a certain number of times, the step is terminated and the process of the next step is executed. The same applies to the following steps.
- the HTML file 113 used by the user terminal 101 For each user terminal 101 specified based on the identification information of the model information file 526, for example, the HTML file 113 used by the user terminal 101, the CSS file 107 referred to when the HTML file 113 is executed, and the script language file. 108 etc. are specified. These identifications are performed by designating the identification information for the object shown in FIG.
- HTML files 113 for example, among the HTML file 113 portion 113x not used by the user terminal 101 and the CSS file 107, among the CSS file 107 portion 107x and the script language file 108 not used by the user terminal 101.
- a portion 108x of the script language file 108 that is not used by the user terminal 101 is specified.
- the portions 113x, 107x and 108x that are not used by the user terminal 101 are deleted.
- the actual deletion can be easily performed by specifying nothing as an object.
- the user terminal 101 specified based on the identification information of the model information file 526 is a PC
- it is included in any of the HTML file 113, the CSS file 107, the script language file 108, and the like.
- the information of the part corresponding to the mobile information terminal, the information display terminal, etc. other than the PC is deleted.
- the user terminal 101 specified based on the identification information of the model information file 526 is a smartphone, among the information contained in any of the HTML file 113, the CSS file 107, and the script language file 108. , The information of the part that is not used for the smartphone is deleted.
- the HTML file 113 includes, for example, markup that is a symbol that identifies paragraphs, headings, bullet points, and the like. By tracking which markup is specified in the markup included in the HTML file 113, which of the HTML file 113 is used as a clue to the markup specified by the CSS file 107, the script language file 108, etc. It can be seen whether the part is controlled by the CSS file 107, the script language file 108, or the like.
- the control unit D300 of the data acquisition / processing unit D realizes the deletion of unnecessary parts of the processed data.
- the user does not directly browse each of the HTML file 113, the CSS file 107, and the script language file 108.
- the user browses the web content 211 generated by the HTML file 113 or the like through the browser of the user terminal 101.
- each of the HTML file 113, CSS file 107, script language file 108, etc. has display information devised so that humans can understand the contents when the contents described in these files are displayed on CLI or the like. include. These display information are necessary information for the administrator of the application execution server 103 or the like, but are not reflected in the web content 211, and are therefore unnecessary information for the user who uses the user terminal 101.
- the display information to be deleted includes, for example, spaces, tabs, line breaks indicating line breaks and paragraph breaks, and text information such as maintenance notes written in each file that do not affect the display of the web content 211. And so on.
- the control unit D300 of the data acquisition / processing unit D causes all the user terminals 101 described in the model information file 526.
- the unnecessary part of the processed data is deleted based on the display environment of.
- the object of the program is specified together with the identification information.
- the HTML file 113z optimized by the browser of the user terminal 101 is executed, and the deletion is realized.
- FIG. 18 is a flowchart for explaining a step in which a necessary portion is compressed for each display environment of a user terminal.
- the notation of "1,000,000", which means one million of numbers can be expressed as "10E6". This means 10 to the 6th power.
- the former requires 9 characters including the comma that indicates the digit delimiter, while the latter can be expressed by 4 characters including the alphabet characters.
- compression the operation of converting one and the same information into another expression format that can be processed faster by each unit such as the application processing unit A mounted on the application execution server 103, the user terminal 101, and the like is referred to as compression.
- Such a compression operation can be performed using, for example, one or more of existing lossless compression techniques such as LHA, ZIP, GZIP, and BROTLI.
- program data such as HTML file 113, CSS file 107, script language file 108, and one or more of these processed data
- the control unit 112 of the data acquisition / processing unit D realizes compression of necessary parts. ..
- one type or two or more types of compression formats can be used.
- all may be compressed or a part may be compressed. The same applies to the compression of binary data such as the image file 109.
- Step to change execution order Of the web contents 211, for example, the part of the program related to the part of the web contents 211 first displayed on the screen of the user terminal 101 called the first view is executed first. Subsequently, the portion of the web content 211 other than the portion of the web content 211 that is first displayed on the screen of the user terminal 101, which is called the first view, is executed later.
- the display of the portion of the web content 211 that is first displayed on the screen of the user terminal 101 called the first view is prioritized.
- the program parts included in the original data which are included in one or more types of program data such as markup language, programming language, style sheet, script language, etc., are usually executed on the user terminal 101 side in the order described. Will be done.
- This wait time is usually short enough to be negligible for each part of the program and is often overlooked.
- the influence of the waiting time tends to increase. If the effect of waiting time is left unattended, it can be one of the factors that cause users to leave the website. Therefore, the execution order is changed and processing is performed so that unnecessary waiting time does not occur.
- the part of the program refers to the part of the program to be executed later before the part of the program to be executed first
- the part of the program to be executed later is moved up. For example, when it is executed first.
- the program part refers to an element that cannot be executed, for example, if it refers to a code part that existed in the past but does not exist now, it refers to a variable that does not exist now. For example, if it is. In this case, the problematic code part is not executed, for example, the order is skipped and the later code part is executed in advance.
- control unit d300 mounted on the data acquisition / processing unit D determines whether to execute the programs synchronously, asynchronously, or preferentially. It is controlled by the program described.
- Step to change execution timing for example, after the execution of the program portion related to the display of the web content 211 portion first displayed on the screen of the user terminal 101 called the first view is completed, the web content 211 other than the first view is completed. Execution of the program related to the display of the part of is started.
- the execution timing of the formation of the DOM, the download of the content associated with the DOM tree structure to the user terminal 101, the download of the main resources such as the image file, the sound file, and the moving image file is adjusted.
- the execution timing of the program part is adjusted synchronously so that the execution of one program part is completed and then the execution of the next program part is started. NS.
- the execution timing of the program part is adjusted asynchronously for each part of the program that does not affect each other.
- FIG. 19 is a diagram for explaining a step in which the script language file portions 108a108d referred to in the HTML file 113 are executed in series. Reference information of a plurality of script language file portions 108a to 108d is described in the HTML file 113.
- each of the script language file portions 108a to 108d is usually executed serially in this order.
- the relative value of the display completion time of the script language file 108d is 100
- the relative value of the display completion time of the script language file portions 108a to 108c is 5, 10 and 15, respectively.
- processing of the display completion time corresponding to 5 + 10 + 15 + 100 130 based on the relative value of the display completion time until the display of the user terminal 101 is completed. Is required.
- FIG. 20 is a diagram for explaining a step in which the script language file portions 108a to 108c described in the HTML file 113 and the script language file 108d are executed in parallel.
- the execution order of the script language file 108 can be arranged to shorten the generation time of the web content 211.
- the HTML file 113 is processed so that the script language files 108a to 108c are processed in parallel at the same time that the script language file 108d is executed.
- the display completion time of the script language file portions 108a to 108d can be reduced from 130 to 100 based on the relative value.
- FIG. 21 is a diagram for explaining a step in which the execution of the script language file 108d described in the HTML file 113 is postponed. Information that refers only to the script language file portions 108a to 108c may be described in the HTML file 113 first, and the script language file 108d may be referred to at the end of the HTML file 113.
- the step of generating the optimized HTML file 113z, the processed CSS file 132, and the processed script language file 133 is performed for all the user terminals 101 described in the model information file 526.
- the contents described in the model information file 1526 by the control unit d300 of the data acquisition / processing unit D by tracking how the HTML file 113 processes the plurality of script language file portions 108a to 108c in what order. Based on the display environment of all the user terminals 101 corresponding to the above, a new generation of the processed data 210 is realized.
- the display size and capacity are set for each user terminal 101 specified based on the identification information of the model information file 526.
- different types of processed image files 134 are generated.
- the display size of the image file 109 is changed, for example, by generating a plurality of processed image files 134 having different vertical and horizontal lengths without changing the ratio of the vertical and horizontal lengths.
- the capacity of the image file 109 is changed, for example, by changing the number of pixels per unit area of the image file 109, changing the recording recording density per unit time, and the like.
- the type of the image file 109 is changed, for example, when the type of the image file 109 is PNG, the type is changed to JPEG, WEBP, JPEG2000, or the like.
- the step of generating the processed image file 134 is performed for all the user terminals 101 described in the model information file 526.
- the processed data 210 including a new plurality of converted binary data is generated.
- the binary data is a moving image file, a sound file, or the like
- the processed data 210 including a plurality of new converted binary data can be generated by the same procedure.
- FIG. 22 is a flowchart for explaining a step in which processed data is generated.
- the display completion time is measured for each of the optimized HTML file 113z, the processed CSS file 132, the processed script language file 133, and the like.
- the optimized HTML file 113z which is present for each user terminal 101, web page, etc., is displayed to what extent compared to the HTML file 113 before processing when the object of the referenced program is changed. It is measured whether it takes time.
- the processed CSS file 132 is measured as an element how long it takes to complete the display as compared with the CSS file 107 before processing.
- the plurality of processed script language files 133 are measured as an element how long it takes to complete the display as compared with the script language file 108 before processing. For binary data as well, it is measured how long it takes to complete the display as an element by comparing a plurality of past image files and the like with image files and the like before the past.
- the original data 200 and the plurality of processed data 201 are prepared for each user terminal 101.
- the one with the shortest display completion time for each element included in the original data 200 and the plurality of processed data 201 is selected, it is the most among the original data 200 and the plurality of processed data 201 as a whole. It is not always the case that a product with a short display completion time can be obtained. This is because the elements influence each other depending on the combination of the elements, and the display completion time for each of the original data 200 and the plurality of processed data 201 varies.
- which combination has the shortest display completion time is determined by actually performing a preliminary test in advance for each user terminal 101. Further, by forming a model by machine learning based on the data of this preliminary test, it is determined which combination of the original data 200 and the plurality of processed data 210 has the shortest display completion time.
- FIG. 23 is a flowchart for explaining a step in which a signal notifying that the original data 200 has been modified such as addition, movement, deletion, or change is transmitted to the operation control unit. Further, FIG. 23 is a flowchart for explaining a step in which processed data is newly generated by a signal of modification of the original data 200.
- the processed data is newly generated.
- the original data 200 used for the automatic high-speed display control method of the web content 211 the original data first stored in the original data storage area 104 in the storage device 1101 of the application processing unit A can be used as it is.
- the original data 200 is stored in the original data storage area 104 of the application processing unit A. If the original data 200 is modified after a certain period of time, the modified contents are stored in the original data storage area 104.
- each of the contents saved earlier and the contents saved later is monitored and controlled by the application processing unit A based on, for example, a program described in the control unit d300 mounted on the data acquisition / processing unit D. Monitor by unit 1115.
- the monitoring control unit 1115 of the application processing unit A may, for example, among the HTML file 113, the CSS file 107, the script language file 108, and the image file 109 included in the original data 200. Identify the modified part. Then, a signal notifying that the modification has occurred is transmitted from the monitoring control unit 1115 to the operation control unit 1116 and the control unit d300 mounted on the data acquisition / processing unit D.
- the control unit d300 mounted on the data acquisition / processing unit D that has received the signal notifying the modification processes the processed data 201 according to the display environment of the user terminal 101 for the modified part of the original data 200. To generate new processed data 202.
- the data corresponding to the modified portion is processed by the control unit d300 mounted on the data acquisition / processing unit D. It is replaced by the completed data 202.
- the dynamically generated processed data 202 can also replace the corresponding part of the previously existing processed data 210 or the like.
- the processed data 202 newly generated by the modification of the original data 200 replaces the previously generated processed data 210. It will be carried out continuously.
- the program described in the control unit d300 of the data acquisition / processing unit D operates, the processed data 202 according to the display environment of the user terminal 101 is extracted and processed, and stored in the operation control storage unit 1517.
- the application processing unit A receives the request from the user terminal 101, the original data 200 stored in the storage area that can be used by the application processing unit A is processed according to the display environment of the user terminal. Finished data 210 is newly generated.
- Step to specify the display environment of the user terminal Next, after the request processing unit C receives the request from the user terminal 101, the step for the data acquisition / processing unit D to specify the display environment of the user terminal 101 will be described.
- the request transmitted from the user terminal 101 is received by the request processing unit C via the network 102. And it is received by each unit. This request is made via a browser mounted on the user terminal 101.
- the request received by the data acquisition / processing unit D includes, for example, a user agent indicating the model information of the user terminal 101, the type of browser, the type of OS, etc., or any of the websites displayed on the browser of the user terminal 101. It includes a referrer and the like indicating whether the request was sent from the page. Using the information of these user agents, referrers, etc., the data acquisition / processing unit 103 can specify the display environment of the user terminal 101 by means of an accept header, a cookie, or the like.
- Steps for generating web content containing data that can be displayed in the display environment of the user terminal Next, a step of generating the web content 211 including the data that can be displayed in the display environment of the user terminal 101 will be described. Already, the web content 211 that can be displayed for each user terminal 101 in advance has been generated by the step described above. The web content 211 is associated with the user terminal 101.
- a request is transmitted from the monitoring control unit 1415 of the artificial intelligence unit B to the data acquisition / processing unit D.
- the step of selecting the web content 211 including the data that can be displayed in the display environment of the user terminal 101 is performed after the request from the browser of the user terminal 101 is transmitted to the request processing unit C.
- the control unit 1512 of the data acquisition / processing unit D detects that the request from the browser of the user terminal 101 has been sent to the request processing unit C for the data acquisition / processing unit D.
- the identification of the individual display environment of the user terminal 101 is realized by collating the information such as the accept header and the cookie with the model information file 1526 described above.
- the original data 200 that can be displayed using this display environment is specified.
- the HTML file 113, the CSS file 107, the script language file 108, the image file 109, and the like included in the original data 200 are specified.
- the processed data 210 that can be displayed using this display environment is specified.
- the optimized HTML file 113z, the processed CSS file 132, the processed script language file 133, the image file 109, and the processed image file 134 are specified.
- each code part, file part, etc. are stored in the processed data storage area 130 in the form of a program object defined in the optimized HTML file 113z.
- the request processing unit C receives the request from the user terminal 101, the web content 211 including the data that can be displayed in the display environment of the user terminal is mounted on the data acquisition / processing unit D as a control unit. Selected by d300. At this stage, there are a plurality of web contents 211 that can be displayed on the user terminal 101.
- the web content 211 displayed on each user terminal 101 is determined to be one by the control unit 1512 of the data acquisition / processing unit D.
- the processed data 201 which is the program data for displaying the web content 211 on the user terminal 101, is transmitted from the control unit 1512 of the data acquisition / processing unit D to the application processing unit A. Then, the content of the processed data 201 is reflected in the optimized HTML file 113z instead of the HTML file 113 that reflects the content of the original data 200 arranged in the application processing unit A.
- the optimized HTML file 113z is downloaded to each user terminal 101 for all user terminals 101 whose display environment is specified through the network 102 via the application processing unit A and the request processing unit C.
- the optimized HTML file 113z is executed by the browser or the like of each user terminal 101 that has received the optimized HTML file 113z, and the web content 211 corresponding to each user terminal 101 is the user terminal 101. It is displayed on each browser.
- the display completion time of the web content 211 largely depends on the part of the program included in the original data 200 and the plurality of processed data 201. A program portion with a smaller capacity is preferable because the display completion time is usually shorter than that with a less capacity reduction.
- the original data 200 may complete display faster than any plurality of processed data 201.
- the original data 200 and the plurality of processed data 201 are used to measure the display completion time in each user terminal 101 by conducting a preliminary test or the like in advance. It is possible to specify the order in which the display completion time is actually short. In addition, machine learning can be performed using these data to form a trained model. Using this trained model, it is possible to specify the order in which the display completion time is actually short.
- the original data 200 includes a plurality of HTML files 113 corresponding to a plurality of web pages constituting the web content 211, and various program data and binary data referenced and executed from each of the plurality of HTML files 113.
- the processed data 201 is referenced and executed from each of the plurality of optimized HTML files 113z corresponding to the plurality of web pages constituting the web content 211 and the plurality of optimized HTML files 113z. Includes various processed program data and processed binary data. These original data 200 and processed data 201 are resources required for displaying the web content 211, respectively.
- the resource required for displaying the user terminal 101 for each user terminal 101 of the user is the optimum resource.
- the processed data is generated for each display environment of the user terminal 101 of the user and for each resource required for displaying the web content 211.
- the optimum resource that can be executed when the optimum resource that can be executed is selected for each display environment of the user terminal 101 of the user, the optimum resource has the same capacity of various files stored, an extension that specifies various file types, and the like. Even in this case, the expression format required to realize the optimum resource is not limited to one. Therefore, even if there are a plurality of optimal resources that appear to be the same optimal resource among the plurality of optimal resources, the optimal resource that has a difference in display completion time when actually executed may be included.
- the information regarding the display completion time between the optimum resources for one user terminal 101 is, for example, actually a preliminary test in advance. Is decided.
- the display completion time can be determined relatively accurately by a method using model formation by machine learning or the like using data on the display completion time obtained by a preliminary test or the like.
- the storage device 1501 of the data acquisition / processing unit D described above may also include a time execution control unit 1520.
- the execution program 1522 stored in the time execution storage unit 1521 connected to the time execution control unit 1520 implements the present invention, for example, the original data 200 of the application processing unit A, the processed data 210, 202, etc. after a certain period of time has elapsed.
- the data necessary for implementing the automatic high-speed display control method of the web content according to the first embodiment and the preliminary storage data of the program are duplicated and stored in the time execution storage unit 1521 of the data acquisition / processing unit D.
- the preliminary storage data stored in the time execution storage unit 1521 of the data acquisition / processing unit D is transferred to the auxiliary storage unit 1105 of the application processing unit A in addition to the data acquisition / processing unit D through the network 102 and stored. You can also.
- the application processing unit A described above can monitor the original data 200 and deal with it.
- monitoring of the original data 200 can be performed by the data acquisition / processing unit D.
- the modified portion of the original data 200 is specified, and the processed data 201 corresponding to this modified portion is generated.
- the processed data 210 having the shortest display completion time is specified for each user terminal 101 from the original data 200 and the plurality of processed data 201 and the like.
- the control unit d300 mounted on the data acquisition / processing unit D identifies the processed data 210 selected from the original data 200 and the plurality of processed data 201 that can be displayed on the user terminal 101. .. Then, the processed data 210 is transmitted from the data acquisition / processing unit D in the order of the application processing unit A, and is received by the user terminal 101 through the network 102. The received processed data 210 is displayed on the browser of the user terminal 101.
- the processed data 202 that can be displayed on the user terminal 101 by the control unit d300 of the data acquisition / processing unit D is applied from the data acquisition / processing unit D to the application. It is transmitted via the processing unit A and received by the user terminal 101 via the network 102. The received processed data 202 is displayed on the browser of the user terminal 101.
- the original data 200 is changed, added, deleted, or otherwise modified, when a request is received from the user terminal 101 to the request processing unit C, application processing controlled by the control unit 1512 of the data acquisition / processing unit D is performed.
- the processed data 202 including the updated web content 212 of the web content 211 is transmitted to the user terminal 101 via the unit A each time.
- the user terminal 101 can display the web content 211 including the updated web content 212.
- the user terminal 101 that has received the processed data 202 for displaying the web content 212 transmitted from the application processing unit A via the request processing unit C and the network 102 by the above series of steps is mounted on the user terminal 101.
- Web content 212 can be displayed at high speed from the first time on the browser.
- the HTML file 113z optimized by the application execution server 103 is downloaded for each user terminal 101, and the HTML file 113z optimized by the browser of the user terminal 101 or the like is executed. .. Web contents based on the optimized HTML file 113z are displayed on the browser of the user terminal 101 or the like.
- the application execution server 103 When the user first sends a request from the browser of the user terminal 101 to the application execution server 103 through the network 102, the application execution server 103 sends the HTML file 113 or the like included in the original data 200 to the user terminal 101 as a response. Can be sent. On the other hand, the application execution server 103 also transmits the optimized HTML file 113z and the like.
- the HTML file 113 and the optimized HTML file 113z may coexist and be saved in the user terminal 101, but normally, the HTML file 113 is downloaded by the optimized HTML file 113z for each user terminal 101. Will be done. If you select an object to reproduce the same contents as the HTML file 113 as each object of the program included in the optimized HTML file 113z, the HTML file 113 can be easily reproduced using the optimized HTML file 113z. You can also do it.
- the optimized HTML file 113z downloaded to the user terminal 101 relates to a reference portion relating to a resource directly described in the optimized HTML file 113z, and an external resource referenced by the optimized HTML file 113z. All of the resource information such as the reference part is converted into a format that can be handled as a program object. Identification information is associated with each object, and which object is used in which part of the optimized HTML file 113z is managed by, for example, the database 1106 of the data acquisition / processing unit D. be able to.
- the browser or the like of the user terminal 101 requests an object for all resources referenced by the optimized HTML file 113z from the data acquisition / processing unit D according to the strategy plan drafted by the artificial intelligence unit B, that is, the strategy file 1412. It can be received via the network 102 via the processing unit C.
- By associating these resources with each object of the optimized HTML file 113z it is possible to instantly display the web content on the browser or the like of the user terminal 101. Then, the order and timing of downloading the resources used for display on the user terminal 101 for each user terminal 101 are implemented based on the strategy plan devised by the artificial intelligence unit B.
- Steps for artificial intelligence unit B to formulate a strategy plan Next, the step in which the artificial intelligence unit B formulates a strategy plan for displaying the web content on the user terminal 101 will be described.
- the application processing unit A and the artificial intelligence unit B can communicate with each other via the request processing unit C.
- the artificial intelligence unit B and the data acquisition / processing unit D can communicate with each other.
- the data acquisition / processing unit D which has become able to communicate with the application processing unit A via the request processing unit C, acquires the original data 200 stored in the original data storage area 1530 of the application processing unit A, and the data acquisition / processing unit D. Save and process.
- the processed data is stored in the processed data storage area 1540 of the data acquisition / processing unit D. Further, the original data 200 stored in the original data storage area 104 of the application processing unit A can be processed while being read, and the processed result can be stored in the processed data storage area 130 of the application processing unit A.
- the original data 200 stored in the application processing unit A is frequently updated or dynamically generated. That is, the original data 200 changes with time.
- the artificial intelligence unit B has a relationship with the time for displaying the web content on each user terminal 101 in this process, and there is a possibility that an error may occur as a result of preventing the web content from being displayed on the browser of the user terminal 101.
- Learn about each data such as display completeness as to whether the expected web content is displayed on the browser of the user terminal 101.
- the attributes that these data have in common are analyzed, for example, by statistical processing, and are associated with the length of the display completion time of the web content.
- the HTML file 113 included in the original data 200 includes HTML code portions 113a, 113b, 113c, CSS code portions 107a, 107b, 107c, script language code portions 108a, 108b, 108c, and the like.
- At least one of the original data 200 and the plurality of processed data 210 includes at least one of program data and binary data.
- the program data includes a program described in one or more kinds such as a markup language, a programming language, a style sheet, and a script language.
- the binary data includes one or more kinds of files such as an image file, a sound file, and a moving image file. From these program data, binary data, and the like, a part of the program to be executed and a part of the program not to be executed are specified for each display environment of the user terminal 101.
- the original data 200 contains at least one of program data and binary data.
- the program data contains at least one description selected from the group consisting of markup language, programming language, style sheet, and script language. If the binary data contains at least one of an image file, a sound file and a video file
- Information about data acquisition / processing unit D 602 From at least one data selected from the group consisting of the markup language, the programming language, the style sheet and the script language included in the original data 200, the step of changing the execution order for each display environment of the user terminal was carried out.
- Information about data acquisition / processing unit D 603 From at least one data selected from the group consisting of the markup language, the programming language, the style sheet and the script language included in the original data 200, the step of changing the execution timing for each display environment of the user terminal was carried out.
- Information about data acquisition / processing unit D 604 Data acquisition in which one selected from the group consisting of the number of display pixels per unit area, recording density per unit time, capacity and storage format is converted from the binary data contained in the original data 200.
- Information about processing unit D 605 Information about which data is combined to generate the processed data 210 from the original data 200 and a plurality of processed data 606, Information 607 regarding the processed data 210 including at least one selected from the group consisting of the original data 200 and a plurality of processed data, and the time until the processed data 210 can be input and accepted by the user terminal 101.
- the artificial intelligence unit B learns about information 608 and the like regarding which of the application processing unit A, the data acquisition / processing unit D, and the cloud distribution server 608 has been transmitted to the user terminal 101.
- the artificial intelligence unit B learns the correlation with the steps required for each, and forms a trained model.
- the markup language, programming language, and style included in the original data 200 are included. Predict how the data acquisition / processing unit D can process the sheet, script language, etc. to minimize the time until the web content based on the processed data 210 can be input and accepted on the user terminal 101. can do. It was
- the original data 200 required to be displayed on one user terminal 101 is specified based on the correlation learned by the artificial intelligence unit B, the binary data and the like included in the original data 200 are displayed.
- the data acquisition / processing unit D can predict how to process the web content based on the processed data 210 to minimize the time until the user terminal 101 can accept input. It was
- the processed data 210 generated by the data acquisition / processing unit is downloaded to the user terminal 101 based on the correlation learned by the artificial intelligence unit B, and then executed by the browser or the like of each user terminal 101. It is possible to predict whether the processed data 210 generated by the data acquisition / processing unit should be executed from the browser of each user terminal 101 on the application execution server 103 side through the network 102.
- an emulator such as a headless browser that can reproduce an environment similar to the browser environment mounted on the user terminal 101 is used to check whether the prediction obtained by the artificial intelligence unit B learning the above information is actually correct. Can be verified by preliminary test using.
- this emulator can be mounted on the control unit 1512 of the data acquisition / processing unit D.
- points will be added if the time until the web content based on the processed data 210 can be input and accepted by the user terminal 101 can be shortened.
- the points will be deducted.
- Information about the points added and deducted is fed back to the control unit 1512 of the artificial intelligence unit B.
- the artificial intelligence unit B can reflect the result in the strategic plan drafted by the artificial intelligence unit B. By repeating this step, a trained model is formed.
- the learning method of the artificial intelligence unit B is not particularly limited.
- a known method for artificial intelligence can be appropriately selected and adopted.
- Examples of the method of utilizing such artificial intelligence include methods such as machine learning and deep learning.
- neural networks, model formation and prediction by reinforcement learning, prediction by Bayesian estimation, clustering by the DB scan method, and the like are used.
- artificial intelligence algorithms such as the KNN method, the decision tree method, and the MT method can be used together.
- the HTML file 113 included in the original data 200 includes HTML code portions 113a, 113b, 113c, CSS code portions 107a, 107b, 107c, and script language code portions 108a, 108b. , 108c and the like.
- the style sheets of F107a 1 , F107b 1 , and F107c 1 as objects are substituted in place of the CSS code portions 107a, 107b, 107c included in the HTML file 113. ..
- These CSS code portions F107a 1 , F107b 1 , F107c 1, etc. are stored in, for example, the data acquisition / processing unit D.
- the data of the code portion of these style sheets F107a 1 , F107b 1 , F107c 1 and the like is the user from the application execution server 103 through the network 102 when the request is first transmitted from the user terminal 101 to the application execution server 103. It is downloaded and saved in the terminal 101.
- the optimized HTML file 113z When the optimized HTML file 113z is executed by the browser of the user terminal 101 or the like, the contents of the CSS code portions F107a 1 , F107b 1 , F107c 1 and the like are executed.
- the CSS code portions F107a 1 , F107b 1 , F107c 1, etc. can be executed after being downloaded to the user terminal 101, or the application execution server 103 can be executed from the browser or the like mounted on the user terminal 101 through the network 102. It can also be executed using the one stored in the above.
- the script language code part is the same as the case of the CSS code part. According to the strategy plan devised by the artificial intelligence unit B, the script language programs of F108a 1 , F108b 1 , and F108c 1 as objects are substituted for the script language code portions 108a, 108b, 108c included in the HTML file 113. ing.
- the script language programs F108a 1 , F108b 1 , F108c 1, and the like are stored in, for example, the data acquisition / processing unit D.
- the code portion of these script language programs can be downloaded to the user terminal 101 and then executed, or stored in the application execution server 103 or the like from the browser or the like mounted on the user terminal 101 through the network 102. It can also be executed using a script.
- the script language programs of F108a 1 , F108b 1 , and F108c 1 as objects included in the optimized HTML file 113z are an artificial intelligence unit. It will be implemented according to the strategic plan drafted by B.
- HTML file 113 included in the original data 200 is changed, even if the HTML file 113 is dynamically generated and its contents change with the passage of time, it can be dealt with by the first embodiment of the present invention.
- the relationship between the HTML file 113 and the optimized HTML file 113z in FIG. 16 described above can be understood as a state cut out at a certain moment.
- the relationship between the HTML file 113 and the optimized HTML file 113z is associated with the identification information as an object.
- the application processing unit A has functions such as changing the time stamp and outputting the difference of the changed contents when the HTML file 113 is changed.
- the object of the optimized HTML file 113z corresponding to the changed part of the HTML file 113 can be specified by the identification information.
- the processed data is prepared by the data acquisition / processing unit D for each of the changed objects and associated with the identification information.
- the object is assigned to the optimized HTML file 113z. Specifically, which object is reflected in the optimized HTML file 113z is carried out according to the strategic plan drafted by the artificial intelligence unit B, as in the case described above.
- the data acquisition / processing unit D can save the processing history of the original data 200 saved in the application processing unit A.
- a plurality of processed data 201 that can be individually displayed are generated for each user terminal 101 that is expected to send a request to the application processing unit A, and the original data 200 and the plurality of processed data are prepared in advance. From 201, the processed data 210 that enables input acceptance of web contents to the user terminal 101 at the fastest speed is specified by a preliminary test, a trained model, or the like.
- the processed data 210 which enables the user terminal 101 to receive input of web content at the fastest speed, has data on the correlation of which attribute should be focused on in the artificial intelligence unit B. It is stored in database 1406.
- a statistical index related to the above attribute can be obtained.
- the data acquisition / processing unit D tried to examine all cases, and the web content can be input to the user terminal 101 at the fastest speed. Even if the exact same data as the processed data 210 cannot be applied, it is possible to deal with the situation by creating new data using the strategic plan of the artificial intelligence unit B.
- the automatic high-speed display control method for web contents request processing that can access the application processing unit A in which the original data 200 for displaying the web contents on the user terminal 101 is stored. If the unit C is installed, the automatic high-speed display control method for the web content according to the first embodiment of the present invention is ready for implementation. Since no special specification change is required for the application processing unit A, the automatic high-speed display control method for web contents according to the present invention can be easily implemented.
- the application processing unit A actually receives a request from the user terminal 101, the original data 200 is transmitted to the user terminal 101 through the network 102 in response to each request, and the web content based on the original data 200 is sent to the user 101.
- the original data 200 is processed by each unit and replaced with the processed data 210 in a time shorter than the time until it is displayed on the browser or the like and can be accepted on the user terminal 101, and is replaced with the processed data 210 on the user terminal 101. Will be sent.
- the web content based on the original data 200 is displayed for each user 101, and the web content based on the processed data 210 is displayed on the user terminal 101 by the time it can be accepted on the user terminal 101. Can be accepted above.
- the application execution server 103 that can receive a request from the user terminal 101 by the user through the network 102 corresponds to the request.
- An application execution server 103 having a function of transmitting the original data 200 as a response to the user terminal 101 through the network 102 and displaying the web content of the original data 200 on the user terminal 101 is used.
- the application execution server 103 has this function, the function as the application processing unit A can be realized.
- the automatic high-speed display control method for web content according to the first embodiment of the present invention can be incorporated into, for example, a server for displaying web content that has been conventionally operated. In this case, it can be implemented by performing migration such as changing the operating environment to the application execution server 103. It was
- the user uses the processed data 201 in which the original data 200 is optimized and includes the optimum resource having a short display completion time, and the display completion time is shorter than when the original data 200 is used.
- Web contents can be displayed at high speed on a browser or the like of each terminal 101.
- FIG. 24 is an automatic high-speed display control system for implementing the automatic high-speed display control method for web contents according to the second embodiment of the present invention, and is a schematic diagram describing a reverse proxy type configuration.
- the reverse proxy type of the second embodiment of the invention according to the present invention uses the reverse proxy server 1703 in addition to the application execution server 103 as compared with the all-in-one type of the first embodiment described above. Further, the reverse proxy server 1703 is the same as the all-in-one type of the first embodiment except that the artificial intelligence unit B, the request processing unit C, and the data acquisition / processing unit D are installed.
- the application execution server 103 and the reverse proxy server 1703 can send and receive data to and from each other through the network 102.
- the application execution server 103 and the reverse proxy server 1703 are provided with a communication interface 1102 and a communication interface 1702, respectively, and can transmit and receive data through the network 102.
- a communication interface 1102 and a communication interface 1702 respectively, and can transmit and receive data through the network 102.
- the hardware configuration of the reverse proxy server 1703 is exactly the same as that of the application execution server 103 used in the first embodiment.
- the reverse proxy server 1703 also has one or more physical machines, one or more virtual machines, and one or two. At least one execution environment selected from the group consisting of the above containers can be adopted.
- FIG. 25 is a diagram for explaining the details of the hardware configuration included in the storage device 1701 of the reverse proxy server 1703 used in the automatic high-speed display control method of the web content according to the second embodiment of the present invention.
- An OS (OPERATING SYSTEM) 1705 is introduced in the storage device 1701 to control the central processing unit 1700, each storage area of the storage device 1701, each program, and the like.
- the storage device 1701 of the reverse proxy server 1703 is equipped with an artificial intelligence unit B, a request processing unit C, a data acquisition / processing unit D, and a database 1706.
- the storage device 1101 of the application execution server 103 includes an application processing unit A, an original data storage area 104, and a database 1106.
- the original data 200 displayed on the user terminal 101 is stored in the original data storage area 104.
- the hardware configuration other than the above is the same as that of the all-in-one type of the first embodiment.
- FIGS. 26 to 28 are schematic diagram for explaining how a request from a user is processed.
- the request transmitted from the browser or the like of the user terminal 101 operated by the user is received by the request processing unit C of the reverse proxy server 1703 through the network 102.
- This request is transmitted from the request processing unit C to the application processing unit A of the application execution server 103.
- the application processing unit A Upon receiving the request, the application processing unit A transmits, for example, the original data 200 such as the HTML file 113 to the request processing unit C as a response.
- the original data 200 such as the HTML file 113 is transmitted in the order of the artificial intelligence unit B and the data acquisition / processing unit D through the request processing unit C.
- the data acquisition / processing unit D optimizes the original data 200 such as the HTML file 113.
- the processed data 201 such as the optimized HTML file 113z is transmitted to the user terminal 101 of the user through the network 102 via the data acquisition / processing unit D and the request processing unit C.
- the processed data 201 such as the optimized HTML file 113z
- an object for displaying the web content on the browser or the like of the user terminal 101 which is referred to by the HTML file 113z or the like, is described.
- the HTML file 113z or the like optimized by the browser or the like of the user terminal 101 is executed.
- the corresponding optimum resource can be selected based on the identification information of the object.
- the optimum resource is acquired from the data acquisition / processing unit D, and the optimum resource is transmitted from the request processing unit C to the user terminal 101.
- the request processing unit C acquires the corresponding resource from the original data 200.
- the acquired resource is transmitted from the request processing unit C to the user terminal 101. If the optimal resource does not exist, the optimal resource is generated by the data acquisition / processing unit D in the background and is replaced with the resource based on the original data.
- the data acquisition / processing unit D proceeds with the generation of the optimum resource in the background.
- the optimal resource is generated, the resource based on the original data is replaced by the optimal resource.
- the user terminal 101 and the reverse proxy server 1703 communicate with each other, for example, before a request is transmitted from a browser mounted on the user terminal 101 to the reverse proxy server 1703 or the like by the user.
- the crawler unit 200D installed in the data acquisition / processing unit D crawls the original data 200 and the like stored in the application execution server 103.
- resources optimized by the optimization unit d100 installed in the data acquisition / processing unit D are generated and stored in the database 1706 of the reverse proxy server 1703.
- the crawler unit d200 installed in the data acquisition / processing unit D periodically crawls the original data 200 stored in the application processing unit A, and automatically optimized resources are generated and stored in the database 1706. The steps are carried out. In addition, the point that the original data 200 is monitored, the original data 200 is crawled if there is a change in the original data 200, the optimized resource is automatically generated, and the resource is utilized as the optimum resource of the user terminal 101 is mentioned earlier. It is the same as the case of Embodiment 1 described in 1.
- Which optimum resource is selected for each user terminal 101 is determined based on the strategy plan drafted by the artificial intelligence unit B, as in the case of the first embodiment described above.
- the unit A transmits the original data 200 for displaying the web content on the user terminal 101 of the user as a response.
- This response is received by the user terminal 101 through the network 102 via the request processing unit C of the reverse proxy server 1703.
- the web content based on the original data 200 is displayed on the user terminal 101 by a browser or the like mounted on the user terminal 101.
- the application execution server including the application processing unit A in which the original data 200 for displaying the web content on the user terminal 101 is stored.
- the reverse proxy type of the second embodiment can be implemented by newly introducing the reverse proxy server 1703 while operating the 103. In the reverse proxy type of the second embodiment, there is no need to migrate the original data 200 or the like. Further, by changing the DNS of the application execution server 103 to the reverse proxy server 1703, it is possible to easily implement the automatic high-speed display control method of the web content according to the second embodiment of the present invention.
- the original data 200 is optimized, and the original data 200 is used by using the processed data 201 including the optimum resource having a short display completion time.
- the web content can be displayed at high speed on the browser or the like of each user terminal 101 in a shorter display completion time than in the case of using.
- FIG. 29 is an automatic high-speed display control system for implementing the automatic high-speed display control method for web contents according to the third embodiment of the present invention, and is a schematic diagram describing a nanoagent type configuration.
- the nanoagent type of the third embodiment of the present invention uses the artificial intelligence server 1403 and the data acquisition server 1603 in addition to the application execution server 103 as compared with the all-in-one type of the first embodiment described above. Is different. Another difference is that the application processing unit A and the request processing unit C are installed in the application execution server 103. Further, the difference is that the artificial intelligence processing intelligence unit B is installed in the artificial intelligence server 1403 and the data acquisition / processing unit D is installed in the data acquisition server 1603.
- the hardware configurations of the artificial intelligence server 1403 and the data acquisition server 1603 are the same as those of the application execution server 103 used for the all-in-one type of the first embodiment described above.
- Each of the application execution server 103, the artificial intelligence server 1403, and the data acquisition server 1603 can send and receive data to and from each other through the network 102.
- the application execution server 103, the artificial intelligence server 1403, and the data acquisition server 1603 are provided with communication interfaces 1102, 1402, and 1602, respectively, and can transmit and receive data to and from each other through the network 102.
- communication interfaces 1102, 1402, and 1602, respectively can transmit and receive data to and from each other through the network 102.
- each of the artificial intelligence server 1403 and the data acquisition server 1603 is also composed of a group consisting of a physical machine, a virtual machine, and a container. It can be executed using at least one execution environment of choice.
- FIGS. 30 to 32 are schematic diagram for explaining how a request from a user is processed.
- the request transmitted from the browser or the like of the user terminal 101 operated by the user is transmitted in the order of request processing unit C and application processing unit A through the network 102.
- the request transmitted from each user terminal 101 to the application execution server 103 via the network 102 is processed by the request processing unit C and the application processing. Received in the order of unit A.
- the application processing unit A transmits the original data 200 for displaying the web content on the user terminal 101 of the user as a response through the request processing unit C. This response is received by the user terminal 101 through the network 102. Then, the web content based on the original data 200 is displayed on the user terminal 101 by a browser or the like mounted on the user terminal 101.
- the HTML file 113 generated by the application processing unit A can also be transmitted to the user terminal 101.
- the request processing unit C interrupts the processing in which the response is executed from the application processing unit A to the user terminal 101 through the network 102, and acquires the original data 200 such as the HTML file 113.
- a request from the request processing unit C is transmitted through the network 102 in the order of the artificial intelligence unit B of the artificial intelligence server 1403 and the data acquisition / processing unit D of the data acquisition server 1603. Will be done.
- the data acquisition / processing unit D of the data acquisition server 1603 optimizes the original data 200 such as the HTML file 113.
- the processed data 201 such as the optimized HTML file 113z passes through the data acquisition server 1603 and the artificial intelligence server 1403 in which the data acquisition / processing unit D is installed, and then through the request processing unit C of the application execution server 103 and the network 102. It is transmitted to the user terminal 101 of the user.
- the processed data 201 such as the optimized HTML file 113z describes, for example, an object for displaying the web content on the browser or the like of the user terminal 101, which is referred to by the HTML file 113z or the like.
- the request processing unit C acquires the optimum resource from the data acquisition / processing unit D based on the reference information by the object of the program described in the optimized HTML file 113z or the like, and the data acquisition server 1603 and the artificial intelligence server 1403. And, it is transmitted to the user terminal 101 through the network 102 via the application execution server 103.
- the application processing unit A of the application execution server 103 acquires the corresponding resource from the original data 200.
- the acquired resource is transmitted from the request processing unit C of the application execution server 103 to the user terminal 101 through the network 102. If the optimal resource does not exist, the optimal resource is generated by the data acquisition / processing unit D in the background and is replaced with the resource based on the original data.
- the data acquisition server when the user terminal 101 and the application execution server 103 are not communicating with each other, such as before a request is transmitted from the browser mounted on the user terminal 101 to the application execution server 103 by the user, the data acquisition server.
- an application execution server including an application processing unit A in which original data 200 for displaying web contents on a user terminal 101 is stored.
- the nanoagent type of the third embodiment there is no need to migrate the original data 200 or the like. Further, since it is not necessary to change the DNS of the application execution server 103, the automatic high-speed display control method for web contents according to the third embodiment of the present invention can be easily implemented.
- a server equipped with the same unit as the data acquisition / processing unit D of the data acquisition server 1603 is additionally installed at a short distance of the application execution server 103 to acquire the data of the data acquisition server 1603. By performing the same processing as the processing unit D, it is possible to prevent a decrease in communication speed.
- nanoagent type of the third embodiment of the present invention since no special migration or DNS change is required, it can be easily applied to a system for distributing web contents that is already in operation.
- the original data 200 is optimized, and the original data 200 is used by using the processed data 201 including the optimum resource having a short display completion time.
- the web content can be displayed at high speed on the browser or the like of each user terminal 101 in a shorter display completion time than in the case of using.
- FIG. 33 is an automatic high-speed display control system for implementing the automatic high-speed display control method for web contents according to the fourth embodiment of the present invention, and is a schematic diagram describing a SaaS type configuration.
- the SAA (Software as a Service) type of the fourth embodiment of the present invention has an application processing unit A, an artificial intelligence processing intelligence unit B, and a request processing unit as compared with the all-in-one type of the first embodiment described above. The difference is that C and the data acquisition / processing unit D are each installed on the cloud 1803.
- the units A to D can communicate with each other in one execution environment.
- the SaaS type of the first embodiment the units A to D can communicate with each other through the network 102. Other than that, it is the same as the case of the first embodiment.
- the network 102 is an execution environment consisting of at least one selected from a group consisting of one or more physical machines, one or more virtual machines, and one or more containers that can communicate through the network 102.
- the automatic high-speed display control method for web contents according to the fourth embodiment of the present invention can also be constructed in this cloud environment. What is built under this cloud environment is the SaaS type.
- the execution is performed regardless of the type of cloud platform used, the difference in the providing company, the difference in whether the data center for executing the cloud environment is in the home country or in a foreign country, and the like. You can select and build an environment.
- FIGS. 34 to 36 are schematic diagram for explaining how a request from a user is processed.
- the request transmitted from the browser or the like of the user terminal 101 operated by the user is transmitted to the request processing unit C through the network 102.
- the request processing unit C that has received the request transmitted to the cloud 1803 is the user terminal of the user through the application processing unit A.
- the original data 200 for displaying the web content on the 101 is transmitted as a response. This response is received by the user terminal 101 through the network 102. Then, the original content is displayed on the user terminal 101 by a browser or the like mounted on the user terminal 101.
- the original data such as the HTML file 113 dynamically generated and stored by the application processing unit A is sent to the user terminal 101. You can also send it.
- the request processing unit C interrupts the processing in which the response is executed from the application processing unit A to the user terminal 101 through the network 102, and acquires the HTML file 113 and the like. For example, based on the acquired HTML file 113 or the like, a request is transmitted from the request processing unit C to the artificial intelligence unit B and the data acquisition / processing unit D through the network 102.
- the data acquisition / processing unit D Based on the strategy plan drafted by the artificial intelligence unit B, the data acquisition / processing unit D optimizes the HTML file 113 and the like. For example, the optimized HTML file 113z is transmitted to the user terminal 101 of the user through the network 102 via the data acquisition / processing unit D, the artificial intelligence unit B, and the request processing unit C.
- the request processing unit C acquires the optimum resource from the data acquisition / processing unit D and uses it via the artificial intelligence unit B. It is transmitted to the person terminal 101.
- the request processing unit C acquires the corresponding resource from the original data 200.
- the acquired resource is transmitted from the application processing unit A to the user terminal 101 via the request processing unit C. If the optimal resource does not exist, the optimal resource is generated by the data acquisition / processing unit D in the background and is replaced with the resource based on the original data.
- the user terminal 101 and the request processing unit C communicate with each other, for example, before a request is transmitted to the request processing unit C from a browser or the like mounted on the user terminal 101 by the user.
- the crawler unit d200 installed in the data acquisition / processing unit D crawls the original data 200 and the like stored in the application processing unit A.
- resources optimized by the optimization unit d100 installed in the data acquisition / processing unit D are generated and stored in the database 1706 installed in the cloud 1803.
- the crawler unit d200 installed in the data acquisition / processing unit D periodically crawls the original data 200 that can be used by the application processing unit A, and automatically optimized resources are generated and stored in the database 1706. The steps to be taken are carried out. In addition, the point that the original data 200 is monitored, the original data 200 is crawled if there is a change in the original data 200, the optimized resource is automatically generated, and the resource is utilized as the optimum resource of the user terminal 101 is mentioned earlier. It is the same as the case of Embodiment 1 described in 1.
- the web content is set in a cloud environment separately from the conventional server operated for displaying the web content on the user terminal 101.
- the original data 200, etc., and the environment for displaying these original data 200, etc. on the user terminal are migrated.
- the DNS of the conventional server operated for displaying the web content on the user terminal 101 is changed to the cloud 1803.
- the SassS type of Embodiment 4 is implemented on the cloud without changing the environment of the conventional server operated to display the web content on the user terminal 101. can.
- the original data 200 is optimized, and the original data 200 is used by using the processed data 201 including the optimum resource having a short display completion time.
- the web content can be displayed at high speed on the browser or the like of each user terminal 101 in a shorter display completion time than in the case of using.
- a smartphone is adopted as the user terminal 101.
- the steps for generating the web content 211 described below are the same as in the case of the first embodiment of the present invention.
- FIG. 37 is a conceptual diagram for explaining a mechanism for displaying the web content 211 on the user terminal 101 at high speed.
- the communication congestion 401 There are two major factors that prevent the web content 211 from being displayed at high speed on the user terminal 101.
- One is the communication congestion 401, and the remaining one is the drawing congestion 402.
- the original data 200 (reference numeral 400 in FIG. 37) also includes data unnecessary for the individual user terminal 101. Therefore, if the original data 200 is transmitted to the user terminal 101 as it is, it will take an extra time to complete the transmission of the original data to the user terminal 101.
- the first embodiment it was mainly related to the delivery optimization for improving the communication congestion 401 in FIG. 37 (reference numeral 403 in FIG. 37).
- the drawing congestion 402 is eliminated.
- drawing means that the web content 211 or the like is displayed on the user terminal 101.
- One of the reasons for the drawing congestion 401 shown in FIG. 37 is that a large amount of miscellaneous information is attempted to be transmitted from the request processing unit C to the user terminal 101 at once.
- the drawing of the portion corresponding to the first view is prioritized as the information to be transmitted to the user terminal 101 first from the resources required for displaying the web content 211 (the drawing of the portion corresponding to the first view is prioritized.
- Reference numeral 404 in FIG. 37 Next, communication is restricted, and priority is given to shifting to a state in which the user terminal 101 can accept input from the user (reference code 404 in FIG. 37). Subsequently, the communication is organized, and the parts other than the portion corresponding to the first view from the sources required for displaying the web content 211 are ordered and transmitted to the user terminal 101 (reference code 405 in FIG. 37).
- the user terminal 101 shifts to a state in which input from the user can be accepted, that is, the user terminal 101 performs screen operations such as scrolling, tapping, clicking, and dragging, various text input, voice input, and an image. It means that it is in a state where it can accept input operations such as input.
- the portion other than the portion corresponding to the first view is systematically transmitted to the user terminal 101, for example, for drawing other than the portion corresponding to the first view. If there are two or more required program parts, and if the program parts interfere with each other, give priority to one of them, wait for the completion of the priority program part, and then wait for the completion of the next program part. In the case of synchronous execution, which moves to the execution of the program part When the program parts do not interfere with each other, it means the case of asynchronous execution in which the execution of the program part is started without waiting for the completion of the other program parts.
- each original data 200 stored in all the application processing units A is processed by the data acquisition / processing unit D. Therefore, a plurality of processed data 201 are generated.
- the plurality of processed data 201 correspond to all the user terminals 101 that are expected to access the request processing unit C, and before the request is transmitted from the user terminal 101 to the application execution server 103. It is automatically generated.
- the processed data 201 is used with a plurality of processed data 201 corresponding to the web content 211a called the first view corresponding to the initial display screen A in the browser of the user terminal 101 for each user terminal 101. It is generated by being divided into a plurality of processed data 201 corresponding to the web content 211b different from the first view, which does not correspond to the initial display screen A in the browser of the user terminal 101.
- Original data based on the shortest time from when a request is transmitted from the user terminal 101 to the application processing unit A until the web content 211a can be input and accepted by the user terminal 101.
- the processed data 210 corresponding to the web content displayed in the first view is selected from the 200 and the plurality of processed data 201.
- the artificial intelligence unit B For each user terminal 101, information such as how to process and how to combine in the data acquisition / processing unit D, and web content 211a can be input and accepted in the shortest time on each user terminal 101.
- the artificial intelligence unit B has already learned the correlation with the processed data 210 regarding the time until it becomes.
- the artificial intelligence unit B can formulate a strategic plan for selecting the optimum processed data 210 by performing statistical processing using the data obtained in the preliminary test. Even if the original data 200 stored in the application processing unit A is dynamically generated or changed, if the original data 200 is changed, the artificial intelligence unit B up to now plans. Based on the proposed strategy, new processed data 210 is generated.
- the request processing unit C When a request is actually made from the user terminal 101 to the request processing unit C, not all of the web contents 211 are transmitted to the user terminal 101, but the initial display screen A in the browser of the user terminal 101 is displayed. The minimum portion including the processed data 201 necessary for displaying the corresponding web content 211a called the first view is first divided and transmitted.
- the request processing unit C When a request is transmitted from the browser or the like mounted on the user terminal 101 to the request processing unit C, the request processing unit C that has received the request sends the request to the application processing unit A and the artificial intelligence unit. Further, the request is transmitted to the data acquisition / processing unit D directly via the network 102 via the artificial intelligence unit B or not via the artificial intelligence unit B.
- Step to specify the data corresponding to the initial display screen of the user terminal 101 In the display environment of the user terminal 101, information such as a user agent and a referrer included in the signal transmitted from the user terminal 101 to the application processing unit A is stored in the setting file storage unit 1523 of the data acquisition / processing unit D. It can be identified by collating with the model information file 1526.
- each user terminal 101 which part of the web content 211 corresponds to the first view has been learned in advance by a preliminary test and machine learning using the data obtained by the preliminary test. It can be determined using a model.
- the display environment of the initial display screen A in the browser of the user terminal 101 can be specified based on the information described in the model information file 1526.
- information on program data such as characters, numbers, and symbols described in the HTML file 113 described above with reference to FIG. 16 and the optimized HTML file 113z.
- Information such as the size of the program data described in the CSS file 107 and the processed CSS file 132, From the information such as the size and placement position of the image file 109 and the processed image file 134, the HTML file 113, the CSS file 107, the script language file 108, the optimized HTML file 113z, the processed CSS file 132, and the processed script. It is specified which part of the language file 133, the image file 109, the processed image file 134, and the like is displayed on the initial display screen A corresponding to the first view in the browser of the user terminal 101.
- the HTML file 113 the CSS file 107, the script language file 108, and the optimized HTML file 113z, which can be displayed using this display environment and correspond to the first view, respectively.
- the processed CSS file 132, the processed script language file 133, the image file 109, the processed image file 134, and the like are specified. These identifications are carried out by the program described in the control unit d300 mounted on the data acquisition / processing unit D.
- Step to identify the corresponding data other than the initial display screen of the user terminal If the data displayed on the initial display screen A in the browser of the user terminal 101 is specified, the data corresponding to other than the initial display screen A corresponding to the first view of the user terminal 101 can be specified accordingly.
- the data excluding the data displayed on the initial display screen A in the browser of the user terminal 101 from the web contents 211 and the web contents 212 is the data corresponding to other than the initial display screen A of the user terminal 101.
- the web content 211 includes the web content 211a corresponding to the first view and the web content 211b not corresponding to the first view.
- the resource for displaying the web content 211 includes the HTML data 301 corresponding to the first view in the HTML file 113 or the optimized HTML file 113z. Further, among the CSS file 107 and the processed CSS file 132, the CSS data 302 corresponding to the first view is included.
- the script language data 303 corresponding to the first view is included.
- the image file 109 and the processed image file 134 the image data 304 corresponding to the first view is included.
- the user terminal 101 Upon receiving the resource for displaying the web content 211a corresponding to the first view of the user terminal 101, the user terminal 101 displays the web content 211a on the browser mounted on the user terminal 101 in a short display completion time. Can be done.
- the code portion for allowing the user terminal 101 to accept input from the user is given priority and transmitted to the user terminal 101 (reference code in FIG. 37). 404).
- the user When a user of the user terminal 101 is interested in the web content 211a corresponding to the first view displayed on the browser of the user terminal 101, the user causes the user terminal 101 to display additional information.
- the specific example of the case of causing is as follows.
- the user of the user terminal 101 clicks a button or the like displayed on the browser of the user terminal 101, and in order to see the information displayed by scrolling the initial display screen A in the browser of the user terminal 101.
- the user scrolls the browser of the user terminal 101, and even though a certain period of time has passed from the display of the initial display screen A in the browser of the user terminal 101, the user does not leave the initial display screen A and continues reading the displayed contents. Take actions such as.
- the browser installed in the user terminal 101 detects the event information.
- the optimized HTML file 113z or the like corresponding to the request is first downloaded to the user terminal 101.
- reference information about resources is described as an object as a function of the program.
- an object for inserting an object into the optimized HTML file 113z or the like as a function of a program is also described.
- the program code added to the optimized HTML file 113z or the like immediately relieves the remaining resources for displaying the remaining web contents 211b in the network 102. It is transmitted to the user terminal 101 via.
- the user terminal 101 that has received the resource for displaying the web content 211b can display the web content 211b at high speed on the browser mounted on the user terminal 101.
- the resource for displaying the web content 211b may be transmitted to the user terminal 101 at one time, or may be transmitted in a divided manner.
- necessary data can be supplied to the user terminal 101 at a necessary time. Therefore, the congestion of data transmission to each user terminal 101, the congestion of data processing for displaying the web content on the user terminal 101, and the congestion of drawing are eliminated. As a result, automatic high-speed display of web contents is realized.
- the optimized HTML file 113z or the like When the optimized HTML file 113z or the like is downloaded to the user terminal 101 of the user, the resource corresponding to the object defined in the optimized HTML file 113z is downloaded to the user terminal 101, or the resource corresponding to the object is downloaded to the user terminal 101. It becomes accessible through the network 102. After that, the user can freely browse the web contents by the browser or the like of the user terminal 101 by operating the browser or the like mounted on the user terminal 101 of the user.
- a smartphone is adopted as the user terminal 101.
- the steps for generating the web content 211 described below are the same as in the case of the first embodiment of the present invention.
- Embodiment 6 of the present invention automatic high-speed display of web content is performed based on the user experience of the user who browses the web content and the engagement generated between the user and the website caused by the user browsing the web content. The steps to be realized change.
- the "user experience” used in the disclosure of the present invention means the content experienced by the user who browses the web content displayed on the user terminal.
- the user reads the text information displayed in the web content, scrolls the browser installed in the user terminal to further read the text information, and links associated with the web content. Click to browse the linked content, play the video file associated with the web content, play the music file, browse the image file, enter the text information in the form field and send the text information,
- One or more of the acts such as purchasing the product displayed on the web content can be mentioned.
- the actual individual user experience can be captured as event information by the browser installed in each user terminal 101.
- the user who browses the web content determines that he / she is not interested in the web content or the information requested for the web content is not posted, the user takes an action called withdrawal. If a user does not leave the web content at first glance and browse the web content again, the score associated with the user experience for that user is zero.
- the display completion time that the user can tolerate is said to be within 2 seconds. Which display completion time is acceptable depends on your engagement with your website.
- the user cannot wait even for 1 second.
- the user experience is increased. Then, when the provider of the web content displayed on the user terminal of the user performs all the actions related to the web content provided by the administrator of the website, the user about the user at that time is performed. The experience is maximized.
- the relative value of the score related to the user experience can be positioned as 100.
- engagement used in the disclosure of the present invention is a trust relationship fostered through the web content between the user who browses the web content displayed on the user terminal and the operator of the website. Means.
- this trust relationship is treated as being related to the user experience. That is, if there is no engagement between the user and the website operator, for example, if the user is not browsing the web content, the engagement corresponds to zero as a relative value. However, after the request is transmitted from the user terminal 101 to the request processing unit C or the like even once, the user experience of accessing the web content is added as the engagement score. Therefore, the engagement score for the user terminal 101 whose history of accessing the request processing unit C or the like is stored in the user terminal 101 or the like is recorded as a value larger than zero.
- the value of engagement based on user experience for each user varies between 0 and 100 as a relative value. According to the present inventor's knowledge, the value of engagement tends to be small for users who are not interested in web content, and conversely, the value of engagement tends to be large for users who are interested in web content. It has been found by previous studies by.
- the display processing of the web content displayed on the user terminal browsed by each user is adjusted according to the engagement score of the user, and the satisfaction level of the user browsing the website is adjusted. Is disclosed how to maximize.
- the engagement score between the user and the web content is calculated.
- the lowest engagement score is assigned as a relative value of 0.
- the act of sending the request to the application processing unit A is one user experience, so the engagement score is added.
- the web content displayed on the user terminal 101 is selected based on the engagement score.
- the web content 211 having the shortest display completion time is assigned to the user with the lowest engagement score. Further, for example, the web content 211 having the longest display completion time and having abundant content is assigned to the user having the highest engagement score.
- the engagement score used in the sixth embodiment of the present invention is associated with the identification data for identifying the user terminal 101 that has sent the request to the request processing unit C for each user terminal 101 and the identification data. It is calculated based on the historical data for each user terminal and the user experience associated with.
- data such as an accept header and a cookie that identifies the user terminal 101 are stored in a database through a program described in the control unit 1512 of the data acquisition / processing unit D. Recorded at 506. These data are identification data for identifying the user terminal 101.
- the actions such as clicking, scrolling, dragging, and inputting text performed by the user by the browser mounted on the user terminal 101 are stored as an event in a cookie or the like for each user terminal 101.
- the engagement score can be managed by the program added to the optimized HTML file 113z or the like downloaded for each user terminal 101, as described in the case of the fifth embodiment. ..
- the engagement score is managed on the user terminal 101, but the engagement score can be managed on the execution environment side such as the application execution server 103, for example.
- the data related to the event can be detected on the data acquisition / processing unit 103 side via the request processing unit C and the processing unit A. These event information can also be transmitted as signals to the control unit 1512 mounted on the data acquisition / processing unit D.
- the event information transmitted to the data acquisition / processing unit D via the network 102 is analyzed, for example, in association with the event handler defined in the control unit d300 of the data acquisition / processing unit D shown in FIG. This event information is recorded as historical data for each user terminal 101 in each user terminal 101 and, if necessary, in the database 1106.
- the historical data for each user terminal 101 includes, for example, the number of requests by the user sent from the browser, the type of request by the user sent from the browser, the staying time of the website by the user, and the interval between the requests sent from the browser.
- One type or two or more types such as the period of.
- Specific historical data is as follows.
- the history data for each user terminal 101 for example, the time 301 when the user reads the text information displayed on the web content 211.
- the number of times the text information 308 and the text information 308 entered in the form field associated with the web content 211 have been sent 309, Of the products displayed on the web content 211, the purchased product 310 and the number of times the product 310 was purchased 311 Of the services displayed on the web content 211, the service 312 requested to be provided and the number
- the distance 317 or the like of the mouse or the like moved on the browser screen of the user terminal 101 can be mentioned.
- the history data for each user terminal 101 can be used by selecting one type or two or more types.
- the historical data for each user terminal 101 stored in the database 1106 corresponds to the user experience for each user.
- the step of calculating the engagement score for each user terminal 101 is carried out as follows.
- the formula (A) is a formula for calculating the engagement score for each user terminal 101.
- fi is a function corresponding to the history data for each user terminal 101, and ai indicates a coefficient for each function.
- i is a natural number, and each value corresponds to each historical data.
- k is the total number of historical data.
- the history data for each user terminal 101 is stored in the database 1106 as a variable i.
- the time 301 for reading the text information per one website visit of a specific user is relative to the average time for reading the text information per one website visit for each user.
- the proportions correspond.
- the ratio to the average historical data is associated with the variable fi.
- the engagement score of the user who browses the web content 211 by the user terminal 101, but leaves in less than 2 seconds and then has no browsing history again is set to zero.
- the value of the formula (A) for the user showing the largest value calculated by the formula (A) is set to 100.
- the coefficient ai is an index of which item is emphasized.
- the value of 0100 is obtained as a relative value for each user terminal 101 used by all the users who have sent the request to the server.
- Each of these values is the engagement score from the publication of the web content 211 to the present. Engagement scores are added each time the user browses the web content 211. Therefore, the engagement score is not constant for each user and changes over time for each user.
- Steps in which web content is selected according to the engagement score Next, a step of selecting the web content 211 according to the engagement score will be described. Based on the history information for each user and the identification information information of the user terminal 101 linked to this history information, the combination of files that can be used in the display environment for each user terminal 101 is specified, and the user terminal is specified.
- the data acquisition / processing unit D can generate a plurality of web contents 211 having different display completion times for each 101.
- the resource corresponding to the web content 211 having the shortest display completion time of the web content is selected.
- the deleted resource is selected to the extent that the display of the user terminal 101 does not cause a problem.
- a resource from which a video file, a link for playing a video file, a link for displaying an advertisement such as an advertisement file / advertisement link, etc. has been deleted is selected.
- the one with the shortest display completion time is specified.
- the processed CSS file 132 For example, regarding the processed CSS file 132, the processed script language file 133, the processed image file 134, etc., the deleted video file, the link to the video file, the advertisement file, the resource related to the advertisement link, etc. are deleted. Is identified.
- the combination data having the shortest display completion time is specified. Since the processing of the web content 211 displayed by the combination data having the shortest display completion time is completed in advance, the information such as the user agent and the referrer is actually obtained by collating with the model information file 1526. It is possible to respond to the display environment of the user terminal 101 within 0.2 seconds, preferably within 100 ms, as the display completion time.
- the request is made. It is possible to reduce the time required from the processing unit C to the completion of transmission of the web content 211 to the user terminal 101.
- the web content 211 is displayed quickly, but the web content 211 that is not omitted is selected.
- a video file, a link for playing a video file, etc., and a link for displaying an advertisement such as an advertisement file / advertisement link are not deleted.
- the resource for displaying the web content 211 on which the displayable information is posted is selected. Specifically, from the specified file group that can be used in the display environment of the user terminal 101, the display completion time is short and there is no omitted information according to each file type. The combination is extracted.
- the HTML file 113 and the optimized HTML file 113z are compared, and the one with the short display completion time is adopted from the ones without the omitted information.
- the display completion time is short among those for which there is no omitted information for each of the CSS file 107 and the processed CSS file 132, the script language file 108 and the processed script language file 133, the image file 109 and the processed image file 134. Things are adopted.
- a combination of data having a short display completion time is specified from those without omitted information.
- the web content 211 which includes data that combines data with a short display completion time from those that do not have omitted information, is a user terminal 101 obtained by collating information such as a user agent and a referral with a model information file 526. Since it is selected based on the display environment, it can correspond to the display screen of the user terminal 101.
- the web content 211 can be input and accepted on the user terminal 101 after the request is transmitted from the user terminal 101 to the request processing unit C or the like.
- the processed data 210 that has the shortest time to become is selected.
- the user's engagement score is the highest, it takes the longest time from the request sent from the user terminal 101 to the application processing unit A until the web content 211 can be input and accepted on the user terminal 101.
- Processed data 210 is selected. In the middle of the case where the user's engagement score is the highest and the case where the user's engagement score is the lowest, the web content 211 can be input and accepted on the user terminal 101 after the request is transmitted from the user terminal 101 to the application processing unit A.
- the processed data 210 is selected, which is an intermediate time between the case where the time is the shortest and the case where the time is the longest.
- FIG. 38 is a flowchart for explaining how the user experience is reflected in the step of realizing the automatic high-speed display of the web content.
- the user transmits the request 101 from the user terminal 101 to the application processing unit A (step S3001).
- a request is transmitted from the request processing unit C and the application processing unit A to the artificial intelligence unit B and the data acquisition / processing unit D (step S3002).
- the data acquisition / processing unit D specifies the display environment of the user terminal 101 from the information such as the accept header and the cookie included in the request (step S3003).
- the engagement score so far can be specified based on the identification information associated with the user terminal 101 from the information such as the accept header and the cookie (step S3004).
- the processed data 210 according to the obtained engagement score is selected, and the object corresponding to the processed data 210 is transmitted to the data acquisition / processing unit D, the artificial intelligence unit B, the application processing unit A, and the request processing unit C. NS. Then, the resource of the processed data 210 is associated with the object of the optimized HTML file 113z (step S3005).
- the HTML file 113z optimized by the browser of the user terminal 101 or the like is executed. Then, the web content 211 is displayed on the user terminal 101 (step S3008).
- step S3006 of FIG. 38 the processed data 210 to be transmitted to the user terminal 101 is selected from the engagement score for the user associated with the user terminal 101.
- Whether or not this distribution is correct can be determined by whether or not the user leaves the user terminal 101 at an early stage.
- step S3006 For example, if the user does not leave and continues to browse the web content 211, it can be seen that the selection in step S3006 is correct. On the contrary, if the user does not continue to browse the web content 211 and leaves early, it can be seen that the selection in step S3006 is incorrect. If the selection in step S3006 is correct, the engagement score is added, and if the selection in step S3006 is incorrect, the engagement score is subtracted. By this operation, it is possible to automatically increase the user's satisfaction with the web content in a more detailed manner based on the user experience.
- the automatic high-speed display control method for web contents according to the present invention can be easily installed in a system for displaying web contents using a conventionally used network. Further, since the speed of displaying the web content can be improved, it can be widely applied in the communication field dealing with the web content using the network.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Databases & Information Systems (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Data Mining & Analysis (AREA)
- Information Transfer Between Computers (AREA)
Abstract
【課題】ユーザの利用者端末からリクエストが送信されてウェブコンテンツがユーザの利用者端末上で入力受付可能になるまでの時間内に、ユーザの利用者端末毎に、調整後のウェブコンテンツを表示するウェブコンテンツの自動高速表示制御方法を提供する。 【解決手段】 利用者端末からリクエストが送信されてからウェブコンテンツが利用者端末で入力受付可能になるまでの時間内に、 サーバのリクエスト処理ユニットがリクエストを検出するステップと、人工知能サーバが、戦略案を立案するステップと、戦略案に基づいて、処理済みデータが生成するステップと、利用者端末で処理済みデータによるウェブコンテンツが表示されるステップとが実施され、 前記戦略案を立案するステップが、ウェブコンテンツをより速く表示するための処理済みデータが共通して有する属性を学習するステップを含む、ウェブコンテンツの自動高速表示制御方法。
Description
本発明は、ウェブコンテンツの自動高速表示制御方法に関する。
パーソナルコンピュータ(PC)、スマートフォン、タブレットなどの利用者端末を使って、ユーザは知りたい情報を好きな時に検索し、検索結果として利用者端末に表示されたウェブコンテンツをユーザは閲覧することができる。
ユーザは検索結果が利用者端末に速く表示されることを通常希望する。このため、ユーザにウェブコンテンツを提供する速度を向上させることは重要である。
従来、フィーチャーフォン等の携帯情報端末にウェブコンテンツを表示させるための通信規格、携帯情報端末のデータ処理規格等は、通信事業者毎に定める規格に従っていた。
このため同じ通信事業者間で同じ規格のフィーチャーフォン等の携帯情報端末を使う場合であれば、同じウェブコンテンツを問題なく表示できる。この一方で、例えば異なる通信事業者間で通信が行われる場合、ユーザが通信データの規格に合わないフィーチャーフォン等の携帯情報端末を使用する場合には、ユーザの携帯情報端末に正常にウェブコンテンツが表示されない問題が生じていた。
この問題に対応するために、異なる通信事業者間の通信データを、ユーザが使用する携帯情報端末の通信データの規格に合わせて変換する、いわゆる通信データ変換技術が進展してきた。この通信データ変換技術を用いて、表示の互換性を実現できる。
このため同じ通信事業者間で同じ規格のフィーチャーフォン等の携帯情報端末を使う場合であれば、同じウェブコンテンツを問題なく表示できる。この一方で、例えば異なる通信事業者間で通信が行われる場合、ユーザが通信データの規格に合わないフィーチャーフォン等の携帯情報端末を使用する場合には、ユーザの携帯情報端末に正常にウェブコンテンツが表示されない問題が生じていた。
この問題に対応するために、異なる通信事業者間の通信データを、ユーザが使用する携帯情報端末の通信データの規格に合わせて変換する、いわゆる通信データ変換技術が進展してきた。この通信データ変換技術を用いて、表示の互換性を実現できる。
一方、ユーザにウェブコンテンツを高速に提供する方法として、アカマイ社が提供するAKAMAI IMAGE MANAGERの技術が知られている。アカマイ社の技術によれば、ウェブサイトに表示される個々の画像について、ブラウザ、利用者端末に最適なサイズ、品質、ファイル形式の組み合わせを自動的に提供できるとされる(非特許文献1)。
またウェブサーバに保存されているデータをユーザの利用者端末に表示させる方法としてCDN(CONTENT DELIVERY NETWORK)と呼ばれる方法が知られている(特許文献1)。
ウェブサイトの運営者は、CDNを提供する企業と契約して、企業が提供するCDNの方法を使うことができる。この場合、管理者が公開するウェブサイトのドメインは、CDNを提供する企業のドメインではなく、ウェブサイトの運営者が指定するドメインを使うことができる。これにより、ウェブサイトの運営者は自己のドメインを維持したまま、ユーザに対して強力なCDNの方法を提供することができる。
ウェブサイトの運営者は、CDNを提供する企業と契約して、企業が提供するCDNの方法を使うことができる。この場合、管理者が公開するウェブサイトのドメインは、CDNを提供する企業のドメインではなく、ウェブサイトの運営者が指定するドメインを使うことができる。これにより、ウェブサイトの運営者は自己のドメインを維持したまま、ユーザに対して強力なCDNの方法を提供することができる。
CDNの場合は、複数のウェブサーバ群が準備され、それぞれのウェブサーバに同じデータが保存されている。そしてユーザがCDNの方法を使うと、ユーザの利用者端末に最も近いウェブサーバからデータがユーザの利用者端末に送信される。
一つのウェブサーバに対して一度に多数の利用者端末からのアクセスがあれば、ウェブサーバの処理対応の負荷が大きくなる。ウェブサーバの単位時間当たりの処理能力には限度があるから、一定以上のアクセスが一つのウェブサーバに集中すれば、そのウェブサーバの処理時間は遅延する傾向がある。
CDNの方法によれば、一つのウェブサーバに対して一度に多数の利用者端末からのアクセスが集中した場合でも、複数のウェブサーバ群同士で形成された通信網を通じて余力のあるウェブサーバを活用できるから、ウェブサーバの処理時間の遅延を防止して、ユーザの利用者端末からの多くのデータ要求に高速に対応できる。
CDNの方法によれば、一つのウェブサーバに対して一度に多数の利用者端末からのアクセスが集中した場合でも、複数のウェブサーバ群同士で形成された通信網を通じて余力のあるウェブサーバを活用できるから、ウェブサーバの処理時間の遅延を防止して、ユーザの利用者端末からの多くのデータ要求に高速に対応できる。
一方、ウェブコンテンツを最新の状態に保つ技術として、タスクライナーと呼ばれる方法が知られている(非特許文献2)。
タスクライナーの一つである、GULPと呼ばれる方法を用いた場合、ウェブコンテンツを表示するためのオリジナルデータを常時監視さている。そしてオリジナルデータに改変があったことが検知されると、自動的にオリジナルデータが改変され、ウェブコンテンツが自動的に即時更新される。
タスクライナーの一つである、GULPと呼ばれる方法を用いた場合、ウェブコンテンツを表示するためのオリジナルデータを常時監視さている。そしてオリジナルデータに改変があったことが検知されると、自動的にオリジナルデータが改変され、ウェブコンテンツが自動的に即時更新される。
アカマイ社のホームページ(https://www.akamai.com/us/en/solutions/performance/image-management.jsp)
GULPのホームページ(https://gulpjs.com/)
ところでウェブコンテンツがユーザの利用者端末に高速表示されるためには、ユーザの利用者端末に高速表示されるように、ウェブコンテンツを構成するオリジナルデータが調整されていることが必要である。
この様な調整としては、例えば、ユーザの利用者端末の高速表示を妨げる要素が前記オリジナルデータに存在するなら、このオリジナルデータに含まれる要素を削除する、オリジナルデータに含まれる要素処理を後回しにする等の方法、
ユーザの利用者端末に転送されるオリジナルデータの容量削減、圧縮等による、前記オリジナルデータの転送時間の削減等の方法等が挙げられる。
これらの調整は、ウェブコンテンツを提供するウェブサイトの管理者により通常実施される。そしてこれらの調整により、ウェブコンテンツはユーザの利用者端末に高速表示される。
この様な調整としては、例えば、ユーザの利用者端末の高速表示を妨げる要素が前記オリジナルデータに存在するなら、このオリジナルデータに含まれる要素を削除する、オリジナルデータに含まれる要素処理を後回しにする等の方法、
ユーザの利用者端末に転送されるオリジナルデータの容量削減、圧縮等による、前記オリジナルデータの転送時間の削減等の方法等が挙げられる。
これらの調整は、ウェブコンテンツを提供するウェブサイトの管理者により通常実施される。そしてこれらの調整により、ウェブコンテンツはユーザの利用者端末に高速表示される。
しかしウェブコンテンツがユーザの利用者端末に高速表示されるのはこれらの調整が完了した時点である。一方でウェブコンテンツがユーザの利用者端末に表示される速度は、上記の調整が完了した後に、経時的に遅くなる傾向がある。
通常ウェブコンテンツは日々更新されていくが、更新されたウェブコンテンツの中には、先に調整が完了しているウェブコンテンツの部分以外に、新たなウェブコンテンツの部分が追加されて調整が完了していないウェブコンテンツの部分が増加するからである。
通常ウェブコンテンツは日々更新されていくが、更新されたウェブコンテンツの中には、先に調整が完了しているウェブコンテンツの部分以外に、新たなウェブコンテンツの部分が追加されて調整が完了していないウェブコンテンツの部分が増加するからである。
また上記に説明したオリジナルデータに含まれる要素を削除する、オリジナルデータに含まれる要素の処理を後回しにする、オリジナルデータの容量を削減し、圧縮する等の方法についても解決が必要な問題が含まれる。単にこれらの方法が実施されるだけでは、ウェブコンテンツがユーザの利用者端末毎に正常に表示されるとは限らない。利用者端末上でウェブコンテンツを表示するのに必要な要素を削除等した場合には、正しく利用者端末にウェブコンテンツが表示されないことも起こりうる。
またオリジナルデータの表示に要する時間よりも調整後のデータの表示に要する時間が短くなるとは限らない。
またオリジナルデータの表示に要する時間よりも調整後のデータの表示に要する時間が短くなるとは限らない。
一般的に、オリジナルデータ毎にウェブコンテンツの高速表示に必要とされる、改善すべき点が異なる。また利用者端末の種類毎にウェブコンテンツの高速表示に必要とされる、改善すべき点が異なる。
オリジナルデータに対して一律に同じ調整を行ったのではウェブコンテンツを利用者端末毎に表示する際に、不具合が生じる可能性がある。
このため、それぞれのオリジナルデータの内容を個別に把握した上で、それぞれのウェブコンテンツに適した対策を、利用者端末の種類に応じて実施する必要がある。
この結果、ウェブコンテンツを提供するウェブサイトの管理者は、ウェブコンテンツの高速表示のために多くの工程処理を常時要求されることが多い。
そしてこれらの調整は、一回の処理に数日以上の時間を要することもある。
オリジナルデータに対して一律に同じ調整を行ったのではウェブコンテンツを利用者端末毎に表示する際に、不具合が生じる可能性がある。
このため、それぞれのオリジナルデータの内容を個別に把握した上で、それぞれのウェブコンテンツに適した対策を、利用者端末の種類に応じて実施する必要がある。
この結果、ウェブコンテンツを提供するウェブサイトの管理者は、ウェブコンテンツの高速表示のために多くの工程処理を常時要求されることが多い。
そしてこれらの調整は、一回の処理に数日以上の時間を要することもある。
先に説明した従来の通信データ変換技術の場合、単位時間当たりのデータ転送容量を増大できればウェブコンテンツの表示の高速化が達成される。
しかし単位時間当たりのデータ転送容量を増大した場合でも上記の調整に多くの労力と時間がかかる問題は残ったままである。
同様にCDNを用いたデータ処理時間の遅延防止の方法を用いた場合でも、上記の調整に多くの労力と時間がかかる問題が残る。
しかし単位時間当たりのデータ転送容量を増大した場合でも上記の調整に多くの労力と時間がかかる問題は残ったままである。
同様にCDNを用いたデータ処理時間の遅延防止の方法を用いた場合でも、上記の調整に多くの労力と時間がかかる問題が残る。
また先に説明したタスクライナーの技術を用いた場合でも、ウェブコンテンツを表示するためのオリジナルデータに改変があった場合に、その改変内容を一律にウェブコンテンツに反映することはできる。しかしタスクライナーの技術ではオリジナルデータ毎に要求される改善点、利用者端末の種類毎に要求される改善点等、それぞれの個別の問題に応じて対応することが難しい。
本発明の目的は、サーバに対してユーザの利用者端末からリクエストが送信されてから、調整前のウェブコンテンツがユーザの利用者端末上で入力受付可能になるまでに、ユーザの利用者端末毎に、調整前のウェブコンテンツを表示するためのオリジナルデータの処理が完了し、前記時間よりも短い時間内に、調整後のウェブコンテンツをそれぞれの利用者端末に表示することにある。
ユーザが利用者端末により、ウェブコンテンツを閲覧する際には、(1)ネットワークを通じて通信可能な一または二以上のサーバに対して利用者端末からリクエストが送信されるステップと、(2)利用者端末にウェブコンテンツを表示するためのオリジナルデータがサーバから利用者端末に送信されるステップと、(3)前記ウェブコンテンツが利用者端末で入力受付可能になるステップが実施される。
先に説明した課題を解決するため、本発明者が鋭意検討した結果、前記(1)から(3)のステップを実施する際に、ウェブコンテンツを表示するためのオリジナルデータを利用者端末にそのまま送信するのではなく、サーバに設置されたリクエスト処理ユニットに利用者端末からのリクエストの送信があった場合、アプリケーション処理ユニットに保存されたオリジナルデータが、人工知能ユニットが立案した戦略案に基づいてデータ取得・処理ユニットで処理された後に、処理済みデータが利用者端末に送信されるステップを含むウェブコンテンツの自動高速表示制御方法が、本発明の目的に適うことを見出し、本発明を完成するに至った。
先に説明した課題を解決するため、本発明者が鋭意検討した結果、前記(1)から(3)のステップを実施する際に、ウェブコンテンツを表示するためのオリジナルデータを利用者端末にそのまま送信するのではなく、サーバに設置されたリクエスト処理ユニットに利用者端末からのリクエストの送信があった場合、アプリケーション処理ユニットに保存されたオリジナルデータが、人工知能ユニットが立案した戦略案に基づいてデータ取得・処理ユニットで処理された後に、処理済みデータが利用者端末に送信されるステップを含むウェブコンテンツの自動高速表示制御方法が、本発明の目的に適うことを見出し、本発明を完成するに至った。
すなわち、本発明は、
[1]ネットワークを通じて通信可能な一または二以上のサーバに対して利用者端末からリクエストが送信されてから、利用者端末にウェブコンテンツを表示するためのオリジナルデータがサーバから利用者端末に送信されて、ウェブコンテンツが利用者端末で入力受付可能になるまでに、
前記サーバに設置されたリクエスト処理ユニットに対して、利用者端末から送信されたリクエストが、アプリケーション処理ユニットと人工知能ユニットが受信するステップと、
アプリケーション処理ユニットが、ウェブコンテンツを表示するためのオリジナルデータをデータ取得・処理ユニットに対して送信するステップと、
人工知能ユニットが、ウェブコンテンツを利用者端末毎に表示する戦略案を立案するステップと、
データ取得・処理ユニットが、利用者端末にウェブコンテンツを表示するためのオリジナルデータを受信するステップと、
前記戦略案に基づいて、データ取得・処理ユニットによりオリジナルデータが加工されて、複数の加工済みデータが生成するステップと、
前記オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのリソースから、利用者端末毎にウェブコンテンツを表示するための処理済みデータが選択されるステップと、
前記利用者端末毎にウェブコンテンツを表示するための処理済みデータが、利用者端末毎に送信されて、利用者端末毎にウェブコンテンツが表示されるステップと、
が実施され、
前記サーバが、一または二以上の物理マシン、一または二以上の仮想マシン、ならびに、一または二以上のコンテナからなる群より選ばれる少なくとも一つの実行環境からなり、
前記戦略案を立案するステップが、
前記オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのリソースのうち、
利用者端末毎に、利用者端末にウェブコンテンツをより速く表示するための処理済みデータが共通して有する属性を学習するステップと、
利用者端末毎に、前記属性に基づいて、前記オリジナルデータをデータ取得・処理ユニットで処理するステップと、
を含むことを特徴とする、ウェブコンテンツの自動高速表示制御方法を提供するものである。
[1]ネットワークを通じて通信可能な一または二以上のサーバに対して利用者端末からリクエストが送信されてから、利用者端末にウェブコンテンツを表示するためのオリジナルデータがサーバから利用者端末に送信されて、ウェブコンテンツが利用者端末で入力受付可能になるまでに、
前記サーバに設置されたリクエスト処理ユニットに対して、利用者端末から送信されたリクエストが、アプリケーション処理ユニットと人工知能ユニットが受信するステップと、
アプリケーション処理ユニットが、ウェブコンテンツを表示するためのオリジナルデータをデータ取得・処理ユニットに対して送信するステップと、
人工知能ユニットが、ウェブコンテンツを利用者端末毎に表示する戦略案を立案するステップと、
データ取得・処理ユニットが、利用者端末にウェブコンテンツを表示するためのオリジナルデータを受信するステップと、
前記戦略案に基づいて、データ取得・処理ユニットによりオリジナルデータが加工されて、複数の加工済みデータが生成するステップと、
前記オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのリソースから、利用者端末毎にウェブコンテンツを表示するための処理済みデータが選択されるステップと、
前記利用者端末毎にウェブコンテンツを表示するための処理済みデータが、利用者端末毎に送信されて、利用者端末毎にウェブコンテンツが表示されるステップと、
が実施され、
前記サーバが、一または二以上の物理マシン、一または二以上の仮想マシン、ならびに、一または二以上のコンテナからなる群より選ばれる少なくとも一つの実行環境からなり、
前記戦略案を立案するステップが、
前記オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのリソースのうち、
利用者端末毎に、利用者端末にウェブコンテンツをより速く表示するための処理済みデータが共通して有する属性を学習するステップと、
利用者端末毎に、前記属性に基づいて、前記オリジナルデータをデータ取得・処理ユニットで処理するステップと、
を含むことを特徴とする、ウェブコンテンツの自動高速表示制御方法を提供するものである。
また、本発明の一つは、
[2]リソースが、オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのデータを含み、
処理済みデータが、オブジェクト置換済みプログラムを含み、
リソース参照部分を有するオリジナルデータが、リソース参照部分をプログラムのオブジェクトに置換されて、オブジェクト置換済みプログラムが、生成するステップと、
前記オブジェクトが、識別情報と共にリソース毎に対応付けられるステップと、
利用者端末毎に、利用者端末に搭載されたブラウザでオブジェクト置換済みプログラムが実行されると、
オブジェクト置換済みプログラムに含まれるオブジェクトが識別情報によりリソースを特定し、そのリソースが実行されるステップと、
を含む、上記[1]に記載のウェブコンテンツの自動高速表示制御方法を提供するものである。
[2]リソースが、オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのデータを含み、
処理済みデータが、オブジェクト置換済みプログラムを含み、
リソース参照部分を有するオリジナルデータが、リソース参照部分をプログラムのオブジェクトに置換されて、オブジェクト置換済みプログラムが、生成するステップと、
前記オブジェクトが、識別情報と共にリソース毎に対応付けられるステップと、
利用者端末毎に、利用者端末に搭載されたブラウザでオブジェクト置換済みプログラムが実行されると、
オブジェクト置換済みプログラムに含まれるオブジェクトが識別情報によりリソースを特定し、そのリソースが実行されるステップと、
を含む、上記[1]に記載のウェブコンテンツの自動高速表示制御方法を提供するものである。
また、本発明の一つは、
[3]利用者端末毎に、前記属性に基づいて、前記オリジナルデータをデータ取得・処理ユニットで処理するステップが、
前記処理済みデータに含まれるプログラムのうち、実行させるプログラムを選択するステップ、
前記処理済みデータに含まれるプログラムのうち、優先して実行させるプログラムを選択するステップ、
前記処理済みデータに含まれるプログラムのうち、遅延して実行させるプログラムを選択するステップ、
前記処理済みデータに含まれるプログラムのうち、実行させるプログラムの実行順序を選択するステップ、
前記処理済みデータに含まれるプログラムのうち、実行させるプログラムの実行タイミングを選択するステップ、
および
前記オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのリソースから、利用者端末毎にウェブコンテンツを表示するための処理済みデータを選択するステップ、
からなる群より選ばれる少なくとも一つのステップを含む、上記[1]または[2]に記載のウェブコンテンツの自動高速表示制御方法を提供するものである。
[3]利用者端末毎に、前記属性に基づいて、前記オリジナルデータをデータ取得・処理ユニットで処理するステップが、
前記処理済みデータに含まれるプログラムのうち、実行させるプログラムを選択するステップ、
前記処理済みデータに含まれるプログラムのうち、優先して実行させるプログラムを選択するステップ、
前記処理済みデータに含まれるプログラムのうち、遅延して実行させるプログラムを選択するステップ、
前記処理済みデータに含まれるプログラムのうち、実行させるプログラムの実行順序を選択するステップ、
前記処理済みデータに含まれるプログラムのうち、実行させるプログラムの実行タイミングを選択するステップ、
および
前記オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのリソースから、利用者端末毎にウェブコンテンツを表示するための処理済みデータを選択するステップ、
からなる群より選ばれる少なくとも一つのステップを含む、上記[1]または[2]に記載のウェブコンテンツの自動高速表示制御方法を提供するものである。
また、本発明の一つは、
[4]オリジナルデータが、プログラムデータおよびバイナリデータの少なくとも一つを含み、
プログラムデータが、マークアップ言語、プログラミング言語、スタイルシート、スクリプト言語からなる群より選ばれる少なくとも一つを有するコードを含み、
バイナリデータが、画像ファイル、音ファイルおよび動画ファイルの少なくとも一つを含み、
リソースが、オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つを含み、
加工済みデータが生成されるステップが、
(1)オリジナルデータに含まれる、マークアップ言語、プログラミング言語、スタイルシートおよびスクリプト言語からなる群より選ばれる少なくとも一つを有するコードから、利用者端末の表示環境ごとに不要部分が削除されるステップと、
(2)オリジナルデータに含まれる、マークアップ言語、プログラミング言語、スタイシートおよびスクリプト言語からなる群より選ばれる少なくとも一つを有するコードから、利用者端末の表示環境ごとに必要部分が圧縮されるステップと、
(3)オリジナルデータに含まれる、マークアップ言語、プログラミング言語、スタイルシートおよびスクリプト言語からなる群より選ばれる少なくとも一つを有するコードから、利用者端末の表示環境ごとに実行順序が変更されるステップと、
(4)オリジナルデータに含まれる、マークアップ言語、プログラミング言語、スタイルシートおよびスクリプト言語からなる群より選ばれる少なくとも一つを有するコードから、利用者端末の表示環境ごとに実行タイミングが変更されるステップと、
(5)オリジナルデータに含まれる、バイナリデータから、単位面積当たりの表示画素数、単位時間当たりの録画録音密度、容量および保存形式からなる群より選ばれる少なくとも一つが変換されるステップと、
の(1)~(5)からなる群より選ばれる少なくとも一つのステップを含み、
利用者端末毎にウェブコンテンツが表示されるステップが、
リクエストが利用者端末からネットワークを通じてリクエスト処理ユニットに送信されるステップと、
リクエスト処理ユニットに受信されたリクエストから、利用者端末毎の表示環境が特定されるステップと、
利用者端末のブラウザからリクエストがリクエスト処理ユニットに送信された後に、アプリケーション処理ユニットおよびデータ取得・処理ユニットの少なくとも一つからリソースが利用者端末毎に送信され、利用者端末毎のブラウザに表示されるステップと、
を含む、上記[1]~[3]のいずれかに記載のウェブコンテンツの自動高速表示制御方法を提供するものである。
[4]オリジナルデータが、プログラムデータおよびバイナリデータの少なくとも一つを含み、
プログラムデータが、マークアップ言語、プログラミング言語、スタイルシート、スクリプト言語からなる群より選ばれる少なくとも一つを有するコードを含み、
バイナリデータが、画像ファイル、音ファイルおよび動画ファイルの少なくとも一つを含み、
リソースが、オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つを含み、
加工済みデータが生成されるステップが、
(1)オリジナルデータに含まれる、マークアップ言語、プログラミング言語、スタイルシートおよびスクリプト言語からなる群より選ばれる少なくとも一つを有するコードから、利用者端末の表示環境ごとに不要部分が削除されるステップと、
(2)オリジナルデータに含まれる、マークアップ言語、プログラミング言語、スタイシートおよびスクリプト言語からなる群より選ばれる少なくとも一つを有するコードから、利用者端末の表示環境ごとに必要部分が圧縮されるステップと、
(3)オリジナルデータに含まれる、マークアップ言語、プログラミング言語、スタイルシートおよびスクリプト言語からなる群より選ばれる少なくとも一つを有するコードから、利用者端末の表示環境ごとに実行順序が変更されるステップと、
(4)オリジナルデータに含まれる、マークアップ言語、プログラミング言語、スタイルシートおよびスクリプト言語からなる群より選ばれる少なくとも一つを有するコードから、利用者端末の表示環境ごとに実行タイミングが変更されるステップと、
(5)オリジナルデータに含まれる、バイナリデータから、単位面積当たりの表示画素数、単位時間当たりの録画録音密度、容量および保存形式からなる群より選ばれる少なくとも一つが変換されるステップと、
の(1)~(5)からなる群より選ばれる少なくとも一つのステップを含み、
利用者端末毎にウェブコンテンツが表示されるステップが、
リクエストが利用者端末からネットワークを通じてリクエスト処理ユニットに送信されるステップと、
リクエスト処理ユニットに受信されたリクエストから、利用者端末毎の表示環境が特定されるステップと、
利用者端末のブラウザからリクエストがリクエスト処理ユニットに送信された後に、アプリケーション処理ユニットおよびデータ取得・処理ユニットの少なくとも一つからリソースが利用者端末毎に送信され、利用者端末毎のブラウザに表示されるステップと、
を含む、上記[1]~[3]のいずれかに記載のウェブコンテンツの自動高速表示制御方法を提供するものである。
また、本発明の一つは、
[5]オリジナルデータが加工されて、複数の加工済みデータが生成するステップが、
前記データ取得・処理ユニットが通信可能な記憶領域に保存された利用者端末に関する機種情報データに基づいて、利用者端末毎に複数の加工済みデータが生成されるステップを含み、
前記オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのリソースから、利用者端末毎にウェブコンテンツを表示するための処理済みデータが選択されるステップが、
利用者端末毎に、機種情報データに基づいて利用者端末の表示画面の表示環境を特定するステップと、
利用者端末毎に、ウェブコンテンツのうち、利用者端末の表示画面の表示環境に合わせて最初に表示されるウェブコンテンツの部分を特定するステップと、
前記利用者端末毎にウェブコンテンツを表示するための処理済みデータが利用者端末毎に送信されて、利用者端末毎にウェブコンテンツが表示されるステップが、ウェブコンテンツのうち、利用者端末の表示画面の表示環境に合わせて最初に表示されるウェブコンテンツに対応する処理済みデータを利用者端末に優先して送信するステップと、
を含む、上記[1]~[4]のいずれかに記載のウェブコンテンツの自動高速表示制御方法を提供するものである。
[5]オリジナルデータが加工されて、複数の加工済みデータが生成するステップが、
前記データ取得・処理ユニットが通信可能な記憶領域に保存された利用者端末に関する機種情報データに基づいて、利用者端末毎に複数の加工済みデータが生成されるステップを含み、
前記オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのリソースから、利用者端末毎にウェブコンテンツを表示するための処理済みデータが選択されるステップが、
利用者端末毎に、機種情報データに基づいて利用者端末の表示画面の表示環境を特定するステップと、
利用者端末毎に、ウェブコンテンツのうち、利用者端末の表示画面の表示環境に合わせて最初に表示されるウェブコンテンツの部分を特定するステップと、
前記利用者端末毎にウェブコンテンツを表示するための処理済みデータが利用者端末毎に送信されて、利用者端末毎にウェブコンテンツが表示されるステップが、ウェブコンテンツのうち、利用者端末の表示画面の表示環境に合わせて最初に表示されるウェブコンテンツに対応する処理済みデータを利用者端末に優先して送信するステップと、
を含む、上記[1]~[4]のいずれかに記載のウェブコンテンツの自動高速表示制御方法を提供するものである。
また、本発明の一つは、
[6]ウェブコンテンツが利用者端末毎に表示されるステップが、
ウェブコンテンツのうち、利用者端末の画面に最初に表示される部分に対応するデータが利用者端末に送信されるステップと、
利用者端末に利用者端末の画面に最初に表示される部分に対応するウェブコンテンツの部分が表示されてから一定時間が経過したことを示すイベント情報、および、ユーザが利用者端末を操作して利用者端末に対して追加の情報を表示させる行動を起こしたことを示すイベント情報の少なくとも一つのイベント情報が、サーバおよびブラウザの少なくとも一つにより検出されるステップと、
前記イベント情報をアプリケーション処理ユニット、人工知能ユニット、データ取得・処理ユニットおよび利用者端末に搭載されたブラウザの少なくとも一つが検出した後に、ウェブコンテンツの残りの一部または全部の部分を表示するためのリソースが、アプリケーション処理ユニットおよびデータ取得・処理ユニットの少なくとも一つから、ネットワークを通じて利用者端末に送信されるステップと、
を含む、上記[1]~[5]のいずれかに記載のウェブコンテンツの自動高速表示制御方法を提供するものである。
[6]ウェブコンテンツが利用者端末毎に表示されるステップが、
ウェブコンテンツのうち、利用者端末の画面に最初に表示される部分に対応するデータが利用者端末に送信されるステップと、
利用者端末に利用者端末の画面に最初に表示される部分に対応するウェブコンテンツの部分が表示されてから一定時間が経過したことを示すイベント情報、および、ユーザが利用者端末を操作して利用者端末に対して追加の情報を表示させる行動を起こしたことを示すイベント情報の少なくとも一つのイベント情報が、サーバおよびブラウザの少なくとも一つにより検出されるステップと、
前記イベント情報をアプリケーション処理ユニット、人工知能ユニット、データ取得・処理ユニットおよび利用者端末に搭載されたブラウザの少なくとも一つが検出した後に、ウェブコンテンツの残りの一部または全部の部分を表示するためのリソースが、アプリケーション処理ユニットおよびデータ取得・処理ユニットの少なくとも一つから、ネットワークを通じて利用者端末に送信されるステップと、
を含む、上記[1]~[5]のいずれかに記載のウェブコンテンツの自動高速表示制御方法を提供するものである。
また、本発明の一つは、
[7]ウェブコンテンツが利用者端末毎に表示されるステップが、
ウェブコンテンツのうち、利用者端末の画面に最初に表示される部分を表示するためのリソースが利用者端末に送信されるステップと、
ウェブコンテンツのうち、利用者端末の画面に最初に表示される部分が入力受付可能になるまでの時間が伸縮するステップと、
を含む、上記[6]に記載のウェブコンテンツの自動高速表示制御方法を提供するものである。
[7]ウェブコンテンツが利用者端末毎に表示されるステップが、
ウェブコンテンツのうち、利用者端末の画面に最初に表示される部分を表示するためのリソースが利用者端末に送信されるステップと、
ウェブコンテンツのうち、利用者端末の画面に最初に表示される部分が入力受付可能になるまでの時間が伸縮するステップと、
を含む、上記[6]に記載のウェブコンテンツの自動高速表示制御方法を提供するものである。
また、本発明の一つは、
[8]ウェブコンテンツを閲覧するユーザのユーザ体験に基づいて、ユーザとウェブコンテンツとのエンゲージメントのスコアが算出されるステップと、
前記エンゲージメントのスコアに基づいて、利用者端末毎に、ウェブコンテンツのうち、利用者端末の画面に最初に表示される部分が入力受付可能になるまでの時間が伸縮するステップと、
を含む、上記[7]に記載のウェブコンテンツの自動高速表示制御方法を提供するものである。
[8]ウェブコンテンツを閲覧するユーザのユーザ体験に基づいて、ユーザとウェブコンテンツとのエンゲージメントのスコアが算出されるステップと、
前記エンゲージメントのスコアに基づいて、利用者端末毎に、ウェブコンテンツのうち、利用者端末の画面に最初に表示される部分が入力受付可能になるまでの時間が伸縮するステップと、
を含む、上記[7]に記載のウェブコンテンツの自動高速表示制御方法を提供するものである。
また、本発明は、
[9]上記[1]~[8]のいずれかに記載のウェブコンテンツの自動高速表示制御方法を実施するためのプログラムであって、
ネットワークを通じて通信可能な一または二以上のサーバに対して利用者端末からリクエストが送信されてから、利用者端末にウェブコンテンツを表示するためのオリジナルデータがサーバから利用者端末に送信されて、ウェブコンテンツが利用者端末で入力受付可能になるまでに、
前記サーバに設置されたリクエスト処理ユニットに対して、利用者端末から送信されたリクエストが、アプリケーション処理ユニットと人工知能ユニットが受信する手段と、
アプリケーション処理ユニットが、ウェブコンテンツを表示するためのオリジナルデータをデータ取得・処理ユニットに対して送信する手段と、
人工知能ユニットが、ウェブコンテンツを利用者端末毎に表示する戦略案を立案する手段と、
データ取得・処理ユニットが、利用者端末にウェブコンテンツを表示するためのオリジナルデータを受信する手段と、
前記戦略案に基づいて、データ取得・処理ユニットによりオリジナルデータが加工されて、複数の加工済みデータが生成する手段と、
前記オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのリソースから、利用者端末毎にウェブコンテンツを表示するための処理済みデータが選択される手段と、
前記利用者端末毎にウェブコンテンツを表示するための処理済みデータが、利用者端末毎に送信されて、利用者端末毎にウェブコンテンツが表示される手段と、
を備え、
前記サーバが、一または二以上の物理マシン、一または二以上の仮想マシン、ならびに、一または二以上のコンテナからなる群より選ばれる少なくとも一つの実行環境からなり、
前記戦略案を立案する手段が、
前記オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのリソースのうち、
利用者端末毎に、利用者端末にウェブコンテンツをより速く表示するための処理済みデータが共通して有する属性を学習する手段と、
利用者端末毎に、前記属性に基づいて、前記オリジナルデータをデータ取得・処理ユニットで処理する手段と、
を含む、ウェブコンテンツの自動高速表示制御プログラムを提供するものである。
[9]上記[1]~[8]のいずれかに記載のウェブコンテンツの自動高速表示制御方法を実施するためのプログラムであって、
ネットワークを通じて通信可能な一または二以上のサーバに対して利用者端末からリクエストが送信されてから、利用者端末にウェブコンテンツを表示するためのオリジナルデータがサーバから利用者端末に送信されて、ウェブコンテンツが利用者端末で入力受付可能になるまでに、
前記サーバに設置されたリクエスト処理ユニットに対して、利用者端末から送信されたリクエストが、アプリケーション処理ユニットと人工知能ユニットが受信する手段と、
アプリケーション処理ユニットが、ウェブコンテンツを表示するためのオリジナルデータをデータ取得・処理ユニットに対して送信する手段と、
人工知能ユニットが、ウェブコンテンツを利用者端末毎に表示する戦略案を立案する手段と、
データ取得・処理ユニットが、利用者端末にウェブコンテンツを表示するためのオリジナルデータを受信する手段と、
前記戦略案に基づいて、データ取得・処理ユニットによりオリジナルデータが加工されて、複数の加工済みデータが生成する手段と、
前記オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのリソースから、利用者端末毎にウェブコンテンツを表示するための処理済みデータが選択される手段と、
前記利用者端末毎にウェブコンテンツを表示するための処理済みデータが、利用者端末毎に送信されて、利用者端末毎にウェブコンテンツが表示される手段と、
を備え、
前記サーバが、一または二以上の物理マシン、一または二以上の仮想マシン、ならびに、一または二以上のコンテナからなる群より選ばれる少なくとも一つの実行環境からなり、
前記戦略案を立案する手段が、
前記オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのリソースのうち、
利用者端末毎に、利用者端末にウェブコンテンツをより速く表示するための処理済みデータが共通して有する属性を学習する手段と、
利用者端末毎に、前記属性に基づいて、前記オリジナルデータをデータ取得・処理ユニットで処理する手段と、
を含む、ウェブコンテンツの自動高速表示制御プログラムを提供するものである。
また、本発明の一つは、
[10]上記[9]に記載されたウェブコンテンツの自動高速表示制御プログラムを記録した、記憶装置を提供するものである。
[10]上記[9]に記載されたウェブコンテンツの自動高速表示制御プログラムを記録した、記憶装置を提供するものである。
また、本発明は、
[11]上記[1]~[8]のいずれかに記載のウェブコンテンツの自動高速表示制御方法を実施するためのシステムであって、
ネットワークを通じて通信可能な一または二以上のサーバに対して利用者端末からリクエストが送信されてから、利用者端末にウェブコンテンツを表示するためのオリジナルデータがサーバから利用者端末に送信されて、ウェブコンテンツが利用者端末で入力受付可能になるまでに、
前記サーバに設置されたリクエスト処理ユニットに対して、利用者端末から送信されたリクエストが、アプリケーション処理ユニットと人工知能ユニットが受信する手段と、
アプリケーション処理ユニットが、ウェブコンテンツを表示するためのオリジナルデータをデータ取得・処理ユニットに対して送信する手段と、
人工知能ユニットが、ウェブコンテンツを利用者端末毎に表示する戦略案を立案する手段と、
データ取得・処理ユニットが、利用者端末にウェブコンテンツを表示するためのオリジナルデータを受信する手段と、
前記戦略案に基づいて、データ取得・処理ユニットによりオリジナルデータが加工されて、複数の加工済みデータが生成する手段と、
前記オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのリソースから、利用者端末毎にウェブコンテンツを表示するための処理済みデータが選択される手段と、
前記利用者端末毎にウェブコンテンツを表示するための処理済みデータが、利用者端末毎に送信されて、利用者端末毎にウェブコンテンツが表示される手段と、
を備え、
前記サーバが、一または二以上の物理マシン、一または二以上の仮想マシン、ならびに、一または二以上のコンテナからなる群より選ばれる少なくとも一つの実行環境からなり、
前記戦略案を立案する手段が、
前記オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのリソースのうち、
利用者端末毎に、利用者端末にウェブコンテンツをより速く表示するための処理済みデータが共通して有する属性を学習する手段と、
利用者端末毎に、前記属性に基づいて、前記オリジナルデータをデータ取得・処理ユニットで処理する手段と、
を含む、ウェブコンテンツの自動高速表示制御システムを提供するものである。
[11]上記[1]~[8]のいずれかに記載のウェブコンテンツの自動高速表示制御方法を実施するためのシステムであって、
ネットワークを通じて通信可能な一または二以上のサーバに対して利用者端末からリクエストが送信されてから、利用者端末にウェブコンテンツを表示するためのオリジナルデータがサーバから利用者端末に送信されて、ウェブコンテンツが利用者端末で入力受付可能になるまでに、
前記サーバに設置されたリクエスト処理ユニットに対して、利用者端末から送信されたリクエストが、アプリケーション処理ユニットと人工知能ユニットが受信する手段と、
アプリケーション処理ユニットが、ウェブコンテンツを表示するためのオリジナルデータをデータ取得・処理ユニットに対して送信する手段と、
人工知能ユニットが、ウェブコンテンツを利用者端末毎に表示する戦略案を立案する手段と、
データ取得・処理ユニットが、利用者端末にウェブコンテンツを表示するためのオリジナルデータを受信する手段と、
前記戦略案に基づいて、データ取得・処理ユニットによりオリジナルデータが加工されて、複数の加工済みデータが生成する手段と、
前記オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのリソースから、利用者端末毎にウェブコンテンツを表示するための処理済みデータが選択される手段と、
前記利用者端末毎にウェブコンテンツを表示するための処理済みデータが、利用者端末毎に送信されて、利用者端末毎にウェブコンテンツが表示される手段と、
を備え、
前記サーバが、一または二以上の物理マシン、一または二以上の仮想マシン、ならびに、一または二以上のコンテナからなる群より選ばれる少なくとも一つの実行環境からなり、
前記戦略案を立案する手段が、
前記オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのリソースのうち、
利用者端末毎に、利用者端末にウェブコンテンツをより速く表示するための処理済みデータが共通して有する属性を学習する手段と、
利用者端末毎に、前記属性に基づいて、前記オリジナルデータをデータ取得・処理ユニットで処理する手段と、
を含む、ウェブコンテンツの自動高速表示制御システムを提供するものである。
本発明のウェブコンテンツの自動高速表示制御方法によれば、ネットワークを通じて通信可能な一または二以上のサーバに対して利用者端末からリクエストが送信されてから、利用者端末にウェブコンテンツを表示するためのオリジナルデータがサーバから利用者端末に送信されて、ウェブコンテンツが利用者端末で入力受付可能になるまでに、利用者端末毎にウェブコンテンツを表示するためのオリジナルデータの処理が完了し、利用者端末毎に対して処理済みデータが送信されて利用者端末にウェブコンテンツが表示される。
このため、本発明に係る方法によれば、これまでサーバに対してリクエストを送信していない利用者端末から最初のリクエストがあった場合でも、初回から、オリジナルデータに基づくウェブコンテンツが利用者端末で入力受付可能になる時間よりも短い時間で、処理済みデータに基づくウェブコンテンツが利用者端末毎に受付可能になる状態を実現できる。
このため、本発明に係る方法によれば、これまでサーバに対してリクエストを送信していない利用者端末から最初のリクエストがあった場合でも、初回から、オリジナルデータに基づくウェブコンテンツが利用者端末で入力受付可能になる時間よりも短い時間で、処理済みデータに基づくウェブコンテンツが利用者端末毎に受付可能になる状態を実現できる。
またウェブコンテンツを表示するためのオリジナルデータは、データ取得・処理ユニット等によりクロール、監視することができる。このためオリジナルデータに変化があった場合にはその変化に対応して処理済みデータを生成し、オリジナルデータの変化後に、利用者端末からリクエストがあった場合でも、初回から、処理済みデータに対応したウェブコンテンツを提供することができる。
また本発明のウェブコンテンツの自動高速表示制御方法によれば、サーバから送信された、オリジナルデータに基づくウェブコンテンツがそのまま利用者端末に送信される前に、リクエスト処理ユニットを介して、オリジナルデータがアプリケーション処理ユニットからデータ取得・処理ユニットに取り出され、人工知能ユニットにより立案された戦略に基づいてオリジナルデータが加工される。そして処理済みデータが利用者端末毎に送信されて、処理済みデータに基づくウェブコンテンツが利用者端末毎に、利用者端末に表示される。
このため、人間がオリジナルデータの状態や処理済みデータの状態を目視により確認、編集する必要がなく、ウェブコンテンツの自動高速表示が実現される。
このため、人間がオリジナルデータの状態や処理済みデータの状態を目視により確認、編集する必要がなく、ウェブコンテンツの自動高速表示が実現される。
加えて本発明のウェブコンテンツの自動高速表示制御方法によれば、リクエスト処理ユニット等を通じてオリジナルデータおよび処理済みデータ等を利用者端末と通信できる。
このためサーバにリクエスト処理ユニットを設置するだけで、また必要に応じてマイグレーションおよびDNSの変更の少なくとも一つを行うだけで、本発明のウェブコンテンツの自動高速表示制御方法を実施できるから、簡単な操作でウェブコンテンツの自動高速表示を実現することができる。
このためサーバにリクエスト処理ユニットを設置するだけで、また必要に応じてマイグレーションおよびDNSの変更の少なくとも一つを行うだけで、本発明のウェブコンテンツの自動高速表示制御方法を実施できるから、簡単な操作でウェブコンテンツの自動高速表示を実現することができる。
本発明に係るウェブコンテンツの自動高速表示制御方法を実施するための自動高速表示制御システムは、アプリケーション処理ユニットA、人工知能ユニットB、リクエスト処理ユニットCおよびデータ取得・処理ユニットDを少なくとも含む。
本発明の開示においては、はじめにA~Dの四つのユニットを組み合わせた複数の実施形態が開示される。本発明に係るウェブコンテンツの自動高速表示制御方法を実施するための自動高速表示制御システムの構成については、A~Dの四つのユニットの組み合わせにより、オールインワン型(実施形態1)、リバースプロキシ型(実施形態2)、ナノエージョント型(実施形態3)およびSasS型(実施形態4)の大きく四つに分類される。
以下に、それぞれの実施形態について図面を参照しつつ説明する。なお、本発明は以下の実施形態に限定されるものではない。
以下に、それぞれの実施形態について図面を参照しつつ説明する。なお、本発明は以下の実施形態に限定されるものではない。
[実施形態1:オールインワン型]
図1は、本発明の実施形態1に係るウェブコンテンツの自動高速表示制御方法を実施するための自動高速表示制御システムを説明するための模式図である。本発明の実施形態1では、一つの例として、A~Dの四つのユニットが一つの実行環境内に構築されている。
図1は、本発明の実施形態1に係るウェブコンテンツの自動高速表示制御方法を実施するための自動高速表示制御システムを説明するための模式図である。本発明の実施形態1では、一つの例として、A~Dの四つのユニットが一つの実行環境内に構築されている。
本発明の実施形態1の場合は、実行環境の一つの例として、アプリケーション実行サーバ103が採用されている。
ユーザは利用者端末101を操作して、ネットワーク102を通じて、アプリケーション実行サーバ103と通信できる。
ユーザは利用者端末101を操作して、ネットワーク102を通じて、アプリケーション実行サーバ103と通信できる。
ユーザが操作する利用者端末101から、リクエストが、ネットワーク102を通じてリクエスト処理ユニットCに送信される。
このリクエストは、利用者端末101に搭載されたブラウザ等にウェブコンテンツを表示するためのデータの送信をアプリケーション実行サーバ103に求めるものである。このリクエストは、最初にリクエスト処理ユニットCに送信される。
このリクエストは、利用者端末101に搭載されたブラウザ等にウェブコンテンツを表示するためのデータの送信をアプリケーション実行サーバ103に求めるものである。このリクエストは、最初にリクエスト処理ユニットCに送信される。
本発明に使用される利用者端末101は一つに限定されず、二以上を使用することができる。また利用者端末101も、アプリケーション実行サーバ103も、相互にネットワーク102を通じて通信することができればよい。利用者端末101とアプリケーション実行サーバ103との相互の位置関係に、特に限定はない。
本発明の開示においては、リクエスト処理ユニットCは、利用者端末101から送信されるリクエストを最初に受信する機能を有する。下記の実施形態2~6のそれぞれについても同様である。
利用者端末101から送信されたリクエストに基づいて、アプリケーション処理ユニットAに保存されているオリジナルデータが加工される。このオリジナルデータは、ウェブコンテンツを利用者端末101毎に表示するためのデータである。
オリジナルデータの加工は、人工知能ユニットBの立案した戦略案に基づいて、データ取得・処理ユニットDにより実施される。
最初にこれらのAからDの四つのユニットについて説明する。
利用者端末101から送信されたリクエストに基づいて、アプリケーション処理ユニットAに保存されているオリジナルデータが加工される。このオリジナルデータは、ウェブコンテンツを利用者端末101毎に表示するためのデータである。
オリジナルデータの加工は、人工知能ユニットBの立案した戦略案に基づいて、データ取得・処理ユニットDにより実施される。
最初にこれらのAからDの四つのユニットについて説明する。
[A.アプリケーション処理ユニットについて]
図2は、本発明に使用するアプリケーション処理ユニットAを説明するための模式図である。
本発明に使用するアプリケーション処理ユニットAは、ウェブコンテンツを表示するためのオリジナルデータ200等を保存し、利用者端末101、各ユニット等に利用者端末101毎からのリクエスト、オリジナルデータ200に含まれるリソース等を送信する機能を主として担う。
図2は、本発明に使用するアプリケーション処理ユニットAを説明するための模式図である。
本発明に使用するアプリケーション処理ユニットAは、ウェブコンテンツを表示するためのオリジナルデータ200等を保存し、利用者端末101、各ユニット等に利用者端末101毎からのリクエスト、オリジナルデータ200に含まれるリソース等を送信する機能を主として担う。
なお本発明の開示における各ファイルの記載は例示であり、データがファイル形式で管理できることを意味する。データをファイル形式で管理することにより、CLI等を通じて、人間が目視等によりデータを管理することができる。
図2では、データがファイル形式で管理できることを模式的に示している。
図2では、データがファイル形式で管理できることを模式的に示している。
オリジナルデータ200には、例えば、ウェブコンテンツを利用者端末101に表示するために必要なHTMLファイル113、このHTMLファイル113に関連付けられたリソース等が含まれる。
このHTMLファイル113は、例えば、データベース1106に関連付けられたPHP105等のプログラムにより、動的または静的に生成される。
このHTMLファイル113は、例えば、データベース1106に関連付けられたPHP105等のプログラムにより、動的または静的に生成される。
またアプリケーション処理ユニットAには、HTMLファイル113が参照するCSSファイル107、スクリプト言語ファイル108、画像ファイル109等のリソースが保存されている。
これらのリソースは適宜HTMLファイル113から参照され、実行することができる。また、HTMLファイル113内部に直接記載されたCSSのスタイルシート、JavaScript(登録商標)等のプログラム等を実行することもできる。
これらのリソースは適宜HTMLファイル113から参照され、実行することができる。また、HTMLファイル113内部に直接記載されたCSSのスタイルシート、JavaScript(登録商標)等のプログラム等を実行することもできる。
例えば、利用者端末101に送信されたHTMLファイル113等を利用者端末101が受信する。そして利用者端末101に受信されたHTMLファイル113等が利用者端末101に搭載されたブラウザ等で実行される。HTMLファイル113等が実行されると、その実行に伴い、HTMLファイル113等に関連付けられたスタイルシートであるCSSファイル107、プログラムであるスクリプト言語ファイル108等のリソース等が実行される。この実行によりオリジナルデータ200等に基づくウェブコンテンツ等を利用者端末101に表示することができる。
[B.人工知能ユニットについて]
図3は、本発明に使用する人工知能ユニットを説明するための模式図である。
本発明に使用する人工知能ユニットBは、それぞれのAからDの各ユニットに対して動作の指針を与える、司令塔としての機能を主として担う。
具体的には、例えば、アプリケーション処理ユニットAに保存されているオリジナルデータ200を、利用者端末101のそれぞれの表示環境に応じて加工する、複数の加工済みデータ201の中から利用者端末101毎に最適なものを選択する、加工済みデータ201に含まれるプログラムの実行順序、実行タイミング等を決定する等の一または二以上の戦略案を生成する。人工知能ユニットBの人工知能制御部1410により、戦略案としての戦略ファイル1412が人工知能記憶領域1430に生成される。
図3は、本発明に使用する人工知能ユニットを説明するための模式図である。
本発明に使用する人工知能ユニットBは、それぞれのAからDの各ユニットに対して動作の指針を与える、司令塔としての機能を主として担う。
具体的には、例えば、アプリケーション処理ユニットAに保存されているオリジナルデータ200を、利用者端末101のそれぞれの表示環境に応じて加工する、複数の加工済みデータ201の中から利用者端末101毎に最適なものを選択する、加工済みデータ201に含まれるプログラムの実行順序、実行タイミング等を決定する等の一または二以上の戦略案を生成する。人工知能ユニットBの人工知能制御部1410により、戦略案としての戦略ファイル1412が人工知能記憶領域1430に生成される。
オリジナルデータ200を用いてウェブコンテンツが利用者端末101に表示されて、利用者端末101のブラウザ等で入力受付可能となるまでに、ウェブコンテンツを利用者端末101毎に表示するための戦略案が生成される。そしてこの戦略案に基づいて、オリジナルデータ200の加工、選択、配信等が実施される。その結果、オリジナルデータ200を用いてウェブコンテンツが利用者端末101に表示されて、利用者端末101で入力受付可能となるまでに、処理済みデータを用いてウェブコンテンツを利用者端末101毎に表示することが実現される。
この戦略案は、例えば、戦略ファイル1412として人工知能ユニットBが利用できる保存領域に保存することができる。戦略ファイル1412は、人工知能ユニットB内部に保存される場合に限定されず、例えば、人工知能ユニットBの外部に保存して、人工知能ユニットBが利用できるようにすることもできる。
この戦略案は、例えば、戦略ファイル1412として人工知能ユニットBが利用できる保存領域に保存することができる。戦略ファイル1412は、人工知能ユニットB内部に保存される場合に限定されず、例えば、人工知能ユニットBの外部に保存して、人工知能ユニットBが利用できるようにすることもできる。
本発明の実施形態1の場合は、一つの例として戦略案が戦略ファイル1412として説明されているが、戦略案はファイル形式で保存される場合に限定されない。戦略案は、人工知能ユニットBが実行できる形式で保存されればよく、実行サーバ103が利用できるデータベース等に保存して活用することもできる。
[C.リクエスト処理ユニットについて]
図4は、本発明に使用するリクエスト処理ユニットを説明するための模式図である。
本発明に使用するリクエスト処理ユニットCは、先に示した図1に例示されるように、ユーザが操作する利用者端末101のブラウザ等から送信されたリクエストを最初に受信する、いわば通信ゲートとしての機能を主として担う。
図4では、一つの例として、アプリケーション実行サーバ103にアプリケーション処理ユニットA、人工知能ユニットB、リクエスト処理ユニットCおよびデータ取得・処理ユニットDが配置されている場合が図示されている。
図4は、本発明に使用するリクエスト処理ユニットを説明するための模式図である。
本発明に使用するリクエスト処理ユニットCは、先に示した図1に例示されるように、ユーザが操作する利用者端末101のブラウザ等から送信されたリクエストを最初に受信する、いわば通信ゲートとしての機能を主として担う。
図4では、一つの例として、アプリケーション実行サーバ103にアプリケーション処理ユニットA、人工知能ユニットB、リクエスト処理ユニットCおよびデータ取得・処理ユニットDが配置されている場合が図示されている。
本発明の実施形態1では、本発明に使用されるアプリケーション処理ユニットA、人工知能ユニットB、リクエスト処理ユニットCおよびデータ取得・処理ユニットDのそれぞれのユニットが一つの実行環境下で実施される。
本発明の開示においては、実行環境とは、一または二以上の物理マシン、一または二以上の仮想マシン、ならびに一または二以上のコンテナからなる群より選ばれる少なくとも一つにより構築される環境をいう。
本発明の実施形態1の場合は、例えば、一つの実行環境であるアプリケーション実行サーバ103が使用されている。
この実行環境は、例えば、複数の物理マシン、複数の仮想マシン、複数のコンテナ等から構成される場合であっても、一つの物理マシンが実際に存在するかのように運用することができる。
本発明の実施形態1の場合は、例えば、一つの実行環境であるアプリケーション実行サーバ103が使用されている。
この実行環境は、例えば、複数の物理マシン、複数の仮想マシン、複数のコンテナ等から構成される場合であっても、一つの物理マシンが実際に存在するかのように運用することができる。
本発明の開示においては、ユーザが操作する利用者端末101のブラウザ等からリクエストが送信される。このリクエストは、ネットワーク102、リクエスト処理ユニットCを通じて、アプリケーション処理ユニットA、人工知能ユニットB、データ取得・処理ユニットD等に受信される。そしてそのリクエストに対応するレスポンスが、アプリケーション処理ユニットA、人工知能ユニットB、データ取得・処理ユニットD等から送信される。そしてそのレスポンスが、ネットワーク102を通じて利用者端末101で受信される。
[D.データ取得・処理ユニットについて]
図5は、本発明に使用するデータ取得・処理ユニットを説明するための模式図である。
本発明に使用するデータ取得・処理ユニットDは、アプリケーション処理ユニットAから、リクエスト処理ユニットCを通じてオリジナルデータ200等を取得し、それぞれの利用者端末101に適したリソースの最適化等を実施する機能を主として担う。
データ取得・処理ユニットDは、例えば、最適化ユニットd100、クローラーユニットd200およびコントロールユニットd300等を含む。
図5は、本発明に使用するデータ取得・処理ユニットを説明するための模式図である。
本発明に使用するデータ取得・処理ユニットDは、アプリケーション処理ユニットAから、リクエスト処理ユニットCを通じてオリジナルデータ200等を取得し、それぞれの利用者端末101に適したリソースの最適化等を実施する機能を主として担う。
データ取得・処理ユニットDは、例えば、最適化ユニットd100、クローラーユニットd200およびコントロールユニットd300等を含む。
最適化ユニットd100では、人工知能ユニットBが立案した戦略案が記載された戦略ファイル1412に基づいて、例えば、アプリケーション処理ユニットAに保存されているHTMLファイル113の最適化、CSSファイル107、スクリプト言語ファイル108、画像ファイル109等のリソースの最適化が実施される。
クローラーユニットd200では、例えば、アプリケーション処理ユニットAに保存されているHTMLファイル113、CSSファイル107、スクリプト言語ファイル108、画像ファイル109等のリソースをクロールして、それらのデータの取得、保存、監視等を行う。
次に先に示した図4に基づいて、本発明の実施形態1に係るウェブコンテンツの自動高速表示制御方法を実施するための自動高速表示制御システムについて説明する。
図4において、利用者端末101と、有線接続または無線接続によりアプリケーション実行サーバ103とが、ネットワーク102を通じて相互に通信できる。
利用者端末101の具体例としては、例えば、スマートフォン、フィーチャーフォン等の携帯情報端末、PDA(PERSONAL DIGITAL ASSISTANT)、タブレット等の情報表示端末、スマートウォッチ、スマートメガネ等のウェアラブル通信端末、PC(PERSONAL COMPUTER)等のコンピュータ等が挙げられる。
図4では、一つの利用者端末101が例示されているが、実際には一または二以上の利用者端末101を使用することができる。
利用者端末101の具体例としては、例えば、スマートフォン、フィーチャーフォン等の携帯情報端末、PDA(PERSONAL DIGITAL ASSISTANT)、タブレット等の情報表示端末、スマートウォッチ、スマートメガネ等のウェアラブル通信端末、PC(PERSONAL COMPUTER)等のコンピュータ等が挙げられる。
図4では、一つの利用者端末101が例示されているが、実際には一または二以上の利用者端末101を使用することができる。
本発明の実施形態1に使用されるネットワーク102としては、例えば、VPN(VIRTUAL PRIVATE NETWORK)、LAN(LOCAL AREA NETWORK)、WAN(WIDE AREA NETWORK)、PSTN(PUBLIC SWITCHED TELEPHONE NETWORK)、インターネット、イントラネット、イーサネット(登録商標)、携帯電話網、公衆交換電話網等の一または二以上を挙げることができる。
ネットワーク102は、光ファイバー・通信用電線等を利用した有線、赤外線・電波等の電磁波等を利用した無線等を通じて、利用者端末101、各種実行環境等に対して相互に通信できる環境を提供できる。
ネットワーク102は、光ファイバー・通信用電線等を利用した有線、赤外線・電波等の電磁波等を利用した無線等を通じて、利用者端末101、各種実行環境等に対して相互に通信できる環境を提供できる。
アプリケーション実行サーバ103は、利用者端末101に対して、各国言語による文字、記号、数字等のプログラムデータ、画像、動画、音声等のバイナリデータ等を含むウェブサイト等の情報を提供する機能を有する。
アプリケーション実行サーバ103は、ネットワーク102を通じて、オリジナルデータによるウェブコンテンツを利用者端末101に表示させる機能を有するものであれば、その構成に限定はない。
またアプリケーション実行サーバ103には、アプリケーション処理ユニットA、人工知能ユニットB、リクエスト処理ユニットCおよびデータ取得・処理ユニットDが少なくとも搭載されている。
[実施形態1に使用される各装置のハードウェア構成]
図6は、本発明の実施形態1に係るウェブコンテンツの自動高速表示制御方法に使用される利用者端末101のハードウェア構成の一例を説明するための図である。
[利用者端末101のハードウェア構成]
最初に利用者端末101のハードウェア構成について説明する。
利用者端末101は、例えば、中央演算処理装置1000(CPU、CENTRAL PROCESSING UNIT)、記憶装置1001、通信用インターフェイス1002、入力装置1003および表示装置1004等のハードウェア構成を備える。これらのハードウェア構成はそれぞれ接続されていて相互に通信が可能である。
図6は、本発明の実施形態1に係るウェブコンテンツの自動高速表示制御方法に使用される利用者端末101のハードウェア構成の一例を説明するための図である。
[利用者端末101のハードウェア構成]
最初に利用者端末101のハードウェア構成について説明する。
利用者端末101は、例えば、中央演算処理装置1000(CPU、CENTRAL PROCESSING UNIT)、記憶装置1001、通信用インターフェイス1002、入力装置1003および表示装置1004等のハードウェア構成を備える。これらのハードウェア構成はそれぞれ接続されていて相互に通信が可能である。
中央演算処理装置1000はプログラムに記載された内容を実行できる回路を搭載していて、各種処理を実行できる。
中央演算処理装置1000の構成は、一つのマイクロプロセッサを搭載するものに限定されず、二以上のプロセッサを搭載するマルチプロセッサを含むものであってもよい。
中央演算処理装置1000の構成は、一つのマイクロプロセッサを搭載するものに限定されず、二以上のプロセッサを搭載するマルチプロセッサを含むものであってもよい。
記憶装置1001は、利用者端末101の動作に必要なデータ、プログラム等を記憶することができる。記憶装置1001は、例えば、主記憶部1001aと補助記憶部1001bとを含む。
主記憶部としては、例えば、RAM等の揮発性メモリが使用される。また補助記憶部としては、例えば、ハードディスク、ソリッドステートディスク、フラッシュメモリ等の不揮発性メモリが使用される。
記憶装置1001には、例えば、利用者端末101で使用することのできるブラウザについてのアプリケーションプログラム等が保存されている。このブラウザによりウェブコンテンツを利用者端末101で閲覧することができる。
主記憶部としては、例えば、RAM等の揮発性メモリが使用される。また補助記憶部としては、例えば、ハードディスク、ソリッドステートディスク、フラッシュメモリ等の不揮発性メモリが使用される。
記憶装置1001には、例えば、利用者端末101で使用することのできるブラウザについてのアプリケーションプログラム等が保存されている。このブラウザによりウェブコンテンツを利用者端末101で閲覧することができる。
通信用インターフェイス1002は、例えば、ネットワーク102を介してリクエスト処理ユニットC等から送信された各種データを受信し中央演算処理装置1000に各種データを転送する。
また通信用インターフェイス1002は、利用者端末101からネットワーク102を介してリクエスト処理ユニットC等に各種データを送信する。
また通信用インターフェイス1002は、利用者端末101からネットワーク102を介してリクエスト処理ユニットC等に各種データを送信する。
入力装置1003は、利用者端末101に対して各種操作を入力する装置である。入力装置1003は、例えば、表示装置1004と一体化したものを使用してもよいし、入力装置1003と、表示装置1004とが分離したものを使用してもよい。
入力装置1003は、ユーザからの各種データ入力を受け付けることができる。受け付けられた各種データは中央演算処理装置1000に転送される。
入力装置1003としては、例えば、タッチパネル、タッチパッド、マウス、キーボード、カメラ、マイク等が挙げられる。
例えば、タッチパネルやタッチパッドの場合には、ユーザの指による操作、タッチペン等の専用の入力具による操作等により各種データの入力を受け付ける。
入力装置1003としては、例えば、タッチパネル、タッチパッド、マウス、キーボード、カメラ、マイク等が挙げられる。
例えば、タッチパネルやタッチパッドの場合には、ユーザの指による操作、タッチペン等の専用の入力具による操作等により各種データの入力を受け付ける。
マウスの場合は、例えば、マウスの移動、マウスに搭載された左右キーの選択、クリックの回数、タップ、ドラッグ、ドロップ等の操作などにより各種データの入力を受け付ける。
キーボードの場合は、例えば、キーボードに搭載された各種キーの選択、および各種キーを同時に選択する操作などにより各種データの入力を受け付ける。
カメラの場合は、例えば、カメラにより撮影された画像を解析して中央演算処理装置1000に転送できる信号に変換することにより各種データの入力を受け付ける。
マイクの場合は、例えば、マイクにより聴音された音声を解析して中央演算処理装置1000に転送できる信号に変換することにより各種データの入力を受け付ける。
表示装置1004は、中央演算処理装置1000により処理された各種データを表示できる。
表示装置1004としては、例えば、液晶パネル、LEDパネル、有機ELパネル、液晶モニタ、LEDモニタ、有機ELモニタ等が挙げられる。表示装置1004は各種データの入力を受け付けるタッチパネルであってもよい。
表示装置1004としては、例えば、液晶パネル、LEDパネル、有機ELパネル、液晶モニタ、LEDモニタ、有機ELモニタ等が挙げられる。表示装置1004は各種データの入力を受け付けるタッチパネルであってもよい。
[アプリケーション実行サーバ103のハードウェア構成]
次にアプリケーション実行サーバ103のハードウェア構成について説明する。なお、アプリケーション実行サーバ103は全体として一つの実行環境から構築されているものであれば、その構成に特に限定はない。
ここでは、一例として、アプリケーション実行サーバ103のハードウェア構成が物理マシンにより構成される場合を例に挙げて説明する。アプリケーション実行サーバ103の構成は、先に説明した通り、物理マシンにより構成される場合に限定されない。一または二以上の物理マシン、一または二以上の仮想マシンならびに一または二以上のコンテナ等からなる群より選ばれる少なくとも一つの実行環境を選択した場合でも、一つの物理マシンにより構成される実行環境と同様の実行環境を構築して、本発明の実施形態1に使用することができる。
次にアプリケーション実行サーバ103のハードウェア構成について説明する。なお、アプリケーション実行サーバ103は全体として一つの実行環境から構築されているものであれば、その構成に特に限定はない。
ここでは、一例として、アプリケーション実行サーバ103のハードウェア構成が物理マシンにより構成される場合を例に挙げて説明する。アプリケーション実行サーバ103の構成は、先に説明した通り、物理マシンにより構成される場合に限定されない。一または二以上の物理マシン、一または二以上の仮想マシンならびに一または二以上のコンテナ等からなる群より選ばれる少なくとも一つの実行環境を選択した場合でも、一つの物理マシンにより構成される実行環境と同様の実行環境を構築して、本発明の実施形態1に使用することができる。
図7は、本発明の実施形態1に係るウェブコンテンツの自動高速表示制御方法に使用されるアプリケーション実行サーバのハードウェア構成を説明するための図である。
アプリケーション実行サーバ103は、例えば、中央演算処理装置1100(CPU、CENTRAL PROCESSING UNIT)、記憶装置1101、通信用インターフェイス1102、入力装置1103および表示装置1104等のハードウェア構成を備える。
これらのハードウェア構成はそれぞれ接続されていて相互に通信が可能である。
アプリケーション実行サーバ103は、例えば、中央演算処理装置1100(CPU、CENTRAL PROCESSING UNIT)、記憶装置1101、通信用インターフェイス1102、入力装置1103および表示装置1104等のハードウェア構成を備える。
これらのハードウェア構成はそれぞれ接続されていて相互に通信が可能である。
中央演算処理装置1100は、例えば、記憶装置1101の記憶領域等に保存されたプログラムを実行できる回路を搭載していて、各種処理を実行できる。
中央演算処理装置1100の構成は、一つのマイクロプロセッサを搭載するものに限定されず、二以上のプロセッサを搭載するマルチプロセッサを含むものであってもよい。
中央演算処理装置1100の構成は、一つのマイクロプロセッサを搭載するものに限定されず、二以上のプロセッサを搭載するマルチプロセッサを含むものであってもよい。
記憶装置1101は、例えば、アプリケーション処理ユニットAの動作に必要なデータ、プログラム等を記憶することができる。記憶装置1101は、例えば、主記憶部1101aと補助記憶部1101bとを含む。
主記憶部としては、例えば、RAM等の揮発性メモリが使用される。また補助記憶部としては、例えば、ハードディスク、ソリッドステートディスク、フラッシュメモリ等の不揮発性メモリが使用される。
図7では、一例として記憶装置1101の内部にリクエスト処理ユニットC等の各ユニットが設置されている。AからDの各ユニットは、一つの記憶装置1101に設置してもよいし、AからDの各ユニットが相互に通信可能であれば、異なる記憶装置に分散して設置することもできる。
図7では、一例として記憶装置1101の内部にリクエスト処理ユニットC等の各ユニットが設置されている。AからDの各ユニットは、一つの記憶装置1101に設置してもよいし、AからDの各ユニットが相互に通信可能であれば、異なる記憶装置に分散して設置することもできる。
通信用インターフェイス1102は、ネットワーク102を通じて利用者端末101等から送信された各種データを受信し中央演算処理装置1100等に各種データを転送する。
またリクエスト処理ユニットCからネットワーク102を通じて利用者端末101に各種データを送信する。
またリクエスト処理ユニットCからネットワーク102を通じて利用者端末101に各種データを送信する。
入力装置1103は、AからDの各ユニット等に対してデータを入力するための装置である。入力装置1103は、例えば、表示装置1104と一体化したものを使用してもよいし、入力装置1103と、表示装置1104とが分離したものを使用してもよい。
入力装置1103は、アプリケーション実行サーバ103の管理者による各種データの入力を受け付けることができる。受け付けられた各種データは中央演算処理装置1100に転送される。
入力装置1103としては、例えば、タッチパネル、タッチパッド、マウス、キーボード、カメラ、マイク等が挙げられる。
入力装置1103としては、例えば、タッチパネル、タッチパッド、マウス、キーボード、カメラ、マイク等が挙げられる。
表示装置1104は、中央演算処理装置1100により処理された各種データを表示できる。
表示装置1104としては、例えば、液晶パネル、LEDパネル、有機ELパネル、液晶モニタ、LEDモニタ、有機ELモニタ等が挙げられる。表示装置1104は各種データの入力を受け付けるタッチパネルであってもよい。
表示装置1104としては、例えば、液晶パネル、LEDパネル、有機ELパネル、液晶モニタ、LEDモニタ、有機ELモニタ等が挙げられる。表示装置1104は各種データの入力を受け付けるタッチパネルであってもよい。
アプリケーション実行サーバ103を操作する際には、例えば、アプリケーション実行サーバ103の管理者が、表示装置1104に表示されたCLI(COMMAND LINE INTERFACE)等の入力装置1103により、例えば文字、数字、記号等のデータを入力して行う。
[アプリケーション実行サーバ103の記憶装置1101に含まれるハードウェア構成の詳細]
次にアプリケーション実行サーバ103の記憶装置1101に含まれるハードウェア構成の詳細について説明する。
図8は、本発明の実施形態1に係るウェブコンテンツの自動高速表示制御方法に使用される、アプリケーション実行サーバ103の記憶装置1101に含まれるハードウェア構成の詳細を説明するための模式図である。
次にアプリケーション実行サーバ103の記憶装置1101に含まれるハードウェア構成の詳細について説明する。
図8は、本発明の実施形態1に係るウェブコンテンツの自動高速表示制御方法に使用される、アプリケーション実行サーバ103の記憶装置1101に含まれるハードウェア構成の詳細を説明するための模式図である。
記憶装置1101にはOS(OPERATING SYSTEM)1105が導入されていて、中央演算処理装置1100、記憶装置1101の各記憶領域、各プログラム等を制御できる。
OS1105は市場から有償または無料で入手できる。
OS1105は市場から有償または無料で入手できる。
図8で、記憶装置1101はオリジナルデータ記憶領域104およびデータベース1106を備えている。オリジナルデータ記憶領域104には、利用者端末101に表示されるオリジナルデータ200が保存されている。
また記憶装置1101にはアプリケーション処理ユニットA、人工知能ユニットB、リクエスト処理ユニットCおよびデータ取得・処理ユニットDが設置されている。
本発明の実施形態1では、発明の実施形態1に係るウェブコンテンツの自動高速表示制御方法は、例えば、動作環境に含まれるOS1105上で各ユニットに含まれるプログラムを中央演算処理装置1500により動作させて実現される。
また記憶装置1101にはアプリケーション処理ユニットA、人工知能ユニットB、リクエスト処理ユニットCおよびデータ取得・処理ユニットDが設置されている。
本発明の実施形態1では、発明の実施形態1に係るウェブコンテンツの自動高速表示制御方法は、例えば、動作環境に含まれるOS1105上で各ユニットに含まれるプログラムを中央演算処理装置1500により動作させて実現される。
[ウェブコンテンツの自動高速表示制御方法に使用されるアプリケーション処理ユニットA]
図8に示されるように、アプリケーション実行サーバ103はアプリケーション処理ユニットAを備えている。
アプリケーション処理ユニットAは、オリジナルデータ200を保存するためのオリジナルデータ記憶領域104およびデータベース1106に加えて、加工済みデータ記憶領域130を備えている。
この加工済みデータ記憶領域130は、アプリケーション処理ユニットAの他に、例えば、データ取得・処理ユニットD内に設けることができる。
図8に示されるように、アプリケーション実行サーバ103はアプリケーション処理ユニットAを備えている。
アプリケーション処理ユニットAは、オリジナルデータ200を保存するためのオリジナルデータ記憶領域104およびデータベース1106に加えて、加工済みデータ記憶領域130を備えている。
この加工済みデータ記憶領域130は、アプリケーション処理ユニットAの他に、例えば、データ取得・処理ユニットD内に設けることができる。
アプリケーション実行サーバ103の記憶装置1101に設置されたアプリケーション処理ユニットAは、必要に応じて、例えば、監視制御部1115、動作制御部1116および動作制御記憶部1117等を備えることもできる。
例えば、アプリケーション処理ユニットAの動作制御記憶部1117には、プログラムにより記載された各種のアプリケーションに対応できるように、OS1105の種類、実行環境等に関するデータと共に、動作制御部1116が動作するために必要なデータが保存されている。
また例えば、監視制御部1115は、オリジナルデータ記憶領域104に保存されたオリジナルデータ200に改変があった場合には、自動でその改変を検出することができる。
オリジナルデータ200に改変があったことを知らせる信号は人工知能ユニットBおよびデータ取得・処理ユニットDの少なくとも一方に送信される。
オリジナルデータ200に改変があったことを知らせる信号は人工知能ユニットBおよびデータ取得・処理ユニットDの少なくとも一方に送信される。
監視制御部1115は、アプリケーション処理ユニットAに保存されているオリジナルデータ200を監視している。例えば、図2の場合であれば、オリジナルデータ200に含まれるPHPファイル105、HTMLファイル113、CSSファイル107、スクリプト言語ファイル108、画像ファイル109等のリソースのいずれかに追加、移動、削除、変更等の改変があれば、この改変を検出できる。
アプリケーション実行サーバ103のOS1105に監視制御部1115を実現できる機能が設置されている場合にはその機能を用いてアプリケーション処理ユニットAに監視制御部1115を設置することができる。アプリケーション実行サーバ103のOS1105に監視制御部1115を実現できる機能が設置されていない場合には、オリジナルデータ200の変更を監視できる機能を有するプログラムをアプリケーション処理ユニットAに設置して対応することもできる。
監視制御部1115は、アプリケーション処理ユニットAに設置することは特に限定されず、アプリケーション処理ユニットAに代えて、またはアプリケーション処理ユニットAと共に、データ取得・処理ユニットDに設置することもできる。アプリケーション処理ユニットAとデータ取得・処理ユニットDの少なくとも一方に設置すればよい。
アプリケーション実行サーバ103の記憶装置1101に設置されているアプリケーション処理ユニットAは、例えば、時間実行制御部1120を備えることもできる。
アプリケーション実行サーバ103の時間実行制御部1120は、ネットワーク102を通じて正確な現在時刻を入手できる。時間実行制御部1120の時間実行記憶部1521に、いつ、どのタイミングで、何を実行するかの情報を記載した実行プログラ1122が保存されている。
時間実行制御部1120は、データ取得・処理ユニットDに設置することもできる。
時間実行制御部1120により、定められた日時の定められた時刻に実行が必要な各種ステップを実施することができる。
アプリケーション実行サーバ103の時間実行制御部1120は、ネットワーク102を通じて正確な現在時刻を入手できる。時間実行制御部1120の時間実行記憶部1521に、いつ、どのタイミングで、何を実行するかの情報を記載した実行プログラ1122が保存されている。
時間実行制御部1120は、データ取得・処理ユニットDに設置することもできる。
時間実行制御部1120により、定められた日時の定められた時刻に実行が必要な各種ステップを実施することができる。
[ウェブコンテンツの自動高速表示制御方法に使用される人工知能ユニットB]
先の図3に例示されるように、アプリケーション実行サーバ103の記憶装置1101に設置された人工知能ユニットBは、人工知能制御部1410を備えている。
人工知能制御部Bは、例えば、Python、C++、JavaScript(登録商標)等のプログラミング言語等により記載されたプログラム等がアプリケーション実行サーバ103に搭載されたOS等を含む実行環境で実行できる。人工知能制御部1410は戦略ファイル1412を生成することができる。生成された戦略ファイル1412は、人工知能記憶領域1430に保存される。また戦略ファイル1412をデータベース1106等に関連付けて保存することができる。
先の図3に例示されるように、アプリケーション実行サーバ103の記憶装置1101に設置された人工知能ユニットBは、人工知能制御部1410を備えている。
人工知能制御部Bは、例えば、Python、C++、JavaScript(登録商標)等のプログラミング言語等により記載されたプログラム等がアプリケーション実行サーバ103に搭載されたOS等を含む実行環境で実行できる。人工知能制御部1410は戦略ファイル1412を生成することができる。生成された戦略ファイル1412は、人工知能記憶領域1430に保存される。また戦略ファイル1412をデータベース1106等に関連付けて保存することができる。
[ウェブコンテンツの自動高速表示制御方法に使用されるリクエスト処理ユニットC]
リクエスト処理ユニットCは、ネットワーク102を通じて利用者端末101等との通信を可能にし、各ユニット間等でデータを通信できる機能を持つ。
図4および図8に示されるように、アプリケーション実行サーバ103の記憶装置 1101に設置されたリクエスト処理ユニットCは、例えば、アプリケーション実行サーバ103の通信用インターフェイス1102を介して、ネットワーク102を通じてデータの入出力が可能な通信データ制御部1510を備えている。
リクエスト処理ユニットCは、ネットワーク102を通じて利用者端末101等との通信を可能にし、各ユニット間等でデータを通信できる機能を持つ。
図4および図8に示されるように、アプリケーション実行サーバ103の記憶装置 1101に設置されたリクエスト処理ユニットCは、例えば、アプリケーション実行サーバ103の通信用インターフェイス1102を介して、ネットワーク102を通じてデータの入出力が可能な通信データ制御部1510を備えている。
通信データ制御部1510は、JavaScript(登録商標)等のプログラム等によりアプリケーション実行サーバ10に対する外部からのリクエスト、各ユニットからのリクエスト等、またこれらのリクエストに対するレスポンスを処理することができる。
リクエスト処理ユニットCがアプリケーション実行サーバ103に設置されると、アプリケーション処理ユニットA、人工知能ユニットB、データ取得・処理ユニットD等のそれぞれは、リクエスト処理ユニットCと相互に通信可能な状態を維持することができる。
[ウェブコンテンツの自動高速表示制御方法に使用されるデータ取得・処理ユニットD]
先の図5に例示されるように、アプリケーション実行サーバ103の記憶装置1101に設置されたデータ取得・処理ユニットDは、例えば、最適化ユニットd100、クローラーユニットd200およびコントロールユニットd300を含むことができる。
最適化ユニットd100、クローラーユニットd200およびコントロールユニットd300は、Python、C++、JavaScript(登録商標)等のプログラミング言語等によりアプリケーション実行サーバ10に搭載されたOSを含む実行環境上で実行できる。
データ取得・処理ユニットDにより処理されたデータは、データベース1106等に保存することができる。
先の図5に例示されるように、アプリケーション実行サーバ103の記憶装置1101に設置されたデータ取得・処理ユニットDは、例えば、最適化ユニットd100、クローラーユニットd200およびコントロールユニットd300を含むことができる。
最適化ユニットd100、クローラーユニットd200およびコントロールユニットd300は、Python、C++、JavaScript(登録商標)等のプログラミング言語等によりアプリケーション実行サーバ10に搭載されたOSを含む実行環境上で実行できる。
データ取得・処理ユニットDにより処理されたデータは、データベース1106等に保存することができる。
また例えば、データ取得・処理ユニットDのコントロールユニットd300に記載されたプログラムにより、最適化ユニットd100、クローラーユニットd200等が制御される。
このクローラーユニットd200に搭載されたプログラムにより構成されたクローラーにより、アプリケーション処理ユニットAのオリジナルデータ記憶領域104に保存されているオリジナルデータ200等をクロールして取得し、保存することができる。
またオリジナルデータ200等を監視し、オリジナルデータ200等に変更があった場合には、その変更に応じた加工済みデータ等のリソースが最適化ユニットd100に搭載されたプログラムにより生成される。
またオリジナルデータ200等を監視し、オリジナルデータ200等に変更があった場合には、その変更に応じた加工済みデータ等のリソースが最適化ユニットd100に搭載されたプログラムにより生成される。
また例えば、データ取得・処理ユニットDのコントロールユニットd300はウェブワーカーとしても機能することができる。アプリケーション実行サーバ103の実行に左右されずに、独立してバックグランドで各種プログラムの処理を実行することもできる。
[ウェブコンテンツの自動高速表示制御方法に使用されるオリジナルデータ200]
次に本発明の実施形態1に係るウェブコンテンツの自動高速表示制御方法に使用されるオリジナルデータ200について説明する。
次に本発明の実施形態1に係るウェブコンテンツの自動高速表示制御方法に使用されるオリジナルデータ200について説明する。
本発明に使用されるオリジナルデータ200は、動的または静的に生成されたものがアプリケーション処理ユニットAが設置されているオリジナルデータ記憶領域104に保存されている。
なお、本発明に係るウェブコンテンツの自動高速表示制御方法では、アプリケーション実行サーバ103に対して利用者端末101からリクエストが送信された場合、利用者端末101にウェブコンテンツを表示するためのオリジナルデータ200が、そのまま、前記アプリケーション実行サーバ103から利用者端末101に送信されて、ウェブコンテンツが利用者端末101に表示することもできる。
本発明の実施形態1に係るウェブコンテンツを含め、本発明の開示においては、本発明に係る自動高速表示制御方法を実施する場合と、オリジナルデータ200に基づく本発明に係る自動高速表示制御方法を実施しない場合のウェブコンテンツの配信を、相互に切り替えることができる。
本発明の開示に使用するオリジナルデータ200としては、例えば、プログラムデータ(1)、バイナリデータ(2)等の一つもしくは二以上が挙げられる。
具体的には、プログラムデータ(1)としては、例えば、
HTML、XML等のマークアップ言語、
PHP、Perl、Java(登録商標)、C、Lua等のプログラミング言語、
CSS、SCSS等のスタイルシート、JavaScript(登録商標)、TypeScript(登録商標)、JavaScript(登録商標)のライブラリであるJquery(登録商標)等のスクリプト言語等の一つもしくは二以上を含むデータ等が挙げられる。
また、バイナリデータ(2)としては、例えば、
画像ファイル、音ファイル、動画ファイル等の一つもしくは二以上のデータ等が挙げられる。
具体的には、プログラムデータ(1)としては、例えば、
HTML、XML等のマークアップ言語、
PHP、Perl、Java(登録商標)、C、Lua等のプログラミング言語、
CSS、SCSS等のスタイルシート、JavaScript(登録商標)、TypeScript(登録商標)、JavaScript(登録商標)のライブラリであるJquery(登録商標)等のスクリプト言語等の一つもしくは二以上を含むデータ等が挙げられる。
また、バイナリデータ(2)としては、例えば、
画像ファイル、音ファイル、動画ファイル等の一つもしくは二以上のデータ等が挙げられる。
プログラムデータ(1)には、例えば、数字データ、記号データ、文字データ等が含まれる。
またバイナリデータ(2)には、例えば、音データ、画像データ、動画データ等の人間の五感で知覚できるデータ等が含まれる。
またバイナリデータ(2)には、例えば、音データ、画像データ、動画データ等の人間の五感で知覚できるデータ等が含まれる。
マークアップ言語は、HTML、XML等、ウェブサイト等の基本構造を記述する文書に使用される。
またPHP、Perl、Java(登録商標)、C、Lua等のプログラミング言語は、実際にアプリケーション実行サーバ103等を動作させ、ウェブコンテンツを利用者端末101毎に表示できる言語である。
CSS、SCSS等のスタイルシートは、主として利用者端末101のブラウザ等に表示される文字、数字、記号、画像等の位置、大きさ、種類等のデザイン構成を制御するプログラムである。
またJavaScript(登録商標)、TypeScript(登録商標)、JavaScript(登録商標)のライブラリであるJquery(登録商標)等のスクリプト言語は、主として、利用者端末101に表示されたウェブサイト等のユーザによるボタン等に対するクリック操作、スクロール操作等の処理をはじめ、ウェブコンテンツを利用者端末101に表示するために必要な多種多様な処理を行うプログラムである。
またPHP、Perl、Java(登録商標)、C、Lua等のプログラミング言語は、実際にアプリケーション実行サーバ103等を動作させ、ウェブコンテンツを利用者端末101毎に表示できる言語である。
CSS、SCSS等のスタイルシートは、主として利用者端末101のブラウザ等に表示される文字、数字、記号、画像等の位置、大きさ、種類等のデザイン構成を制御するプログラムである。
またJavaScript(登録商標)、TypeScript(登録商標)、JavaScript(登録商標)のライブラリであるJquery(登録商標)等のスクリプト言語は、主として、利用者端末101に表示されたウェブサイト等のユーザによるボタン等に対するクリック操作、スクロール操作等の処理をはじめ、ウェブコンテンツを利用者端末101に表示するために必要な多種多様な処理を行うプログラムである。
先に説明した図2は、本発明の実施形態1に使用されるアプリケーション処理ユニットAに設置された記憶装置1101のオリジナルデータ記憶領域104と加工済みデータ記憶領域130に保存される各ファイルの関係を説明するための模式図である。
図2では、一つの具体例として、PHPのプログラミング言語がPHPファイル105のデータとしてオリジナルデータ記憶領域104に保存されている。またデータベース1106にはPHPファイル105の表示に必要なデータが格納されている。
本発明に係る実施形態1の場合では、図2に例示されるように、一例としてプログラミング言語としてPHPファイル105に記載されるPHPが使用されているが、本発明に使用するプログラミング言語はPHPに限定されず、Lua等、ウェブコンテンツの表示を実現できるものであれば適宜選択して使用することができる。
またリソース124の一例として、CSSファイル107、スクリプト言語ファイル108および画像ファイル109についてのデータがオリジナルデータ記憶領域104に保存されている。
PHPファイル105等に記載されたプログラムにより、利用者端末101のブラウザ等にウェブコンテンツを表示するために必要なデータがデータベース1106から参照される。
また、PHPファイル105等にCSSファイル107、スクリプト言語ファイル108および画像ファイル109へのアクセス情報を記載し、PHPファイル105等から、CSSファイル107、スクリプト言語ファイル108および画像ファイル109のデータを用いて、利用者端末101に表示されるウェブコンテンツを生成できる。
PHPファイル105等の中で定義された変数はデータベース1106に保存されている。
データベース1106にはデータ読込手段、データ書込手段、データ保存手段、データ検索手段等が備えられている。
PHPファイル105等に記載された変数に対応するデータをデータベース1106にあらかじめ書き込み保存する。
そしてPHPファイル105等に記載された変数を元に、データベース1106に保存されたデータを呼び出すことができる。
PHPファイル105等に記載された変数に対応するデータをデータベース1106にあらかじめ書き込み保存する。
そしてPHPファイル105等に記載された変数を元に、データベース1106に保存されたデータを呼び出すことができる。
ユーザが操作する利用者端末101に搭載されたブラウザ等がPHPファイル105等に記載されたプログラムを実行して、HTMLファイル113を生成することもできるし、アプリケーション処理ユニットAがPHPファイル105等に記載されたプログラムを実行して、HTMLファイル113を生成することもできる。
HTMLファイル113は、静的に事前に生成されてもよいし、利用者端末101からのリクエストの前、またはリクエスト直後に、動的に生成されてもよい。またPHPファイル105等に記載されたプログラムが実行される度に、都度、動的に生成されてもよい。
通常は、HTMLファイル113は動的に生成される。以下、同様である。
通常は、HTMLファイル113は動的に生成される。以下、同様である。
例えば、HTMLファイル113等が参照するCSSファイル107、スクリプト言語ファイル108についても、静的に事前に生成されてもよいし、利用者端末101からのリクエストの前、または直後に、PHPファイル105に記載されたプログラムが実行される度に、都度、動的に生成されてもよい。
[ユーザからのリクエストに対するオールインワン型による処理の流れ]
図9~図11のそれぞれは、ユーザからのリクエストがどのように処理されるのかを説明するための模式図である。
図9~図11のそれぞれは、縦軸が時間を示し、横軸がデータの流れを示している。
ユーザが操作する利用者端末101のブラウザ等から送信されたリクエストは、ネットワーク102を通じてリクエスト処理ユニットCに送信される。
図9~図11のそれぞれは、ユーザからのリクエストがどのように処理されるのかを説明するための模式図である。
図9~図11のそれぞれは、縦軸が時間を示し、横軸がデータの流れを示している。
ユーザが操作する利用者端末101のブラウザ等から送信されたリクエストは、ネットワーク102を通じてリクエスト処理ユニットCに送信される。
本発明の実施形態1に係るウェブコンテンツの自動高速表示制御方法を実施しない場合には、リクエストを受信したリクエスト処理ユニットCは、リクエストをアプリケーション処理ユニットAにリクエストを送信する。リクエストを受信したアプリケーション処理ユニットAは、ユーザの利用者端末101にウェブコンテンツを表示するためのオリジナルデータ200をレスポンスとしてリクエスト処理ユニットCに送信する。そしてこのレスポンスはリクエスト処理ユニットCからネットワーク102を通じて利用者端末101に送信される。送信されたレスポンスは利用者端末101で受信される。そして利用者端末101に搭載されたブラウザ等により、オリジナルデータ200に基づくウェブコンテンツが利用者端末101に表示される。
本発明の実施形態1に係るウェブコンテンツの自動高速表示制御方法の場合は、ユーザが操作する利用者端末101のブラウザ等から送信されたリクエストが、ネットワーク102を通じてリクエスト処理ユニットCに送信された後のオリジナルデータ200の処理動作に加えて、処理済みデータの処理動作が実施される。
図9に例示されるように、ユーザが操作する利用者端末101のブラウザ等から送信されたリクエストは、ネットワーク102を通じてリクエスト処理ユニットCに送信される。
リクエストを受信したリクエスト処理ユニットCは、リクエストをアプリケーション処理ユニットAに送信する。リクエストを受信したアプリケーション処理ユニットAは、ユーザの利用者端末101にウェブコンテンツを表示するためのHTMLファイル113等を、例えば動的に生成する。
リクエストを受信したリクエスト処理ユニットCは、リクエストをアプリケーション処理ユニットAに送信する。リクエストを受信したアプリケーション処理ユニットAは、ユーザの利用者端末101にウェブコンテンツを表示するためのHTMLファイル113等を、例えば動的に生成する。
HTMLファイル113は、リソースを参照する部分を有するオリジナルデータの一例である。リソースを参照する部分を有するオリジナルデータとしては、例えば、HTMLファイル、XMLファイル、PHPファイル等の一種もしくは二種以上が挙げられる。
この際、利用者端末101に受信されたHTMLファイル113が参照するリソースの利用者端末101に対するダウンロードが始まる動作を実施することもできる。
または人工知能ユニットBで立案された戦略案に基づいてダウンロードを待機することもできる。
このダウンロードは、アプリケーション処理ユニットAのオリジナルデータ記憶領域104に保存されている、HTMLファイル113が参照するリソースが、アプリケーション処理ユニットA、リクエスト処理ユニットCを経て、ネットワーク102を通じて利用者端末101に送信されることを意味する。
または人工知能ユニットBで立案された戦略案に基づいてダウンロードを待機することもできる。
このダウンロードは、アプリケーション処理ユニットAのオリジナルデータ記憶領域104に保存されている、HTMLファイル113が参照するリソースが、アプリケーション処理ユニットA、リクエスト処理ユニットCを経て、ネットワーク102を通じて利用者端末101に送信されることを意味する。
リクエスト処理ユニットCはアプリケーション処理ユニットAからリクエスト処理ユニットCを経てネットワーク102を通じて利用者端末101に対してレスポンスとしてのダウンロードが実行される処理に割り込み、図9に示されるようにHTMLファイル113のデータを取得する。
具体的には、利用者端末101のブラウザ等から送信されたリクエストが、ネットワーク102を通じてリクエスト処理ユニットCに送信される。次にリクエスト処理ユニットCからリクエストがアプリケーション処理ユニットAに送信される。
リクエストを受信したアプリケーション処理ユニットAは、レスポンスとして、例えば、HTMLファイル113等のデータをリクエスト処理ユニットCに送信する。
具体的には、利用者端末101のブラウザ等から送信されたリクエストが、ネットワーク102を通じてリクエスト処理ユニットCに送信される。次にリクエスト処理ユニットCからリクエストがアプリケーション処理ユニットAに送信される。
リクエストを受信したアプリケーション処理ユニットAは、レスポンスとして、例えば、HTMLファイル113等のデータをリクエスト処理ユニットCに送信する。
取得されたHTMLファイル113等のデータが、リクエスト処理ユニットCから人工知能ユニットB、データ取得・処理ユニットDの順に送信される。人工知能ユニットBで立案された戦略案に基づいて、データ取得・処理ユニットDがHTMLファイル113等の最適化を行う。
最適化されたHTMLファイル113zについてのデータは、データ取得・処理ユニットD、人工知能ユニットBおよびリクエスト処理ユニットCを経て、ネットワーク102を通じてユーザの利用者端末101に送信される。
最適化されたHTMLファイル113zについてのデータは、データ取得・処理ユニットD、人工知能ユニットBおよびリクエスト処理ユニットCを経て、ネットワーク102を通じてユーザの利用者端末101に送信される。
例えば、リソースを参照する部分を有するオリジナルデータの一つであるHTMLファイル113は、HTMLファイル113により参照されてウェブコンテンツを利用者端末101のブラウザ等に表示するためのリソースについての情報が記載されている。
データ取得・処理ユニットDで、HTMLファイル113に含まれるリソースを参照する部分が、プログラムのオブジェクトに置換されて、最適化されたHTMLファイル113zが生成する。このオブジェクトのそれぞれには、対応するリソースを特定するための識別情報が付与されている。最適化されたHTMLファイル113zはオブジェクト置換済みプログラムの一例である。
データ取得・処理ユニットDで、HTMLファイル113に含まれるリソースを参照する部分が、プログラムのオブジェクトに置換されて、最適化されたHTMLファイル113zが生成する。このオブジェクトのそれぞれには、対応するリソースを特定するための識別情報が付与されている。最適化されたHTMLファイル113zはオブジェクト置換済みプログラムの一例である。
図10に示されるように、利用者端末101毎に搭載されたブラウザ等で最適化されたHTMLファイル113zが実行されると、最適化されたHTMLファイル113zに記載されたオブジェクトに基づいて、ネットワーク102を通じてリクエスト処理ユニットCから、データ取得・処理ユニットDにリクエストが送信される。リクエストを受信したデータ取得・処理ユニットDから最適リソースが選択され、リクエスト処理ユニットCを経て、ネットワーク102を通じて最適リソースが利用者端末101に送信される。
また最適リソースが存在しない場合には、図10に示されるように、リクエスト処理ユニットCはアプリケーション処理ユニットAに保存されているオリジナルデータ200から対応するリソースを取得する。取得されたリソースは、アプリケーション処理ユニットAからリクエスト処理ユニットCを経て利用者端末101に送信される。
最適リソースが存在しない場合には、オリジナルデータ200から対応するリソースが使用される。この一方、データ取得・処理ユニットDで、最適リソースの生成、選択がバックグラウンドで進められる。最適リソースが生成されると、データ取得・処理ユニットDからリクエスト処理ユニットCを経て、ネットワーク102を通じて最適リソースが利用者端末101に送信される。そして利用者端末101毎に使用されていたリソースが、最適リソースにより置換される。
また図11に示されるように、例えば、ユーザによる利用者端末101に搭載されたブラウザ等からリクエストがアプリケーション実行サーバ103に送信される前等、利用者端末101とアプリケーション実行サーバ103が互いに通信をしていない時等に、データ取得・処理ユニットDに設置されたクローラーユニットd200のクロール制御部1510は、アプリケーション実行サーバ103に保存されたオリジナルデータ200等をクロールする。
クロールされたオリジナルデータ200等に基づいて、データ取得・処理ユニットDに設置された最適化ユニットd100の制御部1610により最適化されたリソースが生成され、データベース1106に蓄積される。
データ取得・処理ユニットDに設置されたクローラーユニットd200は定期的にアプリケーション処理ユニットAに保存されたオリジナルデータ200をクロールし、自動的に最適化リソースが生成され、データベース1106に蓄積されるステップが実施される。
オリジナルデータ200の変化を捕捉するために、この変化をデータ取得・処理ユニットDおよびアプリケーション処理ユニットAの少なくとも一方に搭載されたプログラムにより、オリジナルデータ200が監視される。
オリジナルデータ200に変化があると、データ取得・処理ユニットDに設置されたクローラーユニットd200はオリジナルデータ200をクロールし、自動的に最適化リソースが生成される。
オリジナルデータ200に変化があると、データ取得・処理ユニットDに設置されたクローラーユニットd200はオリジナルデータ200をクロールし、自動的に最適化リソースが生成される。
クロール、監視等により生成した、最適化リソースは、例えば、利用者端末101毎からリクエストがある毎に継続的に利用者端末101にダウンロードされる。
[オリジナルデータ200の処理の詳細]
図12および図13は、オリジナルデータ200がどのように処理されるかを説明するための概念図である。
図12および図13は、オリジナルデータ200がどのように処理されるかを説明するための概念図である。
本発明の開示では、利用者端末101にウェブコンテンツを表示するためのオリジナルデータ200に含まれるマークアップ言語およびプログラミング言語の少なくとも一方が記載されたプログラムデータに含まれる全てのリソースの参照部分が、プログラムにより定義されたオブジェクトにより置換されて、オブジェクト置換済みプログラムが生成されるステップと、
オブジェクト置換済みプログラムが参照するリソースに対応するリソースが加工されて最適化リソースが生成されるステップと、
が含まれる。
オブジェクト置換済みプログラムが参照するリソースに対応するリソースが加工されて最適化リソースが生成されるステップと、
が含まれる。
[オブジェクト置換済みプログラムが生成されるステップ]
利用者端末101にウェブコンテンツを表示するためのプログラムデータとしては、例えば、HTML、XML等のマークアップ言語、PHP、Perl、Java(登録商標)、C、Lua等のプログラミング言語の少なくとも一つが記載されたプログラムデータ等が挙げられる。
図12では、利用者端末101にウェブコンテンツを表示するためのオリジナルデータ200に含まれるマークアップ言語およびプログラミング言語の少なくとも一方が記載されたデータの一例として、HTMLファイル113が例示さている。
HTMLファイル113には、例えば、ヘッド部分113iおよびボディ部分113j等が含まれる。
利用者端末101にウェブコンテンツを表示するためのプログラムデータとしては、例えば、HTML、XML等のマークアップ言語、PHP、Perl、Java(登録商標)、C、Lua等のプログラミング言語の少なくとも一つが記載されたプログラムデータ等が挙げられる。
図12では、利用者端末101にウェブコンテンツを表示するためのオリジナルデータ200に含まれるマークアップ言語およびプログラミング言語の少なくとも一方が記載されたデータの一例として、HTMLファイル113が例示さている。
HTMLファイル113には、例えば、ヘッド部分113iおよびボディ部分113j等が含まれる。
ヘッド部分113iには、例えば、HTMLファイル113の実行に必要なCSS、SCSS等のスタイルシート、JavaScript(登録商標)、TypeScript(登録商標)、JavaScript(登録商標)のライブラリであるJquery(登録商標)等のスクリプト言語等により記載されたプログラム等の参照部分等が記載されている。
ボディ部分113jには、例えば、利用者端末101のブラウザ等に表示されて、利用者端末101を操作するユーザが読むプログラムデータ、画像ファイル、音ファイル、動画ファイル等のバイナリデータ等の参照部分が記載されている。
また例えば、利用者端末101のブラウザ等に表示されて、利用者端末101を操作するユーザが読むプログラムデータ、利用者端末101のブラウザ等の制御に必要な各種プログラム等の参照部分が記載されている。
図13では、一つの例として、置換済みプログラムデータとして新たに生成された、最適化されたHTMLファイル113zが例示さている。置換済みプログラムデータは、例えば、HTMLファイル、XMLファイル等のマークアップ言語等で記載されたデータ、PHPファイル等のプログラミング言語で記載されたデータが含まれる。
図13では、例えば、図12に例示されたHTMLファイル113のうち、参照部分の全てが識別情報と共にオブジェクトに変換されている様子が例示さている。
HTMLファイル113には参照部分が含まれているが、この参照部分は、HTMLファイル113に直接記載されたスタイルシート、プログラム等の参照部分と、HTMLファイル113の外部に記載されたスタイルシート、プログラム等の参照部分等が存在する。
図13では、例えば、図12に例示されたHTMLファイル113のうち、参照部分の全てが識別情報と共にオブジェクトに変換されている様子が例示さている。
HTMLファイル113には参照部分が含まれているが、この参照部分は、HTMLファイル113に直接記載されたスタイルシート、プログラム等の参照部分と、HTMLファイル113の外部に記載されたスタイルシート、プログラム等の参照部分等が存在する。
マークアップ言語等には参照部分を記載するときに適用される規則があらかじめ定められている。この規則に従って、HTMLファイル113の中で、どの部分が参照部分に該当するかを見分けることができる。
データ取得・処理ユニットDに設置された最適化ユニットd100により、例えば、それぞれの参照部分の全てが、識別情報と共にプログラムが扱うことのできるオブジェクトにより置換される。
なおこの識別情報は、マークアップ言語等に記載されている参照部分とオブジェクトとの対応関係を定めるものであり、一つの参照部分に対して一つのオブジェクトを特定できる一意の情報である。
なおこの識別情報は、マークアップ言語等に記載されている参照部分とオブジェクトとの対応関係を定めるものであり、一つの参照部分に対して一つのオブジェクトを特定できる一意の情報である。
また、本発明の開示におけるオブジェクトとは、利用者端末101、AからDの各ユニット等を含む実行環境が扱うことができる実体を意味し、例えば、変数、配列、関数、プログラム等の一種もしくは二種以上を含む概念を指す。
例えば、HTMLファイル113に記載されているそれぞれの参照部分が、識別情報と共にプログラムが扱うことのできるオブジェクトにより置換されるステップは、実際に参照部分がどのような内容であるか、実行するのにどの程度の時間が必要であるか、容量はどの程度の大きさなのか等の実体的な検討を行うことなく実施することができる。
HTMLファイル113の記載内容および人口知能ユニットBが生成した戦略ファイルの内容から規則に従って形式的に置換箇所を決定することができ、識別情報と共にオブジェクトで置換するだけで、最適化されたHTMLファイル113zを高速に生成することができる。
HTMLファイル113の記載内容および人口知能ユニットBが生成した戦略ファイルの内容から規則に従って形式的に置換箇所を決定することができ、識別情報と共にオブジェクトで置換するだけで、最適化されたHTMLファイル113zを高速に生成することができる。
図13に例示されるように、置換済みプログラムデータとしての最適化されたHTMLファイル113zには、オリジナルデータに含まれるHTMLファイル113の各参照部分がオブジェクト113o1、113o2等により置換されている。
最適化されたHTMLファイル113zのヘッド部分113iには、ユーザが操作する利用者端末101のブラウザ等で最初に実行されるオブジェクト113o1、113o2等が置換により挿入されている。
また最適化されたHTMLファイル113zのボディ部分113jには、最適化されたHTMLファイル113zに識別情報と共にオブジェクトを挿入するためのオブジェクト113o10が記載されている。
加えて、最適化されたHTMLファイル113zのボディ部分には、利用者端末101のブラウザ等で実行されるプログラムが、オブジェクト113o20、113o21等として挿入されている。
また最適化されたHTMLファイル113zのボディ部分113jには、最適化されたHTMLファイル113zに識別情報と共にオブジェクトを挿入するためのオブジェクト113o10が記載されている。
加えて、最適化されたHTMLファイル113zのボディ部分には、利用者端末101のブラウザ等で実行されるプログラムが、オブジェクト113o20、113o21等として挿入されている。
[最適リソースが生成されるステップ]
次に本発明の実施形態1で使用される最適リソースが生成されるステップについて説明する。
最適リソースとしては、例えば、先に説明したプログラムデータ(1)およびバイナリデータ(2)の少なくとも一つを加工して得られるリソース等が挙げられる。
次に本発明の実施形態1で使用される最適リソースが生成されるステップについて説明する。
最適リソースとしては、例えば、先に説明したプログラムデータ(1)およびバイナリデータ(2)の少なくとも一つを加工して得られるリソース等が挙げられる。
本発明に係る実施形態1の場合では、一例としてHTMLファイル113が採用されている。
例えば、静的に生成されてアプリケーション処理ユニットAに保存されているか、または動的に生成されてアプリケーション処理ユニットAに保存されているHTMLファイル113は、ウェブコンテンツを利用者端末101に表示するためのCSSファイル107、スクリプト言語ファイル108および画像ファイル109への参照部分等、リソースへの参照部分等が記載されている。
例えば、静的に生成されてアプリケーション処理ユニットAに保存されているか、または動的に生成されてアプリケーション処理ユニットAに保存されているHTMLファイル113は、ウェブコンテンツを利用者端末101に表示するためのCSSファイル107、スクリプト言語ファイル108および画像ファイル109への参照部分等、リソースへの参照部分等が記載されている。
利用者端末101に搭載されたブラウザ等によりHTMLファイル113に記載されたプログラムが実行されると、その実行に伴ってCSSファイル107、スクリプト言語ファイル108にそれぞれ記載されたプログラムも実行される。
このHTMLファイル113に記載されたプログラムの実行に伴い、ウェブコンテンツが生成される。
このHTMLファイル113に記載されたプログラムの実行に伴い、ウェブコンテンツが生成される。
そして利用者端末101で受信されたウェブコンテンツが利用者端末101に通常は表示される。
例えば、PHPファイル105、HTMLファイル113等に記載されているプログラミング言語等のプログラムデータ、ならびに画像ファイル109による画像データ等のバイナリデータにより表示されるウェブコンテンツは、CSSファイル107、スクリプト言語ファイル108等により、利用者端末101の表示環境に応じて表示位置、表示する大きさ、表示用のレイアウト等が指定される。
先に説明した図2に例示される、本発明に係る実施形態1に使用される一例としてのPHPファイル105、HTMLファイル113、CSSファイル107、スクリプト言語ファイル108および画像ファイル109等についてのデータを含むオリジナルデータ200は、アプリケーション処理ユニットAにアクセスすることが予想されるあらゆる利用者端末101の表示環境に対応してウェブコンテンツを表示できる反面、個々の利用者端末101の表示環境に必要とされないオリジナルデータ200の部分も含む。
例えば、利用者端末101がPCの場合には必要なオリジナルデータ200も、利用者端末101がスマートフォンの場合には必要とされないオリジナルデータ200の部分を含む。
逆に利用者端末101が、例えば、スマートフォン場合には必要なオリジナルデータ200も、利用者端末101がPCの場合には必要とされないオリジナルデータ200の部分を含む。
さらには利用者端末101がスマートフォン場合の場合であっても、異なる複数のスマートフォン間では必要とされるオリジナルデータ200の部分も異なる場合もある。
加えて利用者端末101に搭載されているブラウザの種類によっても、必要とされるオリジナルデータ200の部分が異なる場合がある。
逆に利用者端末101が、例えば、スマートフォン場合には必要なオリジナルデータ200も、利用者端末101がPCの場合には必要とされないオリジナルデータ200の部分を含む。
さらには利用者端末101がスマートフォン場合の場合であっても、異なる複数のスマートフォン間では必要とされるオリジナルデータ200の部分も異なる場合もある。
加えて利用者端末101に搭載されているブラウザの種類によっても、必要とされるオリジナルデータ200の部分が異なる場合がある。
利用者端末101に対して一律に同じオリジナルデータ200をアプリケーション処理ユニットAから利用者端末101に送信すれば、オリジナルデータ200の中に、個々の利用者端末101の表示に必要のないデータが含まれる結果になる。
個々の利用者端末101の表示に必要のないデータがアプリケーション処理ユニットAから個々の利用者端末101に送信されることを防止して、表示完了時間を短くするために、オリジナルデータ200がデータ取得・処理ユニットDで処理されて、複数の加工済みデータ201が生成される。
オリジナルデータ200は、プログラムデータおよびバイナリデータの少なくとも一つを含む。
オリジナルデータ200にはマークアップ言語により記載されたデータが含まれる。
またマークアップ言語の記載には、直接記載されたスタイルシート、プログラミング言語、スクリプト言語等の参照情報が含まれる。
またマークアップ言語の記載には、外部のスタイルシート、外部のスクリプト言語、外部のバイナリデータ等への参照情報が含まれる。
なお、ここでいう「外部」とは、マークアップ言語の記載に直接記載はされていないが、マークアップ言語の記載から参照することによりウェブコンテンツとして活用できるものをいう。
オリジナルデータ200にはマークアップ言語により記載されたデータが含まれる。
またマークアップ言語の記載には、直接記載されたスタイルシート、プログラミング言語、スクリプト言語等の参照情報が含まれる。
またマークアップ言語の記載には、外部のスタイルシート、外部のスクリプト言語、外部のバイナリデータ等への参照情報が含まれる。
なお、ここでいう「外部」とは、マークアップ言語の記載に直接記載はされていないが、マークアップ言語の記載から参照することによりウェブコンテンツとして活用できるものをいう。
具体的には、例えば、マークアップ言語が記載されているファイルの一つであるHTMLファイル113には、HTMLファイル113に直接記載されたHTMLファイルの複数のコード部分、CSSファイル107の複数のコード部分およびスクリプト言語ファイル108の複数のコード部分等の参照情報が含まれる。
また、HTMLファイル113が参照する複数のCSSファイル107の外部のファイル部分および複数のスクリプト言語ファイル108の外部のファイル部分等が含まれる。
画像ファイル、音ファイル、動画ファイルなどの一種もしくは二種以上の外部のファイルに関する参照部分もHTMLファイル113に記載されている。
また、HTMLファイル113が参照する複数のCSSファイル107の外部のファイル部分および複数のスクリプト言語ファイル108の外部のファイル部分等が含まれる。
画像ファイル、音ファイル、動画ファイルなどの一種もしくは二種以上の外部のファイルに関する参照部分もHTMLファイル113に記載されている。
オリジナルデータ200がネットワーク102を経由して、表示環境が特定された全ての利用者端末101に送信できる。このオリジナルデータ200を受信したそれぞれの利用者端末101のブラウザ等で、HTMLファイル113を実行すれば、オリジナルデータ200に基づくウェブコンテンツ211が表示される。
次に、本発明に係る実施形態1の全体像を示すため、加工済みデータの生成と、リソースの最適化について説明する。
図14は、処理済みデータの生成と、リソースの最適化との関係を説明するためのフローチャートである。
前提として、機種情報ファイルに記載された全てのユーザの利用者端末101にオリジナルデータ200は通常表示可能である。
通常は、利用者端末101の表示に不具合が生じないように、オリジナルデータ200が作成されているからである。
仮にオリジナルデータ200に不具合がある場合には、例えば、データ取得・処理ユニットDに搭載されたヘッドレスブラウザ等のエミュレータ等により、不具合が検出される。この検出された不具合についての情報を元に、個別に不具合を修正することができる。
図14は、処理済みデータの生成と、リソースの最適化との関係を説明するためのフローチャートである。
前提として、機種情報ファイルに記載された全てのユーザの利用者端末101にオリジナルデータ200は通常表示可能である。
通常は、利用者端末101の表示に不具合が生じないように、オリジナルデータ200が作成されているからである。
仮にオリジナルデータ200に不具合がある場合には、例えば、データ取得・処理ユニットDに搭載されたヘッドレスブラウザ等のエミュレータ等により、不具合が検出される。この検出された不具合についての情報を元に、個別に不具合を修正することができる。
例えば、最初に、オリジナルデータ200に含まれるプログラムデータおよびバイナリデータを処理する。
オリジナルデータ200に含まれるプログラムデータおよびバイナリデータは、人工知能ユニットB、データ取得・処理ユニットDの順に送信される。
データ取得・処理ユニットDで受信されたプログラムデータおよびバイナリデータは、データ取得・処理ユニットDのオリジナルデータ保存領域1530に保存することができる。
先の図2で示した通り、プログラムデータには、例えば、HTMLファイル113、CSSファイル107、スクリプト言語ファイル108等の一種もしくは二種以上が含まれる。
先の図2で示した通り、プログラムデータには、例えば、HTMLファイル113、CSSファイル107、スクリプト言語ファイル108等の一種もしくは二種以上が含まれる。
またバイナリデータには、例えば、画像ファイル、音ファイル、動画ファイル等の一種もしくは二種以上が含まれる。
本発明における実施形態1では、プログラムデータに含まれるマークアップ言語が記載されているファイルの一例として、HTMLファイル113が採用されている。
オリジナルデータ200により、利用者端末101に表示されるウェブコンテンツは、通常、複数のウェブページを有する。この一つひとつのウェブページに、それぞれ複数のプログラムデータとしてのHTMLファイル113が対応する。図2の場合では、HTMLファイル113で示されている。
HTMLファイル113のそれぞれは、利用者端末101のブラウザで再読込操作を必要とせずに表示できる単位となっている。
続いて処理に必要なプログラムデータの全部または一部のデータがデータ取得・処理ユニットDに送信される(ステップS1021、S1022)。
データ取得・処理ユニットDに送信されたプログラムデータの全部または一部のデータは、データ取得・処理ユニットDにより処理される(ステップS1023)。
データ取得・処理ユニットDによるプログラムデータの全部または一部のデータの処理としては、例えば、プログラムデータに含まれる、省略可能なプログラム等の削除、プログラム等の圧縮、処理順序の変更、処理タイミングの変更等が挙げられる。
データ取得・処理ユニットDによるプログラムデータの全部または一部のデータの処理としては、例えば、プログラムデータに含まれる、省略可能なプログラム等の削除、プログラム等の圧縮、処理順序の変更、処理タイミングの変更等が挙げられる。
プログラムデータに関する全部または一部のデータの処理には、例えば、HTMLファイル113等が参照するプログラムデータ、バイナリデータ等のリソースのそれぞれをオブジェクトとして扱う場合が含まれる。HTMLファイル113が参照するプログラムデータ、HTMLファイル113が参照するバイナリデータ等のそれぞれの部分を、HTMLファイル113の中で定義されるオブジェクトとして扱うことにより、簡便に処理済みデータを特定することができる。
同様に、例えば、HTMLファイル113等が参照するスタイルシート、スクリプト言語等についても、データ取得・処理ユニットDで処理される(ステップS1023)。
また、例えば、HTMLファイル113等が参照するバイナリデータ等が処理される(ステップS1024)。
ステップS1023とステップS1024の処理は直列に実施されているが、同時に並行して実施することもできる。
ステップS1023とステップS1024の処理は直列に実施されているが、同時に並行して実施することもできる。
ステップS1023からステップS1024までの処理は、オリジナルコンテンツ200に含まれるそれぞれのリソースに対する処理である。すなわち、オリジナルコンテンツ200に含まれるプログラムデータ、バイナリデータに対する処理である。
オリジナルコンテンツ200に含まれるそれぞれのリソースに対する処理は、同じリソースについて、一回もしくは複数回実施される。
それぞれのリソースに対する処理が実施された回数に対応する、加工済みプログラムデータ、加工済みバイナリデータが得られる。
オリジナルコンテンツ200に含まれるそれぞれのリソースに対する処理は、同じリソースについて、一回もしくは複数回実施される。
それぞれのリソースに対する処理が実施された回数に対応する、加工済みプログラムデータ、加工済みバイナリデータが得られる。
次に、複数の加工済みデータの中から、利用者端末101に表示可能な処理済みデータ210が選択される(ステップS1025)。
先のステップS1023およびステップS1024はオリジナルデータ200に含まれるそれぞれのリソースに対する処理である。
先のステップS1023およびステップS1024はオリジナルデータ200に含まれるそれぞれのリソースに対する処理である。
これに対し、ステップS1025では、加工されたリソースを組み合わせることにより、一つの処理済みデータ210が生成される。この一つの処理済みデータ210が一つのウェブページに該当する。利用者端末101毎に、表示完了時間の異なる複数の処理済みデータ210が生成される。ウェブページのそれぞれは、利用者端末101のブラウザで再読込操作を行うことなくブラウザに表示される一つの単位になっている。
同様に、全てのオリジナルコンテンツ200に含まれる、それぞれのウェブページについて、それぞれ複数の処理済みデータ210が生成される。
同様に、全てのオリジナルコンテンツ200に含まれる、それぞれのウェブページについて、それぞれ複数の処理済みデータ210が生成される。
続いて、オリジナルデータ200と、複数の処理済みデータ210の中から、一種類の利用者端末101に表示可能なものについて、この利用者端末101に対する表示完了時間を基準に順位付けが実施される(ステップS1026)。
同様のステップにより、順位付けが、全ての処理済みデータ210について実施される。
なお、本発明の開示においては、「表示完了時間」とは、利用者端末101からリクエストが送信されてから、利用者端末101に搭載されているブラウザ等で、そのリクエストに対応するウェブページがユーザにより入力受付可能になるまでの時間をいう。
また「入力受付可能」とは、利用者端末101に搭載されているブラウザが、ユーザによるタップ、クリック、ドラッグ、ドロップ等の操作、テキスト入力等の操作に対して反応する状態になることをいう。
なお、本発明の開示においては、「表示完了時間」とは、利用者端末101からリクエストが送信されてから、利用者端末101に搭載されているブラウザ等で、そのリクエストに対応するウェブページがユーザにより入力受付可能になるまでの時間をいう。
また「入力受付可能」とは、利用者端末101に搭載されているブラウザが、ユーザによるタップ、クリック、ドラッグ、ドロップ等の操作、テキスト入力等の操作に対して反応する状態になることをいう。
表示完了時間は、後述する予備試験、また予備試験により得られたデータを用いた機械学習等の学習済みモデルを用いた解析により見積もることができる。この見積もりを用いて、表示完了時間を基準とする順位付けが実行できる。
上記のステップを経て、それぞれの利用者端末101に対応する処理済みデータ210が準備される。準備された処理済みデータ210は、データ取得・処理ユニットDからリクエスト処理ユニットCを介してアプリケーション処理ユニットA内部にある加工済みデータ記憶領域130に保存することもできる。
次に利用者端末101からネットワーク102を経て、リクエスト処理ユニットCに送信されたリクエストから、その利用者端末101に表示されるウェブコンテンツが選択される(S1027)。
実際にユーザの利用者端末101から、リクエスト処理ユニットCがリクエストを受信した直後に、リクエストが人工知能ユニットB、データ取得・処理ユニットDの順にリクエストが送信される。
データ取得・処理ユニットDの制御部1512でリクエストの内容が解析される。リクエストの内容に応じて、それぞれの利用者端末101に表示されるウェブコンテンツが選択される。
実際にユーザの利用者端末101から、リクエスト処理ユニットCがリクエストを受信した直後に、リクエストが人工知能ユニットB、データ取得・処理ユニットDの順にリクエストが送信される。
データ取得・処理ユニットDの制御部1512でリクエストの内容が解析される。リクエストの内容に応じて、それぞれの利用者端末101に表示されるウェブコンテンツが選択される。
本発明の開示においては、「リクエスト処理ユニットCがリクエストを受信した直後」とは、リクエスト処理ユニットCが利用者端末101からリクエストを受信してから0.2秒以内、すなわち、200m秒以内を意味する。この時間は、100m秒以内であれば好ましい。
またリクエスト処理ユニットCがリクエストを受信してから利用者端末101が入力受付可能になるまでの時間は200m秒以内であれば好ましく、100m秒以内であればさらに好ましい。
人間が視覚、聴覚等の五感により情報を受け取ってから、実際に行動に移るまでの時間は通常0.2秒程度である。200m秒以内にリクエスト処理ユニットC等が応答すれは、利用者端末101を利用するユーザは、ウェブコンテンツがリアルタイムに利用者端末101のブラウザ等に表示されていると感じることができる。
またリクエスト処理ユニットCがリクエストを受信してから利用者端末101が入力受付可能になるまでの時間は200m秒以内であれば好ましく、100m秒以内であればさらに好ましい。
人間が視覚、聴覚等の五感により情報を受け取ってから、実際に行動に移るまでの時間は通常0.2秒程度である。200m秒以内にリクエスト処理ユニットC等が応答すれは、利用者端末101を利用するユーザは、ウェブコンテンツがリアルタイムに利用者端末101のブラウザ等に表示されていると感じることができる。
実際には利用者端末101からリクエスト処理ユニットCを経てデータ取得・処理ユニットDに送信されたリクエストから、その利用者端末101に表示されるウェブコンテンツを構成する処理済みデータ210が選択される(S1027)。
オブジェクト置換済みプログラムとしての最適化されたHTMLファイル113zには、事前に識別情報とともにオブジェクトが準備されている。識別情報に基づいて処理済みデータ210をオブジェクトと対応させるだけで、最適化されたHTMLファイル113zの準備が完了する。
アプリケーション処理ユニットAおよびデータ取得・処理ユニットDの少なくとも一つのユニットに一括保存または分散保存された処理済みデータ210は、ネットワーク102を通じて利用者端末101に送信されて、利用者端末101側でダウンロードされる。
利用者端末101のブラウザ等で最適化されたHTMLファイル113zを実行すると、利用者端末101毎にダウンロードされたリソース等を実行することができる。
また利用者端末101にダウンロードされていなくても、利用者端末101のブラウザ等からネットワーク102を通じて参照することが可能なリソース等を利用者端末101のブラウザ等で実行することもできる。
これらのリソースは先に説明したオブジェクトにより最適化されたHTMLファイル113zで管理されているため、その取捨選択を高速で実施できる。
また利用者端末101にダウンロードされていなくても、利用者端末101のブラウザ等からネットワーク102を通じて参照することが可能なリソース等を利用者端末101のブラウザ等で実行することもできる。
これらのリソースは先に説明したオブジェクトにより最適化されたHTMLファイル113zで管理されているため、その取捨選択を高速で実施できる。
利用者端末101のブラウザ等で最適化されたHTMLファイル113zを実行して、それぞれの利用者端末101で、処理済みデータ210に基づくウェブコンテンツが表示される(S1028)。
上記の各ステップを経て、本発明の実施形態1に係るウェブコンテンツの自動高速表示制御方法を実施することができる。
[処理済みデータが生成されるステップ]
次にオリジナルデータ200から、処理済みデータ210が生成されるステップについて詳しく説明する。
次にオリジナルデータ200から、処理済みデータ210が生成されるステップについて詳しく説明する。
処理済みデータ210が生成されるステップは、例えば、リクエスト処理ユニットCが利用者端末101からリクエストを受信する前、リクエスト処理ユニットCが利用者端末101からリクエストを受信した直後およびアプリケーション実行サーバ103と利用者端末101との通信が終了した後の少なくとも一つのタイミング等で実施される。
プログラムデータに含まれるマークアップ言語には、利用者端末101に表示されてユーザが直接読み取ることができる、文字、数字、記号等を有する文書が含まれる。またこの文書には利用者端末101に表示するのに必要な、DOM(DOCUMENTS OBJECT MODEL)およびDOMのツリー構造を構成するNodeオブジェクト等も含まれる。
Nodeオブジェクトには、段落、見出し、箇条書き等を識別する記号であるマークアップが含まれる。
Nodeオブジェクトには、段落、見出し、箇条書き等を識別する記号であるマークアップが含まれる。
マークアップ言語に含まれるマークアップの中で、どのマークアップがプログラミング言語、スタイルシート、スクリプト言語等に指定されているかを追跡することにより、マークアップ言語に含まれる文書のどの部分が、例えば、HTMLファイル、CSSファイル、スクリプト言語ファイル等に記載されたコード部分により制御されているのかをデータ取得・処理ユニットDの制御部112により自動で検出することができる。
例えば、マークアップ言語から、文書以外のデータ、すなわち、マークアップ言語を含むHTMLファイル113に直接記載されているHTMLファイルの複数のコード部分、マークアップ言語の一つであるHTMLファイル113に直接記載されているスタイルシートの複数のコード部分、マークアップ言語の一つであるHTMLファイル113に直接記載されているスクリプト言語の複数のコード部分、マークアップ言語の一つであるHTMLファイル113に記載されている外部のスタイルシートへの参照部分、マークアップ言語の一つであるHTMLファイル113に記載されている外部のスクリプト言語への参照部分、マークアップ言語の一つであるHTMLファイル113に記載されている外部のバイナリデータへの参照部分等のそれぞれが、識別情報ともにオブジェクトとなる。そしてこれらを扱うオブジェクトが、最適化されたHTMLファイル113zの中で使用される。
これらのオブジェクトは、識別情報と共にアプリケーション実行サーバ103の処理済みデータ記憶領域130(図8参照)に保存される。
なお本発明の開示においては、定義したオブジェクトを扱うプロブラミング言語としてJavaScript(登録商標)が使用されている。オブジェクトを扱うプログラムについては、上記目的を達成できるものであれば、特に限定はない。
そして、参照部分が、プロブラムのオブジェクトに置換された、最適化されたHTMLファイル113zが生成される。この最適化されたHTMLファイル113zは、オリジナルデータ201が含むウェブコンテンツ211を構成する複数のウェブページのそれぞれに対応して複数生成される。
複数生成される最適化されたHTMLファイル113zは、静的に生成されてもよいし、動的に生成されてもよい。
複数生成される最適化されたHTMLファイル113zは、ブラウザを再読込せずに表示される一つのウェブページに対応して一または二以上存在する。
また利用者端末101の種類に応じて一または二以上存在する。
また利用者端末101の種類に応じて一または二以上存在する。
本発明の開示では、それぞれの最適化されたHTMLファイル113zの中で使用されるオブジェクトは、それぞれ識別情報が付与されてデータ取得・処理ユニットDの処理済みデータ記憶領域130に保存される。これらの識別情報により処理の対象となるコード部分等の参照部分等を特定できる。
またプログラムで定義されたオブジェクトとしてのデータに記載されている、外部のバイナリデータへの参照部分から、処理の対象となる、オリジナルデータ200に含まれる画像ファイル、音ファイル、動画ファイル等のバイナリデータを特定できる。
本発明の実施形態1では、オリジナルデータ200および複数の加工済みデータ201の少なくとも一つのリソースは、プログラムデータおよびバイナリデータの少なくとも一つを含む。
またプログラムデータは、マークアップ言語、プログラミング言語、スタイルシート、スクリプト言語などの一種もしくは二種以上で記載されたプログラム等を含む。
またプログラムデータは、マークアップ言語、プログラミング言語、スタイルシート、スクリプト言語などの一種もしくは二種以上で記載されたプログラム等を含む。
一方、バイナリデータは、画像ファイル、音ファイル、動画ファイルなどの一種もしくは二種以上のファイルを含む。
これらのプログラム等から、実行させるプログラムの部分および実行させないプログラムの部分が利用者端末101の表示環境ごとにそれぞれ特定される。
一方、利用者端末101の表示環境は、利用者端末101の表示装置1104に表示可能な環境であり、利用者端末101の種類、OSの種類、ブラウザの種類、表示装置1104の大きさ、単位面積当たりの表示画素数等により利用者端末101ごとに定まる。
図15は、データ取得・処理ユニットDの記憶装置1501の設定ファイル格納部1523に保存された機種情報ファイル1526を説明するための模式図である。
利用者端末101としては、スマートフォン、フィーチャーフォン等の携帯情報端末、PDA、タブレット等の情報表示端末、スマートウォッチ、スマートメガネ等のウェアラブル通信端末、PC等のコンピュータ等ごとに種類の違いがある。
また例えば、同じスマートフォンでも、搭載されるOSの違い、搭載されるブラウザの違い、表示画面の大きさ、表示画面の素子数等の表示環境の違い等もある。
これらの表示環境の違いはそれぞれの利用者端末101についての公開された入手可能な機種情報により特定される。
これらの表示環境の違いはそれぞれの利用者端末101についての公開された入手可能な機種情報により特定される。
利用者端末101の表示環境については、利用者端末101毎に製造メーカー等がその仕様を公開している。この公開情報に基づいて、利用者端末101についての表示環境が整理される。この表示環境は利用者端末101毎に複数存在する。
図15に示す通り、利用者端末101を特定する識別情報、利用者端末101が、携帯情報端末であるか、情報表示端末であるか、またはコンピュータであるか等を示す機種情報、利用者端末101に搭載されているOSの種類についてのOS情報、利用者端末101に搭載されているブラウザ情報、利用者端末101の表示画面の画素数、表示画面のサイズ等を示す表示環境情報等に対応する情報がデータ取得・処理ユニットDの機種情報ファイル1526に格納されている。
なお、図15では説明の便宜上、表形式でデータが模式的に表現されているが、実際には、JSON,CSV,TSV等の各種ファイル形式等、データベース形式等でデータが保存されている。
通常、利用者端末101は大量生産され市場に供給される。このため、利用者端末101の表示環境は概ね規格化されている。データ取得・処理ユニットDの設定ファイル格納部523にある機種情報ファイル526に格納されている表示環境の情報は無限にあるわけではなく、有限時間内に機種情報ファイル526に対して整理できる。
機種情報ファイル526は、個々の全ての利用者端末101についての情報を含んでもよいし、一定のカテゴリーに属する利用者端末101についての情報をグループ化して、そのグループ情報を含んでもよい。グループ情報は任意の一つの利用者端末101を選択した際に、グループ情報から機種情報ファイル526に基づいて、その利用者端末101の表示環境を特定できるものであれば、その表現形式に特に限定はない。
データ取得・処理ユニットDの制御部1512は、機種情報ファイル1526に記載された全ての利用者端末101の表示環境に基づいて、先に説明したプログラムおよびファイル等から、実行させるプログラムの部分および実行させないプログラムの部分を利用者端末101の表示環境ごとにそれぞれ特定する。
実行させるプログラムの部分の具体例としては、例えば、利用者端末101の表示装置1104に表示される部分に寄与するプログラムの部分等が挙げられる。
実行させないプログラムの部分の具体例としては、例えば、利用者端末101の表示装置1104に表示されない部分に寄与するプログラムの部分等が挙げられる。
実行させないプログラムの部分の具体例としては、例えば、利用者端末101の表示装置1104に表示されない部分に寄与するプログラムの部分等が挙げられる。
例えば、スマートフォンのみで使用されるプログラムの部分は、スマートフォン以外の利用者端末101では使用されないから、スマートフォン以外の利用者端末101では、スマートフォンのみで使用されるプログラムの部分は実行されないプログラムの部分に該当する。
実行させるプログラムの部分および実行させないプログラムの部分は、利用者端末101毎に通常異なる。
利用者端末101毎に実行させるプログラムの部分および実行させないプログラムの部分を特定するためには、例えば、機種情報ファイル1526に記載された全ての利用者端末101の情報に基づいて、利用者端末101毎に、事前に実際に予備試験を行って決定する。また本願発明の実施、予備試験等により得られたデータを学習して得られた学習済みモデルに従って決定する等の手法が採用される。
予備試験や実際の本願発明の実施により得られたデータを用いて、人工知能ユニットDによる機械学習等によってモデルを形成することができる。形成された学習済みモデルから得られる、リスク許容度内の予測は、予備試験の結果と同等に扱うことができる。
利用者端末101毎に実行させるプログラムの部分および実行させないプログラムの部分を特定するためには、例えば、機種情報ファイル1526に記載された全ての利用者端末101の情報に基づいて、利用者端末101毎に、事前に実際に予備試験を行って決定する。また本願発明の実施、予備試験等により得られたデータを学習して得られた学習済みモデルに従って決定する等の手法が採用される。
予備試験や実際の本願発明の実施により得られたデータを用いて、人工知能ユニットDによる機械学習等によってモデルを形成することができる。形成された学習済みモデルから得られる、リスク許容度内の予測は、予備試験の結果と同等に扱うことができる。
この予備試験およびモデル形成の少なくとも一方のステップを繰り返せば、概ね、オリジナルデータ200のどの部分が利用者端末101毎の実行に必要なプログラムの部分に該当するかの傾向が分かる。
オリジナルデータ200のどの部分が利用者端末101の実行に必要なプログラムに該当するかどうかの許容度の判断については、全ての利用者端末101または任意に抽出された利用者端末101について、事前に実際に予備試験等を行って検証することもできる。
オリジナルデータ200のどの部分が利用者端末101の実行に必要なプログラムに該当するかどうかの許容度の判断については、全ての利用者端末101または任意に抽出された利用者端末101について、事前に実際に予備試験等を行って検証することもできる。
なお、本発明の開示において「事前に」との意味は、利用者端末101からユーザが実際にリクエスト処理ユニットCに対してリクエストを送信する前に、という意味である。
本発明の開示では、例えば、データ取得・処理ユニットDの制御部1512に、ヘッドレスブラウザ等のエミュレータと呼ばれる利用者端末101に搭載されたブラウザ環境と同様の環境が搭載されている。例えば、このエミュレータ等を用いて、予備試験および機械学習等によるモデル形成を行うことができる。
本来なら実行させるプログラムの部分に該当するのに、間違って実行させないプログラムの部分と判断されて削除された場合には、利用者端末101の表示に不具合が生じる。
不具合が生じるかどうかについては、例えば、データ取得・処理ユニットDに搭載された利用者端末101に対応するヘッドレスブラウザ等のエミュレータを用いた予備試験等により、エラー信号が生じるかどうかを手がかりに、事前に調べることができる。このエラー信号がデータ取得・処理ユニット103の制御部112で検出されると、実行させないプログラムの部分を選択する際に、どの段階で不具合が生じたのかを特定することができる。
不具合が生じるかどうかについては、例えば、データ取得・処理ユニットDに搭載された利用者端末101に対応するヘッドレスブラウザ等のエミュレータを用いた予備試験等により、エラー信号が生じるかどうかを手がかりに、事前に調べることができる。このエラー信号がデータ取得・処理ユニット103の制御部112で検出されると、実行させないプログラムの部分を選択する際に、どの段階で不具合が生じたのかを特定することができる。
予備試験等により、ある程度オリジナルデータ200のどの部分に実行させないプログラムの部分があるのかは判明する。しかしこれまでプログラムを実行したことがない場合等、予備情報が存在しない状況では、予備試験ではオリジナルデータ200のどの部分が実行させないプログラムに該当するのかは詳細にはわからない。
そこで、例えば、一つの利用者端末101に搭載されたブラウザがエラーを発生させていない状態から、一つずつ実行させないプログラムの部分をプログラムの中から外す操作を繰り返す。そして利用者端末101に搭載されたブラウザがエラー信号を発したことを最初に検出した時点で、最後に外した実行させないプログラムの部分が、本来なら実行させるプログラムの部分に該当することが分かる。
上記の予備試験等で得られたデータを利用して、機械学習等によるモデル形成を行い、学習済みモデルを用いてブラウザのエラー発生状況を検証することによっても、エラーを生じさせる部分を特定するとが可能である。
また例えば、一つずつ、もしくは関連する複数の組み合わせ毎に、実行させないプログラムの部分をプログラムの中から外しては、エミュレータ中で再現された利用者端末101の表示内容をキャプチャ画面として逐次画像ファイルに保存する操作を繰り返す。
オリジナルデータ200に基づくキャプチャ画面と、その後のキャプチャ画面とを比較し、両者が一致しなくなった時点で最後に外した実行させないプログラムの部分が、本来なら実行させるプログラムの部分に該当すことが分かる。
この操作を機械学習等を通じてモデルを形成することにより、問題を生じさせるプログラムの部分を検出することができる。
オリジナルデータ200に基づくキャプチャ画面と、その後のキャプチャ画面とを比較し、両者が一致しなくなった時点で最後に外した実行させないプログラムの部分が、本来なら実行させるプログラムの部分に該当すことが分かる。
この操作を機械学習等を通じてモデルを形成することにより、問題を生じさせるプログラムの部分を検出することができる。
上記の操作により、一つの利用者端末101について、実際にオリジナルデータ200のどの部分が利用者端末101の実行に必要なプログラムの部分に該当するかが分かる。
この操作を実現させるプログラムがデータ取得・処理ユニット103の制御部1512に保存されている。このデータ取得・処理ユニット103の制御部1512に保存されているプログラムを実行することにより、上記の操作が自動で実施される。
この操作を実現させるプログラムがデータ取得・処理ユニット103の制御部1512に保存されている。このデータ取得・処理ユニット103の制御部1512に保存されているプログラムを実行することにより、上記の操作が自動で実施される。
上記の操作を繰り返して、機種情報ファイル1526に記載された利用者端末101の情報に基づいて、事前に実際に予備試験を行う。またこの予備試験を通じて学習済みモデルによるモデル形成を行う。この予備試験およびモデル形成等の結果から、全ての利用者端末101について、利用者端末101毎に実行させるプログラムの部分および実行させないプログラムの部分の情報が特定される。特定された情報は、機種情報ファイル1526に関連付けられて、識別情報と共にデータ取得・処理ユニットDの設定ファイル格納部1523に保存される。
次に、利用者端末101毎に複数の特定された実行させるプログラムの部分のうち、優先して実行させるプログラムの部分と遅延して実行させるプログラムの部分の実行順序を決定するステップについて説明する。
一つの例として、ここではファーストビューと呼ばれる利用者端末101の画面に最初に表示されるウェブコンテンツ211の部分の表示が優先される場合を取り上げて説明する。
一つの例として、ここではファーストビューと呼ばれる利用者端末101の画面に最初に表示されるウェブコンテンツ211の部分の表示が優先される場合を取り上げて説明する。
ユーザがウェブコンテンツ211に含まれるウェブページを閲覧するときにもっとも重要なのは、ファーストビューに含まれるコンテンツである。
ファーストビューを構成するリソースはできるだけ早く配信して、それ以外のファーストビューを構成しないリソースは遅く配信、場合によっては削除する。
ファーストビューの表示に関連しないデータがアプリケーション処理ユニットAおよびデータ取得・処理ユニットDからなる群より選ばれる少なくとも一つから選択されて利用者端末101に先に送信されると、利用者端末101のファーストビューの表示に関連しないデータ処理に時間を要するため、利用者端末101のファーストビューの表示が遅延する。
この遅延を防止するために、例えば、HTMLファイル113、CSSファイル107、スクリプト言語ファイル108等に含まれるプログラムのうち、ファーストビューの表示に関係がないプログラム部分の実行を後回しにし、ファーストビューに関係するプログラムの実行を優先させる。またそれぞれのプログラムの実行タイミングも調整される。
このようにプログラムの実行順序および実行タイミングを変更することにより、ファーストビューの表示を速く完結することができ、ウェブサイトからのユーザの離脱を軽減することができる。
なお、ファーストビューの表示がどのように実現されるかについては、本発明に係る実施形態5で、さらに詳細に説明する。
なお、ファーストビューの表示がどのように実現されるかについては、本発明に係る実施形態5で、さらに詳細に説明する。
次に、処理済みデータ210が生成されるステップについて、具体的に説明する。
処理済みデータ210が生成されるステップは、オリジナルデータに含まれるリソース、すなわち、マークアップ言語、プログラミング言語、スタイルシート、スクリプト言語等の一種もしくは二種以上を有するプログラムデータと、オリジナルデータに含まれる画像ファイル、音ファイル、動画ファイルなどの一種もしくは二種以上のバイナリデータのそれぞれについて実施される。
処理済みデータ210が生成されるステップは、オリジナルデータに含まれるリソース、すなわち、マークアップ言語、プログラミング言語、スタイルシート、スクリプト言語等の一種もしくは二種以上を有するプログラムデータと、オリジナルデータに含まれる画像ファイル、音ファイル、動画ファイルなどの一種もしくは二種以上のバイナリデータのそれぞれについて実施される。
オリジナルデータに含まれる、マークアップ言語、プログラミング言語、スタイルシート、スクリプト言語等の一種もしくは二種以上により記載されたプログラムデータに含まれるプログラムの部分は、先に説明したとおり、最適化されたHTMLファイル113zの中で、識別情報と共にプログラムのそれぞれのオブジェクトを構成する。
同様に、プログラムの部分が参照するオリジナルデータに含まれる、画像ファイル、音ファイル、動画ファイルなどの一種もしくは二種以上のファイルに関する参照部分も、最適化されたHTMLファイル113zの中で、識別情報と併せてプログラムのオブジェクトを構成する。
図16は、処理前のHTMLファイルと最適化されたHTMLファイルとの対応関係を説明するための概念図である。
先の図13では、処理前のHTMLファイル113に記載されたプログラムデータ、バイナリデータ等の参照部分が、プログラムの関数に使用されるオブジェクトに置換されることを説明した。
図16では、処理前のHTMLファイル113に記載されたプログラムデータ、バイナリデータ等の参照部分が具体的にどのように最適化されたHTMLファイル113zに対応して反映されるかについて説明する。
先の図13では、処理前のHTMLファイル113に記載されたプログラムデータ、バイナリデータ等の参照部分が、プログラムの関数に使用されるオブジェクトに置換されることを説明した。
図16では、処理前のHTMLファイル113に記載されたプログラムデータ、バイナリデータ等の参照部分が具体的にどのように最適化されたHTMLファイル113zに対応して反映されるかについて説明する。
本発明の開示では、オリジナルデータ200に含まれるそれぞれのリソースを加工することにより、利用者端末101の表示環境ごとに複数の加工済みリソースからなる複数の加工済みデータ201が生成される。
つまり、一つの利用者端末101について、複数の加工済みデータ201が生成される。この加工済みデータ201の生成は、識別情報を指定して、プログラムにより定義されたオブジェクトから、それぞれのプログラムの部分を呼び出し、呼び出されたプログラムの部分に対して、追加、移動、削除、変更等の改変を行うことにより実施される。
図16に示されるように、オリジナルデータ200に含まれるHTMLファイル113は、例えば、HTMLコード部分113a,113b,113c、CSSコード部分10
7a,107b,107c、スクリプト言語コード部分108a,108b,108c等を含む。
7a,107b,107c、スクリプト言語コード部分108a,108b,108c等を含む。
CSSコード部分107a,107b,107cのそれぞれは、オブジェクトとして、識別情報と共に、それぞれ、オブジェクトF107a,F107b,F107c等に定義される。
同様に、スクリプト言語コード部分108a,108b,108cのそれぞれは、オブジェクトとして、識別情報と共に、それぞれ、オブジェクトF108a,F108b,F108c等に定義される。
処理済みデータ210が生成されるステップは、プログラムデータから不要部分が削除されるステップ、必要部分が圧縮されるステップ、実行順序が変更されるステップ、実行タイミングが変更されるステップ、重複実行時間が短縮されるステップ等の一種もしくは二種以上、
バイナリデータから、単位面積当たりの表示画素数、単位時間当たりの録画録音密度、容量の大きさ、保存形式等の一種もしくは二種以上が変換されるステップ等の一種もしくは二種以上を含む。
バイナリデータから、単位面積当たりの表示画素数、単位時間当たりの録画録音密度、容量の大きさ、保存形式等の一種もしくは二種以上が変換されるステップ等の一種もしくは二種以上を含む。
[利用者端末の表示環境ごとに不要部分が削除されるステップ]
図17は、利用者端末の表示環境ごとに不要部分が削除されるステップを説明するためのフローチャートである。
なお、一定回数処理を行っても対応する処理が実行できない場合には、そのステップを終了して次のステップの処理が実行される。以下のステップについても同様である。
図17は、利用者端末の表示環境ごとに不要部分が削除されるステップを説明するためのフローチャートである。
なお、一定回数処理を行っても対応する処理が実行できない場合には、そのステップを終了して次のステップの処理が実行される。以下のステップについても同様である。
機種情報ファイル526の識別情報に基づいて特定された利用者端末101毎に、例えば、利用者端末101が利用するHTMLファイル113ならびに、HTMLファイル113の実行時に参照されるCSSファイル107、スクリプト言語ファイル108等が特定される。これらの特定は、図15に示すオブジェクトについての識別情報を指定することにより実施される。
そしてHTMLファイル113のうち、例えば、利用者端末101が使用しないHTMLファイル113の部分113x、CSSファイル107のうち、利用者端末101が使用しないCSSファイル107の部分107xおよびスクリプト言語ファイル108のうち、利用者端末101が使用しないスクリプト言語ファイル108の部分108xがそれぞれ特定される。
これらのファイルのうち、利用者端末101に使用されない部分113x、107xおよび108xが削除される。
例えば、実際の削除は、オブジェクトとして何も指定しないことにより簡単に実施できる。
例えば、実際の削除は、オブジェクトとして何も指定しないことにより簡単に実施できる。
具体的には、例えば、機種情報ファイル526の識別情報に基づいて特定された利用者端末101がPCの場合には、HTMLファイル113、CSSファイル107、スクリプト言語ファイル108等のいずれかに含まれる、PCではない携帯情報端末、情報表示端末等に対応する部分の情報は削除される。
逆に、例えば、機種情報ファイル526の識別情報に基づいて特定された利用者端末101がスマートフォンの場合には、HTMLファイル113、CSSファイル107およびスクリプト言語ファイル108のいずれかに含まれる情報のうち、スマートフォンに使用されない部分の情報は削除される。
HTMLファイル113は、例えば、段落、見出し、箇条書き等を識別する記号であるマークアップを含む。
HTMLファイル113に含まれるマークアップの中で、どのマークアップが指定されているかを追跡することにより、CSSファイル107、スクリプト言語ファイル108等が指定するマークアップを手がかりに、それぞれHTMLファイル113のどの部分がCSSファイル107、スクリプト言語ファイル108等により制御されているのかが分かる。
HTMLファイル113に含まれるマークアップの中で、どのマークアップが指定されているかを追跡することにより、CSSファイル107、スクリプト言語ファイル108等が指定するマークアップを手がかりに、それぞれHTMLファイル113のどの部分がCSSファイル107、スクリプト言語ファイル108等により制御されているのかが分かる。
HTMLファイル113のどの部分がCSSファイル107、スクリプト言語ファイル108等により制御されているかの情報を手がかりに、データ取得・処理ユニットDのコントロルユニットD300により、機種情報ファイル526に記載された全ての利用者端末101の表示環境に基づいて、データ取得・処理ユニットDのコントロールユニットD300により、処理済みデータの不要部分の削除が実現される。
次にユーザは、HTMLファイル113、CSSファイル107およびスクリプト言語ファイル108のそれぞれを直接閲覧しない。
ユーザは、HTMLファイル113等により生成されたウェブコンテンツ211を利用者端末101のブラウザを通して閲覧する。
ユーザは、HTMLファイル113等により生成されたウェブコンテンツ211を利用者端末101のブラウザを通して閲覧する。
一方、HTMLファイル113、CSSファイル107、スクリプト言語ファイル108等のそれぞれは、例えば、これらのファイルに記載された内容をCLIなどに表示した時に人間が内容を理解できるように工夫された表示情報が含まれている。これらの表示情報は、アプリケーション実行サーバ103等の管理者にとっては必要な情報であるが、ウェブコンテンツ211には反映されないため、利用者端末101を使うユーザにとっては不要な情報である。
例えば、HTMLファイル113、CSSファイル107、スクリプト言語ファイル108等に含まれる表示情報のうち、削除しても、ウェブコンテンツ211の表示に影響を与えないものが存在する。これらの表示情報が削除される。
削除される表示情報としては、例えば、ウェブコンテンツ211の表示に影響を与えないスペース、タブ、改行や段落の区切りを示す改行情報、各ファイルに記載された保守管理上の注意書き等のテキスト情報等が挙げられる。
削除される表示情報としては、例えば、ウェブコンテンツ211の表示に影響を与えないスペース、タブ、改行や段落の区切りを示す改行情報、各ファイルに記載された保守管理上の注意書き等のテキスト情報等が挙げられる。
HTMLファイル113、CSSファイル107、スクリプト言語ファイル108等に含まれる表示情報を解析することにより、データ取得・処理ユニットDのコントロールユニットD300により、機種情報ファイル526に記載された全ての利用者端末101の表示環境に基づいて、処理済みデータの不要部分の削除が実現される。
なお、実際には最適化されたHTMLファイル113zの中では、識別情報と併せてプログラムのオブジェクトが指定されている。削除される該当部分のオブジェクトを何もない(null)を指定することにより、利用者端末101のブラウザで最適化されたHTMLファイル113zを実行すれば、削除が実現される。
なお、実際には最適化されたHTMLファイル113zの中では、識別情報と併せてプログラムのオブジェクトが指定されている。削除される該当部分のオブジェクトを何もない(null)を指定することにより、利用者端末101のブラウザで最適化されたHTMLファイル113zを実行すれば、削除が実現される。
[利用者端末の表示環境ごとに必要部分が圧縮されるステップ]
図18は、利用者端末の表示環境ごとに必要部分が圧縮されるステップを説明するためのフローチャートである。
一般に、一つの同じ情報を表現する方法は複数存在する。例えば、数字の百万を意味する「1,000,000」との表記は、「10E6」と表記できる。これは10の6乗との意味である。前者は桁の区切りを示すコンマも含めて9文字が必要なのに対し、後者はアルファベット文字も含めて4文字で表現可能である。
一つの同じ情報を、アプリケーション実行サーバ103に搭載されるアプリケーション処理ユニットA等の各ユニット、利用者端末101等がより速く処理できる別の表現形式に変換する操作を本発明の開示では圧縮という。
一般に、一つの同じ情報を表現する方法は複数存在する。例えば、数字の百万を意味する「1,000,000」との表記は、「10E6」と表記できる。これは10の6乗との意味である。前者は桁の区切りを示すコンマも含めて9文字が必要なのに対し、後者はアルファベット文字も含めて4文字で表現可能である。
一つの同じ情報を、アプリケーション実行サーバ103に搭載されるアプリケーション処理ユニットA等の各ユニット、利用者端末101等がより速く処理できる別の表現形式に変換する操作を本発明の開示では圧縮という。
このような圧縮操作は、例えば、LHA、ZIP、GZIP、BROTLI等の既存の可逆圧縮技術等の一種もしくは二種以上を利用して実施することができる。
HTMLファイル113、CSSファイル107、スクリプト言語ファイル108等のプログラムデータならびにこれらの処理済みデータの一種もしくは二種以上について、データ取得・処理ユニットDの制御部112により、必要部分の圧縮が実現される。
なお、必要部分が圧縮されるステップにおいては、圧縮形式は、一種もしくは二種以上を使用することができる。また必要部分が圧縮されるステップでは、全てを圧縮してもよいし、一部を圧縮してもよい。画像ファイル109等のバイナリデータの圧縮についても同様である。
HTMLファイル113、CSSファイル107、スクリプト言語ファイル108等のプログラムデータならびにこれらの処理済みデータの一種もしくは二種以上について、データ取得・処理ユニットDの制御部112により、必要部分の圧縮が実現される。
なお、必要部分が圧縮されるステップにおいては、圧縮形式は、一種もしくは二種以上を使用することができる。また必要部分が圧縮されるステップでは、全てを圧縮してもよいし、一部を圧縮してもよい。画像ファイル109等のバイナリデータの圧縮についても同様である。
[実行順序が変更されるステップ]
ウェブコンテンツ211のうち、例えば、ファーストビューと呼ばれる利用者端末101の画面に最初に表示されるウェブコンテンツ211の部分に関連するプログラムの部分の実行を先に行う。続いて、ウェブコンテンツ211のうち、ファーストビューと呼ばれる利用者端末101の画面に最初に表示されるウェブコンテンツ211の部分以外に関連するプログラムの部分の実行を後に行う。
ウェブコンテンツ211のうち、例えば、ファーストビューと呼ばれる利用者端末101の画面に最初に表示されるウェブコンテンツ211の部分に関連するプログラムの部分の実行を先に行う。続いて、ウェブコンテンツ211のうち、ファーストビューと呼ばれる利用者端末101の画面に最初に表示されるウェブコンテンツ211の部分以外に関連するプログラムの部分の実行を後に行う。
実行順序については、先に説明した通り、ファーストビューと呼ばれる利用者端末101の画面に最初に表示されるウェブコンテンツ211の部分の表示が優先される。
オリジナルデータに含まれる、マークアップ言語、プログラミング言語、スタイルシート、スクリプト言語等の一種もしくは二種以上のプログラムデータが有するプログラムの部分は、通常、記載された順番に利用者端末101側でそれぞれ実施される。
オリジナルデータに含まれる、マークアップ言語、プログラミング言語、スタイルシート、スクリプト言語等の一種もしくは二種以上のプログラムデータが有するプログラムの部分は、通常、記載された順番に利用者端末101側でそれぞれ実施される。
しかし、先に実行されるはずのプログラムの部分に、後から実行されるプログラムの部分の参照があった場合には、後から実行されるプログラムの部分が利用者端末101で実行が完了するまでは、先に実行されるはずのプログラムの部分が待機することになる。
この待機の時間は、一つひとつのプログラムの部分については十分無視できるほどに通常は短いため、見過ごされやすい。
ところがオリジナルデータ200の規模が大きくなるに従って、待機時間の影響は大きくなる傾向がある。待機時間の影響を放置するとユーザがウェブサイトから離脱を起こす一つの要因となりうる。このため実行順序が変更されて、無駄な待機時間が発生しないように処理される。
ところがオリジナルデータ200の規模が大きくなるに従って、待機時間の影響は大きくなる傾向がある。待機時間の影響を放置するとユーザがウェブサイトから離脱を起こす一つの要因となりうる。このため実行順序が変更されて、無駄な待機時間が発生しないように処理される。
具体的には、プログラムの部分が、先に実行されるプログラムの部分の前に、後から実行されるプログラムの部分を参照している場合には、後から実行されるプログラムの部分を繰り上げて先に実行させる場合等が挙げられる。
またプログラムの部分が、実行できない要素を参照している場合、例えば、過去には存在したが現在は存在していないコード部分等を参照している場合、現在は存在していない変数を参照している場合等が挙げられる。この場合には、問題のあるコード部分を実行せず、例えば、順番を飛ばして後のコード部分を先行して実施させる。
ファーストビューに関連するプログラムの部分以外のプログラムについても実行順序が変更されて、遅延実行される。
遅延実行されるプログラムについては、これらのプログラムのうち、同期して実行するのか、非同期に実行するのか、優先して実行するのか等が、データ取得・処理ユニットDに搭載されたコントロールユニットd300に記載されているプログラムにより制御される。
遅延実行されるプログラムについては、これらのプログラムのうち、同期して実行するのか、非同期に実行するのか、優先して実行するのか等が、データ取得・処理ユニットDに搭載されたコントロールユニットd300に記載されているプログラムにより制御される。
[実行タイミングが変更されるステップ]
実行タイミングについては、例えば、ファーストビューと呼ばれる利用者端末101の画面に最初に表示されるウェブコンテンツ211の部分の表示に関連するプログラムの部分の実行が完了した後に、ファーストビュー以外のウェブコンテンツ211の部分の表示に関連するプログラムの実行が開始される。
実行タイミングについては、例えば、ファーストビューと呼ばれる利用者端末101の画面に最初に表示されるウェブコンテンツ211の部分の表示に関連するプログラムの部分の実行が完了した後に、ファーストビュー以外のウェブコンテンツ211の部分の表示に関連するプログラムの実行が開始される。
DOMの形成、DOMのツリー構造に関連付けられたコンテンツの利用者端末101へのダウンロード、画像ファイル、音ファイル、動画ファイル等の主要なリソースのダウンロード等の実行タイミングが調整される。
互いに影響を及ぼし合うプログラムの部分については、一つのプログラムの部分の実行が終了してから、次のプログラムの部分の実行が開始されるように、同期してプログラムの部分の実行タイミングが調整される。
また互いに影響を及ぼさないプログラムの部分については、それぞれ非同期にプログラムの部分の実行タイミングが調整される。
また互いに影響を及ぼさないプログラムの部分については、それぞれ非同期にプログラムの部分の実行タイミングが調整される。
[重複実行時間が短縮されるステップ]
一方、例えば、HTMLファイル113、CSSファイル107、スクリプト言語ファイル108等のそれぞれのプログラムデータについて、これらのファイルに記載されたプログラムの実行時間の調整も実施される。
図19は、HTMLファイル113で参照されるスクリプト言語ファイル部分108a108dが直列的に実行されるステップを説明するための図である。
HTMLファイル113に複数のスクリプト言語ファイル部分108a~108dの参照情報が記載されている。
一方、例えば、HTMLファイル113、CSSファイル107、スクリプト言語ファイル108等のそれぞれのプログラムデータについて、これらのファイルに記載されたプログラムの実行時間の調整も実施される。
図19は、HTMLファイル113で参照されるスクリプト言語ファイル部分108a108dが直列的に実行されるステップを説明するための図である。
HTMLファイル113に複数のスクリプト言語ファイル部分108a~108dの参照情報が記載されている。
例えば、HTMLファイル113が利用者端末101で実行されると、スクリプト言語ファイル部分108a~108dのそれぞれは、通常はこの順番に、直列的に実行される。
ここで例えば、スクリプト言語ファイル108dの表示完了時間の相対値が仮に100であり、スクリプト言語ファイル部分108a~108cの表示完了時間の相対値がそれぞれ仮に5、10および15であったとする。
ここでスクリプト言語ファイル部分108a~108dがこの順番に実行されたとすると、利用者端末101の表示が完了するまでに、表示完了時間の相対値を基準に5+10+15+100=130に相当する表示完了時間の処理が必要になる。
ここで例えば、スクリプト言語ファイル108dの表示完了時間の相対値が仮に100であり、スクリプト言語ファイル部分108a~108cの表示完了時間の相対値がそれぞれ仮に5、10および15であったとする。
ここでスクリプト言語ファイル部分108a~108dがこの順番に実行されたとすると、利用者端末101の表示が完了するまでに、表示完了時間の相対値を基準に5+10+15+100=130に相当する表示完了時間の処理が必要になる。
図20は、HTMLファイル113に記載されたスクリプト言語ファイル部分108a~108cとスクリプト言語ファイル108dとが並列的に実行されるステップを説明するための図である。
この場合には、スクリプト言語ファイル108の実行順序を整理して、ウェブコンテンツ211の生成時間の短縮が可能である。
この場合には、スクリプト言語ファイル108の実行順序を整理して、ウェブコンテンツ211の生成時間の短縮が可能である。
図20の場合であれば、例えば、スクリプト言語ファイル108dが実行されると同時に、スクリプト言語ファイル部分108a~108cが並行して処理されるようにHTMLファイル113を処理する。
この処理により、スクリプト言語ファイル108dの表示完了時間の相対値100に対応する処理が実行されている間に、表示完了時間の相対値を基準に5+10+15=30に相当する表示完了時間の処理を完結できる。
そうするとスクリプト言語ファイル部分108a~108dの表示完了時間を、相対値を基準に130から100に削減することができる。
この処理により、スクリプト言語ファイル108dの表示完了時間の相対値100に対応する処理が実行されている間に、表示完了時間の相対値を基準に5+10+15=30に相当する表示完了時間の処理を完結できる。
そうするとスクリプト言語ファイル部分108a~108dの表示完了時間を、相対値を基準に130から100に削減することができる。
図21は、HTMLファイル113に記載されたスクリプト言語ファイル108dの実行が後回しにされるステップを説明するための図である。
先にスクリプト言語ファイル部分108a~108cのみを参照する情報をHTMLファイル113に記載しておき、HTMLファイル113の最後にスクリプト言語ファイル108dを参照するように処理することもできる。
先にスクリプト言語ファイル部分108a~108cのみを参照する情報をHTMLファイル113に記載しておき、HTMLファイル113の最後にスクリプト言語ファイル108dを参照するように処理することもできる。
このように処理すれば、相対的に実行時間の長いスクリプト言語ファイル108dの処理を待つことなく他のスクリプト言語ファイル108a~108cの実行を開始することができる。
どのファイルをどの順番に処理すれば最適になるかは、実際に順番を変化させて、それぞれの利用者端末101毎に、ウェブコンテンツ211の表示完了時間を計測して比較することにより決定することができる。
最適化されたHTMLファイル113z、処理済みCSSファイル132および処理済みスクリプト言語ファイル133が生成されるステップは、機種情報ファイル526に記載された全ての利用者端末101について実施される。
HTMLファイル113が複数のスクリプト言語ファイル部分108a~108c等をどの順番でどのように処理するのか追跡することにより、データ取得・処理ユニットDのコントロールユニットd300により、機種情報ファイル1526に記載された内容に該当する全ての利用者端末101の表示環境に基づいて、処理済みデータ210の新たな生成が実現される。
上記のステップを経て、オリジナルデータ200に含まれる、マークアップ言語、スタイルシートおよびスクリプト言語からなる群より選ばれる少なくとも一つ有するデータを処理することができる。
[バイナリデータから、単位面積当たりの表示画素数、単位時間当たりの録画録音密度、容量の大きさ、保存形式からなる群より選ばれる一つを変換して容量が削減されるステップ]
次に例えば、HTMLファイル113、CSSファイル107およびスクリプト言語ファイル108が参照する全ての画像ファイル109等について、機種情報ファイル526の識別情報に基づいて特定された利用者端末101毎に表示サイズ、容量および種類の異なる処理済み画像ファイル134がそれぞれ生成される。
画像ファイル109の表示サイズの変更は、例えば、縦と横の長さの比を変更せずに、縦と横の長さが異なる処理済み画像ファイル134が複数生成されることにより実施される。
画像ファイル109の容量の変更は、例えば、画像ファイル109の単位面積当たりの画素数の変更、単位時間当たりの録画録音密度の変更等により実施される。
次に例えば、HTMLファイル113、CSSファイル107およびスクリプト言語ファイル108が参照する全ての画像ファイル109等について、機種情報ファイル526の識別情報に基づいて特定された利用者端末101毎に表示サイズ、容量および種類の異なる処理済み画像ファイル134がそれぞれ生成される。
画像ファイル109の表示サイズの変更は、例えば、縦と横の長さの比を変更せずに、縦と横の長さが異なる処理済み画像ファイル134が複数生成されることにより実施される。
画像ファイル109の容量の変更は、例えば、画像ファイル109の単位面積当たりの画素数の変更、単位時間当たりの録画録音密度の変更等により実施される。
画像ファイル109の種類の変更は、例えば、画像ファイル109の種類がPNGであった場合には、JPEG、WEBP、JPEG2000等への種類の変更により実施される。
処理済み画像ファイル134が生成されるステップは、機種情報ファイル526に記載された全ての利用者端末101について実施される。
処理済み画像ファイル134が生成されるステップは、機種情報ファイル526に記載された全ての利用者端末101について実施される。
上記のステップを経て、新たな複数の変換済みバイナリデータを含む処理済みデータ210が生成される。
バイナリデータが動画ファイル、音ファイル等の場合も、同様の手順を経て、新たな複数の変換済みバイナリデータを含む処理済みデータ210を生成することができる。
バイナリデータが動画ファイル、音ファイル等の場合も、同様の手順を経て、新たな複数の変換済みバイナリデータを含む処理済みデータ210を生成することができる。
図22は、処理済みデータが生成されるステップを説明するためのフローチャートである。
例えば、オリジナルデータの表示完了時間の測定に加えて、最適化されたHTMLファイル113z、処理済みCSSファイル132および処理済みスクリプト言語ファイル133等のそれぞれについて、表示完了時間が測定される。
利用者端末101毎、ウェブページ毎等に複数ある最適化されたHTMLファイル113zは、参照するプログラムのオブジェクトを変化させた場合に、処理前のHTMLファイル113と比較して、どの程度の表示完了時間がかかるのかが測定される。
処理済みCSSファイル132は、処理前のCSSファイル107と比較して、要素として、どの程度の表示完了時間がかかるのかが測定される。
複数ある処理済みスクリプト言語ファイル133は、処理前のスクリプト言語ファイル108と比較して、要素として、どの程度の表示完了時間がかかるのかが測定される。
バイナリデータについても、複数ある過去済み画像ファイル等と、過去前の画像ファイル等と比較して、要素として、どの程度の表示完了時間がかかるのかが測定される。
例えば、オリジナルデータの表示完了時間の測定に加えて、最適化されたHTMLファイル113z、処理済みCSSファイル132および処理済みスクリプト言語ファイル133等のそれぞれについて、表示完了時間が測定される。
利用者端末101毎、ウェブページ毎等に複数ある最適化されたHTMLファイル113zは、参照するプログラムのオブジェクトを変化させた場合に、処理前のHTMLファイル113と比較して、どの程度の表示完了時間がかかるのかが測定される。
処理済みCSSファイル132は、処理前のCSSファイル107と比較して、要素として、どの程度の表示完了時間がかかるのかが測定される。
複数ある処理済みスクリプト言語ファイル133は、処理前のスクリプト言語ファイル108と比較して、要素として、どの程度の表示完了時間がかかるのかが測定される。
バイナリデータについても、複数ある過去済み画像ファイル等と、過去前の画像ファイル等と比較して、要素として、どの程度の表示完了時間がかかるのかが測定される。
これらの測定は、機種情報ファイル1526の情報に従って、利用者端末101の表示環境ごとに、アプリケーション処理ユニットAが利用者端末101からリクエストを受信する前、アプリケーション処理ユニットAが利用者端末101からリクエストを受信した直後の少なくとも一方の間に実施される。
なお図22では直列処理が例示されているが、それぞれの処理は並列に実施することもできる。
なお図22では直列処理が例示されているが、それぞれの処理は並列に実施することもできる。
上記のステップにより、それぞれの利用者端末101について、オリジナルデータ200および複数の加工済みデータ201が準備される。
なお、オリジナルデータ200および複数の加工済みデータ201に含まれる、それぞれの要素についての表示完了時間の最も短いものを選択すれば、全体としてのオリジナルデータ200および複数の加工済みデータ201の中で最も表示完了時間の短いものが得られるか、というと、そうとは限らない。
要素の組み合わせによっても、それぞれの要素が互いに影響を及ぼし合って、オリジナルデータ200および複数の加工済みデータ201のそれぞれについての表示完了時間が変動するからである。
要素の組み合わせによっても、それぞれの要素が互いに影響を及ぼし合って、オリジナルデータ200および複数の加工済みデータ201のそれぞれについての表示完了時間が変動するからである。
オリジナルデータ200および複数の処理済みデータ210のうち、どの組み合わせが最も表示完了時間が短くなるかについて不明なものについて、利用者端末101毎に、実際に事前に予備試験を行って決定される。
またこの予備試験のデータに基づいて、機械学習によるモデル形成を行うことにより、オリジナルデータ200および複数の処理済みデータ210のうち、どの組み合わせが最も表示完了時間が短くなるかについて決定される。
またこの予備試験のデータに基づいて、機械学習によるモデル形成を行うことにより、オリジナルデータ200および複数の処理済みデータ210のうち、どの組み合わせが最も表示完了時間が短くなるかについて決定される。
[ウェブコンテンツの自動高速表示制御方法に使用されるオリジナルデータ200の更新]
図23は、オリジナルデータ200に追加、移動、削除、変更等の改変があったことを知らせる信号が動作制御部へ送信されるステップを説明するためのフローチャートである。
また図23は、オリジナルデータ200の改変の信号により、加工済みデータが新たに生成されるステップを説明するためのフローチャートである。
図23は、オリジナルデータ200に追加、移動、削除、変更等の改変があったことを知らせる信号が動作制御部へ送信されるステップを説明するためのフローチャートである。
また図23は、オリジナルデータ200の改変の信号により、加工済みデータが新たに生成されるステップを説明するためのフローチャートである。
オリジナルデータ200を監視して、オリジナルデータ200に追加、移動、削除、変更等の改変があったことを検出した時点で、加工済みデータが新たに生成される。
ウェブコンテンツ211の自動高速表示制御方法に使用されるオリジナルデータ200は、最初にアプリケーション処理ユニットAの記憶装置1101にあるオリジナルデータ記憶領域104に保存されたものをそのまま使用し続けることができる。
ウェブコンテンツ211の自動高速表示制御方法に使用されるオリジナルデータ200は、最初にアプリケーション処理ユニットAの記憶装置1101にあるオリジナルデータ記憶領域104に保存されたものをそのまま使用し続けることができる。
一方、ユーザは古い情報に加えて最新の情報の入手も通常希望する。このユーザの希望に応えてサーバ管理者はオリジナルデータ200を更新する作業が通常発生する。
オリジナルデータ200に改変があったことを検出するためは、一定時間経過後にオリジナルデータ200に変化が生じているかを追跡すればよい。
オリジナルデータ200はアプリケーション処理ユニットAのオリジナルデータ記憶領域104に保存されている。一定時間経過後にオリジナルデータ200に改変があった場合には、改変後の内容がオリジナルデータ記憶領域104に保存される。
そして先に保存された内容と、後に保存された内容のそれぞれを、例えば、データ取得・処理ユニットDに搭載されたコントロールユニットd300に記載されたプログラム等に基づいて、アプリケーション処理ユニットAの監視制御部1115で監視する。先に保存された内容と、後に保存された内容とをそれぞれ比較すればオリジナルデータ200のどの部分に差異が生じたかを、例えば、図7等に示される監視制御部1115等に記載されたプログラムにより検出することができる。
差異の有無を調べる時間間隔を短く設定することにより、瞬時に変更があったことを検出できる。
差異の有無を調べる時間間隔を短く設定することにより、瞬時に変更があったことを検出できる。
オリジナルデータ200に改変があった場合には、アプリケーション処理ユニットAの監視制御部1115は、例えば、オリジナルデータ200に含まれるHTMLファイル113、CSSファイル107、スクリプト言語ファイル108および画像ファイル109のうち、改変のあった部分を特定する。
そして改変があったことを知らせる信号が監視制御部1115から動作制御部1116およびデータ取得・処理ユニットDに搭載されたコントロールユニットd300に送信される。
そして改変があったことを知らせる信号が監視制御部1115から動作制御部1116およびデータ取得・処理ユニットDに搭載されたコントロールユニットd300に送信される。
改変を知らせる信号を受信したデータ取得・処理ユニットDに搭載されたコントロールユニットd300は、オリジナルデータ200のうち改変があった部分について利用者端末101の表示環境に応じた加工済みデータ201を処理して、新たな加工済みデータ202を生成する。
アプリケーション処理ユニットAの加工済みデータ記憶領域114に保存されている処理済みデータ210のうち、改変があった部分に対応するデータが、データ取得・処理ユニットDに搭載されたコントロールユニットd300により、処理済みデータ202により置換される。
アプリケーション処理ユニットAの加工済みデータ記憶領域114に保存されている処理済みデータ210のうち、改変があった部分に対応するデータが、データ取得・処理ユニットDに搭載されたコントロールユニットd300により、処理済みデータ202により置換される。
本発明の開示においては、オリジナルデータ200に関連するデータについてのタイムスタンプと呼ばれる、最新保存時間についての情報が変更されたものについて、実際にオリジナルデータ200等について改変があったかどうかを検証せずに、動的に生成された処理済みデータ202により、先に存在する処理済みデータ210等の該当部分を置換することもできる。
オリジナルデータ200が改変されると、その改変とほぼ同時に、オリジナルデータ200の改変に伴って新たに生成された処理済みデータ202により、先に生成されている処理済みデータ210が置換される動作が継続的に実施される。
データ取得・処理ユニットDのコントロールユニットd300に記載されたプログラムが動作し、利用者端末101の表示環境に応じた処理済みデータ202が抽出処理されて、動作制御記憶部1517に保存される。
上記のステップを経て、アプリケーション処理ユニットAが利用者端末101からリクエストを受信する前に、アプリケーション処理ユニットAが利用できる記憶領域に保存されたオリジナルデータ200から利用者端末の表示環境に応じた処理済みデータ210が新たに生成される。
[利用者端末の表示環境を特定するステップ]
次にリクエスト処理ユニットCが利用者端末101からリクエストを受信した後に、データ取得・処理ユニットDが、利用者端末101の表示環境を特定するステップについて説明する。
次にリクエスト処理ユニットCが利用者端末101からリクエストを受信した後に、データ取得・処理ユニットDが、利用者端末101の表示環境を特定するステップについて説明する。
ネットワーク102を通じて利用者端末101がネットワーク102を通じてリクエスト処理ユニットCに接続可能な状態になると、利用者端末101から送信されたリクエストはネットワーク102を経由してリクエスト処理ユニットCに受信される。そしてそれぞれのユニットに受信される。
このリクエストは利用者端末101に搭載されるブラウザを経由して行われる。
このリクエストは利用者端末101に搭載されるブラウザを経由して行われる。
データ取得・処理ユニットDが受信したリクエストには、例えば、利用者端末101の機種情報、ブラウザの種類、OSの種類等を示すユーザエージェント、利用者端末101のブラウザに表示されるウェブサイトのどのページからリクエストが送信されたかを示すリファラ等が含まれる。
これらのユーザエージェント、リファラ等の情報を利用して、アクセプトヘッダー、クッキー等によりデータ取得・処理ユニット103は、利用者端末101の表示環境を特定できる。
これらのユーザエージェント、リファラ等の情報を利用して、アクセプトヘッダー、クッキー等によりデータ取得・処理ユニット103は、利用者端末101の表示環境を特定できる。
[利用者端末の表示環境に表示可能なデータを含むウェブコンテンツが生成されるステップ]
次に、利用者端末101の表示環境に表示可能なデータを含むウェブコンテンツ211が生成されるステップについて説明する。
既に、先に説明したステップにより、事前に利用者端末101毎に表示できるウェブコンテンツ211は生成されている。このウェブコンテンツ211と、利用者端末101との対応付けを行う。
次に、利用者端末101の表示環境に表示可能なデータを含むウェブコンテンツ211が生成されるステップについて説明する。
既に、先に説明したステップにより、事前に利用者端末101毎に表示できるウェブコンテンツ211は生成されている。このウェブコンテンツ211と、利用者端末101との対応付けを行う。
利用者端末101のブラウザからのリクエストがネットワーク102を通じてリクエスト処理ユニットCに送信されると、このリクエストはアプリケーション処理ユニットAと人工知能ユニットBに送信される。このリクエストは人工知能ユニットBの監視制御部1415で受信される。
またデータ取得・処理ユニットDに対して、人工知能ユニットBの監視制御部1415から、リクエストが送信される。
利用者端末101の表示環境に表示可能なデータを含むウェブコンテンツ211が選択されるステップは、利用者端末101のブラウザからのリクエストがリクエスト処理ユニットCに送信された後に実施される。
データ取得・処理ユニットDに対して利用者端末101のブラウザからのリクエストがリクエスト処理ユニットCに送信されたことをデータ取得・処理ユニットDの制御部1512が検出する。
利用者端末101の個別の表示環境の特定は、アクセプトヘッダー、クッキー等の情報を、先に説明した機種情報ファイル1526と照合することにより実現される。
利用者端末101の個別の表示環境の特定は、アクセプトヘッダー、クッキー等の情報を、先に説明した機種情報ファイル1526と照合することにより実現される。
利用者端末101の表示環境が特定されると、この表示環境を使って表示できるオリジナルデータ200が特定される。具体的には、オリジナルデータ200に含まれる、HTMLファイル113、CSSファイル107、スクリプト言語ファイル108、画像ファイル109等が特定される。
同様に、利用者端末101の表示環境が特定されると、この表示環境を使って表示できる処理済みデータ210が特定される。具体的には最適化されたHTMLファイル113z、処理済みCSSファイル132、処理済みスクリプト言語ファイル133、画像ファイル109、処理済み画像ファイル134が特定される。
実際には最適化されたHTMLファイル113zの中で定義されたプログラムのオブジェクトの形でそれぞれのコード部分、ファイル部分等は処理済みデータ記憶領域130に保存されている。
どのオブジェクトを用いた場合に、どの程度の表示完了時間を要するかは事前の予備試験、予備試験等のデータを利用して機械学習等で形成された学習済みモデル等による検討で判明している。
このため、リクエスト処理ユニットCが利用者端末101からリクエストを受信した直後に、利用者端末の表示環境に表示可能なデータを含むウェブコンテンツ211が、データ取得・処理ユニットDに搭載されたコントロールユニットd300により選択される。この段階では、利用者端末101に表示可能なウェブコンテンツ211は複数存在する。
このため、リクエスト処理ユニットCが利用者端末101からリクエストを受信した直後に、利用者端末の表示環境に表示可能なデータを含むウェブコンテンツ211が、データ取得・処理ユニットDに搭載されたコントロールユニットd300により選択される。この段階では、利用者端末101に表示可能なウェブコンテンツ211は複数存在する。
そして予備試験によりあらかじめ判明している個々の利用者端末101に表示される表示完了時間が最も短い順番、およびこのデータを用いた機械学習により得られている学習済みデータの少なくとも一方に基づいて、それぞれの利用者端末101に表示されるウェブコンテンツ211がデータ取得・処理ユニットDの制御部1512でそれぞれ一つに決定される。
このウェブコンテンツ211を利用者端末101で表示するためのプログラムデータとなる加工済みデータ201が、データ取得・処理ユニットDの制御部1512からアプリケーション処理ユニットAに送信される。そして加工済みデータ201の内容がアプリケーション処理ユニットAに配置されたオリジナルデータ200の内容を反映するHTMLファイル113に代えて、最適化されたHTMLファイル113zに反映される。
最適化されたHTMLファイル113zは、アプリケーション処理ユニットA、リクエスト処理ユニットCを経て、ネットワーク102を通じて表示環境が特定された全ての利用者端末101についてそれぞれの利用者端末101にダウンロードされる。
この最適化されたHTMLファイル113zを受信した利用者端末101毎のブラウザ等で、最適化されたHTMLファイル113zを実行して、それぞれの利用者端末101に対応したウェブコンテンツ211が利用者端末101毎のブラウザ等に表示される。
この最適化されたHTMLファイル113zを受信した利用者端末101毎のブラウザ等で、最適化されたHTMLファイル113zを実行して、それぞれの利用者端末101に対応したウェブコンテンツ211が利用者端末101毎のブラウザ等に表示される。
[表示完了時間に基づく最適リソースの順位付けのステップ]
次に、これらのオリジナルデータ200および複数の加工済みデータ201について、実際にこれらのオリジナルデータ200および複数の加工済みデータ201を含むウェブコンテンツ211がそれぞれの利用者端末101について選択されるか説明する。
ウェブコンテンツ211を表示するために、オリジナルデータ200および複数の加工済みデータ201のうちどれを選択するかは、事前に予備試験によりウェブコンテンツ211の表示完了時間を計測して比較する。そしてこれらの表示完了時間のデータを用いて機械学習を行い学習済みモデルを形成する。
予備試験および学習済みモデル形成の少なくとも一方によりウェブコンテンツ211の表示完了時間を計測等して比較するステップはデータ取得・処理ユニットDで実施される。
次に、これらのオリジナルデータ200および複数の加工済みデータ201について、実際にこれらのオリジナルデータ200および複数の加工済みデータ201を含むウェブコンテンツ211がそれぞれの利用者端末101について選択されるか説明する。
ウェブコンテンツ211を表示するために、オリジナルデータ200および複数の加工済みデータ201のうちどれを選択するかは、事前に予備試験によりウェブコンテンツ211の表示完了時間を計測して比較する。そしてこれらの表示完了時間のデータを用いて機械学習を行い学習済みモデルを形成する。
予備試験および学習済みモデル形成の少なくとも一方によりウェブコンテンツ211の表示完了時間を計測等して比較するステップはデータ取得・処理ユニットDで実施される。
ウェブコンテンツ211の表示完了時間を計測等して比較するステップにより、一つの利用者端末101に関する、オリジナルデータ200および複数の加工済みデータ201のそれぞれのデータについての表示完了時間に関連して、どれが優位かについての情報が、データ取得・処理ユニットDのオリジナルデータ保存領域104および処理済みデータ保存領域130にそれぞれ保存される。
ウェブコンテンツ211の表示完了時間は、オリジナルデータ200および複数の加工済みデータ201に含まれるプログラムの部分に大きく依存する。
プログラムの部分は容量がより削減されたものが、容量がそれほど削減されていないものよりも通常は表示完了時間が短くなるので好ましい。
プログラムの部分は容量がより削減されたものが、容量がそれほど削減されていないものよりも通常は表示完了時間が短くなるので好ましい。
ただし、容量が小さいもの全てが、表示完了時間が短くなるとは限らない。さらにはバイナリデータについても、容量が小さいものが表示完了時間が短くなるとは限らない。
場合によっては、どの複数の加工済みデータ201よりも、オリジナルデータ200が、表示が速く完了する可能性もある。
場合によっては、どの複数の加工済みデータ201よりも、オリジナルデータ200が、表示が速く完了する可能性もある。
そこで本発明の開示においては、オリジナルデータ200および複数の加工済みデータ201を用いて、それぞれの利用者端末101における表示完了時間を事前に予備試験等を実施して計測することにより、それぞれのデータについて実際に表示完了時間が短い順番を特定できる。またこれらのデータを用いて機械学習を行い、学習済みモデルを形成することができる。この学習済みモデルを用いて実際に表示完了時間が短い順番を特定することができる。
オリジナルデータ200は、ウェブコンテンツ211を構成する複数のウェブページにそれぞれ対応する複数のHTMLファイル113と、複数のHTMLファイル113のそれぞれから参照実行される各種プログラムデータおよびバイナリデータを含む。
また加工済みデータ201は、ウェブコンテンツ211を構成する複数のウェブページにそれぞれ対応する複数の最適化されたHTMLファイル113zと、複数の最適化されたHTMLファイル113zのそれぞれから参照されて実行される各種処理済みプログラムデータおよび処理済みバイナリデータを含む。
これらのオリジナルデータ200および加工済みデータ201がそれぞれウェブコンテンツ211の表示に必要なリソースである。
これらのオリジナルデータ200および加工済みデータ201がそれぞれウェブコンテンツ211の表示に必要なリソースである。
またこれらのリソースの中から、ユーザの利用者端末101毎に利用者端末101の表示に必要となるリソースが、最適リソースである。最適リソースは、一つの利用者端末101毎に複数存在する。
処理済みデータの生成は、ユーザの利用者端末101の表示環境ごと、ウェブコンテンツ211の表示に必要なリソースごとに行われる。
また、ユーザの利用者端末101の表示環境ごとに実行可能な最適リソースが選択された場合、その最適リソースが、保存されている各種ファイルの容量、各種ファイルの種類を指定する拡張子等が同じ場合でも、その最適リソースを実現するために必要な表現形式は一つと限らない。このため、複数の最適リソースの中に、見かけが同じ最適リソースに見える複数の最適リソースが存在した場合でも、実際に実行した場合に表示完了時間に差が生じる最適リソースが含まれる場合がある。
明らかに他の最適リソースよりも表示完了時間が短いことが判明している最適リソースを除き、一つの利用者端末101に対する最適リソース同士の表示完了時間に関する情報は、例えば、実際に事前に予備試験を行い決定される。また予備試験等により得られた表示完了時間に関するデータを用いた機械学習等によるモデル形成を用いた方法によっても、表示完了時間を比較的正確に決定することができる。
[データのバックアップ]
先に説明した、データ取得・処理ユニットDの記憶装置1501は時間実行制御部1520を備えることもできる。
先に説明した、データ取得・処理ユニットDの記憶装置1501は時間実行制御部1520を備えることもできる。
時間実行制御部1520に接続された時間実行記憶部1521に保存された実行プログラム1522により、一定時間経過後に、例えばアプリケーション処理ユニットAのオリジナルデータ200、処理済みデータ210,202等の本発明の実施形態1に係るウェブコンテンツの自動高速表示制御方法を実施するために必要なデータやプログラムの予備保存データが複製され、データ取得・処理ユニットDの時間実行記憶部1521に保存される。
また一定時間経過後に、例えば、予備保存データの中から一定期間を経過した古いものが削除される。
データ取得・処理ユニットDの時間実行記憶部1521に保存された予備保存データは、データ取得・処理ユニットDに加えて、アプリケーション処理ユニットAの補助記憶部1105にネットワーク102を通じて転送し、保存することもできる。
データ取得・処理ユニットDの時間実行記憶部1521に保存された予備保存データは、データ取得・処理ユニットDに加えて、アプリケーション処理ユニットAの補助記憶部1105にネットワーク102を通じて転送し、保存することもできる。
またオリジナルデータ200に改変があった場合、先に説明したアプリケーション処理ユニットAでオリジナルデータ200を監視して、対応することができる。
本発明の開示においては、例えば、オリジナルデータ200の監視はデータ取得・処理ユニットDにより実施することもできる。
本発明の開示においては、例えば、オリジナルデータ200の監視はデータ取得・処理ユニットDにより実施することもできる。
例えば、オリジナルデータ200の一部に改変があると、オリジナルデータ200の改変部分が特定され、この改変部分に対応した加工済みデータ201が生成される。
先に説明した予備試験等により、オリジナルデータ200および複数の加工済みデータ201等の中から、利用者端末101毎に、最も表示完了時間が短い処理済みデータ210が特定される。
次にデータ取得・処理ユニットDに搭載されたコントロールユニットd300により、利用者端末101に表示可能な、オリジナルデータ200ならびに複数の加工済みデータ201の中から選ばれた処理済みデータ210が特定される。
そして処理済みデータ210が、データ取得・処理ユニットDからアプリケーション処理ユニットAの順番に送信され、ネットワーク102を通じて利用者端末101で受信される。
受信された処理済みデータ210が利用者端末101のブラウザで表示される。
そして処理済みデータ210が、データ取得・処理ユニットDからアプリケーション処理ユニットAの順番に送信され、ネットワーク102を通じて利用者端末101で受信される。
受信された処理済みデータ210が利用者端末101のブラウザで表示される。
同様に、オリジナルデータ200の全てに改変がある場合には、データ取得・処理ユニットDのコントロールユニットd300により、利用者端末101に表示可能な処理済みデータ202が、データ取得・処理ユニットDからアプリケーション処理ユニットAを経て送信され、ネットワーク102を介して利用者端末101で受信される。
受信された処理済みデータ202が、利用者端末101のブラウザで表示される。
受信された処理済みデータ202が、利用者端末101のブラウザで表示される。
またオリジナルデータ200に変更、追加、削除等の改変があれば、利用者端末101からリクエストがリクエスト処理ユニットCに受信されると、データ取得・処理ユニットDの制御部1512により制御されたアプリケーション処理ユニットAを経て、利用者端末101にウェブコンテンツ211のうち更新されたウェブコンテンツ212を含む処理済みデータ202が都度送信される。
例えば、オリジナルデータ200の全てに改変がある場合には、ウェブコンテンツ211の全てが更新されたウェブコンテンツ212に置換される。
利用者端末101では、更新されたウェブコンテンツ212を含むウェブコンテンツ211を表示することができる。
利用者端末101では、更新されたウェブコンテンツ212を含むウェブコンテンツ211を表示することができる。
上記一連のステップにより、アプリケーション処理ユニットAからリクエスト処理ユニットC、ネットワーク102を経て送信されたウェブコンテンツ212を表示するための処理済みデータ202を受信した利用者端末101は、利用者端末101に搭載されたブラウザにウェブコンテンツ212を、初回から、高速に表示することができる。
本発明の開示においては、例えば、アプリケーション実行サーバ103で最適化されたHTMLファイル113zが利用者端末101毎にダウンロードされ、利用者端末101のブラウザ等で最適化されたHTMLファイル113zが実行される。最適化されたHTMLファイル113zに基づくウェブコンテンツが利用者端末101のブラウザ等に表示される。
最初にユーザが利用者端末101のブラウザ等からネットワーク102を通じてアプリケーション実行サーバ103にリクエストを送信した場合、レスポンスとしてアプリケーション実行サーバ103は、オリジナルデータ200に含まれるHTMLファイル113等を利用者端末101に送信することができる。その一方で、アプリケーション実行サーバ103は最適化されたHTMLファイル113z等も送信する。
HTMLファイル113と最適化されたHTMLファイル113zはそれぞれ併存して利用者端末101に保存されてもよいが、通常は、HTMLファイル113は最適化されたHTMLファイル113zが利用者端末101毎にダウンロードされる。
最適化されたHTMLファイル113zに含まれるプログラムのそれぞれのオブジェクトとして、HTMLファイル113と同じ内容を再現するようにオブジェクトを選択すれば最適化されたHTMLファイル113zを用いてHTMLファイル113を簡単に再現することもできる。
最適化されたHTMLファイル113zに含まれるプログラムのそれぞれのオブジェクトとして、HTMLファイル113と同じ内容を再現するようにオブジェクトを選択すれば最適化されたHTMLファイル113zを用いてHTMLファイル113を簡単に再現することもできる。
例えば、利用者端末101にダウンロードされた最適化されたHTMLファイル113zは、最適化されたHTMLファイル113zに直接記載されたリソースに関する参照部分、最適化されたHTMLファイル113zが参照する外部のリソースに関する参照部分等のリソース情報の全てが、全てプログラムのオブジェクトとして扱うことのできる形式に変換されている。それぞれのオブジェクトには識別情報が関連付けられていて、どのオブジェクトが最適化されたHTMLファイル113zのどの部分で使用されるオブジェクトなのかを、例えば、データ取得・処理ユニットDのデータベース1106等により管理することができる。
利用者端末101のブラウザ等は、人工知能ユニットBの立案した戦略案、つまり戦略ファイル1412に従って、最適化されたHTMLファイル113zが参照する全てのリソースについてのオブジェクトをデータ取得・処理ユニットDからリクエスト処理ユニットCを介して、ネットワーク102を経由して受け取ることができる。
これらのリソースを最適化されたHTMLファイル113zのそれぞれのオブジェクトに対応付けることにより、瞬時に利用者端末101のブラウザ等にウェブコンテンツを表示することができる。そして利用者端末101で表示に使用されるリソースの利用者端末101毎に対するダウンロードの順番、タイミングが、人工知能ユニットBにより立案された戦略案に基づいて実施される。
これらのリソースを最適化されたHTMLファイル113zのそれぞれのオブジェクトに対応付けることにより、瞬時に利用者端末101のブラウザ等にウェブコンテンツを表示することができる。そして利用者端末101で表示に使用されるリソースの利用者端末101毎に対するダウンロードの順番、タイミングが、人工知能ユニットBにより立案された戦略案に基づいて実施される。
[人工知能ユニットBが戦略案を立案するステップ]
次に人工知能ユニットBが、ウェブコンテンツを利用者端末101に表示する戦略案を立案するステップについて説明する。
リクエスト処理ユニットCを介してアプリケーション処理ユニットAと人工知能ユニットBとが相互に通信可能となる。
次に人工知能ユニットBが、ウェブコンテンツを利用者端末101に表示する戦略案を立案するステップについて説明する。
リクエスト処理ユニットCを介してアプリケーション処理ユニットAと人工知能ユニットBとが相互に通信可能となる。
また人工知能ユニットBとデータ取得・処理ユニットDも相互に通信可能となる。
リクエスト処理ユニットCを介して、アプリケーション処理ユニットAと通信可能になったデータ取得・処理ユニットDは、アプリケーション処理ユニットAのオリジナルデータ記憶領域1530に保存されたオリジナルデータ200をデータ取得・処理ユニットDに保存して加工する。加工されたデータはデータ取得・処理ユニットDの加工済みデータ記憶領域1540に保存される。
またアプリケーション処理ユニットAのオリジナルデータ記憶領域104に保存されたオリジナルデータ200を読取りながら加工し、加工された結果をアプリケーション処理ユニットAのの加工済みデータ記憶領域130に保存することもできる。
またアプリケーション処理ユニットAのオリジナルデータ記憶領域104に保存されたオリジナルデータ200を読取りながら加工し、加工された結果をアプリケーション処理ユニットAのの加工済みデータ記憶領域130に保存することもできる。
実際にはアプリケーション処理ユニットAに保存されているオリジナルデータ200は頻繁に更新されたり、動的に生成されたりする。つまりオリジナルデータ200は経時的に変化する。
オリジナルデータ200が経時的に変化するたびに、先に説明した各ステップが実施されて、新たな処理済みデータ210が生成される。
人工知能ユニットBはこの過程をそれぞれの利用者端末101にウェブコンテンツを表示させる時間との関係、ウェブコンテンツを利用者端末101のブラウザに表示させることを妨げる結果となるエラーが発生する可能性、期待通りのウェブコンテンツが利用者端末101のブラウザに表示されているかについての表示の完全性等のそれぞれのデータに関して学習する。
これらのデータが共通して持つ属性を、例えば統計処理により解析して、ウェブコンテンツの表示完了時間の長短と関連付ける。
人工知能ユニットBはこの過程をそれぞれの利用者端末101にウェブコンテンツを表示させる時間との関係、ウェブコンテンツを利用者端末101のブラウザに表示させることを妨げる結果となるエラーが発生する可能性、期待通りのウェブコンテンツが利用者端末101のブラウザに表示されているかについての表示の完全性等のそれぞれのデータに関して学習する。
これらのデータが共通して持つ属性を、例えば統計処理により解析して、ウェブコンテンツの表示完了時間の長短と関連付ける。
例えば、オリジナルデータ200に含まれるHTMLファイル113は、HTMLコード部分113a,113b,113c、CSSコード部分107a,107b,107c、スクリプト言語コード部分108a,108b,108c等を含む。
本発明の実施形態1では、オリジナルデータ200および複数の処理済みデータ210の少なくとも一つは、プログラムデータおよびバイナリデータの少なくとも一つを含む。
またプログラムデータは、マークアップ言語、プログラミング言語、スタイルシート、スクリプト言語などの一種もしくは二種以上で記載されたプログラムを含む。
一方、バイナリデータは、画像ファイル、音ファイル、動画ファイルなどの一種もしくは二種以上のファイルを含む。
これらのプログラムデータ、バイナリデータ等から、実行させるプログラムの部分および実行させないプログラムの部分が利用者端末101の表示環境ごとにそれぞれ特定される。
一方、バイナリデータは、画像ファイル、音ファイル、動画ファイルなどの一種もしくは二種以上のファイルを含む。
これらのプログラムデータ、バイナリデータ等から、実行させるプログラムの部分および実行させないプログラムの部分が利用者端末101の表示環境ごとにそれぞれ特定される。
例えば、オリジナルデータ200が、プログラムデータおよびバイナリデータの少なくとも一つを含み、
プログラムデータが、マークアップ言語、プログラミング言語、スタイルシート、スクリプト言語からなる群より選ばれる少なくとも一つの記載を含み、
バイナリデータが、画像ファイル、音ファイルおよび動画ファイルの少なくとも1つを含む場合、
プログラムデータが、マークアップ言語、プログラミング言語、スタイルシート、スクリプト言語からなる群より選ばれる少なくとも一つの記載を含み、
バイナリデータが、画像ファイル、音ファイルおよび動画ファイルの少なくとも1つを含む場合、
オリジナルデータ200に含まれる、マークアップ言語、プログラミング言語、スタイルシートおよびスクリプト言語からなる群より選ばれる少なくとも一つの記載を含むデータから、利用者端末101の表示環境ごとに不要部分が削除されるステップが実施されたデータ取得・処理ユニットDに関する情報601、
オリジナルデータ200に含まれる、マークアップ言語、プログラミング言語、スタイルシートおよびスクリプト言語からなる群より選ばれる少なくとも一つのデータから、利用者端末の表示環境ごとに必要部分が圧縮されるステップが実施されたデータ取得・処理ユニットDに関する情報602、
オリジナルデータ200に含まれる、マークアップ言語、プログラミング言語、スタイルシートおよびスクリプト言語からなる群より選ばれる少なくとも一つのデータから、利用者端末の表示環境ごとに実行順序が変更されるステップが実施されたデータ取得・処理ユニットDに関する情報603、
オリジナルデータ200に含まれる、マークアップ言語、プログラミング言語、スタイルシートおよびスクリプト言語からなる群より選ばれる少なくとも一つのデータから、利用者端末の表示環境ごとに実行タイミングが変更されるステップが実施されたデータ取得・処理ユニットDに関する情報604、
オリジナルデータ200に含まれる、バイナリデータから、単位面積当たりの表示画素数、単位時間当たりの録画録音密度、容量および保存形式からなる群より選ばれる一つが変換されるステップが実施されたデータ取得・処理ユニットDに関する情報605、
オリジナルデータ200ならびに複数の加工済みデータの中から、どのデータを組み合わせて処理済みデータ210が生成されたかについての情報606、
オリジナルデータ200ならびに複数の加工済みデータからなる群より選ばれる少なくとも一つを含む処理済みデータ210と、処理済みデータ210が利用者端末101で入力受付可能になるまでの時間に関する情報607
利用者端末101毎に、アプリケーション処理ユニットA、データ取得・処理ユニットDおよびクラウド配信サーバ608のいずれから利用者端末101に送信されたかに関する情報608等について、人工知能ユニットBは学習する。
オリジナルデータ200に含まれる、マークアップ言語、プログラミング言語、スタイルシートおよびスクリプト言語からなる群より選ばれる少なくとも一つのデータから、利用者端末の表示環境ごとに必要部分が圧縮されるステップが実施されたデータ取得・処理ユニットDに関する情報602、
オリジナルデータ200に含まれる、マークアップ言語、プログラミング言語、スタイルシートおよびスクリプト言語からなる群より選ばれる少なくとも一つのデータから、利用者端末の表示環境ごとに実行順序が変更されるステップが実施されたデータ取得・処理ユニットDに関する情報603、
オリジナルデータ200に含まれる、マークアップ言語、プログラミング言語、スタイルシートおよびスクリプト言語からなる群より選ばれる少なくとも一つのデータから、利用者端末の表示環境ごとに実行タイミングが変更されるステップが実施されたデータ取得・処理ユニットDに関する情報604、
オリジナルデータ200に含まれる、バイナリデータから、単位面積当たりの表示画素数、単位時間当たりの録画録音密度、容量および保存形式からなる群より選ばれる一つが変換されるステップが実施されたデータ取得・処理ユニットDに関する情報605、
オリジナルデータ200ならびに複数の加工済みデータの中から、どのデータを組み合わせて処理済みデータ210が生成されたかについての情報606、
オリジナルデータ200ならびに複数の加工済みデータからなる群より選ばれる少なくとも一つを含む処理済みデータ210と、処理済みデータ210が利用者端末101で入力受付可能になるまでの時間に関する情報607
利用者端末101毎に、アプリケーション処理ユニットA、データ取得・処理ユニットDおよびクラウド配信サーバ608のいずれから利用者端末101に送信されたかに関する情報608等について、人工知能ユニットBは学習する。
予備試験により、どのデータ取得・処理ユニットDにどのステップを担当させたか、その結果、どのような加工済みデータ201が生成したか、オリジナルデータ200ならびに複数の加工済みデータ201を組み合わせて生成された処理済みデータ210について、仮に利用者端末101からリクエスト処理ユニットCにリクエストがあった場合に、どの程度の表示完了時間で処理済みデータ210に基づくウェブコンテンツが利用者端末101で入力受付可能になるか等についての情報、利用者端末101のIPアドレスから推測できるユーザの位置情報等が既に得られている。
これらの情報を元に、利用者端末101からネットワーク102を通じてリクエスト処理ユニットCにリクエストがあった場合に、処理済みデータ210に基づくウェブコンテンツが利用者端末101で入力受付可能になるまでの時間と、それぞれに要したステップとの相関関係を人工知能ユニットBは学習し、学習済みモデルを形成する。
学習済みモデルを形成する際には、利用者端末101毎にウェブコンテンツをより速く表示するための処理済みデータが共通して有する属性に着目して人工知能ユニットBに学習させることが好ましい。
学習済みモデルを形成する際には、利用者端末101毎にウェブコンテンツをより速く表示するための処理済みデータが共通して有する属性に着目して人工知能ユニットBに学習させることが好ましい。
人工知能ユニットBが学習した相関関係に基づいて、一つの利用者端末101に表示させるために必要なオリジナルデータ200が特定されると、オリジナルデータ200に含まれる、マークアップ言語、プログラミング言語、スタイルシート、スクリプト言語等を、データ取得・処理ユニットDで、どのように加工すれば処理済みデータ210に基づくウェブコンテンツが利用者端末101で入力受付可能になるまでの時間を最短にできるかを予測することができる。
同様に、人工知能ユニットBが学習した相関関係に基づいて、一つの利用者端末101に表示させるために必要なオリジナルデータ200が特定されると、オリジナルデータ200に含まれる、バイナリデータ等を、データ取得・処理ユニットDで、どのように加工すれば処理済みデータ210に基づくウェブコンテンツが利用者端末101で入力受付可能になるまでの時間を最短にできるかを予測することができる。
また、人工知能ユニットBが学習した相関関係に基づいて、オリジナルデータ200ならびにデータ取得・処理ユニットDで処理された複数の加工済みデータ201のうち、どのデータを組み合わせれば処理済みデータ210に基づくウェブコンテンツが利用者端末101で入力受付可能になるまでの時間を最短にできるかを予測することができる。
さらに、人工知能ユニットBが学習した相関関係に基づいて、データ取得・処理ユニットで生成された処理済みデータ210を、利用者端末101にダウンロードさせてから、利用者端末101毎のブラウザ等で実行させるのか、またはデータ取得・処理ユニットで生成された処理済みデータ210を利用者端末101毎のブラウザからネットワーク102を通じてアプリケーション実行サーバ103側で実行すればよいのかを予測することができる。
そして人工知能ユニットBが上記の情報を学習して得られた予測が実際に正しいかどうかを、利用者端末101に搭載されたブラウザ環境と同様の環境を再現可能なヘッドレスブラウザ等のエミュレータを用いて予備試験により検証できる。例えば、このエミュレータはデータ取得・処理ユニットDの制御部1512に搭載することができる。
予備試験の結果、予測通り、処理済みデータ210に基づくウェブコンテンツが利用者端末101で入力受付可能になるまでの時間を短縮することができれば加点する。逆に処理済みデータ210に基づくウェブコンテンツが利用者端末101で入力受付可能になるまでの時間が遅延する結果になれば減点する。
この加点と減点についての情報が、人工知能ユニットBの制御部1512にフィードバックされる。フィードバックされた情報を元に、人工知能ユニットBはその結果を人工知能ユニットBが立案した戦略案に反映することができる。このステップを繰り返して行うことにより、学習済みモデルが形成される。
この加点と減点についての情報が、人工知能ユニットBの制御部1512にフィードバックされる。フィードバックされた情報を元に、人工知能ユニットBはその結果を人工知能ユニットBが立案した戦略案に反映することができる。このステップを繰り返して行うことにより、学習済みモデルが形成される。
人工知能ユニットBの学習の方法に特に限定はない。公知の人工知能に関する方法を適宜選択して採用することができる。
このような人工知能を活用する方法としては、例えば、機械学習、深層学習等の方法が挙げられる。本発明の開示においてはニューラルネットワーク、強化学習によるモデル形成と予測、ベイズ推定による予測、DBスキャン法によるクラスタリング等が利用される。必要に応じてKNN法、決定木法、MT法等の人工知能アルゴリズムを併用することもできる。
このような人工知能を活用する方法としては、例えば、機械学習、深層学習等の方法が挙げられる。本発明の開示においてはニューラルネットワーク、強化学習によるモデル形成と予測、ベイズ推定による予測、DBスキャン法によるクラスタリング等が利用される。必要に応じてKNN法、決定木法、MT法等の人工知能アルゴリズムを併用することもできる。
[オリジナルデータ200から加工済みデータ201の生成の具体例]
先に説明した図16に示されるように、例えば、オリジナルデータ200に含まれるHTMLファイル113は、HTMLコード部分113a,113b,113c、CSSコード部分107a,107b,107c、スクリプト言語コード部分108a,108b,108c等を含む。
先に説明した図16に示されるように、例えば、オリジナルデータ200に含まれるHTMLファイル113は、HTMLコード部分113a,113b,113c、CSSコード部分107a,107b,107c、スクリプト言語コード部分108a,108b,108c等を含む。
人工知能ユニットBの立案した戦略案により、HTMLファイル113に含まれるCSSコード部分107a,107b,107cに代えて、オブジェクトとしてのF107a1,F107b1,F107c1のそれぞれのスタイルシートが代入されている。
これらのCSSコード部分F107a1,F107b1,F107c1等は、例えば、データ取得・処理ユニットDに保存されている。
これらのスタイルシートF107a1,F107b1,F107c1等のコード部分のデ
ータは、最初に利用者端末101からアプリケーション実行サーバ103にリクエストが送信された際に、アプリケーション実行サーバ103からネットワーク102を通じて利用者端末101にダウンロードされて保存されている。
これらのスタイルシートF107a1,F107b1,F107c1等のコード部分のデ
ータは、最初に利用者端末101からアプリケーション実行サーバ103にリクエストが送信された際に、アプリケーション実行サーバ103からネットワーク102を通じて利用者端末101にダウンロードされて保存されている。
利用者端末101のブラウザ等で最適化されたHTMLファイル113zが実行されると、CSSコード部分F107a1,F107b1,F107c1等の内容が実行される。
CSSコード部分F107a1,F107b1,F107c1等は、利用者端末101にダウンロードしてから実行することもできるし、利用者端末101に搭載されたブラウザ等から、ネットワーク102を通じて、アプリケーション実行サーバ103等に保存されているものを用いて実行することもできる。
CSSコード部分F107a1,F107b1,F107c1等は、利用者端末101にダウンロードしてから実行することもできるし、利用者端末101に搭載されたブラウザ等から、ネットワーク102を通じて、アプリケーション実行サーバ103等に保存されているものを用いて実行することもできる。
スクリプト言語コード部分についてもCSSコード部分の場合と同様である。
人工知能ユニットBの立案した戦略案により、HTMLファイル113に含まれるスクリプト言語コード部分108a,108b,108cに代えて、オブジェクトとしてのF108a1,F108b1,F108c1のそれぞれのスクリプト言語プログラムが代入されている。
人工知能ユニットBの立案した戦略案により、HTMLファイル113に含まれるスクリプト言語コード部分108a,108b,108cに代えて、オブジェクトとしてのF108a1,F108b1,F108c1のそれぞれのスクリプト言語プログラムが代入されている。
スクリプト言語プログラムF108a1,F108b1,F108c1等は、例えば、データ取得・処理ユニットDに保存されている。
これらのスクリプト言語プログラムのコード部分は、利用者端末101にダウンロードしてから実行することもできるし、利用者端末101に搭載されたブラウザ等から、ネットワーク102を通じて、アプリケーション実行サーバ103等に保存されているものを用いて実行することもできる。
これらのスクリプト言語プログラムのコード部分は、利用者端末101にダウンロードしてから実行することもできるし、利用者端末101に搭載されたブラウザ等から、ネットワーク102を通じて、アプリケーション実行サーバ103等に保存されているものを用いて実行することもできる。
最適化されたHTMLファイル113zに含まれるオブジェクトとしてのF107a1,F107b1,F107c1のそれぞれのスタイルシート等、
最適化されたHTMLファイル113zに含まれるオブジェクトとしてのF108a1,F108b1,F108c1のそれぞれのスクリプト言語プログラム等について、
利用者端末101にダウンロードさせてから実行させるのか、または、データ取得・処理ユニットD等に保存しておき、利用者端末101のブラウザからネットワーク102を通じて実行させるのか等の各ステップは、人工知能ユニットBの立案した戦略案に従って実施される。
最適化されたHTMLファイル113zに含まれるオブジェクトとしてのF108a1,F108b1,F108c1のそれぞれのスクリプト言語プログラム等について、
利用者端末101にダウンロードさせてから実行させるのか、または、データ取得・処理ユニットD等に保存しておき、利用者端末101のブラウザからネットワーク102を通じて実行させるのか等の各ステップは、人工知能ユニットBの立案した戦略案に従って実施される。
オリジナルデータ200に含まれるHTMLファイル113に変更があった場合、動的に生成されてその内容が時間の経過と共に変化する場合でも、本発明に係る実施形態1で対応できる。
先に説明した図16におけるHTMLファイル113と最適化されたHTMLファイル113zとの関係は、ある瞬間に切り出された状態として理解することができる。
先に説明した図16におけるHTMLファイル113と最適化されたHTMLファイル113zとの関係は、ある瞬間に切り出された状態として理解することができる。
HTMLファイル113と最適化されたHTMLファイル113zとの関係はオブジェクトとして、識別情報と共に対応付けられている。
HTMLファイル113に変化があった場合には、過去のHTMLファイル113の内容と現在のHTMLファイル113の内容が異なる。例えば、アプリケーション処理ユニットAはHTMLファイル113に変更があった場合には、タイムスタンプが変更される、変更内容の差分を出力する等の機能を備えている。この機能を利用して、HTMLファイル113のうち変更のあった部分に対応する、最適化されたHTMLファイル113zのオブジェクトを識別情報により特定することができる。
HTMLファイル113に変化があった場合には、過去のHTMLファイル113の内容と現在のHTMLファイル113の内容が異なる。例えば、アプリケーション処理ユニットAはHTMLファイル113に変更があった場合には、タイムスタンプが変更される、変更内容の差分を出力する等の機能を備えている。この機能を利用して、HTMLファイル113のうち変更のあった部分に対応する、最適化されたHTMLファイル113zのオブジェクトを識別情報により特定することができる。
変更されたオブジェクトのそれぞれに対して、加工済みデータをデータ取得・処理ユニットDが準備して識別情報により対応づける。そのオブジェクトが最適化されたHTMLファイル113zに代入される。
具体的にどのオブジェクトをどのように最適化されたHTMLファイル113zに反映させるかは、先に説明した場合と同様に、人工知能ユニットBの立案した戦略案に従って実施される。
具体的にどのオブジェクトをどのように最適化されたHTMLファイル113zに反映させるかは、先に説明した場合と同様に、人工知能ユニットBの立案した戦略案に従って実施される。
上記に説明したステップによりデータ取得・処理ユニットDにより、アプリケーション処理ユニットAに保存されたオリジナルデータ200を加工した履歴を保存することができる。
アプリケーション処理ユニットAにリクエストを送信することが予想される全ての利用者端末101毎に個別に表示可能な複数の加工済みデータ201を生成しておき、事前にオリジナルデータ200ならびに複数の加工済みデータ201の中から、最速で利用者端末101に対してウェブコンテンツが入力受付可能になる処理済みデータ210を予備試験、学習済みモデル等により特定する。
処理済みデータ210が特定されるまでに、アプリケーション処理ユニットAに保存されているオリジナルデータ200をデータ取得・処理ユニットDで、どのように加工したか、得られた加工済みデータ201等をどのように組み合わせたか等の知見から、最速で利用者端末101に対してウェブコンテンツが入力受付可能になる処理済みデータ210にはどの属性に着目すればよいかの相関関係に関するデータが人工知能ユニットBのデータベース1406に蓄積される。
アプリケーション処理ユニットAに保存されているオリジナルデータ200等の処理に関連する相関関係を解析することにより、上記属性に関連する統計的な指標が得られる。
この属性を人工知能ユニットBが立案する戦略案に反映させることにより、データ取得・処理ユニットDが全ての場合について検討を試みた、最速で利用者端末101に対してウェブコンテンツが入力受付可能になる処理済みデータ210と全く同じデータが適用できない場合が仮に生じたとしても、その状況を人工知能ユニットBの戦略案を用いて新たなデータを作成して対応することができる。
この属性を人工知能ユニットBが立案する戦略案に反映させることにより、データ取得・処理ユニットDが全ての場合について検討を試みた、最速で利用者端末101に対してウェブコンテンツが入力受付可能になる処理済みデータ210と全く同じデータが適用できない場合が仮に生じたとしても、その状況を人工知能ユニットBの戦略案を用いて新たなデータを作成して対応することができる。
本発明に係る発明の実施形態1のウェブコンテンツの自動高速表示制御方法によれば、利用者端末101にウェブコンテンツを表示させるためのオリジナルデータ200が保存されたアプリケーション処理ユニットAにアクセスできるリクエスト処理ユニットCを設置すれば本発明に係る発明の実施形態1のウェブコンテンツの自動高速表示制御方法の実施準備が整う。
アプリケーション処理ユニットAに対して特別な仕様変更は必要ないから、簡単に本発明に係るウェブコンテンツの自動高速表示制御方法を実施することができる。
アプリケーション処理ユニットAに対して特別な仕様変更は必要ないから、簡単に本発明に係るウェブコンテンツの自動高速表示制御方法を実施することができる。
実際にアプリケーション処理ユニットAに利用者端末101からリクエストがあれば、それぞれのリクエストに応答してオリジナルデータ200をネットワーク102を通じて利用者端末101に送信し、オリジナルデータ200に基づくウェブコンテンツが利用者101のブラウザ等に表示され、利用者端末101上で受付可能になるまでの時間よりも短い時間で、オリジナルデータ200が各ユニットにより処理されて処理済みデータ210に置換されて、利用者端末101に送信される。
そしてオリジナルデータ200に基づくウェブコンテンツが利用者101毎に表示され、利用者端末101上で受付可能になるまでに、処理済みデータ210に基づくウェブコンテンツが利用者101に表示され、利用者端末101上で受付可能にすることができる。
本発明に係る発明の実施形態1のウェブコンテンツの自動高速表示制御方法の場合、ユーザによる利用者端末101からのリクエストを、ネットワーク102を通じて受信できるアプリケーション実行サーバ103であって、そのリクエストに対応したオリジナルデータ200をレスポンスとして、ネットワーク102を通じて利用者端末101に送信し、オリジナルデータ200によるウェブコンテンツを利用者端末101に表示できる機能を備えたアプリケーション実行サーバ103が使用される。
この機能を備えたアプリケーション実行サーバ103であれば、アプリケーション処理ユニットAとしての機能を実現することができる。
本発明に係る発明の実施形態1のウェブコンテンツの自動高速表示制御方法は、例えば、従来運用されているウェブコンテンツを表示するためのサーバに組み込むことができる。この場合、アプリケーション実行サーバ103に動作環境の変更等のマイグレーションを行うことにより実施できる。
本発明の実施形態1の場合、オリジナルデータ200が最適化され、表示完了時間の短い最適リソースを含む加工済みデータ201を用いて、オリジナルデータ200を使用した場合よりも短い表示完了時間で利用者端末101毎のブラウザ等に高速にウェブコンテンツを表示することができる。
[実施形態2:リバースプロキシ型]
図24は、本発明の実施形態2に係るウェブコンテンツの自動高速表示制御方法を実施するための自動高速表示制御システムであり、リバースプロキシ型の構成を記載した概略図である。
本発明に係る発明の実施形態2のリバースプロキシ型は、先に説明した実施形態1のオールインワン型と比較して、アプリケーション実行サーバ103に加えてリバースプロキシサーバ1703を使用する点、
またリバースプロキシサーバ1703に、人工知能ユニットB、リクエスト処理ユニットCおよびデータ取得・処理ユニットDが設置されている点以外は、実施形態1のオールインワン型の場合と同様である。
図24は、本発明の実施形態2に係るウェブコンテンツの自動高速表示制御方法を実施するための自動高速表示制御システムであり、リバースプロキシ型の構成を記載した概略図である。
本発明に係る発明の実施形態2のリバースプロキシ型は、先に説明した実施形態1のオールインワン型と比較して、アプリケーション実行サーバ103に加えてリバースプロキシサーバ1703を使用する点、
またリバースプロキシサーバ1703に、人工知能ユニットB、リクエスト処理ユニットCおよびデータ取得・処理ユニットDが設置されている点以外は、実施形態1のオールインワン型の場合と同様である。
アプリケーション実行サーバ103およびリバースプロキシサーバ1703は、ネットワーク102を通じて互いにデータを送受信することができる。アプリケーション実行サ
ーバ103およびリバースプロキシサーバ1703にはそれぞれ通信用インターフェイス1102および通信用インターフェイス1702が設置されていて、ネットワーク102を通じてデータを送受信できる。
以下に、実施形態1のオールインワン型と異なる点を中心に説明する。
ーバ103およびリバースプロキシサーバ1703にはそれぞれ通信用インターフェイス1102および通信用インターフェイス1702が設置されていて、ネットワーク102を通じてデータを送受信できる。
以下に、実施形態1のオールインワン型と異なる点を中心に説明する。
リバースプロキシサーバ1703のハードウェア構成は、実施形態1に使用したアプリケーション実行サーバ103の場合と全く同様である。
本発明の実施形態2の場合において、実施形態1に使用したアプリケーション実行サーバ103の場合と同様、リバースプロキシサーバ1703についても一または二以上の物理マシン、一または二以上の仮想マシンならびに一または二以上のコンテナからなる群より選ばれる少なくとも一つの実行環境を採用することができる。
本発明の実施形態2の場合において、実施形態1に使用したアプリケーション実行サーバ103の場合と同様、リバースプロキシサーバ1703についても一または二以上の物理マシン、一または二以上の仮想マシンならびに一または二以上のコンテナからなる群より選ばれる少なくとも一つの実行環境を採用することができる。
図25は、本発明の実施形態2に係るウェブコンテンツの自動高速表示制御方法に使用される、リバースプロキシサーバ1703の記憶装置1701に含まれるハードウェア構成の詳細を説明するための図である。
記憶装置1701にはOS(OPERATING SYSTEM)1705が導入されていて、中央演算処理装置1700、記憶装置1701の各記憶領域、各プログラム等を制御できる。
図25に示されるように、リバースプロキシサーバ1703の記憶装置1701には人工知能ユニットB、リクエスト処理ユニットC、データ取得・処理ユニットDおよびデータベース1706設置されている。
図25に示されるように、リバースプロキシサーバ1703の記憶装置1701には人工知能ユニットB、リクエスト処理ユニットC、データ取得・処理ユニットDおよびデータベース1706設置されている。
またアプリケーション実行サーバ103の記憶装置1101にはアプリケーション処理ユニットA、オリジナルデータ記憶領域104およびデータベース1106を備えている。オリジナルデータ記憶領域104には、利用者端末101に表示されるオリジナルデータ200が保存されている。
上記以外のハードウェア構成については実施形態1のオールインワン型の場合と同様である。
上記以外のハードウェア構成については実施形態1のオールインワン型の場合と同様である。
[ユーザからのリクエストに対するリバースプロキシ型による処理の流れ]
図26~図28のそれぞれは、ユーザからのリクエストがどのように処理されるのかを説明するための模式図である。
ユーザが操作する利用者端末101のブラウザ等から送信されたリクエストは、ネットワーク102を通じてリバースプロキシサーバ1703のリクエスト処理ユニットCで受信される。
このリクエストは、リクエスト処理ユニットCから、アプリケーション実行サーバ103のアプリケーション処理ユニットAに送信される。
リクエストを受信したアプリケーション処理ユニットAはレスポンスとして例えば、HTMLファイル113等のオリジナルデータ200を、リクエスト処理ユニットCに送信する。HTMLファイル113等のオリジナルデータ200は、リクエスト処理ユニットCを通じて人工知能ユニットB、データ取得・処理ユニットDの順に送信される。
図26~図28のそれぞれは、ユーザからのリクエストがどのように処理されるのかを説明するための模式図である。
ユーザが操作する利用者端末101のブラウザ等から送信されたリクエストは、ネットワーク102を通じてリバースプロキシサーバ1703のリクエスト処理ユニットCで受信される。
このリクエストは、リクエスト処理ユニットCから、アプリケーション実行サーバ103のアプリケーション処理ユニットAに送信される。
リクエストを受信したアプリケーション処理ユニットAはレスポンスとして例えば、HTMLファイル113等のオリジナルデータ200を、リクエスト処理ユニットCに送信する。HTMLファイル113等のオリジナルデータ200は、リクエスト処理ユニットCを通じて人工知能ユニットB、データ取得・処理ユニットDの順に送信される。
人工知能ユニットBで立案された戦略案に基づいて、データ取得・処理ユニットDがHTMLファイル113等のオリジナルデータ200の最適化を行う。
最適化されたHTMLファイル113z等の加工済みデータ201は、データ取得・処理ユニットDおよびリクエスト処理ユニットCを経て、ネットワーク102を通じてユーザの利用者端末101に送信される。
最適化されたHTMLファイル113z等の加工済みデータ201は、データ取得・処理ユニットDおよびリクエスト処理ユニットCを経て、ネットワーク102を通じてユーザの利用者端末101に送信される。
最適化されたHTMLファイル113z等の加工済みデータ201には、HTMLファイル113z等により参照されてウェブコンテンツを利用者端末101のブラウザ等に表示するためのオブジェクトが記載されている。
図27に示されるように、利用者端末101のブラウザ等で最適化されたHTMLファイル113z等が実行される。この場合、最適化されたHTMLファイル113z等に記載されたオブジェクトに基づいて、オブジェクトの識別情報により対応する最適リソースを選択することができる。データ取得・処理ユニットDから最適リソースが取得され、リクエスト処理ユニットCから利用者端末101に最適リソースが送信される。
図27に示されるように、利用者端末101のブラウザ等で最適化されたHTMLファイル113z等が実行される。この場合、最適化されたHTMLファイル113z等に記載されたオブジェクトに基づいて、オブジェクトの識別情報により対応する最適リソースを選択することができる。データ取得・処理ユニットDから最適リソースが取得され、リクエスト処理ユニットCから利用者端末101に最適リソースが送信される。
図27に示されるように、最適リソースが存在しない場合には、リクエスト処理ユニットCは、オリジナルデータ200から対応するリソースを取得する。取得されたリソースは、リクエスト処理ユニットCから利用者端末101に送信される。最適リソースが存在しない場合には、バックグランドでデータ取得・処理ユニットDで最適リソースが生成されて、オリジナルデータによるリソースと置換される。
この場合、バックグランドでデータ取得・処理ユニットDが最適リソースの生成を進める。最適リソースが生成されるとオリジナルデータによるリソースは、最適リソースにより置換される。
また図28に示されるように、例えば、ユーザによる利用者端末101に搭載されたブラウザ等からリクエストがリバースプロキシサーバ1703等に送信される前等、利用者端末101とリバースプロキシサーバ1703が互いに通信をしていない時に、データ取得・処理ユニットDに設置されたクローラーユニット200Dは、アプリケーション実行サーバ103に保存されたオリジナルデータ200等をクロールする。
クロールされたオリジナルデータ200等に基づいて、データ取得・処理ユニットDに設置された最適化ユニットd100により最適化されたリソースが生成され、リバースプロキシサーバ1703のデータベース1706に蓄積される。
データ取得・処理ユニットDに設置されたクローラーユニットd200は定期的にアプリケーション処理ユニットAに保存されたオリジナルデータ200をクロールし、自動的に最適化されたリソースが生成され、データベース1706に蓄積されるステップが実施される。またオリジナルデータ200を監視し、オリジナルデータ200に変化があればオリジナルデータ200をクロールし、自動的に最適化されたリソースが生成され、利用者端末101の最適リソースとして活用される点は、先に説明した実施形態1の場合と同様である。
利用者端末101毎にどの最適リソースが選択されるかは、先に説明した実施形態1の場合と同様、人工知能ユニットBが立案した戦略案に基づいて決定される。
本発明の実施形態2に係るウェブコンテンツの自動高速表示制御方法を実施しない場合には、リバースプロキシサーバ1703のリクエスト処理ユニットCを経由してアプリケーション実行サーバ103に送信されたリクエストを受信したアプリケーション処理ユニットAは、ユーザの利用者端末101にウェブコンテンツを表示するためのオリジナルデータ200をレスポンスとして送信する。このレスポンスはリバースプロキシサーバ1703のリクエスト処理ユニットCを経て、ネットワーク102を通じて利用者端末101に受信される。そして利用者端末101に搭載されたブラウザ等により、オリジナルデータ200に基づくウェブコンテンツが利用者端末101に表示される。
本発明に係る発明の実施形態2のウェブコンテンツの自動高速表示制御方法によれば、利用者端末101にウェブコンテンツを表示させるためのオリジナルデータ200が保存されたアプリケーション処理ユニットAを含むアプリケーション実行サーバ103を運用しつつ、新たにリバースプロキシサーバ1703を導入することにより実施形態2のリバースプロキシ型を実施することができる。
実施形態2のリバースプロキシ型では、オリジナルデータ200等のマイグレーションの必要がない。またアプリケーション実行サーバ103のDNSをリバースプロキシサーバ1703に変更することにより、簡単に本発明の実施形態2に係るウェブコンテンツの自動高速表示制御方法を実施することができる。
実施形態2のリバースプロキシ型では、オリジナルデータ200等のマイグレーションの必要がない。またアプリケーション実行サーバ103のDNSをリバースプロキシサーバ1703に変更することにより、簡単に本発明の実施形態2に係るウェブコンテンツの自動高速表示制御方法を実施することができる。
本発明の実施形態2の場合も、先に説明した実施形態1の場合と同様、オリジナルデータ200が最適化され、表示完了時間の短い最適リソースを含む加工済みデータ201を用いて、オリジナルデータ200を使用した場合よりも短い表示完了時間で利用者端末101毎のブラウザ等に高速にウェブコンテンツを表示することができる。
[実施形態3:ナノエージェント型]
図29は、本発明の実施形態3に係るウェブコンテンツの自動高速表示制御方法を実施するための自動高速表示制御システムであり、ナノエージェント型の構成を記載した概略図である。
本発明に係る発明の実施形態3のナノエージェント型は、先に説明した実施形態1のオールインワン型と比較して、アプリケーション実行サーバ103に加えて人工知能サーバ1403およびデータ取得サーバ1603を使用する点が異なる。
またアプリケーション実行サーバ103にアプリケーション処理ユニットAおよびリクエスト処理ユニットCが設置されている点が異なる。
また人工知能サーバ1403に人工知能処理知能ユニットBが設置されている点、および、データ取得サーバ1603にデータ取得・処理ユニットDが設置されている点が異なる。
図29は、本発明の実施形態3に係るウェブコンテンツの自動高速表示制御方法を実施するための自動高速表示制御システムであり、ナノエージェント型の構成を記載した概略図である。
本発明に係る発明の実施形態3のナノエージェント型は、先に説明した実施形態1のオールインワン型と比較して、アプリケーション実行サーバ103に加えて人工知能サーバ1403およびデータ取得サーバ1603を使用する点が異なる。
またアプリケーション実行サーバ103にアプリケーション処理ユニットAおよびリクエスト処理ユニットCが設置されている点が異なる。
また人工知能サーバ1403に人工知能処理知能ユニットBが設置されている点、および、データ取得サーバ1603にデータ取得・処理ユニットDが設置されている点が異なる。
人工知能サーバ1403およびデータ取得サーバ1603のそれぞれのハードウェア構成は、先に説明した実施形態1のオールインワン型に使用したアプリケーション実行サーバ103の場合と同様である。
アプリケーション実行サーバ103、人工知能サーバ1403およびデータ取得サーバ1603のそれぞれは、ネットワーク102を通じて互いにデータを送受信することができる。アプリケーション実行サーバ103、人工知能サーバ1403およびデータ取得サーバ1603にはそれぞれ通信用インターフェイス1102、1402および1602が設置されていて、ネットワーク102を通じて互いにデータを送受信できる。
以下に、実施形態1のオールインワン型と異なる点を中心に説明する。
以下に、実施形態1のオールインワン型と異なる点を中心に説明する。
本発明の実施形態3の場合において、実施形態1に使用したアプリケーション実行サーバ103の場合と同様、人工知能サーバ1403およびデータ取得サーバ1603のそれぞれについても、物理マシン、仮想マシンおよびコンテナからなる群より選ばれる少なくとも一つの実行環境を用いて実行することができる。
[ユーザからのリクエストに対するナノエージェント型による処理の流れ]
図30~図32のそれぞれは、ユーザからのリクエストがどのように処理されるのかを説明するための模式図である。
ユーザが操作する利用者端末101のブラウザ等から送信されたリクエストは、ネットワーク102を通じてリクエスト処理ユニットC、アプリケーション処理ユニットAの順に送信される。
図30~図32のそれぞれは、ユーザからのリクエストがどのように処理されるのかを説明するための模式図である。
ユーザが操作する利用者端末101のブラウザ等から送信されたリクエストは、ネットワーク102を通じてリクエスト処理ユニットC、アプリケーション処理ユニットAの順に送信される。
本発明の実施形態3に係るウェブコンテンツの自動高速表示制御方法を実施しない場合には、利用者端末101毎からネットワーク102を通じてアプリケーション実行サーバ103に送信されたリクエストは、リクエスト処理ユニットC、アプリケーション処理ユ
ニットAの順に受信される。アプリケーション処理ユニットAはユーザの利用者端末101にウェブコンテンツを表示するためのオリジナルデータ200をレスポンスとしてリクエスト処理ユニットCを通じて送信する。このレスポンスはネットワーク102を通じて利用者端末101に受信される。そして利用者端末101に搭載されたブラウザ等により、オリジナルデータ200に基づくウェブコンテンツが利用者端末101に表示される。
ニットAの順に受信される。アプリケーション処理ユニットAはユーザの利用者端末101にウェブコンテンツを表示するためのオリジナルデータ200をレスポンスとしてリクエスト処理ユニットCを通じて送信する。このレスポンスはネットワーク102を通じて利用者端末101に受信される。そして利用者端末101に搭載されたブラウザ等により、オリジナルデータ200に基づくウェブコンテンツが利用者端末101に表示される。
本発明の実施形態3に係るウェブコンテンツの自動高速表示制御方法の場合は、アプリケーション処理ユニットAが生成したHTMLファイル113を利用者端末101に送信することもできる。
一方でリクエスト処理ユニットCはアプリケーション処理ユニットAからネットワーク102を通じて利用者端末101にレスポンスが実行される処理に割り込み、HTMLファイル113等のオリジナルデータ200を取得する。
取得されたHTMLファイル113等のオリジナルデータ200に基づいて、リクエスト処理ユニットCからリクエストが、ネットワーク102を通じて人工知能サーバ1403の人工知能ユニットB、データ取得サーバ1603のデータ取得・処理ユニットDの順に送信される。人工知能サーバ1403の人工知能ユニットBで立案された戦略案に基づいて、データ取得サーバ1603のデータ取得・処理ユニットDがHTMLファイル113等のオリジナルデータ200の最適化を行う。
最適化されたHTMLファイル113z等の加工済みデータ201は、データ取得・処理ユニットDが設置されたデータ取得サーバ1603、人工知能サーバ1403を経て、アプリケーション実行サーバ103のリクエスト処理ユニットC、ネットワーク102を通じてユーザの利用者端末101に送信される。
一方でリクエスト処理ユニットCはアプリケーション処理ユニットAからネットワーク102を通じて利用者端末101にレスポンスが実行される処理に割り込み、HTMLファイル113等のオリジナルデータ200を取得する。
取得されたHTMLファイル113等のオリジナルデータ200に基づいて、リクエスト処理ユニットCからリクエストが、ネットワーク102を通じて人工知能サーバ1403の人工知能ユニットB、データ取得サーバ1603のデータ取得・処理ユニットDの順に送信される。人工知能サーバ1403の人工知能ユニットBで立案された戦略案に基づいて、データ取得サーバ1603のデータ取得・処理ユニットDがHTMLファイル113等のオリジナルデータ200の最適化を行う。
最適化されたHTMLファイル113z等の加工済みデータ201は、データ取得・処理ユニットDが設置されたデータ取得サーバ1603、人工知能サーバ1403を経て、アプリケーション実行サーバ103のリクエスト処理ユニットC、ネットワーク102を通じてユーザの利用者端末101に送信される。
最適化されたHTMLファイル113z等の加工済みデータ201には、例えば、HTMLファイル113z等により参照されてウェブコンテンツを利用者端末101のブラウザ等に表示するためのオブジェクトが記載されている。
最適化されたHTMLファイル113z等に記載されたプログラムのオブジェクトによる参照情報に基づいて、リクエスト処理ユニットCは、データ取得・処理ユニットDから最適リソースを取得し、データ取得サーバ1603、人工知能サーバ1403およびアプリケーション実行サーバ103を経て、ネットワーク102を通じて利用者端末101に送信する。
最適化されたHTMLファイル113z等に記載されたプログラムのオブジェクトによる参照情報に基づいて、リクエスト処理ユニットCは、データ取得・処理ユニットDから最適リソースを取得し、データ取得サーバ1603、人工知能サーバ1403およびアプリケーション実行サーバ103を経て、ネットワーク102を通じて利用者端末101に送信する。
最適リソースが存在しない場合には、アプリケーション実行サーバ103のアプリケーション処理ユニットAは、オリジナルデータ200から対応するリソースを取得する。取得されたリソースは、アプリケーション実行サーバ103のリクエスト処理ユニットCからネットワーク102を通じて利用者端末101に送信される。最適リソースが存在しない場合には、バックグランドでデータ取得・処理ユニットDで最適リソースが生成されて、オリジナルデータによるリソースと置換される。
また例えば、ユーザによる利用者端末101に搭載されたブラウザ等からリクエストがアプリケーション実行サーバ103に送信される前等、利用者端末101とアプリケーション実行サーバ103が互いに通信をしていない時に、データ取得サーバ1603のデータ取得・処理ユニットDに設置されたクローラーユニットd200は、アプリケーション実行サーバ103に保存されたオリジナルデータ200等をクロールする。
クロールされたオリジナルデータ200等に基づいて、データ取得サーバ1603のデータ取得・処理ユニットDに設置された最適化ユニットd100により最適化されたリソースが生成され、データベース1606に蓄積される。またオリジナルデータ200を監視し、オリジナルデータ200に変化があればオリジナルデータ200をクロールし、自
動的に最適化されたリソースが生成され、利用者端末101の最適リソースとして活用される点は、先に説明した実施形態1の場合と同様である。
動的に最適化されたリソースが生成され、利用者端末101の最適リソースとして活用される点は、先に説明した実施形態1の場合と同様である。
本発明に係る発明の実施形態3のウェブコンテンツの自動高速表示制御方法によれば、利用者端末101にウェブコンテンツを表示させるためのオリジナルデータ200が保存されたアプリケーション処理ユニットAを含むアプリケーション実行サーバ103に対してリクエスト処理ユニットCを設置することにより、ネットワーク102を通じて利用できる、世界中に分散配置された、それぞれ一または二以上の人工知能サーバ1403およびデータ取得サーバ1603を利用することができる。
実施形態3のナノエージェント型では、オリジナルデータ200等のマイグレーションの必要がない。またアプリケーション実行サーバ103のDNSを変更する必要もないことから、簡単に本発明の実施形態3に係るウェブコンテンツの自動高速表示制御方法を実施することができる。
実施形態3のナノエージェント型では、オリジナルデータ200等のマイグレーションの必要がない。またアプリケーション実行サーバ103のDNSを変更する必要もないことから、簡単に本発明の実施形態3に係るウェブコンテンツの自動高速表示制御方法を実施することができる。
また必要に応じて、例えば、データ取得サーバ1603のデータ取得・処理ユニットDと同じユニットを備えたサーバをアプリケーション実行サーバ103の近距離に追加して設置して、データ取得サーバ1603のデータ取得・処理ユニットDと同じ処理を実施させることにより、通信速度の低下を防止することもできる。
本発明の実施形態3のナノエージェント型の場合は、特別なマイグレーション、DNSの変更を必要としないため、既に稼働しているウェブコンテンツを配信するシステムに簡単に適用することができる。
本発明の実施形態3の場合も、先に説明した実施形態1の場合と同様、オリジナルデータ200が最適化され、表示完了時間の短い最適リソースを含む加工済みデータ201を用いて、オリジナルデータ200を使用した場合よりも短い表示完了時間で利用者端末101毎のブラウザ等に高速にウェブコンテンツを表示することができる。
[実施形態4:SaaS型]
図33は、本発明の実施形態4に係るウェブコンテンツの自動高速表示制御方法を実施するための自動高速表示制御システムであり、SaaS型の構成を記載した概略図である。
本発明に係る発明の実施形態4のSaaS(Software as a Service)型は、先に説明した実施形態1のオールインワン型と比較して、アプリケーション処理ユニットA、人工知能処理知能ユニットB、リクエスト処理ユニットCおよびデータ取得・処理ユニットDのそれぞれがクラウド1803上に設置されている点が異なる。
先の実施形態1のオールインワン型の場合は一つの実行環境内でそれぞれのユニットAからDが相互に通信可能であった。
こに対して実施形態1のSaaS型の場合は、ネットワーク102を通じてそれぞれのユニットAからDが相互に通信可能となっている。
それ以外は実施形態1の場合と同様である。
図33は、本発明の実施形態4に係るウェブコンテンツの自動高速表示制御方法を実施するための自動高速表示制御システムであり、SaaS型の構成を記載した概略図である。
本発明に係る発明の実施形態4のSaaS(Software as a Service)型は、先に説明した実施形態1のオールインワン型と比較して、アプリケーション処理ユニットA、人工知能処理知能ユニットB、リクエスト処理ユニットCおよびデータ取得・処理ユニットDのそれぞれがクラウド1803上に設置されている点が異なる。
先の実施形態1のオールインワン型の場合は一つの実行環境内でそれぞれのユニットAからDが相互に通信可能であった。
こに対して実施形態1のSaaS型の場合は、ネットワーク102を通じてそれぞれのユニットAからDが相互に通信可能となっている。
それ以外は実施形態1の場合と同様である。
クラウド環境下では、ネットワーク102を通じて通信可能な一または二以上の物理マシン、一または二以上の仮想マシン、ならびに一または二以上のコンテナからなる群より選ばれる少なくとも一つからなる実行環境をネットワーク102上に構築することができる。
本発明の実施形態4に係るウェブコンテンツの自動高速表示制御方法は、このクラウド環境下に構築することもできる。このクラウド環境下に構築されているものがSaas型である。
本発明の実施形態4の場合には、使用するクラウドプラットフォームの種類、提供する企業の相違、クラウド環境を実行するためのデータセンターが自国にあるか外国にあるか等の相違に関係なく、実行環境を選択して構築することができる。
本発明の実施形態4に係るウェブコンテンツの自動高速表示制御方法は、このクラウド環境下に構築することもできる。このクラウド環境下に構築されているものがSaas型である。
本発明の実施形態4の場合には、使用するクラウドプラットフォームの種類、提供する企業の相違、クラウド環境を実行するためのデータセンターが自国にあるか外国にあるか等の相違に関係なく、実行環境を選択して構築することができる。
[ユーザからのリクエストに対するSaaS型による処理の流れ]
図34~図36のそれぞれは、ユーザからのリクエストがどのように処理されるのかを説明するための模式図である。
ユーザが操作する利用者端末101のブラウザ等から送信されたリクエストは、ネットワーク102を通じてリクエスト処理ユニットCに送信される。
図34~図36のそれぞれは、ユーザからのリクエストがどのように処理されるのかを説明するための模式図である。
ユーザが操作する利用者端末101のブラウザ等から送信されたリクエストは、ネットワーク102を通じてリクエスト処理ユニットCに送信される。
本発明の実施形態4に係るウェブコンテンツの自動高速表示制御方法を実施しない場合には、クラウド1803に送信されたリクエストを受信したリクエスト処理ユニットCは、アプリケーション処理ユニットAを通じて、ユーザの利用者端末101にウェブコンテンツを表示するためのオリジナルデータ200をレスポンスとして送信する。このレスポンスはネットワーク102を通じて利用者端末101に受信される。そして利用者端末101に搭載されたブラウザ等により、オリジナルコンテンツが利用者端末101に表示される。
本発明の実施形態4に係るウェブコンテンツの自動高速表示制御方法の場合は、例えば、アプリケーション処理ユニットAで動的に生成されて保存されているHTMLファイル113等のオリジナルデータを利用者端末101に送信することもできる。
一方で図34に示されるように、リクエスト処理ユニットCはアプリケーション処理ユニットAからネットワーク102を通じて利用者端末101にレスポンスが実行される処理に割り込み、HTMLファイル113等を取得する。
例えば、取得されたHTMLファイル113等に基づいて、リクエスト処理ユニットCからリクエストがネットワーク102を通じて人工知能ユニットB、データ取得・処理ユニットDに送信される。人工知能ユニットBで立案された戦略案に基づいて、データ取得・処理ユニットDがHTMLファイル113等の最適化を行う。
例えば、最適化されたHTMLファイル113zは、データ取得・処理ユニットD、人工知能ユニットBおよびリクエスト処理ユニットCを経て、ネットワーク102を通じてユーザの利用者端末101に送信される。
一方で図34に示されるように、リクエスト処理ユニットCはアプリケーション処理ユニットAからネットワーク102を通じて利用者端末101にレスポンスが実行される処理に割り込み、HTMLファイル113等を取得する。
例えば、取得されたHTMLファイル113等に基づいて、リクエスト処理ユニットCからリクエストがネットワーク102を通じて人工知能ユニットB、データ取得・処理ユニットDに送信される。人工知能ユニットBで立案された戦略案に基づいて、データ取得・処理ユニットDがHTMLファイル113等の最適化を行う。
例えば、最適化されたHTMLファイル113zは、データ取得・処理ユニットD、人工知能ユニットBおよびリクエスト処理ユニットCを経て、ネットワーク102を通じてユーザの利用者端末101に送信される。
最適化されたHTMLファイル113z等には、HTMLファイル113zに記載されたプログラムにより定義されたオブジェクトにより参照されてウェブコンテンツを利用者端末101のブラウザ等に表示するためのオブジェクトが記載されている。
最適化されたHTMLファイル113z等に記載されたそれぞれのオブジェクトが指定する参照情報に基づいて、リクエスト処理ユニットCは、データ取得・処理ユニットDから最適リソースを取得し、人工知能ユニットBを経て利用者端末101に送信する。
最適化されたHTMLファイル113z等に記載されたそれぞれのオブジェクトが指定する参照情報に基づいて、リクエスト処理ユニットCは、データ取得・処理ユニットDから最適リソースを取得し、人工知能ユニットBを経て利用者端末101に送信する。
図35に示されるように、最適リソースが存在しない場合には、リクエスト処理ユニットCは、オリジナルデータ200から対応するリソースを取得する。取得されたリソースは、アプリケーション処理ユニットAからリクエスト処理ユニットCを経て利用者端末101に送信される。最適リソースが存在しない場合には、バックグランドでデータ取得・処理ユニットDで最適リソースが生成されて、オリジナルデータによるリソースと置換される。
また、図36に示されるように、例えば、ユーザによる利用者端末101に搭載されたブラウザ等からリクエストがリクエスト処理ユニットCに送信される前等、利用者端末101とリクエスト処理ユニットCが互いに通信をしていない時に、データ取得・処理ユニットDに設置されたクローラーユニットd200は、アプリケーション処理ユニットAに保存されたオリジナルデータ200等をクロールする。
クロールされたオリジナルデータ200等に基づいて、データ取得・処理ユニットDに設置された最適化ユニットd100により最適化されたリソースが生成され、クラウド1803に設置されたデータベース1706に蓄積される。
データ取得・処理ユニットDに設置されたクローラーユニットd200は定期的にアプリケーション処理ユニットAが利用することができるオリジナルデータ200をクロールし、自動的に最適化されたリソースが生成され、データベース1706に蓄積されるステップが実施される。またオリジナルデータ200を監視し、オリジナルデータ200に変化があればオリジナルデータ200をクロールし、自動的に最適化されたリソースが生成され、利用者端末101の最適リソースとして活用される点は、先に説明した実施形態1の場合と同様である。
本発明に係る発明の実施形態4のウェブコンテンツの自動高速表示制御方法を実施するには、ウェブコンテンツを利用者端末101に表示するために運用されている従来のサーバとは別に、クラウド環境にオリジナルデータ200等、これらのオリジナルデータ200等を利用者端末に表示させるための環境等のマイグレーションを実施する。
またウェブコンテンツを利用者端末101に表示するために運用されている従来のサーバのDNSをクラウド1803に変更する。
このようにマイグレーションとDNSを実施するだけで、ウェブコンテンツを利用者端末101に表示するために運用されている従来のサーバの環境に変更を加えることなくクラウド上に実施形態4のSasS型を実施できる。
またウェブコンテンツを利用者端末101に表示するために運用されている従来のサーバのDNSをクラウド1803に変更する。
このようにマイグレーションとDNSを実施するだけで、ウェブコンテンツを利用者端末101に表示するために運用されている従来のサーバの環境に変更を加えることなくクラウド上に実施形態4のSasS型を実施できる。
本発明の実施形態4の場合も、先に説明した実施形態1の場合と同様、オリジナルデータ200が最適化され、表示完了時間の短い最適リソースを含む加工済みデータ201を用いて、オリジナルデータ200を使用した場合よりも短い表示完了時間で利用者端末101毎のブラウザ等に高速にウェブコンテンツを表示することができる。
[実施形態5]
次に本発明の実施形態5に係るウェブコンテンツの自動高速表示制御方法について説明する。
実施形態5に係るウェブコンテンツの自動高速表示制御方法を実現するために必要なステップは、先に説明した本発明の実施形態1から4のいずれの場合でも以下に説明するステップに従って実施できる。
ここでは、一つの例として、先に説明した実施形態1のオールインワン型を例に挙げて説明する。実施形態5に使用するオールインワン型のハードウェア構成は、先に説明いた実施形態1の場合と同様である。
次に本発明の実施形態5に係るウェブコンテンツの自動高速表示制御方法について説明する。
実施形態5に係るウェブコンテンツの自動高速表示制御方法を実現するために必要なステップは、先に説明した本発明の実施形態1から4のいずれの場合でも以下に説明するステップに従って実施できる。
ここでは、一つの例として、先に説明した実施形態1のオールインワン型を例に挙げて説明する。実施形態5に使用するオールインワン型のハードウェア構成は、先に説明いた実施形態1の場合と同様である。
以下に、先の実施形態1と異なる点を中心に説明する。
本発明の実施形態5では、一例として、利用者端末101としてスマートフォンが採用されている。下記に説明するウェブコンテンツ211の生成ステップは、本発明の実施形態1の場合と同様である。
本発明の実施形態5では、一例として、利用者端末101としてスマートフォンが採用されている。下記に説明するウェブコンテンツ211の生成ステップは、本発明の実施形態1の場合と同様である。
図37は、利用者端末101にウェブコンテンツ211が高速表示される仕組みを説明するための概念図である。
利用者端末101にウェブコンテンツ211が高速表示されることを妨げる要因として、大きく二つの要素が存在する。
一つは、通信の渋滞401であり、残る一つは描画の渋滞402である。
通常、オリジナルデータ200(図37の参照符号400)には、個別の利用者端末101には不要なデータも含まれる。このため、オリジナルデータ200がそのまま利用者端末101に送信されると、利用者端末101にオリジナルデータの送信完了まで余分な時間がかかることになる。
先の実施形態1の場合では、主として、図37における通信の渋滞401を改善する配信最適化に関するものであった(図37の参照符号403)。
実施形態5の場合では、通信の渋滞401の解消に加えて、描画の渋滞402の解消を実現する。
利用者端末101にウェブコンテンツ211が高速表示されることを妨げる要因として、大きく二つの要素が存在する。
一つは、通信の渋滞401であり、残る一つは描画の渋滞402である。
通常、オリジナルデータ200(図37の参照符号400)には、個別の利用者端末101には不要なデータも含まれる。このため、オリジナルデータ200がそのまま利用者端末101に送信されると、利用者端末101にオリジナルデータの送信完了まで余分な時間がかかることになる。
先の実施形態1の場合では、主として、図37における通信の渋滞401を改善する配信最適化に関するものであった(図37の参照符号403)。
実施形態5の場合では、通信の渋滞401の解消に加えて、描画の渋滞402の解消を実現する。
本発明の開示において、描画とは、利用者端末101にウェブコンテンツ211等が表示されることをいう。
図37に示される描画の渋滞401が生じる理由の一つは、雑多な多量の情報が、一気にリクエスト処理ユニットCから利用者端末101に送信されようとするからである。
図37に示される描画の渋滞401が生じる理由の一つは、雑多な多量の情報が、一気にリクエスト処理ユニットCから利用者端末101に送信されようとするからである。
本発明に係る実施形態5の場合では、ウェブコンテンツ211の表示に必要なリソースの中から、最初に利用者端末101に送信すべき情報として、ファーストビューに対応する部分の描画が優先される(図37の参照符号404)。
次に、通信規制を行い、利用者端末101がユーザからの入力受付可能な状態に移行することを優先する(図37の参照符号404)。
続いて、通信整理を行い、ウェブコンテンツ211の表示に必要なりソースの中から、ファーストビューに対応する部分以外が秩序立てられて利用者端末101に送信される(図37の参照符号405)。
次に、通信規制を行い、利用者端末101がユーザからの入力受付可能な状態に移行することを優先する(図37の参照符号404)。
続いて、通信整理を行い、ウェブコンテンツ211の表示に必要なりソースの中から、ファーストビューに対応する部分以外が秩序立てられて利用者端末101に送信される(図37の参照符号405)。
ここで利用者端末101がユーザからの入力受付可能な状態に移行する、とは、利用者端末101がユーザによる、スクロール、タップ、クリック、ドラッグ等の画面操作、各種テキスト入力、音声入力、画像入力等の入力操作を受け付けることができる状態になることをいう。
またウェブコンテンツ211の表示に必要なリソースの中から、ファーストビューに対応する部分以外が秩序立てられて利用者端末101に送信される、とは、例えば、ファーストビューに対応する部分以外の描画に必要なプログラムの部分が二以上ある場合、互いにプログラムの部分同士が干渉しあう場合には、一方を優先させて実施し、優先させて実施させたプログラムの部分の完了を待ってから、次のプログラムの部分の実行に移る同期実行の場合、
互いにプログラムの部分同士が干渉しない場合には、他のプログラムの部分の完了を待たずに、プログラムの部分の実行を開始する非同期実行の場合等を意味する。
互いにプログラムの部分同士が干渉しない場合には、他のプログラムの部分の完了を待たずに、プログラムの部分の実行を開始する非同期実行の場合等を意味する。
次に本発明に係る実施形態5について詳細に説明する。
利用者端末101に搭載されるブラウザ等からリクエスト処理ユニットCにリクエストが送信される前に、全てのアプリケーション処理ユニットAに保存されたそれぞれのオリジナルデータ200が、データ取得・処理ユニットDにより加工されて、複数の加工済みデータ201が生成されている。
この複数の加工済みデータ201は、リクエスト処理ユニットCにアクセスすることが予想される全ての利用者端末101に対応して、利用者端末101からアプリケーション実行サーバ103に対してリクエストが送信される前に、自動で生成される。
利用者端末101に搭載されるブラウザ等からリクエスト処理ユニットCにリクエストが送信される前に、全てのアプリケーション処理ユニットAに保存されたそれぞれのオリジナルデータ200が、データ取得・処理ユニットDにより加工されて、複数の加工済みデータ201が生成されている。
この複数の加工済みデータ201は、リクエスト処理ユニットCにアクセスすることが予想される全ての利用者端末101に対応して、利用者端末101からアプリケーション実行サーバ103に対してリクエストが送信される前に、自動で生成される。
加工済みデータ201は、それぞれの利用者端末101に対して、利用者端末101のブラウザにおける初期表示画面Aに対応する、ファーストビューと呼ばれるウェブコンテンツ211aに対応する複数の加工済みデータ201と、利用者端末101のブラウザにおける初期表示画面Aに対応しない、ファーストビューとは異なるウェブコンテンツ211bに対応する複数の加工済みデータ201とに分割されて生成されている。
利用者端末101からアプリケーション処理ユニットAにリクエストが送信されてから、利用者端末101でウェブコンテンツ211aが利用者端末101で入力受付可能になるまでの時間が最短になることを基準に、オリジナルデータ200と複数の加工済みデータ201の中からファーストビューに表示されるウェブコンテンツに対応する処理済みデータ210が選択される。
利用者端末101からアプリケーション処理ユニットAにリクエストが送信されてから、利用者端末101でウェブコンテンツ211aが利用者端末101で入力受付可能になるまでの時間が最短になることを基準に、オリジナルデータ200と複数の加工済みデータ201の中からファーストビューに表示されるウェブコンテンツに対応する処理済みデータ210が選択される。
それぞれの利用者端末101について、データ取得・処理ユニットDで、どのように加工するか、どのように組み合わせるか等の情報と、それぞれの利用者端末101で最短でウェブコンテンツ211aが入力受付可能になるまでの時間に関する処理済みデータ210との相関関係を、予備試験により、人工知能ユニットBは既に学習している。
予備試験により得られたデータを用いて統計処理を行い、最適な処理済みデータ210を選択する戦略案を人工知能ユニットBは立案することができる。
アプリケーション処理ユニットAに保存されているオリジナルデータ200が動的に生成された場合でも、変更を受けた場合でも、オリジナルデータ200に変更があった場合には、これまでの人工知能ユニットBが立案した戦略案に基づき、新たな処理済みデータ210が生成される。
予備試験により得られたデータを用いて統計処理を行い、最適な処理済みデータ210を選択する戦略案を人工知能ユニットBは立案することができる。
アプリケーション処理ユニットAに保存されているオリジナルデータ200が動的に生成された場合でも、変更を受けた場合でも、オリジナルデータ200に変更があった場合には、これまでの人工知能ユニットBが立案した戦略案に基づき、新たな処理済みデータ210が生成される。
実際に利用者端末101からリクエスト処理ユニットCにリクエストがあった場合には、ウェブコンテンツ211の全てが利用者端末101に送信されるのではなく、利用者端末101のブラウザにおける初期表示画面Aに対応する、ファーストビューと呼ばれるウェブコンテンツ211aを表示するために必要な加工済みデータ201を含む最小限の部分が最初に分割されて送信される。
利用者端末101に搭載されるブラウザ等からリクエスト処理ユニットCにリクエストが送信されると、リクエストを受信したリクエスト処理ユニットCからアプリケーション処理ユニットAと人工知能ユニットに送信される。またそのリクエストは人工知能ユニットBを経由して、または人工知能ユニットBを経由せずに直接、データ取得・処理ユニットDにネットワーク102を通じて送信される。
[利用者端末101の初期表示画面に対応するデータを特定するステップ]
利用者端末101の表示環境は、利用者端末101からアプリケーション処理ユニットAに送信された信号に含まれるユーザエージェント、リファラ等の情報を、データ取得・処理ユニットDの設定ファイル格納部1523に保存された機種情報ファイル1526と照合して特定できる。
利用者端末101の表示環境は、利用者端末101からアプリケーション処理ユニットAに送信された信号に含まれるユーザエージェント、リファラ等の情報を、データ取得・処理ユニットDの設定ファイル格納部1523に保存された機種情報ファイル1526と照合して特定できる。
実際に、利用者端末101毎に、ウェブコンテンツ211のうち、どの部分がファーストビューに対応するかどうかは、事前に予備試験、また予備試験により得られたデータによる機械学習により形成された学習済みモデルを用いて決定することができる。
利用者端末101のブラウザにおける初期表示画面Aの表示環境は、機種情報ファイル1526に記載された情報に基づいて特定できる。
利用者端末101のブラウザにおける初期表示画面Aの表示環境は、機種情報ファイル1526に記載された情報に基づいて特定できる。
例えば、先に図16により説明したHTMLファイル113および最適化されたHTMLファイル113zに記載された文字、数字、記号等のプログラムデータの情報、
CSSファイル107および処理済みCSSファイル132に記載されたプログラムデータの大きさ等の情報、
画像ファイル109および処理済み画像ファイル134の大きさ、配置位置等の情報から、HTMLファイル113、CSSファイル107、スクリプト言語ファイル108、最適化されたHTMLファイル113z、処理済みCSSファイル132、処理済みスクリプト言語ファイル133、画像ファイル109および処理済み画像ファイル134等のうち、どの部分が利用者端末101のブラウザにおけるファーストビューに対応する初期
表示画面Aに表示されるかが特定される。
CSSファイル107および処理済みCSSファイル132に記載されたプログラムデータの大きさ等の情報、
画像ファイル109および処理済み画像ファイル134の大きさ、配置位置等の情報から、HTMLファイル113、CSSファイル107、スクリプト言語ファイル108、最適化されたHTMLファイル113z、処理済みCSSファイル132、処理済みスクリプト言語ファイル133、画像ファイル109および処理済み画像ファイル134等のうち、どの部分が利用者端末101のブラウザにおけるファーストビューに対応する初期
表示画面Aに表示されるかが特定される。
利用者端末101の表示環境が特定されると、この表示環境を使って表示できる、それぞれファーストビューに対応した、HTMLファイル113、CSSファイル107、スクリプト言語ファイル108、最適化されたHTMLファイル113z、処理済みCSSファイル132、処理済みスクリプト言語ファイル133、画像ファイル109、処理済み画像ファイル134等が特定される。
これらの特定は、データ取得・処理ユニットDに搭載された、コントロールユニットd300に記載されたプログラムにより実施される。
これらの特定は、データ取得・処理ユニットDに搭載された、コントロールユニットd300に記載されたプログラムにより実施される。
[利用者端末の初期表示画面以外に対応するデータを特定するステップ]
利用者端末101のブラウザにおける初期表示画面Aに表示されるデータが特定されれば、それに伴って、利用者端末101のファーストビューに対応する初期表示画面A以外に対応するデータを特定できる。
利用者端末101のブラウザにおける初期表示画面Aに表示されるデータが特定されれば、それに伴って、利用者端末101のファーストビューに対応する初期表示画面A以外に対応するデータを特定できる。
ウェブコンテンツ211、ウェブコンテンツ212の中から、利用者端末101のブラウザにおける初期表示画面Aに表示されるデータを除いたデータが、利用者端末101の初期表示画面A以外に対応するデータとなる。
具体例に従って説明する。
例えば、ウェブコンテンツ211は、ファーストビューに対応するウェブコンテンツ211aおよびファーストビューに対応しないウェブコンテンツ211bを含む。
ウェブコンテンツ211を表示するためのリソースは、HTMLファイル113または最適化されたHTMLファイル113zのうち、ファーストビューに対応するHTMLデータ301を含む。
またCSSファイル107および処理済みCSSファイル132のうち、ファーストビューに対応するCSSデータ302を含む。
例えば、ウェブコンテンツ211は、ファーストビューに対応するウェブコンテンツ211aおよびファーストビューに対応しないウェブコンテンツ211bを含む。
ウェブコンテンツ211を表示するためのリソースは、HTMLファイル113または最適化されたHTMLファイル113zのうち、ファーストビューに対応するHTMLデータ301を含む。
またCSSファイル107および処理済みCSSファイル132のうち、ファーストビューに対応するCSSデータ302を含む。
スクリプト言語ファイル108および処理済みスクリプト言語ファイル133のうち、ファーストビューに対応するスクリプト言語データ303を含む。
画像ファイル109および処理済み画像ファイル134のうち、ファーストビューに対応する画像データ304を含む。
画像ファイル109および処理済み画像ファイル134のうち、ファーストビューに対応する画像データ304を含む。
利用者端末101のファーストビューに対応したウェブコンテンツ211aを表示するためのリソースを受信した利用者端末101は、利用者端末101に搭載されたブラウザにウェブコンテンツ211aを短い表示完了時間で表示することができる。
次に、ファーストビューに対応しないウェブコンテンツ211bのうち、利用者端末101がユーザからの入力受付を可能にするためのコード部分が優先されて利用者端末101に送信される(図37の参照符号404)。
次に利用者端末101にファーストビューに対応するウェブコンテンツ211aが表示された後のステップについて、ユーザの行動に沿って説明する。
利用者端末101のユーザは、利用者端末101のブラウザに表示されたウェブコンテンツ211aに興味を示す場合には、利用者端末101のブラウザに対して追加の情報を表示させる行動を起こす。
逆に利用者端末101のユーザは、利用者端末101のブラウザに表示されたウェブコンテンツ211aに興味を示さない場合には、いわゆる離脱と呼ばれる行動を起こす。
利用者端末101のユーザは、利用者端末101のブラウザに表示されたウェブコンテンツ211aに興味を示す場合には、利用者端末101のブラウザに対して追加の情報を表示させる行動を起こす。
逆に利用者端末101のユーザは、利用者端末101のブラウザに表示されたウェブコンテンツ211aに興味を示さない場合には、いわゆる離脱と呼ばれる行動を起こす。
利用者端末101のユーザが、利用者端末101のブラウザに表示されたファーストビューに対応するウェブコンテンツ211aに興味を示す場合に、そのユーザが利用者端末101に対して追加の情報を表示させる行動を起こす場合の具体例は次の通りである。
例えば、利用者端末101のユーザは、利用者端末101のブラウザに表示されたボタン等をクリックする、利用者端末101のブラウザにおける初期表示画面Aをスクロールすれば表示される情報を見るために、ユーザが利用者端末101のブラウザをスクロールする、利用者端末101のブラウザにおける初期表示画面Aの表示から一定時間経過したにも関わらず初期表示画面Aから離脱せず、表示された内容を読み進める等の行動を起こす。
ユーザのクリック、スクロール等の利用者端末101に対する行動があると利用者端末101に搭載されたブラウザがイベント情報を検出する。
この一方、ユーザが最初に利用者端末101のブラウザ等からリクエストを送信した際に、例えば、そのリクエストに対応して、最適化されたHTMLファイル113z等が最初に利用者端末101にダウンロードされている。
この最適化されたHTMLファイル113z等には、リソースについての参照情報がプログラムの関数としてのオブジェクトとして記載されている。
また最適化されたHTMLファイル113z等には、オブジェクトを最適化されたHTMLファイル113z等にプログラムの関数として挿入するためのオブジェクトも記載されている。
この最適化されたHTMLファイル113z等には、リソースについての参照情報がプログラムの関数としてのオブジェクトとして記載されている。
また最適化されたHTMLファイル113z等には、オブジェクトを最適化されたHTMLファイル113z等にプログラムの関数として挿入するためのオブジェクトも記載されている。
すなわち、最適化されたHTMLファイル113z等のオブジェクトを利用して、任意のプログラムコードを追加して記載することが可能である。
この仕組みにより、利用者端末101に搭載されたブラウザがイベント情報を検出した際に動作するプログラムコードを記載することができる。
この仕組みにより、利用者端末101に搭載されたブラウザがイベント情報を検出した際に動作するプログラムコードを記載することができる。
利用者端末101に搭載されたブラウザがイベント情報を検出すると、最適化されたHTMLファイル113z等に追加されたプログラムコードにより、ただちに残りのウェブコンテンツ211bを表示するための残りのリソースが、ネットワーク102を経由して利用者端末101に送信される。
このように、利用者端末101毎のブラウザ等のファーストビューに必要なリソースとファーストビューに必要のないリソースについて、利用者端末101毎にダウンロードを順位付けすることにより、利用者端末101毎のブラウザ等での描画の渋滞を避けることができる。
ウェブコンテンツ211bを表示するためのリソースを受信した利用者端末101は、利用者端末101に搭載されたブラウザにウェブコンテンツ211bを高速に表示することができる。
なおウェブコンテンツ211bを表示するためのリソースは、利用者端末101に対して一度に送信されてもよいし、分割して送信されてもよい。
なおウェブコンテンツ211bを表示するためのリソースは、利用者端末101に対して一度に送信されてもよいし、分割して送信されてもよい。
ウェブコンテンツ211bを表示するためのリソースの送信については、利用者端末101に対してウェブコンテンツ211bの表示に関連するプログラムの部分同士が干渉する場合には、同期して一つのプログラムの部分の実施が完了した後に、続くプログラムの部分の実施が開始される。
逆に利用者端末101に対してウェブコンテンツ211bの表示に関連するプログラムの部分同士が干渉しない場合には、非同期にそれぞれのプログラムの部分の実施が開始される。
またどのプログラムの実施を優先するか、遅延させるか等についての制御が、人工知能ユニットBが立案した戦略案に従って、データ取得・処理ユニット103に搭載された、コントロールユニットd300に記載されたプログラムにより実現される。このプログラムを最適化されたHTMLファイル113z等のオブジェクトに反映させることにより、ウェブコンテンツの自動高速表示が実現される。
逆に利用者端末101に対してウェブコンテンツ211bの表示に関連するプログラムの部分同士が干渉しない場合には、非同期にそれぞれのプログラムの部分の実施が開始される。
またどのプログラムの実施を優先するか、遅延させるか等についての制御が、人工知能ユニットBが立案した戦略案に従って、データ取得・処理ユニット103に搭載された、コントロールユニットd300に記載されたプログラムにより実現される。このプログラムを最適化されたHTMLファイル113z等のオブジェクトに反映させることにより、ウェブコンテンツの自動高速表示が実現される。
本発明に係る実施例5の場合は、利用者端末101に対して、必要なデータを必要な時に供給することができる。このため個々の利用者端末101に対するデータ送信の渋滞、利用者端末101上でウェブコンテンツを表示するためのデータ処理の渋滞、描画の渋滞が解消される。これにより、ウェブコンテンツの自動高速表示が実現される。
ユーザの利用者端末101に最適化されたHTMLファイル113z等がダウンロードされると、最適化されたHTMLファイル113zに定義付けられているオブジェクトに対応するリソースが利用端末101にダウンロードされるか、またはネットワーク102を通じて参照可能な状態になる。
以降はユーザの利用者端末101に搭載されたブラウザ等の操作により、ユーザは自由に利用者端末101のブラウザ等によりウェブコンテンツを閲覧することができる。
以降はユーザの利用者端末101に搭載されたブラウザ等の操作により、ユーザは自由に利用者端末101のブラウザ等によりウェブコンテンツを閲覧することができる。
[実施形態6]
次に本発明の実施形態6に係るウェブコンテンツの自動高速表示制御方法について説明する。
実施形態6に係るウェブコンテンツの自動高速表示制御方法を実現するために必要なステップは、先に説明した本発明の実施形態5の場合と同様である。
次に本発明の実施形態6に係るウェブコンテンツの自動高速表示制御方法について説明する。
実施形態6に係るウェブコンテンツの自動高速表示制御方法を実現するために必要なステップは、先に説明した本発明の実施形態5の場合と同様である。
以下に、先の実施形態5と異なる点を中心に説明する。
本発明の実施形態6では、一例として、利用者端末101としてスマートフォンが採用されている。下記に説明するウェブコンテンツ211の生成ステップは、本発明の実施形態1の場合と同様である。
本発明の実施形態6では、一例として、利用者端末101としてスマートフォンが採用されている。下記に説明するウェブコンテンツ211の生成ステップは、本発明の実施形態1の場合と同様である。
ウェブコンテンツの自動高速表示を実現する際には、単にウェブコンテンツをそれぞれのユーザの利用者端末101に高速表示するだけではなく、誰に対して何を高速表示するかが問題となる。
本発明の実施形態6では、ウェブコンテンツを閲覧するユーザのユーザ体験と、ウェブコンテンツをユーザが閲覧することにより生じるユーザとウェブサイトとの間に生じるエンゲージメントに基づいて、ウェブコンテンツの自動高速表示を実現するステップが変化する。
本発明の実施形態6では、ウェブコンテンツを閲覧するユーザのユーザ体験と、ウェブコンテンツをユーザが閲覧することにより生じるユーザとウェブサイトとの間に生じるエンゲージメントに基づいて、ウェブコンテンツの自動高速表示を実現するステップが変化する。
本発明の開示で使用される「ユーザ体験」とは、利用者端末に表示されたウェブコンテンツを閲覧したユーザが体験する内容を意味する。
具体的には、例えば、ユーザがウェブコンテンツに表示されているテキスト情報を読む、テキスト情報をさらに読み進めるために、利用者端末に搭載されたブラウザをスクロールする、ウェブコンテンツに関連付けられたリンクをクリックしてリンク先の内容を閲覧する、ウェブコンテンツに関連付けられた動画ファイルを再生する、音楽ファイルを再生する、画像ファイルを閲覧する、フォーム欄にテキスト情報を入力してテキスト情報を送信する、ウェブコンテンツに表示された商品を購入する等の行為の一種もしくは二種以上が挙げられる。
実際の個々のユーザ体験は、利用者端末101毎に搭載されたブラウザ等によりイベント情報として捕捉できる。
ウェブコンテンツを閲覧するユーザが、ウェブコンテンツに興味がないか、またはウェブコンテンツに求める情報が掲載されていないと判断した場合には、ユーザは離脱と呼ばれる行動を起こす。
ユーザがウェブコンテンツを一目見ただけで離脱して、再びウェブコンテンツを閲覧することがないとすれば、そのユーザについてのユーザ体験に関連するスコアはゼロである。
ユーザがウェブコンテンツを一目見ただけで離脱して、再びウェブコンテンツを閲覧することがないとすれば、そのユーザについてのユーザ体験に関連するスコアはゼロである。
ウェブサイトのウェブコンテンツに一つまたは複数含まれるウェブページのうち、ユーザが許容できる表示完了時間は2秒以内といわれている。
どの表示完了時間なら許容されるかについては、ユーザのウェブサイトに対するエンゲージメントによって異なる。
どの表示完了時間なら許容されるかについては、ユーザのウェブサイトに対するエンゲージメントによって異なる。
例えば、ユーザがウェブサイトを信頼しており、そこに必要な情報があると確信しているのであれば、表示完了時間に対するユーザの許容時間は増加する。反対の場合は、1秒であってもユーザは待てない。
逆にユーザが離脱せず、ユーザの利用者端末に表示されたウェブコンテンツを読み進める等の行為をした場合には、ユーザ体験が増加する。
そしてユーザの利用者端末に表示されているウェブコンテンツの提供者が、ウェブサイトの管理者が提供しているウェブコンテンツに関連する行動の全てをユーザが実行すると、その時点におけるそのユーザについてのユーザ体験は最大化する。
そしてユーザの利用者端末に表示されているウェブコンテンツの提供者が、ウェブサイトの管理者が提供しているウェブコンテンツに関連する行動の全てをユーザが実行すると、その時点におけるそのユーザについてのユーザ体験は最大化する。
特定されたユーザについてのユーザ体験が最大化した場合は、そのユーザ体験に関連するスコアの相対値を100として位置づけることができる。
また本発明の開示で使用される「エンゲージメント」とは、利用者端末に表示されたウェブコンテンツを閲覧したユーザと、ウェブサイトの運営者との間に、ウェブコンテンツを介して育成される信頼関係を意味する。
本発明の開示においては、この信頼関係はユーザ体験と関連があるものとして扱う。
つまり、ユーザとウェブサイトの運営者との間にエンゲージメントがない場合、例えば、ユーザがウェブコンテンツを閲覧していない場合は、エンゲージメントは相対値としてゼロに対応する。
ただし、一度でもリクエスト処理ユニットC等に対して利用者端末101からリクエストが送信された後は、ウェブコンテンツにアクセスしたユーザ体験がエンゲージメントスコアとして加算される。このため、リクエスト処理ユニットC等にアクセスした履歴が利用者端末101等に保存されている利用者端末101に関するエンゲージメントスコアはゼロより大きい値が記録されている。
つまり、ユーザとウェブサイトの運営者との間にエンゲージメントがない場合、例えば、ユーザがウェブコンテンツを閲覧していない場合は、エンゲージメントは相対値としてゼロに対応する。
ただし、一度でもリクエスト処理ユニットC等に対して利用者端末101からリクエストが送信された後は、ウェブコンテンツにアクセスしたユーザ体験がエンゲージメントスコアとして加算される。このため、リクエスト処理ユニットC等にアクセスした履歴が利用者端末101等に保存されている利用者端末101に関するエンゲージメントスコアはゼロより大きい値が記録されている。
一方、あるユーザについてのユーザ体験が最大化した場合には、そのユーザとウェブサイトの運営者との間には十分な信頼関係が育成されたと考えることができるので、エンゲージメントは相対値として100に対応する。
つまり、それぞれのユーザについてのユーザ体験に基づくエンゲージメントの値は、相対値として0から100の間で変化する。
本発明者の知見によれば、ウェブコンテンツに興味がないユーザについてはエンゲージメントの値は小さくなり、逆にウェブコンテンツに興味を示すユーザについてはエンゲージメントの値は大きくなる傾向があることが本発明者によるこれまでの検討により判明している。
本発明の実施形態6の場合では、ユーザのエンゲージメントスコアに応じて、それぞれのユーザが閲覧する利用者端末に表示されるウェブコンテンツの表示処理が調整されて、ウェブサイトを閲覧するユーザの満足度が最大化する方法が開示される。
本発明者の知見によれば、ウェブコンテンツに興味がないユーザについてはエンゲージメントの値は小さくなり、逆にウェブコンテンツに興味を示すユーザについてはエンゲージメントの値は大きくなる傾向があることが本発明者によるこれまでの検討により判明している。
本発明の実施形態6の場合では、ユーザのエンゲージメントスコアに応じて、それぞれのユーザが閲覧する利用者端末に表示されるウェブコンテンツの表示処理が調整されて、ウェブサイトを閲覧するユーザの満足度が最大化する方法が開示される。
最初にユーザとウェブコンテンツとのエンゲージメントのスコアが算出される。
本発明の実施形態6に使用されるリクエスト処理ユニットC等にこれまでリクエストを送信したことがないユーザに関するエンゲージメントのスコアについては最低のエンゲージメントのスコアが、相対値0として割当てられる。
一度でもリクエスト処理ユニットC等にリクエストを送信したことがあるユーザに関するエンゲージメントのスコアについては、リクエストをアプリケーション処理ユニットAに送信した行為が一つのユーザ体験となるので、エンゲージメントのスコアが加算される。
本発明の実施形態6に使用されるリクエスト処理ユニットC等にこれまでリクエストを送信したことがないユーザに関するエンゲージメントのスコアについては最低のエンゲージメントのスコアが、相対値0として割当てられる。
一度でもリクエスト処理ユニットC等にリクエストを送信したことがあるユーザに関するエンゲージメントのスコアについては、リクエストをアプリケーション処理ユニットAに送信した行為が一つのユーザ体験となるので、エンゲージメントのスコアが加算される。
またウェブサイトへの訪問回数が多い、ウェブサイトでの滞在時間が長い、ウェブサイトを訪問する間隔が短い、ウェブサイトに実装されているリンク、ボタン等をクリックする回数が多い、動画ファイル・音ファイル等の再生時間が長い、動画ファイル・音ファイル等のクリック回数が多い等のユーザ体験が充実しているユーザに関してはこれらの行為の度にエンゲージメントのスコアが加算されていく。結果として、ユーザ体験が充実しているユーザに関しては、高いエンゲージメントのスコアが割当てられる。ユーザ体験が最大化したユーザに対しては、エンゲージメントのスコアが相対値100として割り当てられる。
このエンゲージメントのスコアは相対値として、0から100の間で変動する。
このエンゲージメントのスコアは相対値として、0から100の間で変動する。
まずユーザの利用者端末101の表示環境ごとに、それぞれ利用者端末101に表示されるウェブコンテンツが、エンゲージメントのスコアに基づいて選択される。
一種類の利用者端末101について、例えば、最も表示完了時間が短いウェブコンテンツ211が、最もエンゲージメントスコアの低いユーザに割り当てられる。また例えば、最も表示完了時間が長い内容が充実したウェブコンテンツ211が、最もエンゲージメントスコアの高いユーザに割り当てられる。
[利用者端末毎にエンゲージメントのスコアを算出するステップ]
次に利用者端末101毎にエンゲージメントのスコアを算出するステップについて説明する。
次に利用者端末101毎にエンゲージメントのスコアを算出するステップについて説明する。
本発明に係る実施形態6に使用するエンゲージメントのスコアは、利用者端末101毎に、リクエスト処理ユニットCに対してリクエストを送信した利用者端末101を特定する識別データと、前記識別データに関連付けられた利用者端末毎の履歴データと、に関連付けられたユーザ体験に基づいて算出される。
利用者端末101が、リクエスト処理ユニットCにリクエストを送信すると、利用者端末101を特定するアクセプトヘッダー、クッキー等のデータが、データ取得・処理ユニットDの制御部1512に記載されたプログラムを通じて、データベース506に記録される。これらのデータは利用者端末101を特定するための識別データとなる。
また利用者端末101に搭載されたブラウザにより、ユーザが行うクリック、スクロール、ドラッグ、テキストの入力等の行為は、イベントとして利用者端末101毎のクッキー等に保存される。
この情報に基づいて、先の実施形態5の場合で説明したのと同様、利用者端末101毎にダウンロードされた、最適化されたHTMLファイル113z等に追加されたプログラムによりエンゲージメントのスコアを管理できる。
この情報に基づいて、先の実施形態5の場合で説明したのと同様、利用者端末101毎にダウンロードされた、最適化されたHTMLファイル113z等に追加されたプログラムによりエンゲージメントのスコアを管理できる。
エンゲージメントのスコアの管理は、利用者端末101で実施されるが、エンゲージメントのスコアの管理は、例えば、アプリケーション実行サーバ103等の実行環境側で管理することもできる。
例えば、イベントに関するデータは、リクエスト処理ユニットC、処理ユニットAを経由して、データ取得・処理ユニット103側で検出することもできる。これらのイベント情報を信号としてデータ取得・処理ユニットDに搭載された制御部1512に送信することもできる。
ネットワーク102を介してデータ取得・処理ユニットDに送信されるイベント情報を、例えば、図4に示すデータ取得・処理ユニットDのコントロールユニットd300に定義されたイベントハンドラと対応させて解析する。このイベント情報は利用者端末101毎の履歴データとして、利用者端末101毎、および必要に応じてデータベース1106に記録される。
利用者端末101毎の履歴データとしては、例えば、ブラウザから送信されたユーザによるリクエストの回数、ブラウザから送信されたユーザによるリクエストの種類、ユーザによるウェブサイトの滞在時間ならびにブラウザから送信されたリクエスト間の期間等の一種もしくは二種以上が挙げられる。
具体的な履歴データを挙げると、次の通りである。
利用者端末101毎の履歴データとしては、例えば、ユーザがウェブコンテンツ211に表示されているテキスト情報を読む時間301、
ウェブコンテンツ211に関連付けられたリンクをクリックしてリンク先の内容を閲覧したリンク302およびリンク302をクリックした回数303、
ウェブコンテンツ211に関連付けられた動画ファイルのうち、再生された動画ファイル304、動画ファイル304を再生した回数305および動画ファイル304を閲覧した時間305、
ウェブコンテンツ211に関連付けられた音楽ファイルのうち、再生された音楽ファイル306、音楽ファイル306を再生した回数307および音楽ファイル306を閲覧した時間307、
ウェブコンテンツ211に関連付けられたフォーム欄に入力したテキスト情報308およびテキスト情報308を送信した回数309、
ウェブコンテンツ211に表示された商品のうち、購入した商品310および商品310を購入した回数311、
ウェブコンテンツ211に表示された役務のうち、提供を依頼した役務312および役務312を依頼した回数313、
アプリケーション処理ユニットAにリクエストを送信した回数313、
アプリケーション処理ユニットAにリクエストを最初に送信してから最後に送信した時までの期間314、
アプリケーション処理ユニットAにリクエストを前回送信してから今回送信した時までの期間315、
利用者端末101のブラウザ画面をスクロールした回数、タッチした回数等の回数316、
利用者端末101のブラウザ画面で移動したマウス等の距離317等が挙げられる。
利用者端末101毎の履歴データは、一種もしくは二種以上を選択して使用することができる。
データベース1106に保存された利用者端末101毎の履歴データは、ユーザ毎のユーザ体験に対応する。
利用者端末101毎の履歴データとしては、例えば、ユーザがウェブコンテンツ211に表示されているテキスト情報を読む時間301、
ウェブコンテンツ211に関連付けられたリンクをクリックしてリンク先の内容を閲覧したリンク302およびリンク302をクリックした回数303、
ウェブコンテンツ211に関連付けられた動画ファイルのうち、再生された動画ファイル304、動画ファイル304を再生した回数305および動画ファイル304を閲覧した時間305、
ウェブコンテンツ211に関連付けられた音楽ファイルのうち、再生された音楽ファイル306、音楽ファイル306を再生した回数307および音楽ファイル306を閲覧した時間307、
ウェブコンテンツ211に関連付けられたフォーム欄に入力したテキスト情報308およびテキスト情報308を送信した回数309、
ウェブコンテンツ211に表示された商品のうち、購入した商品310および商品310を購入した回数311、
ウェブコンテンツ211に表示された役務のうち、提供を依頼した役務312および役務312を依頼した回数313、
アプリケーション処理ユニットAにリクエストを送信した回数313、
アプリケーション処理ユニットAにリクエストを最初に送信してから最後に送信した時までの期間314、
アプリケーション処理ユニットAにリクエストを前回送信してから今回送信した時までの期間315、
利用者端末101のブラウザ画面をスクロールした回数、タッチした回数等の回数316、
利用者端末101のブラウザ画面で移動したマウス等の距離317等が挙げられる。
利用者端末101毎の履歴データは、一種もしくは二種以上を選択して使用することができる。
データベース1106に保存された利用者端末101毎の履歴データは、ユーザ毎のユーザ体験に対応する。
利用者端末101毎にエンゲージメントのスコアを算出するステップは次のように実施される。
数式(A)は、利用者端末101毎にエンゲージメントのスコアを算出するための式である。
fiは利用者端末101毎の履歴データに対応する関数であり、aiは、各関数に対する係数を示す。iは自然数であり、それぞれの値はそれぞれの履歴データに対応する。kは履歴データの総数である。
fiは利用者端末101毎の履歴データに対応する関数であり、aiは、各関数に対する係数を示す。iは自然数であり、それぞれの値はそれぞれの履歴データに対応する。kは履歴データの総数である。
利用者端末101毎の履歴データは、変数iとしてデータベース1106に保存されてい
る。
例えば、i=1に対応するオブジェクトFiには、各ユーザの一回のウェブサイト訪問当たりのテキスト情報を読む平均時間に対する、特定ユーザの一回のウェブサイト訪問当たりのテキスト情報を読む時間301の割合が対応する。
また例えば、i=2は、ウェブコンテンツ211に存在する総リンク数に対する、特定の
ユーザがクリックしたリンク302の種類の割合が対応する。
また例えば、i=3は、各ユーザの一回のウェブサイト訪問当たりのリンククリック平均
回数に対する、特定のユーザがクリックしたリンク302をクリックした回数303の割合が対応する。
以下、同様に、個々のユーザ体験毎に、それぞれの平均の履歴データに対する割合を変数fiにより対応させる。
る。
例えば、i=1に対応するオブジェクトFiには、各ユーザの一回のウェブサイト訪問当たりのテキスト情報を読む平均時間に対する、特定ユーザの一回のウェブサイト訪問当たりのテキスト情報を読む時間301の割合が対応する。
また例えば、i=2は、ウェブコンテンツ211に存在する総リンク数に対する、特定の
ユーザがクリックしたリンク302の種類の割合が対応する。
また例えば、i=3は、各ユーザの一回のウェブサイト訪問当たりのリンククリック平均
回数に対する、特定のユーザがクリックしたリンク302をクリックした回数303の割合が対応する。
以下、同様に、個々のユーザ体験毎に、それぞれの平均の履歴データに対する割合を変数fiにより対応させる。
次に、ウェブコンテンツ211を利用者端末101により閲覧したが、例えば、2秒未満で離脱して、その後再び閲覧履歴がないユーザのエンゲージメントのスコアをゼロに設定する。
上記数式(A)の係数aiの全ての初期値を1としたときに、数式(A)により算出されるもっとも大きい値を示すユーザについての上記数式(A)の値を100とする。
なお係数aiは、どの項目を重視するかの指標である。これらの係数を変化させた場合に、どの係数の組み合わせが最も短時間で全員のエンゲージメントスコアを高めることができるかを基準に、人工知能ユニットBの戦略に基づいて自動で調整される。
上記数式(A)の係数aiの全ての初期値を1としたときに、数式(A)により算出されるもっとも大きい値を示すユーザについての上記数式(A)の値を100とする。
なお係数aiは、どの項目を重視するかの指標である。これらの係数を変化させた場合に、どの係数の組み合わせが最も短時間で全員のエンゲージメントスコアを高めることができるかを基準に、人工知能ユニットBの戦略に基づいて自動で調整される。
上記のステップにより、サーバにリクエストを送信した全てのユーザが使用した利用者端末101毎に、0100の値が相対値として得られる。
このそれぞれの値が、ウェブコンテンツ211を公開してから現在までのエンゲージメントのスコアである。
ユーザがウェブコンテンツ211を閲覧するたびにエンゲージメントのスコアは加算されていく。このため、エンゲーメントスコアは各ユーザについて一定ではなく、各ユーザについて経時的に変化する。
このそれぞれの値が、ウェブコンテンツ211を公開してから現在までのエンゲージメントのスコアである。
ユーザがウェブコンテンツ211を閲覧するたびにエンゲージメントのスコアは加算されていく。このため、エンゲーメントスコアは各ユーザについて一定ではなく、各ユーザについて経時的に変化する。
[エンゲージメントのスコアに応じたウェブコンテンツが選択されるステップ]
次にエンゲージメントのスコアに応じたウェブコンテンツ211が選択されるステップについて説明する。
ユーザ毎の履歴情報と、この履歴情報に結びつけられた利用者端末101の識別情報情報に基づいて、利用者端末101毎の表示環境に利用可能なファイルの組み合わせが特定されていて、利用者端末101毎に表示完了時間の異なる複数のウェブコンテンツ211をデータ取得・処理ユニットDで生成することができる。
次にエンゲージメントのスコアに応じたウェブコンテンツ211が選択されるステップについて説明する。
ユーザ毎の履歴情報と、この履歴情報に結びつけられた利用者端末101の識別情報情報に基づいて、利用者端末101毎の表示環境に利用可能なファイルの組み合わせが特定されていて、利用者端末101毎に表示完了時間の異なる複数のウェブコンテンツ211をデータ取得・処理ユニットDで生成することができる。
ここでエンゲージメントのスコアが一定値未満のユーザに対しては、ウェブコンテンツの表示完了時間が最も短いウェブコンテンツ211に対応するリソースが選択される。
この際、例えば、テキストファイルの段落を削除する、参照するCSSファイル107および処理済みCSSファイル132、スクリプト言語ファイル108および処理済みスクリプト言語ファイル133、画像ファイル109および処理済み画像ファイル134のそれぞれの種類を、利用者端末101の表示に不具合が生じないところまで削除されたリソースが選択される。
また例えば、動画ファイル、動画ファイルを再生するためののリンク、広告ファイル・広告リンク等の広告を表示するためのリンク等が削除されたリソースが選択される。
同様に、CSSファイル107および処理済みCSSファイル132、スクリプト言語ファイル108および処理済みスクリプト言語ファイル133、画像ファイル109および処理済み画像ファイル134のそれぞれについて表示完了時間が最も短いものが特定される。
例えば、処理済みCSSファイル132、処理済みスクリプト言語ファイル133、処理済み画像ファイル134等について、削除された動画ファイル、動画ファイルへのリンク、広告ファイル・広告リンク等に関連する内容が削除されたリソースが特定される。
複数の処理済みデータ210と、複数の処理済みデータ210に対応するオリジナルデータ200のうち、最も表示完了時間が短い組み合わせデータが特定される。
最も表示完了時間が短い組み合わせデータにより表示されるウェブコンテンツ211の処理は、事前に完了しているため、実際には、ユーザエージェント、リファラ等の情報を、機種情報ファイル1526と照合して得られた利用者端末101の表示環境に表示完了時間として0.2秒以内、好ましくは100m秒以内に対応可能である。
最も表示完了時間が短い組み合わせデータにより表示されるウェブコンテンツ211の処理は、事前に完了しているため、実際には、ユーザエージェント、リファラ等の情報を、機種情報ファイル1526と照合して得られた利用者端末101の表示環境に表示完了時間として0.2秒以内、好ましくは100m秒以内に対応可能である。
上述のステップにより、エンゲージメントのスコアが一定値以下のユーザに対して,データ取得・処理ユニットD等を経由して、リクエスト処理ユニットCが送信する、特定された利用者端末101の表示環境に表示可能なウェブコンテンツ211が得られる。
事前の予備試験、および予備試験により得られたデータに基づく機械学習により形成された学習済みモデル等により、最も表示完了時間が短いウェブコンテンツ211を表示するためのリソースが選択されているので、リクエスト処理ユニットCから利用者端末101へウェブコンテンツ211の送信完了まで掛かる時間を短縮することができる。
次にエンゲージメントのスコアが一定値以上のユーザに対しては、ウェブコンテンツ211が速く表示されつつ、省略されているものがないウェブコンテンツ211を選択する。
具体的には、例えば、動画ファイル、動画ファイル等を再生するためのリンク、広告ファイル・広告リンク等の広告を表示するためのリンクが削除されていないものが選択される。
この場合は、利用者端末101の表示環境に利用可能なファイルのうち、表示可能な情報が掲載されたウェブコンテンツ211を表示するためのリソースが選択される。
具体的には、特定された、利用者端末101の表示環境に利用可能なファイル群の中から、それぞれのファイルの種類に応じて、表示完了時間が短く、かつ、省略した情報がないファイルの組み合わせが抽出される。
具体的には、特定された、利用者端末101の表示環境に利用可能なファイル群の中から、それぞれのファイルの種類に応じて、表示完了時間が短く、かつ、省略した情報がないファイルの組み合わせが抽出される。
例えば、HTMLファイル113および最適化されたHTMLファイル113zを比較し、省略した情報がないものの中から表示完了時間が短いものが採用される。
同様に、CSSファイル107および処理済みCSSファイル132、スクリプト言語ファイル108および処理済みスクリプト言語ファイル133、画像ファイル109および処理済み画像ファイル134のそれぞれについて省略した情報がないものの中から表示完了時間が短いものが採用される。
抽出処理された複数の処理済みデータと、抽出処理された複数の加工済みデータに対応するオリジナルデータ200のうち、省略した情報がないものの中から表示完了時間の短いデータの組み合わせが特定される。
省略した情報がないものの中から表示完了時間が短いものを組み合わせたデータを含むウェブコンテンツ211は、ユーザエージェント、リファラ等の情報を、機種情報ファイル526と照合して得られた利用者端末101の表示環境を元に選択されているので、利用者端末101の表示画面に対応可能である。
次に個々のユーザのエンゲージメントスコアに応じて、どのようにウェブコンテンツの高速表示を実現するステップが変化するかについて説明する。
図37に示されるように、個々のユーザのエンゲージメントスコアに応じて、利用者端末101からアプリケーション処理ユニットAにリクエストが送信されてから、利用者端末101でウェブコンテンツ211が入力受付可能になるまでの時間が調整されるステップを説明するための模式図である。
図37に示されるように、ユーザのエンゲージメントスコアが最も低い場合には、利用者端末101からリクエスト処理ユニットC等にリクエストが送信されてから、利用者端末101でウェブコンテンツ211が入力受付可能になるまでの時間が最も短くなる処理済みデータ210が選択される。
逆にユーザのエンゲージメントスコアが最も高い場合には、利用者端末101からアプリケーション処理ユニットAにリクエストが送信されてから、利用者端末101でウェブコンテンツ211が入力受付可能になるまでの時間が最も長くなる処理済みデータ210が選択される。
ユーザのエンゲージメントスコアが最も高い場合と最も低い場合の中間の場合には、利用者端末101からアプリケーション処理ユニットAにリクエストが送信されてから、利用者端末101でウェブコンテンツ211が入力受付可能になるまでの時間が最も短くなる場合と最も長くなる場合との中間の時間となる処理済みデータ210が選択される。
逆にユーザのエンゲージメントスコアが最も高い場合には、利用者端末101からアプリケーション処理ユニットAにリクエストが送信されてから、利用者端末101でウェブコンテンツ211が入力受付可能になるまでの時間が最も長くなる処理済みデータ210が選択される。
ユーザのエンゲージメントスコアが最も高い場合と最も低い場合の中間の場合には、利用者端末101からアプリケーション処理ユニットAにリクエストが送信されてから、利用者端末101でウェブコンテンツ211が入力受付可能になるまでの時間が最も短くなる場合と最も長くなる場合との中間の時間となる処理済みデータ210が選択される。
図38は、ユーザ体験がどのようにウェブコンテンツの自動高速表示を実現するステップに反映されるかを説明するためのフローチャートである。
最初にユーザが利用者端末101からリクエスト101をアプリケーション処理ユニットAに送信する(ステップS3001)。
リクエスト処理ユニットCおよびアプリケーション処理ユニットAから、リクエストが、人工知能ユニットBおよびデータ取得・処理ユニットDに送信される(ステップS3002)。
データ取得・処理ユニットDは、リクエストに含まれるアクセプトヘッダー、クッキー等の情報から利用者端末101の表示環境を特定する(ステップS3003)。
またアクセプトヘッダー、クッキー等の情報から利用者端末101に関連付けられた識別情報に基づいて、これまでのエンゲージメントスコアを特定することができる(ステップS3004)。
最初にユーザが利用者端末101からリクエスト101をアプリケーション処理ユニットAに送信する(ステップS3001)。
リクエスト処理ユニットCおよびアプリケーション処理ユニットAから、リクエストが、人工知能ユニットBおよびデータ取得・処理ユニットDに送信される(ステップS3002)。
データ取得・処理ユニットDは、リクエストに含まれるアクセプトヘッダー、クッキー等の情報から利用者端末101の表示環境を特定する(ステップS3003)。
またアクセプトヘッダー、クッキー等の情報から利用者端末101に関連付けられた識別情報に基づいて、これまでのエンゲージメントスコアを特定することができる(ステップS3004)。
得られたエンゲージメントスコアに応じた処理済みデータ210が選択され、その処理済みデータ210に対応するオブジェクトがデータ取得・処理ユニットD、人口知能ユニットB、アプリケーション処理ユニットA、リクエスト処理ユニットCに送信される。そして処理済みデータ210のリソースが、最適化されたHTMLファイル113zのオブジェクトに対応づけられる(ステップS3005)。
利用者端末101のブラウザ等で最適化されたHTMLファイル113zが実行される。そして利用者端末101でウェブコンテンツ211が表示される(ステップS3008)。
利用者端末101のブラウザ等で最適化されたHTMLファイル113zが実行される。そして利用者端末101でウェブコンテンツ211が表示される(ステップS3008)。
図38のステップS3006で、利用者端末101に関連付けられたユーザについてのエンゲージメントスコアから、利用者端末101に送信される処理済みデータ210が選択される。
エンゲージメントスコアが低いユーザについては、ファーストビューの描画を優先する(図37の参照符号410参照)。
ファーストビューの描画を優先することにより、エンゲージメントスコアの低いユーザが離脱することを防止できる。
逆にエンゲージメントスコアが高いユーザについては、利用者端末101のブラウザ等が入力受付可能になるまでの時間を遅延させず、最初から内容が充実したコンテンツを配信する(図37の参照符号430参照)。
このように、利用者端末101で入力受付可能になるまでの時間を変化させて、利用者端末101毎にエンゲージメントスコアに応じて、配信内容を振り分けることができる。
ファーストビューの描画を優先することにより、エンゲージメントスコアの低いユーザが離脱することを防止できる。
逆にエンゲージメントスコアが高いユーザについては、利用者端末101のブラウザ等が入力受付可能になるまでの時間を遅延させず、最初から内容が充実したコンテンツを配信する(図37の参照符号430参照)。
このように、利用者端末101で入力受付可能になるまでの時間を変化させて、利用者端末101毎にエンゲージメントスコアに応じて、配信内容を振り分けることができる。
この振り分けが正しいかどうかは、ユーザが利用者端末101から早期に離脱するかしないかにより判断することができる。
例えば、ユーザが離脱せず、ウェブコンテンツ211を閲覧する動作を続けた場合には、ステップS3006の選択は正しいことが分かる。逆にユーザがウェブコンテンツ211を閲覧する動作を続けず、早期に離脱した場合には、ステップS3006の選択は正しくないことが分かる。
ステップS3006の選択が正しい場合にはエンゲージメントスコアを加算し、ステップS3006の選択が正しくない場合にはエンゲージメントスコアを減算する。
この操作により、ユーザ体験に基づいて、よりきめ細やかにユーザのウェブコンテンツに対する満足度を自動的に高めることができる。
ステップS3006の選択が正しい場合にはエンゲージメントスコアを加算し、ステップS3006の選択が正しくない場合にはエンゲージメントスコアを減算する。
この操作により、ユーザ体験に基づいて、よりきめ細やかにユーザのウェブコンテンツに対する満足度を自動的に高めることができる。
本発明に係るウェブコンテンツの自動高速表示制御方法は、従来使用されているネットワークを利用者したウェブコンテンツを表示するシステムに簡単に設置することができる。また、ウェブコンテンツを表示する速度を向上させることができるから、ネットワークを利用したウェブコンテンツを扱う通信分野で広く応用することができる。
101 利用者端末
102 ネットワーク
103 アプリケーション実行サーバ
A アプリケーション処理ユニット
B 人工知能ユニット
C リクエスト処理ユニット
D データ取得・処理ユニット
d100 最適化ユニット
d200 クローラーユニット
d300 コントロールユニット
1523 設定ファイル格納部
104 オリジナルデータ記憶領域
105 PHPファイル
107 CSSファイル
107a,b,c CSSコード部分
107x,108x,113x 利用者端末に使用されない部分
F107a~F107c,F108a~F108c オブジェクト
108 スクリプト言語ファイル
108a~108d スクリプト言語コード部分
109 画像ファイル
113 HTMLファイル
113a~113d HTMLコード部分
113o1,113o2 オブジェクト
113o10,113o20,113o21 オブジェクト
113i ヘッド
113j ボディ
113z 最適化されたHTMLファイル
1115,1715 監視制御部
1116,1716 動作制御部
1117,1717 動作制御記憶部
1120,1720 時間実行制御部
1121,1721 時間実行記憶部
124 リソース
125 設定ファイル
126 機種情報ファイル
130 加工済みデータ記憶領域
132 処理済みCSSファイル
133 処理済みスクリプト言語ファイル
134 処理済み画像ファイル
200 オリジナルデータ
201,202 処理済みデータ
203 CLI
211,212 ウェブコンテンツ
401 通信の渋滞
402 描画の渋滞
403 配信最適化
404 ファーストビューに対応する部分の描画
405 ファーストビューに対応する部分以外の描画
410 エンゲージメントのスコアが最小の場合
420 エンゲージメントのスコアが中間の場合
430 エンゲージメントのスコアが最大の場合
1000,1100 中央演算処理装置
1001,1101,1701 記憶装置
1001a,1101a,1701a 主記憶部
1001b,1101b,1701b 補助記憶部
1002,1102 通信用インターフェイス
1003,1103 入力装置
1004,1104 表示装置
1105,1705 OS
1106,1706 データベース
1403 人工知能サーバ
1410 人工知能知能制御部
1412 戦略ファイル
1430 人工知能記憶領域
1510 通信データ制御部
1503 データ取得サーバ
1703 リバースプロキシサーバ
1803 クラウド
102 ネットワーク
103 アプリケーション実行サーバ
A アプリケーション処理ユニット
B 人工知能ユニット
C リクエスト処理ユニット
D データ取得・処理ユニット
d100 最適化ユニット
d200 クローラーユニット
d300 コントロールユニット
1523 設定ファイル格納部
104 オリジナルデータ記憶領域
105 PHPファイル
107 CSSファイル
107a,b,c CSSコード部分
107x,108x,113x 利用者端末に使用されない部分
F107a~F107c,F108a~F108c オブジェクト
108 スクリプト言語ファイル
108a~108d スクリプト言語コード部分
109 画像ファイル
113 HTMLファイル
113a~113d HTMLコード部分
113o1,113o2 オブジェクト
113o10,113o20,113o21 オブジェクト
113i ヘッド
113j ボディ
113z 最適化されたHTMLファイル
1115,1715 監視制御部
1116,1716 動作制御部
1117,1717 動作制御記憶部
1120,1720 時間実行制御部
1121,1721 時間実行記憶部
124 リソース
125 設定ファイル
126 機種情報ファイル
130 加工済みデータ記憶領域
132 処理済みCSSファイル
133 処理済みスクリプト言語ファイル
134 処理済み画像ファイル
200 オリジナルデータ
201,202 処理済みデータ
203 CLI
211,212 ウェブコンテンツ
401 通信の渋滞
402 描画の渋滞
403 配信最適化
404 ファーストビューに対応する部分の描画
405 ファーストビューに対応する部分以外の描画
410 エンゲージメントのスコアが最小の場合
420 エンゲージメントのスコアが中間の場合
430 エンゲージメントのスコアが最大の場合
1000,1100 中央演算処理装置
1001,1101,1701 記憶装置
1001a,1101a,1701a 主記憶部
1001b,1101b,1701b 補助記憶部
1002,1102 通信用インターフェイス
1003,1103 入力装置
1004,1104 表示装置
1105,1705 OS
1106,1706 データベース
1403 人工知能サーバ
1410 人工知能知能制御部
1412 戦略ファイル
1430 人工知能記憶領域
1510 通信データ制御部
1503 データ取得サーバ
1703 リバースプロキシサーバ
1803 クラウド
Claims (11)
- ネットワークを通じて通信可能な一または二以上のサーバに対して利用者端末からリクエストが送信されてから、利用者端末にウェブコンテンツを表示するためのオリジナルデータがサーバから利用者端末に送信されて、ウェブコンテンツが利用者端末で入力受付可能になるまでに、
前記サーバに設置されたリクエスト処理ユニットに対して、利用者端末から送信されたリクエストが、アプリケーション処理ユニットと人工知能ユニットが受信するステップと、
アプリケーション処理ユニットが、ウェブコンテンツを表示するためのオリジナルデータをデータ取得・処理ユニットに対して送信するステップと、
人工知能ユニットが、ウェブコンテンツを利用者端末毎に表示する戦略案を立案するステップと、
データ取得・処理ユニットが、利用者端末にウェブコンテンツを表示するためのオリジナルデータを受信するステップと、
前記戦略案に基づいて、データ取得・処理ユニットによりオリジナルデータが加工されて、複数の加工済みデータが生成するステップと、
前記オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのリソースから、利用者端末毎にウェブコンテンツを表示するための処理済みデータが選択されるステップと、
前記利用者端末毎にウェブコンテンツを表示するための処理済みデータが、利用者端末毎に送信されて、利用者端末毎にウェブコンテンツが表示されるステップと、
が実施され、
前記サーバが、一または二以上の物理マシン、一または二以上の仮想マシン、ならびに、一または二以上のコンテナからなる群より選ばれる少なくとも一つの実行環境からなり、
前記戦略案を立案するステップが、
前記オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのリソースのうち、
利用者端末毎に、利用者端末にウェブコンテンツをより速く表示するための処理済みデータが共通して有する属性を学習するステップと、
利用者端末毎に、前記属性に基づいて、前記オリジナルデータをデータ取得・処理ユニットで処理するステップと、
を含むことを特徴とする、ウェブコンテンツの自動高速表示制御方法。 - リソースが、オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのデータを含み、
処理済みデータが、オブジェクト置換済みプログラムを含み、
リソース参照部分を有するオリジナルデータが、リソース参照部分をプログラムのオブジェクトに置換されて、オブジェクト置換済みプログラムが、生成するステップと、
前記オブジェクトが、識別情報と共にリソース毎に対応付けられるステップと、
利用者端末毎に、利用者端末に搭載されたブラウザでオブジェクト置換済みプログラムが実行されると、
オブジェクト置換済みプログラムに含まれるオブジェクトが識別情報によりリソースを特定し、そのリソースが実行されるステップと、
を含む、請求項1に記載のウェブコンテンツの自動高速表示制御方法。 - 利用者端末毎に、前記属性に基づいて、前記オリジナルデータをデータ取得・処理ユニットで処理するステップが、
前記処理済みデータに含まれるプログラムのうち、実行させるプログラムを選択するステップ、
前記処理済みデータに含まれるプログラムのうち、優先して実行させるプログラムを選択するステップ、
前記処理済みデータに含まれるプログラムのうち、遅延して実行させるプログラムを選択するステップ、
前記処理済みデータに含まれるプログラムのうち、実行させるプログラムの実行順序を選択するステップ、
前記処理済みデータに含まれるプログラムのうち、実行させるプログラムの実行タイミングを選択するステップ、
および
前記オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのリソースから、利用者端末毎にウェブコンテンツを表示するための処理済みデータを選択するステップ、
からなる群より選ばれる少なくとも一つのステップを含む、請求項1または2に記載のウェブコンテンツの自動高速表示制御方法。 - オリジナルデータが、プログラムデータおよびバイナリデータの少なくとも一つを含み、
プログラムデータが、マークアップ言語、プログラミング言語、スタイルシート、スクリプト言語からなる群より選ばれる少なくとも一つを有するコードを含み、
バイナリデータが、画像ファイル、音ファイルおよび動画ファイルの少なくとも一つを含み、
リソースが、オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つを含み、
加工済みデータが生成されるステップが、
(1)オリジナルデータに含まれる、マークアップ言語、プログラミング言語、スタイルシートおよびスクリプト言語からなる群より選ばれる少なくとも一つを有するコードから、利用者端末の表示環境ごとに不要部分が削除されるステップと、
(2)オリジナルデータに含まれる、マークアップ言語、プログラミング言語、スタイシートおよびスクリプト言語からなる群より選ばれる少なくとも一つを有するコードから、利用者端末の表示環境ごとに必要部分が圧縮されるステップと、
(3)オリジナルデータに含まれる、マークアップ言語、プログラミング言語、スタイルシートおよびスクリプト言語からなる群より選ばれる少なくとも一つを有するコードから、利用者端末の表示環境ごとに実行順序が変更されるステップと、
(4)オリジナルデータに含まれる、マークアップ言語、プログラミング言語、スタイルシートおよびスクリプト言語からなる群より選ばれる少なくとも一つを有するコードから、利用者端末の表示環境ごとに実行タイミングが変更されるステップと、
(5)オリジナルデータに含まれる、バイナリデータから、単位面積当たりの表示画素数、単位時間当たりの録画録音密度、容量および保存形式からなる群より選ばれる少なくとも一つが変換されるステップと、
の(1)~(5)からなる群より選ばれる少なくとも一つのステップを含み、
利用者端末毎にウェブコンテンツが表示されるステップが、
リクエストが利用者端末からネットワークを通じてリクエスト処理ユニットに送信されるステップと、
リクエスト処理ユニットに受信されたリクエストから、利用者端末毎の表示環境が特定されるステップと、
利用者端末のブラウザからリクエストがリクエスト処理ユニットに送信された後に、アプリケーション処理ユニットおよびデータ取得・処理ユニットの少なくとも一つからリソースが利用者端末毎に送信され、利用者端末毎のブラウザに表示されるステップと、
を含む、請求項1~3のいずれかに記載のウェブコンテンツの自動高速表示制御方法。 - オリジナルデータが加工されて、複数の加工済みデータが生成するステップが、
前記データ取得・処理ユニットが通信可能な記憶領域に保存された利用者端末に関する機種情報データに基づいて、利用者端末毎に複数の加工済みデータが生成されるステップを含み、
前記オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのリソースから、利用者端末毎にウェブコンテンツを表示するための処理済みデータが選択されるステップが、
利用者端末毎に、機種情報データに基づいて利用者端末の表示画面の表示環境を特定するステップと、
利用者端末毎に、ウェブコンテンツのうち、利用者端末の表示画面の表示環境に合わせて最初に表示されるウェブコンテンツの部分を特定するステップと、
前記利用者端末毎にウェブコンテンツを表示するための処理済みデータが利用者端末毎に送信されて、利用者端末毎にウェブコンテンツが表示されるステップが、ウェブコンテンツのうち、利用者端末の表示画面の表示環境に合わせて最初に表示されるウェブコンテンツに対応する処理済みデータを利用者端末に優先して送信するステップと、
を含む、請求項1~4のいずれかに記載のウェブコンテンツの自動高速表示制御方法。 - ウェブコンテンツが利用者端末毎に表示されるステップが、
ウェブコンテンツのうち、利用者端末の画面に最初に表示される部分に対応するデータが利用者端末に送信されるステップと、
利用者端末に利用者端末の画面に最初に表示される部分に対応するウェブコンテンツの部分が表示されてから一定時間が経過したことを示すイベント情報、および、ユーザが利用者端末を操作して利用者端末に対して追加の情報を表示させる行動を起こしたことを示すイベント情報の少なくとも一つのイベント情報が、サーバおよびブラウザの少なくとも一つにより検出されるステップと、
前記イベント情報をアプリケーション処理ユニット、人工知能ユニット、データ取得・処理ユニットおよび利用者端末に搭載されたブラウザの少なくとも一つが検出した後に、ウェブコンテンツの残りの一部または全部の部分を表示するためのリソースが、アプリケーション処理ユニットおよびデータ取得・処理ユニットの少なくとも一つから、ネットワークを通じて利用者端末に送信されるステップと、
を含む、請求項1~5のいずれかに記載のウェブコンテンツの自動高速表示制御方法。 - ウェブコンテンツが利用者端末毎に表示されるステップが、
ウェブコンテンツのうち、利用者端末の画面に最初に表示される部分を表示するためのリソースが利用者端末に送信されるステップと、
ウェブコンテンツのうち、利用者端末の画面に最初に表示される部分が入力受付可能になるまでの時間が伸縮するステップと、
を含む、請求項6に記載のウェブコンテンツの自動高速表示制御方法。 - ウェブコンテンツを閲覧するユーザのユーザ体験に基づいて、ユーザとウェブコンテンツとのエンゲージメントのスコアが算出されるステップと、
前記エンゲージメントのスコアに基づいて、利用者端末毎に、ウェブコンテンツのうち、利用者端末の画面に最初に表示される部分が入力受付可能になるまでの時間が伸縮するステップと、
を含む、請求項7に記載のウェブコンテンツの自動高速表示制御方法。 - 請求項1~8のいずれかに記載のウェブコンテンツの自動高速表示制御方法を実施するためのプログラムであって、
ネットワークを通じて通信可能な一または二以上のサーバに対して利用者端末からリクエストが送信されてから、利用者端末にウェブコンテンツを表示するためのオリジナルデータがサーバから利用者端末に送信されて、ウェブコンテンツが利用者端末で入力受付可能になるまでに、
前記サーバに設置されたリクエスト処理ユニットに対して、利用者端末から送信されたリクエストが、アプリケーション処理ユニットと人工知能ユニットが受信する手段と、
アプリケーション処理ユニットが、ウェブコンテンツを表示するためのオリジナルデータをデータ取得・処理ユニットに対して送信する手段と、
人工知能ユニットが、ウェブコンテンツを利用者端末毎に表示する戦略案を立案する手段と、
データ取得・処理ユニットが、利用者端末にウェブコンテンツを表示するためのオリジナルデータを受信する手段と、
前記戦略案に基づいて、データ取得・処理ユニットによりオリジナルデータが加工されて、複数の加工済みデータが生成する手段と、
前記オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのリソースから、利用者端末毎にウェブコンテンツを表示するための処理済みデータが選択される手段と、
前記利用者端末毎にウェブコンテンツを表示するための処理済みデータが、利用者端末毎に送信されて、利用者端末毎にウェブコンテンツが表示される手段と、
を備え、
前記サーバが、一または二以上の物理マシン、一または二以上の仮想マシン、ならびに、一または二以上のコンテナからなる群より選ばれる少なくとも一つの実行環境からなり、
前記戦略案を立案する手段が、
前記オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのリソースのうち、
利用者端末毎に、利用者端末にウェブコンテンツをより速く表示するための処理済みデータが共通して有する属性を学習する手段と、
利用者端末毎に、前記属性に基づいて、前記オリジナルデータをデータ取得・処理ユニットで処理する手段と、
を含む、ウェブコンテンツの自動高速表示制御プログラム。 - 請求項9に記載されたウェブコンテンツの自動高速表示制御プログラムを記録した、記憶装置。
- 請求項1~8のいずれかに記載のウェブコンテンツの自動高速表示制御方法を実施するためのシステムであって、
ネットワークを通じて通信可能な一または二以上のサーバに対して利用者端末からリクエストが送信されてから、利用者端末にウェブコンテンツを表示するためのオリジナルデータがサーバから利用者端末に送信されて、ウェブコンテンツが利用者端末で入力受付可能になるまでに、
前記サーバに設置されたリクエスト処理ユニットに対して、利用者端末から送信されたリクエストが、アプリケーション処理ユニットと人工知能ユニットが受信する手段と、
アプリケーション処理ユニットが、ウェブコンテンツを表示するためのオリジナルデータをデータ取得・処理ユニットに対して送信する手段と、
人工知能ユニットが、ウェブコンテンツを利用者端末毎に表示する戦略案を立案する手段と、
データ取得・処理ユニットが、利用者端末にウェブコンテンツを表示するためのオリジナルデータを受信する手段と、
前記戦略案に基づいて、データ取得・処理ユニットによりオリジナルデータが加工されて、複数の加工済みデータが生成する手段と、
前記オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのリソースから、利用者端末毎にウェブコンテンツを表示するための処理済みデータが選択される手段と、
前記利用者端末毎にウェブコンテンツを表示するための処理済みデータが、利用者端末毎に送信されて、利用者端末毎にウェブコンテンツが表示される手段と、
を備え、
前記サーバが、一または二以上の物理マシン、一または二以上の仮想マシン、ならびに、一または二以上のコンテナからなる群より選ばれる少なくとも一つの実行環境からなり、
前記戦略案を立案する手段が、
前記オリジナルデータならびに複数の加工済みデータからなる群より選ばれる少なくとも一つのリソースのうち、
利用者端末毎に、利用者端末にウェブコンテンツをより速く表示するための処理済みデータが共通して有する属性を学習する手段と、
利用者端末毎に、前記属性に基づいて、前記オリジナルデータをデータ取得・処理ユニットで処理する手段と、
を含む、ウェブコンテンツの自動高速表示制御システム。
Priority Applications (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2022524779A JP7523733B2 (ja) | 2020-05-20 | 2020-05-20 | ウェブコンテンツの自動高速表示制御方法 |
PCT/JP2020/020025 WO2021234882A1 (ja) | 2020-05-20 | 2020-05-20 | ウェブコンテンツの自動高速表示制御方法 |
US17/783,317 US12111876B2 (en) | 2020-05-20 | 2020-05-20 | Automatic high-speed display control method for web content |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
PCT/JP2020/020025 WO2021234882A1 (ja) | 2020-05-20 | 2020-05-20 | ウェブコンテンツの自動高速表示制御方法 |
Publications (1)
Publication Number | Publication Date |
---|---|
WO2021234882A1 true WO2021234882A1 (ja) | 2021-11-25 |
Family
ID=78708256
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/JP2020/020025 WO2021234882A1 (ja) | 2020-05-20 | 2020-05-20 | ウェブコンテンツの自動高速表示制御方法 |
Country Status (3)
Country | Link |
---|---|
US (1) | US12111876B2 (ja) |
JP (1) | JP7523733B2 (ja) |
WO (1) | WO2021234882A1 (ja) |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2016112354A2 (en) * | 2015-01-08 | 2016-07-14 | Instart Logic, Inc. | Html streaming |
WO2019072201A1 (zh) * | 2017-10-13 | 2019-04-18 | 华为技术有限公司 | 网页内容提取方法以及终端设备 |
Family Cites Families (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8010702B2 (en) * | 2001-06-14 | 2011-08-30 | Nokia Corporation | Feature-based device description and content annotation |
US8412812B1 (en) * | 2004-12-30 | 2013-04-02 | Google Inc. | Client-side measurement of load times |
US8069408B2 (en) * | 2006-11-16 | 2011-11-29 | Novell, Inc. | Representing extensible markup language (XML) as an executable having conditional authentication or policy logic |
US8321568B2 (en) | 2008-03-31 | 2012-11-27 | Amazon Technologies, Inc. | Content management |
JP5893258B2 (ja) * | 2011-03-31 | 2016-03-23 | フェリカネットワークス株式会社 | 情報処理装置および方法、並びにプログラム |
US20140068408A1 (en) * | 2012-09-05 | 2014-03-06 | Chegg, Inc. | Presentation of layered content documents in multiscreen systems |
CA2937519A1 (en) * | 2014-01-22 | 2015-07-30 | Ricoh Company, Limited | Data transmission system, terminal device, computer program, and data transmission method |
US9158656B1 (en) * | 2014-07-15 | 2015-10-13 | American Express Travel Related Services Company, Inc. | Systems and methods for progressively launching websites |
US10212121B2 (en) * | 2014-11-24 | 2019-02-19 | Microsoft Technology Licensing, Llc | Intelligent scheduling for employee activation |
US10425464B2 (en) * | 2015-01-08 | 2019-09-24 | Instart Logic, Inc. | Adaptive learning periods in HTML streaming |
US20200159866A1 (en) * | 2018-11-19 | 2020-05-21 | International Business Machines Corporation | Perceived Web Page Loading Time |
US12069039B2 (en) * | 2020-10-23 | 2024-08-20 | EMC IP Holding Company LLC | Dynamically unifying disparate user interface applications in a cloud native environment |
-
2020
- 2020-05-20 WO PCT/JP2020/020025 patent/WO2021234882A1/ja active Application Filing
- 2020-05-20 JP JP2022524779A patent/JP7523733B2/ja active Active
- 2020-05-20 US US17/783,317 patent/US12111876B2/en active Active
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2016112354A2 (en) * | 2015-01-08 | 2016-07-14 | Instart Logic, Inc. | Html streaming |
WO2019072201A1 (zh) * | 2017-10-13 | 2019-04-18 | 华为技术有限公司 | 网页内容提取方法以及终端设备 |
Also Published As
Publication number | Publication date |
---|---|
JPWO2021234882A1 (ja) | 2021-11-25 |
US12111876B2 (en) | 2024-10-08 |
US20230010433A1 (en) | 2023-01-12 |
JP7523733B2 (ja) | 2024-07-29 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11474673B1 (en) | Handling modifications in programming of an iterative message processing system | |
US11886440B1 (en) | Guided creation interface for streaming data processing pipelines | |
US11194552B1 (en) | Assisted visual programming for iterative message processing system | |
US11614923B2 (en) | Dual textual/graphical programming interfaces for streaming data processing pipelines | |
US10776441B1 (en) | Visual programming for iterative publish-subscribe message processing system | |
US10936585B1 (en) | Unified data processing across streaming and indexed data sets | |
US8914736B2 (en) | On-page manipulation and real-time replacement of content | |
US20130060858A1 (en) | Additional Systems and Methods for Curating Content | |
WO2016065302A1 (en) | Systems and methods for managing hashtags | |
US9536445B2 (en) | System and method for visually tracking a learned process | |
CN108780446A (zh) | 时间依赖的机器生成的提示 | |
JP4963619B2 (ja) | 情報検索システム、情報検索装置、検索結果画面情報生成方法及び検索結果画面情報生成処理プログラム | |
US9565224B1 (en) | Methods, systems, and media for presenting a customized user interface based on user actions | |
JP5887971B2 (ja) | ポートレット処理装置、ポータルサーバ、ポータルシステム、ポートレット処理方法、および、コンピュータ・プログラム | |
WO2021234882A1 (ja) | ウェブコンテンツの自動高速表示制御方法 | |
US9292883B2 (en) | System and method for managing a trail | |
US8645262B1 (en) | System and method for displaying security information | |
JP7530383B2 (ja) | ウェブコンテンツの自動表示制御方法 | |
JP6758582B1 (ja) | コンテンツ配信システム、コンテンツ配信プログラム | |
JP4711359B1 (ja) | 情報提示装置、情報提示方法および情報提示プログラム | |
JP5198196B2 (ja) | コンテンツ管理装置 | |
KR20090105692A (ko) | 전문가 추천 검색결과 제작 방법 및 이를 위한 기록매체 | |
JP6148542B2 (ja) | 不動産情報管理システム | |
JP6343630B2 (ja) | 情報処理装置およびコンピュータプログラム | |
JPWO2021234882A5 (ja) |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
121 | Ep: the epo has been informed by wipo that ep was designated in this application |
Ref document number: 20936722 Country of ref document: EP Kind code of ref document: A1 |
|
ENP | Entry into the national phase |
Ref document number: 2022524779 Country of ref document: JP Kind code of ref document: A |
|
NENP | Non-entry into the national phase |
Ref country code: DE |
|
122 | Ep: pct application non-entry in european phase |
Ref document number: 20936722 Country of ref document: EP Kind code of ref document: A1 |