This application is based upon and claims the benefit of priority of the prior Japanese Patent Application No. 2017-231162, filed on Nov. 30, 2017, the entire contents of which are incorporated herein by reference.
The embodiments discussed herein are related to a computer-readable recording medium, an estimation method and an estimation device.
A technology to represent multiple options or items to a user and, based on an answer of choice of the user, search for a preference of the user is known. Furthermore, a technology to, in a system that searches for an item that is specified by a group of attribute from an item space, choose a group of attribute to represent an accurate number of items to the user is known.
Japanese National Publication of International Patent Application No. 2009-540475
Japanese Laid-open Patent Publication No. 2006-330858
It is known that there is a convergence process that is a process to change an index to be input to a system such that another item is represented to enable the user to check and sophisticate the current preference of the user in a process in which a user reaches true preference that the user wants.
When the user changes the content of input such that a new item is represented by performing the convergence process, or the like, the content of input that is changed by the user may be insufficient for representation of another item. For example, even when the user wants to place importance on only the main index, no item with a high score of the main index may appear without changing the values of the sub-indices. In this case, it occurs a situation where the user thinks that the number of times the index is changed is insufficient and updates a list many times but the items are not changed and specifying a preference of the user does not progress.
Furthermore, the system could merely represent a new item that is irrelevant to the content of old inputs. In this case, as an item that is less relevant to the preference of the user resulting from repetitive inputs of indices until now is represented, the item is not useful as information for the user to check the preference of the user or as information for the system to specify a preference of the user.
According to an aspect of the embodiments, a non-transitory computer-readable recording medium stores therein a program that causes a computer to execute a process. The process includes generating a preference trend based on content of a plurality of answers from a respondent for a plurality of inquiries each including a plurality of options; based on a log of content of representation items that are represented at the plurality of inquiries to the respondent, determining whether information that changes the representation items is to be represented; generating an input candidate that changes the representation items according to the determining based on the preference trend; and displaying the input candidate together with the representation items at the plurality of inquiries.
The object and advantages of the invention will be realized and attained by means of the elements and combinations particularly pointed out in the claims.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory and are not restrictive of the invention.
Preferred embodiments will be explained with reference to accompanying drawings. The embodiments do not limit the invention. The embodiments may be combined as long as no inconsistency is caused.
Overall Configuration
In the system, the user terminal 1 that a would-be relocator uses accesses the search device 100 in order to search for a relocation area. The search device 10 causes the user terminal 1 to display questions multiple times, estimates a preference of the would-be relocator (also referred to as user below) including important items and favor, and displays a local government that matches the preference on the user terminal 1. The present system is a system that implements matching between a would-be relocator and a local government that serves as a relocation site.
The relocator matching system will be exemplified to describe the first embodiment; however, embodiments are not limited thereto. Any system may be used as long as, for example, the system estimates a preference of a user according to answers to inquiries to the user.
The user terminal 1 is a computer device that the would-be relocator uses and is, for example, a personal computer, a mobile phone, a tablet terminal or a smartphone. The would-be relocator is an exemplary respondent.
The search device 10 is an exemplary server device that executes the above-described relocator matching. The search device 10 stores various logs including information on local governments, such as “Area A, Area B and Area C”, a log of searches by the would-be relocator, and information on estimation of a preference that the would-be relocator requests from a relocation site. The search device 10 represents inquiries (questions) to the would-be relocator multiple times, estimates a preference of the would-be relocator according to answers to the inquiries and represents a relocation site (local authority) that matches what the would-be relocator wants. In the first embodiment, the relocation site represented to the would-be relocator is also referred to as “item” below.
In general, when choosing an area to which a resident in an urban area relocates, what the would-be relocator wants in a relocation site has to be input to the system; however, it is not possible to take decrease in life convenience after relocation into consideration and thus it is not possible to express a true preference clearly. Thus, the search device 10 realizes a recommendation system that suggests an area appropriate to a would-be relocator to a local government based on the human psychology and executes information representation to the user to enable the would-be relocator to reach a true preference of the would-be relocator that the would-be relocator requests subconsciously or unconsciously.
In such a system, the search device 10 estimates a preference of the user based on answers (preference) to multiple inquiries containing multiple options.
Specifically, the search device 10 generates a preference trend that is a direction of preference of the user based on the content of the multiple answers from the user. Based on the log of content of items that are represented at the inquiries to the user, the search device 10 determines whether the displayed items have to be changed. According to the determination, the search device 10 generates input candidates that change representation items that are represented based on the preference trend and displays the input candidates together with the representation items at the inquiries.
For example, the user wants to verify whether the current choice of the user is correct by weighing another item close to the current preference of the user. Thus, in the process to reach a true preference, the user executes a process to check the current preference of the user and try to derive another item to sophisticate the preference (also referred to as convergence process).
The search device 10 predicts a direction the user is like to prefer from the log data (preference log) of the user and suggests having a preference in the direction to the user. Specifically, the search device 10 suggests candidates that the user would prefer to the user. In this manner, by suggesting more items while switching the representation items, the search device 10 puts changing the items displayed to the user and specifying a preference of the user forward together. In the first embodiment, narrowing down the suggested candidates is expressed as narrowing down directioning.
The storage 12 is an exemplary storage device that stores programs and data and is, for example, a memory and a hard disk. The storage 12 stores a local government information DB 13, a log information DB 14 and a candidate DB 25. The storage 12 is able to store various types of information on the user who is a would-be relocator, such as the name and the progress of estimation of preference, in a storage other than the aforementioned DBs.
The local government information DB 13 is a database in which the search device 10 stores information on local governments that may match the user.
An “area name” stored in the local government information DB 13 is the name of an area of a local government serving as a relocation site. The aforementioned “transportation convenience, shopping, school, ties with neighbors, hospital, and safety” are selling points of the area and the number and content of the items listed herein can be changed optionally. “Transportation convenience” is information about convenience of transportation in the area, “shopping” is information on supermarkets, etc., in the area, “school” is information on schools set in the area. “Ties with neighbors” is information on ties with neighbors in the area, “hospital” is information on hospitals in the area, and “safety” is information on the number of crimes in the area, etc.
In the case illustrated in
The log information DB 14 is a database that stores various logs that occur in relocator matching. Specifically, the log information DB 14 stores inquiries from the search device 10, responses to the inquiries, attribute groups that the user inputs, the log of choices made by the user (preference log), etc.
A candidate DB 15 is a database that stores candidates for items to be represented to the user that are generated by a preference estimator 30 to be described below.
The controller 20 is a processor that controls the entire search device 10 and is, for example, a processor. The controller 20 includes a display controller 21 and the preference estimator 30. The display controller 21 and the preference estimator 30 are exemplary electronic circuits of the processor or exemplary processes that are executed by the processor.
The display controller 21 is a processor that executes control on displaying items according to the preference of the user and includes a preference acceptor 22 and an updater 23. For example, the display controller 21 displays a web screen on which items are represented on the user terminal 1 and accepts a preference of the user on the web screen. The display controller 21 changes the items to represent according to the accepted preference of the user and displays the web screen on which the items are represented on the user terminal 1.
The preference acceptor 22 is a processor that accepts a preference of the user on the web screen on which the items are displayed.
A button 50c and a button 50d are buttons to accept choice of an item on which importance is placed and, the button 50c is chosen to place importance on transportation convenience and the button 50d is chosen to place importance on safety. A button 50e is a button to move to a check screen and is pressed when a satisfactory local government is searched for. A button 50f is a button to request updating the list. A button 50g is a button for addition to the bookmark and is a button for temporarily storing information for the user to use the information to compare and weigh a relocation site. A button 50h is a trigger to execute a process performed by the preference estimator 30 to be described below and is an exemplary trigger of a process that is executed when it is assumed that the user has a trouble in choosing a preference.
For example, when the button 50c is chosen on the web screen illustrated in
The updater 23 is a processor that updates the items to represent according to the preference that is accepted by the preference acceptor 22. Using the web screen, etc., the updater 23 chooses items according to the preference of the user that is accepted before representation of items and represents the chosen item to the user.
Specifically, the updater 23 specifies a position that is preferred by the user in a preference space that is determined by transportation convenience (vertical axis) and safety (horizontal axis) and specify a vector from the origin to the preferred position (preference vector The updater 23 determines rankings of items to represent according to the sequence obtained when the items are orthogonally projected on a straight line extended in parallel with the preference vector (β) in an item space that is determined by transportation convenience (vertical axis) and safety (horizontal preference). In other words, as for the rankings of the items, the rankings and scores of the items are determined by only the ratio of the preference vector (β).
The preference estimator 30 is a processor that, when the user changes the index, suggests a direction in which more new items appear easily and that seems to be close to the true preference of the user. The preference estimator 30 includes a pre-processor 31, a provisional preference estimator 32 and a candidate determination unit 33. Specifically, the preference estimator 30 inhibits the user from entering the convergence process and detects whether the user is in the mode of the convergence process in order to end the convergence process of the user early. When the user is in the mode of the convergence process, the preference estimator 30 not only suggests a single index on which the user is likely to place importance but also represents how to move the index that has to be changed. The provisional preference estimator is an exemplary generator and the candidate determination unit 33 is an exemplary determination unit and an exemplary display controller.
The pre-processor 31 is a processor that executes pro-processing. Specifically, the pre-processor 31 previously calculates multiple preference vectors and rankings of items obtained when each of the preference vectors is chosen and stores the multiple preference vectors and the rankings in the candidate DB 15. For example, using the characteristics of the item space, the pre-processor 31 specifies items each serving as an end point of a convex hull of the item space as items that may be the top item. The pre-processor 31 also specifies which items appear as the top-N items when each end point is the top item and saves the items in the candidate DB 15.
Specific descriptions will be given using
As illustrated in
Thereafter, the pre-processor 31 ranks the items according to the same method as that illustrated in
The provisional preference estimator 32 is a processor that estimates a trend of choice of the user (also referred to as “preference trend” or “provisional preference” below) that is derived from the preference log of the user. Specifically, the provisional preference estimator 32 executes estimation of a preference trend when, when updating the items according to the preference of the user, the represented items do not change, the represented items do not change a given number of times successively, or the button 50h on the web screen illustrated in
First of all, in a case where choosing a preference has been carried out seven times, the provisional preference estimator 32 applies a weight value (w_T) to each of the first (T=1) to seventh (T=7) preferences to increase the new preference (see (B) in
The provisional preference estimator 32 extracts each trend of preference from the list (B) in
The provisional preference estimator 32 divides the weight of each preference by the sum of weights “3.93” to calculate a score of each preference. For example, the provisional preference estimator 32 calculates “2.1/3.93=0.53” as a score of the preference “transportation convenience +”. The provisional preference estimator 32 estimates the preference “transportation convenience +” with a score equal to or larger than a threshold “0.5” that can be set optionally among the scores of the respective preferences as a preference trend and adds the preference trend to the candidate determination unit 33. In other words, the provisional preference estimator 32 estimates that “the user wants to place much importance on transportation convenience”.
The candidate determination unit 33 is a processor that determines whether there is a candidate vector that is able to represent a better item in a direction of preference trend. Specifically, the candidate determination unit 33 determines whether there is another preference vector in a direction that is specified as a preference trend from the current preference vector, using the candidate DB 15 and the method described with reference to
Accordingly, as illustrated in (b) in
The candidate determination unit 33 specifies the top three items corresponding to the choice of the specified candidate vector from from the candidate DB 15 and specifies a difference in number from the three items that are currently represented. For example, as illustrated in
The candidate determination unit 33 specifies that one of the represented items changes when the candidate vector β_B is chosen, the three represented items change when the candidate vector β_H is chosen, and the three represented items change when the candidate vector β_L is chosen. As a result, the candidate determination unit 33 determines the candidate vector β_H and the candidate vector β_L that change the number of items the most among the three candidate vectors, which are candidates, as candidates to be adopted.
As illustrated in (d) in
In other words, as illustrated in
Thereafter, when the displayed message, or the like, is chosen by the user, the candidate determination unit 33 represents new items corresponding to the recommended direction to the user.
Process Flow
Flows of the respective above-described processes will be described. The process performed when a preference of the user is chosen and a process to represent a new item will be described.
Process Performed when Preference of User is Chosen
The updater 23 then associates the preference vector with an item space (S103) and, based on the preference vector and each item, determines rankings of the represented items in the item space (S104). The updater 23 then represents the top-N items to the user (S105).
Process to Represent New Items
As illustrated in
In other words, the pre-processor 31 generates vectors (candidate vectors) that enables the respective end points to be the top and simultaneously records the sets of rankings of the items in the group each of which is obtained when each of the end points is the top. In this case, which items appear in the top-N items when each end point is the top is specified and the items are saved in the candidate DB 15.
When a user operation to request representation of new items is accepted (YES at S204), the provisional preference estimator 32 reads the preferences log of the user from the log information DB 14 and estimates a preference trend based on the preference log (S205).
The candidate determination unit 33 determines whether the representation items do not change by the update of the list of the items that are represented for the previous time (S206). When the representation items with a given number of representation items changed are displayed (NO at S206), the candidate determination unit 33 ends the process and the process in
On the other hand, when the representation items do not change (YES at S206), the candidate determination unit 33 determines whether there is a candidate vector that enables representation of better items in the direction of the preference trend (S207). When there is not a corresponding candidate vector (NO at S207), the candidate determination unit 33 ends the process and the process in
On the other hand, when there is a corresponding candidate vector (YES at S207), the candidate determination unit 33 calculates how many items among the top N list are changed by the candidate vector and specifies a candidate vector that changes the largest number of items (S208).
When there are multiple corresponding candidate vectors (YES at S209), the candidate determination unit 33 calculates similarities in cosine with the current preference vector and specifies a candidate vector with high similarity (S210). On the other hand, when there are not multiple corresponding candidate vectors (NO at S209), the candidate determination unit 33 executes S211 without executing S210.
The candidate determination unit 33 represents a direction to the adopted candidate vector and a message like “Direction in which new X items will appear” to the user (S211). When the represented direction or the represented message is chosen (YES at S212), the candidate determination unit 33 represents corresponding new items to the user (S213). On the other hand, when neither the represented direction nor the represented message is chosen (NO at S212), the process ends and the process in
Effect
As described above, when the preference trend of the user becomes apparent, the search device 10 determines whether to represent information to change the displayed items and represents items that are along the preference trend of the user but were not chosen in the past. Accordingly, the search device 10 is able to store the choice of the user in the past and change the represented items. As a result, the search device 10 is able to meet the request to change the displayed items to the user and move specifying a preference forward.
When the log of choices of items made by the user accumulates, the search device 10 is able to represent content of input change enabling representation of new items along the preference of the user. During the process in which the user chooses a preference, when the preference trend of the user becomes apparent, the search device 10 is able to specify a direction of preference in which new items tend to appear while utilizing the trend. The search device 10 represents preference trend information and content of input change for which a direction in which new items tend to appear is taken into consideration and thus new items to be represented serve as information useful in the convergence process performed by the user and in specifying a preference by the system.
On the other hand, when “transportation convenience high” is specified as a preference trend, it can be specified that there is a useful item in a direction B. In this case, as illustrated in the item space in
In this method, as the represented items change but items irrelevant to the preference of the user are displayed, not information useful to the user but, on the contrary, the convergence process may be promoted resultantly. Furthermore, the log in which the items that are chosen randomly as described above is information unnecessary to estimate a preference trend of the user and the log could cause deterioration in accuracy in estimating a preference trend. Accordingly, the random-representation method is far from an effective method.
The embodiment of the present invention has been described. The invention may be carried out in various different modes in addition to the above-described embodiment.
Item on which importance is placed (preference item)
The first embodiment has been described by exemplifying mapping onto the space of two dimensions that are transportation convenience and safety; however, embodiments are not limited thereto. Transportation convenience, shopping, school, ties with neighbors, hospital and safety represented in
Weight Value
The above-described exemplary setting of weight values is an example only and the setting may be changed optionally. Furthermore, it is also possible to set a value by simple increase such that the weight on a new preference is the largest or set a value regularly. In the first embodiment, the example where a preference with a score equal to or larger than the threshold (0.5) is chosen has been described; however, embodiments are not limited thereto. For example, a preference with the highest score may be chosen.
Determination on Necessity to Change Representation
In the first embodiment, the example where, when the user presses the button 50h, estimating a preference trend and changing the representation items are executed has been described; however, embodiments are not limited thereto. For example, when the log of representation items is stored and changing items smaller in number than a given number, such as one, succeeds a given number of times, such as three times, sequentially, estimating a preference trend and changing the represented items may be executed.
When the number of times the user chooses a preference exceeds a threshold (for example, three times) or when a sum of weight values exceeds a given value (for example, 3), automatic execution may be performed. When the user presses the button 50h and the above-described condition is met, changing the representation items, etc., may be executed.
In the first embodiment, the example where a candidate vector that changes the top item is chosen has been described; however, embodiments are not limited thereto. For example, a candidate vector that changes the second and following items may be chosen and a candidate vector resulting in matching of at least one item may be chosen. The exemplary calculation of similarity is an example only, and another known calculation method may be used.
Content of Representation
The content of the message is exemplified only and may be changeable optionally. Furthermore, an image of item space in which the current preference vector, the estimated direction of preference trend, the recommended direction of item, etc., may be displayed.
Exemplary Preference
In the first embodiment, “+ (plus)” and “− (minus)” are used as as an exemplary notation of preferences of the user to denote attributes (preferences) on which importance is placed, etc. They are however an example only and embodiments are not limited thereto. When the user specifies “+” in a state where items with respect to each area (see
When the user specifies “safety +” in a state where each item is listed in specific examples like those in
Hardware
The communication interface 10a is a network interface card, or the like, and communicates with other servers. The HDD 10b stores programs to implement the functions represented in
The processor 10d reads a program to execute the same processes as those of the respective processors represented in
As described above, the search device 10 operates as an information processing device that executes an estimation method by reading and executing the program. The search device 10 may read the above-described program from a recording medium using a medium read device and execute the read program to implement the same functions as those of the above-described embodiment. Programs in other embodiments are not limited to ones that are executed by the search device 10. For example, the present invention may apply also to a case where another computer or another server executes the program or another computer and another server may cooperate to execute the program.
System
The process procedure, control procedure, specific names, information containing various types of data and parameters may be changed optionally unless otherwise noted.
Each component of each device illustrated in the drawings is a functional idea and thus is not always configured physically as illustrated in the drawings. In other words, specific modes of distribution or integration in each device are not limited to those illustrated in the drawings. In other words, all or part of the components may be configured by being distributed or integrated functionally or physically according to a given unit in accordance with various types of load and usage. For example, the processor that displays items and the processor that estimates a preference may be implemented with different chassis. Furthermore, all or any part of the processing functions that are implemented in the respective devices may be implemented by a CPU and a program that is analyzed and executed by the CPU or may be implemented as hardware using a wired logic.
According to the embodiments, it is possible to move forward changing items to display to a user and specifying a user preference together.
All examples and conditional language recited herein are intended for pedagogical purposes of aiding the reader in understanding the invention and the concepts contributed by the inventor to further the art, and are not to be construed as limitations to such specifically recited examples and conditions, nor does the organization of such examples in the specification relate to a showing of the superiority and inferiority of the invention. Although the embodiments of the present invention have been described in detail, it should be understood that the various changes, substitutions, and alterations could be made hereto without departing from the spirit and scope of the invention.
Number | Date | Country | Kind |
---|---|---|---|
2017-231162 | Nov 2017 | JP | national |