WO2016186110A1 - 情報処理システム、サーバ及びプログラム、並びに端末及びプログラム - Google Patents
情報処理システム、サーバ及びプログラム、並びに端末及びプログラム Download PDFInfo
- Publication number
- WO2016186110A1 WO2016186110A1 PCT/JP2016/064610 JP2016064610W WO2016186110A1 WO 2016186110 A1 WO2016186110 A1 WO 2016186110A1 JP 2016064610 W JP2016064610 W JP 2016064610W WO 2016186110 A1 WO2016186110 A1 WO 2016186110A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- players
- player
- weight
- predetermined player
- cheat
- Prior art date
Links
Images
Classifications
-
- A—HUMAN NECESSITIES
- A63—SPORTS; GAMES; AMUSEMENTS
- A63F—CARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
- A63F13/00—Video games, i.e. games using an electronically generated display having two or more dimensions
- A63F13/30—Interconnection arrangements between game servers and game devices; Interconnection arrangements between game devices; Interconnection arrangements between game servers
- A63F13/35—Details of game servers
-
- A—HUMAN NECESSITIES
- A63—SPORTS; GAMES; AMUSEMENTS
- A63F—CARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
- A63F13/00—Video games, i.e. games using an electronically generated display having two or more dimensions
- A63F13/70—Game security or game management aspects
- A63F13/75—Enforcing rules, e.g. detecting foul play or generating lists of cheating players
-
- A—HUMAN NECESSITIES
- A63—SPORTS; GAMES; AMUSEMENTS
- A63F—CARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
- A63F13/00—Video games, i.e. games using an electronically generated display having two or more dimensions
- A63F13/70—Game security or game management aspects
- A63F13/79—Game security or game management aspects involving player-related data, e.g. identities, accounts, preferences or play histories
-
- A—HUMAN NECESSITIES
- A63—SPORTS; GAMES; AMUSEMENTS
- A63F—CARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
- A63F13/00—Video games, i.e. games using an electronically generated display having two or more dimensions
- A63F13/85—Providing additional services to players
- A63F13/87—Communicating with other players during game play, e.g. by e-mail or chat
-
- A—HUMAN NECESSITIES
- A63—SPORTS; GAMES; AMUSEMENTS
- A63F—CARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
- A63F2300/00—Features of games using an electronically generated display having two or more dimensions, e.g. on a television screen, showing representations related to the game
- A63F2300/50—Features of games using an electronically generated display having two or more dimensions, e.g. on a television screen, showing representations related to the game characterized by details of game servers
- A63F2300/53—Features of games using an electronically generated display having two or more dimensions, e.g. on a television screen, showing representations related to the game characterized by details of game servers details of basic data processing
- A63F2300/535—Features of games using an electronically generated display having two or more dimensions, e.g. on a television screen, showing representations related to the game characterized by details of game servers details of basic data processing for monitoring, e.g. of user parameters, terminal parameters, application parameters, network parameters
Definitions
- the present invention relates to an information processing system, a server and a program, and a terminal and a program.
- Patent Document 1 As a game that can be executed on a terminal such as a smartphone, there is a game in which a plurality of players such as a multi-battle can participate (for example, see Patent Document 1).
- anti-cheat software Anti-Cheat Software
- This conventional cheat countermeasure software detects cheats only for those that can be reliably identified as cheats.
- Patent Document 1 discloses a technique for grouping players who seem to be cheetahs.
- the present invention has been made in view of such circumstances, and an object of the present invention is to establish a technique that can immediately respond to a cheat using an unknown cheat method or a cheat method that is difficult to detect.
- an immediate response cheetahs that use unknown cheat methods or cheat methods that are difficult to detect may be isolated so that they cannot be seen by general players, and the game operator may be warned of the appearance of the cheetah.
- the aim is to establish a technology that can be used.
- an information processing system includes: In an information processing system including a plurality of terminals capable of executing a game by receiving operations of a plurality of players and a server, The server History information acquisition means for executing, for each of the plurality of players, processing for acquiring history information of an operation of a predetermined player during execution of the game from the terminal of the predetermined player; Feature information generating means for generating, for each of the plurality of players, feature information indicating a feature of the operation of the predetermined player based on a predetermined weight value obtained from the operation history information of the predetermined player; With The feature information generating means includes First weight control means for controlling the weight value of the predetermined player to be heavier when the operation tendency of the predetermined player becomes singular with respect to the operation tendency of the set including at least a part of the plurality of players; Second weight control means for controlling the weight value of the predetermined player according to the elapsed time from the operation point of the predetermined player; The feature information for each
- the server of one embodiment of the present invention includes: In a server that communicates with each of a plurality of terminals that can accept the operation of each of a plurality of players and execute a game, History information acquisition means for executing, for each of the plurality of players, processing for acquiring history information of an operation of a predetermined player during execution of the game from the terminal of the predetermined player; Feature information generating means for generating, for each of the plurality of players, feature information indicating a feature of the operation of the predetermined player based on a predetermined weight value obtained from the operation history information of the predetermined player; With The feature information generating means includes First weight control means for controlling the weight value of the predetermined player to be heavier when the operation tendency of the predetermined player becomes singular with respect to the operation tendency of the set including at least a part of the plurality of players; Second weight control means for controlling the weight value of the predetermined player according to the elapsed time from the operation point of the predetermined player; The feature information for each of the plurality of players is generated by
- the program according to one aspect of the present invention is a program corresponding to the server according to one aspect of the present invention described above.
- FIG. 2 is a block diagram showing a hardware configuration of a player terminal as an embodiment of the terminal of the present invention in the information processing system of FIG. It is a block diagram which shows the hardware constitutions of the server which concerns on one Embodiment of this invention among the information processing systems of FIG. It is a schematic diagram which shows an example of the result of the cheat suppression control which the server of FIG. 3 performs. It is a schematic diagram for demonstrating grouping performed at the time of execution of cheat suppression control. It is a functional block diagram which shows the functional structural example of the server of FIG. FIG.
- FIG. 5 is a diagram illustrating a structure example of operation history information and feature information (metadata vector) used in cheat suppression control executed by a server having the functional configuration of FIG. 4.
- 8 shows an example of the structure of the history information shown in FIG. 7 implemented as a three-dimensional array. It is a figure which shows an example of a tweight () function used in the cheat suppression control which the server which has a functional structure of FIG. 4 performs. It is a schematic diagram explaining the content of the calculation formula of the characteristic information used in the cheat suppression control which the server which has a functional structure of FIG. 4 performs.
- FIG. 11 is a diagram showing a graph of each element of feature information calculated by the equation of FIG. 10. It is a flowchart explaining an example of the flow of a process of the server which has a functional structure of FIG.
- the “moving image” includes an image displayed by each of the following first to third processes.
- the first process refers to a process in which a series of still images composed of a plurality of images are continuously switched over time and displayed for each motion of an object (for example, a game character) in a planar image (2D image).
- two-dimensional animation so-called flip-flopping processing, corresponds to the first processing.
- the second process refers to a process in which motions corresponding to respective actions of an object (for example, a game character) in a stereoscopic image (3D model image) are set, and the motions are changed and displayed over time.
- a three-dimensional animation corresponds to the second process.
- the third process refers to a process in which videos (that is, moving images) corresponding to respective actions of an object (for example, a game character) are prepared and the video is played over time.
- FIG. 1 shows the configuration of an information processing system according to an embodiment of the present invention.
- the information processing system shown in FIG. 1 is a system including player terminals 1-0 to 1-m and a server 2 used by each of m + 1 players (m is an arbitrary integer value of 1 or more).
- Each of the player terminals 1-0 to 1-m and the server 2 are connected to each other via a predetermined network N such as the Internet.
- the server 2 provides a game execution environment to each of the player terminals 1-0 to 1-m and provides various services related to the game executed on each of the player terminals 1-0 to 1-m. To do.
- player terminal 1 when it is not necessary to individually distinguish each of the player terminals 1-0 to 1-m, they are collectively referred to as “player terminal 1”.
- FIG. 2 is a block diagram showing a hardware configuration of the player terminal 1 as an embodiment of the terminal of the present invention in the information processing system of FIG.
- the player terminal 1 is composed of a smartphone or the like.
- the player terminal 1 includes a CPU (Central Processing Unit) 21, a ROM (Read Only Memory) 22, a RAM (Random Access Memory) 23, a bus 24, an input / output interface 25, a touch operation input unit 26, a display Unit 27, input unit 28, storage unit 29, communication unit 30, and drive 31.
- a CPU Central Processing Unit
- ROM Read Only Memory
- RAM Random Access Memory
- the CPU 21 executes various processes according to a program recorded in the ROM 22 or a program loaded from the storage unit 29 to the RAM 23.
- the RAM 23 appropriately stores data necessary for the CPU 21 to execute various processes.
- the CPU 21, ROM 22, and RAM 23 are connected to each other via a bus 24.
- An input / output interface 25 is also connected to the bus 24.
- a touch operation input unit 26, a display unit 27, an input unit 28, a storage unit 29, a communication unit 30, and a drive 31 are connected to the input / output interface 25.
- the touch operation input unit 26 includes, for example, a capacitance type or resistive film type (pressure sensitive) position input sensor stacked on the display surface of the display unit 27, and detects coordinates of a position where the touch operation is performed.
- the touch operation refers to an operation of touching or approaching an object with respect to the touch operation input unit 26.
- the object that contacts or approaches the touch operation input unit 26 is, for example, a player's finger or a touch pen.
- touch position the position where the touch operation is performed
- the coordinates of the touch position are referred to as “touch coordinates”.
- the display unit 17 includes a display such as a liquid crystal display, and displays various images such as an image related to a game.
- the touch operation input unit 26 and the display unit 27 constitute a touch panel.
- the input unit 28 is configured with various hardware buttons and the like, and inputs various information according to the player's instruction operation.
- the storage unit 29 is configured by a DRAM (Dynamic Random Access Memory) or the like and stores various data.
- the communication unit 30 controls communication performed with other devices (the server 2 and other player terminals 1 in the example of FIG. 1) via the network N including the Internet.
- the drive 31 is provided as necessary.
- a removable medium 41 composed of a magnetic disk, an optical disk, a magneto-optical disk, a semiconductor memory, or the like is appropriately attached to the drive 31.
- the program read from the removable medium 41 by the drive 31 is installed in the storage unit 29 as necessary.
- the removable medium 41 can also store various data stored in the storage unit 29 in the same manner as the storage unit 29.
- FIG. 3 is a block diagram showing a hardware configuration of the server 2 according to an embodiment of the present invention in the information processing system of FIG.
- the server 2 includes a CPU 51, a ROM 52, a RAM 53, a bus 54, an input / output interface 55, an output unit 56, an input unit 57, a storage unit 58, a communication unit 59, and a drive 60. . Since the configuration of the server 2 is basically the same as the configuration excluding the touch panel of the player terminal 1, the description thereof is omitted here.
- the game can be executed on the player terminal 1 by the cooperation of the various hardware and various software of the player terminal 1 of FIG. 2 and the server 2 of FIG.
- a game in which a plurality of players such as a multi-battle participate is targeted.
- the information processing system of this embodiment can perform various control with respect to a game.
- the information processing system can execute the following control as control for suppressing cheetah in the game (hereinafter referred to as “cheat suppression control”).
- cheat tool many cheetahs cheat using a program or the like (hereinafter referred to as “cheat tool”) that enables cheats in the game. Therefore, the operation data of the player who uses the same cheat tool shares the behavior unique to the cheat tool. That is, players who use the same cheat tool have similar operation tendencies in the game.
- the operation tendency is a tendency obtained from the history information of the player's operation performed on various operation targets such as a predetermined event, and indicates a characteristic of the player regarding the operation method and contents. Therefore, the control invented by the present inventor is cheat suppression control, paying attention to the point that “players using the same cheat tool have similar operation tendencies in the game”.
- cheat suppression control is a control in which players are grouped according to the similarity of operation data, and the range in which information between players can be referred to is limited to the same group.
- the referable range of information between players refers to a range in which information of other players can be browsed and linked with other players in the game.
- FIG. 4 is a schematic diagram illustrating an example of a result of cheat suppression control.
- n groups (G is an arbitrary integer value of 4 or more in the example of FIG. 4) groups G1 to Gn are formed as a result of executing the cheat suppression control.
- Groups G1 and G2 are groups to which normal players who do not cheat belong.
- the difference between the groups G1 and G2 is whether or not the operation tendency is similar. That is, the players belonging to the group G1 have similar operation tendencies to other players belonging to the same group G1, while the operation tendencies are dissimilar to other players belonging to other groups including the group G2.
- the players belonging to the group G2 are similar in operation tendency to other players belonging to the same group G2, but are not similar to other players belonging to other groups including the group G1.
- the group G3 is a group in which players using the same cheat tool are classified.
- the operation data transmitted from the player terminal 1 using the predetermined cheat tool to the server 2 shows an operation tendency unique to the predetermined cheat tool. This operation tendency is common among a plurality of players using the predetermined cheat tool. Accordingly, a group G3 to which a plurality of players using the predetermined cheat tool belong is automatically generated.
- the group Gn is also a group in which players using the same cheat tool are classified.
- the difference between the groups G3 and Gn is whether or not the operation tendency is similar. That is, the group G3 is composed of a group of players that use the first cheat tool, whereas the group Gn is a group of players that use a second cheat tool different from the first cheat tool. It is configured.
- the player terminal 1 of the player belonging to the group Gk (k is an arbitrary integer value from 1 to n) can browse information of other players and cooperate with other players in the game.
- a screen that can be displayed a screen Ik that is limited to those in which other players belong to the same group Gk is displayed.
- a cheetah that uses the first cheat tool can cooperate only with other players (in many cases cheetahs) that use the same first cheat tool, and is a normal player belonging to the groups G1 and G2. Will be automatically quarantined.
- the cheetah using the first cheat tool can cooperate only with other players with similar operation tendencies, that is, other cheetahs with operation tendencies that are clearly different from normal because cheating is performed.
- the cheetah using the first cheat tool recognizes that the service provider (game operator or the like) has detected the cheat action. As a result, the cheetah is expected to stop the cheat. In this way, the cheat itself can be suppressed.
- the information processing system can automatically group players having similar operation tendencies as described above, it is not particularly necessary to perform prior learning for grouping.
- the second cheat tool is an unknown cheat tool
- the players who use the second cheat tool are automatically classified into the group Gn.
- the cheetah using the second cheat tool has another player with a similar operation tendency, that is, another cheetah with an operation tendency clearly different from the normal because of cheating. It can only be linked. Therefore, the cheetah using the second cheat tool will recognize that the service provider has detected the cheat action. As a result, the cheetah is expected to stop the cheat. In this way, even when an unknown second cheat tool has appeared, the cheat itself can be automatically suppressed.
- FIG. 5 is a schematic diagram for explaining grouping performed during execution of cheat suppression control.
- grouping is performed as clustering between players.
- each player is expressed as one vector in a multidimensional vector space (a three-dimensional vector space for convenience of explanation in the example of FIG. 5). That is, the server 2 calculates the similarity between the operation tendency of a certain player and the operation tendency of another player as a distance in the multidimensional vector space. For example, it is assumed that there are n + 1 types of commands (n is an arbitrary integer value) in the game. In this case, the server 2 constructs an n + 1-dimensional vector space with each command type as an axis, and arranges the vectors of each player in the vector space.
- the number n + 1 of vector elements of each player may be several hundred to several thousand depending on the game content. For example, when there are 1000 types of commands in the game, a vector composed of 1000 elements is calculated as a vector for each player. The vector space and the vector of each player can be changed according to the game title.
- the cheat suppression control can be applied to any existing game genre that may appear in the future or, for example, as an existing game genre, it can be applied to a wide range of game genres such as RPG, action RPG, and simulation game.
- a three-dimensional vector space is constructed for convenience of explanation, and the vector of each player is represented as a black dot on this vector space.
- one group is generated by a point group having a short distance.
- groups UG1, UG2, and UG3 are generated as groups to which normal players who do not perform cheat actions or the like belong.
- groups CG1, CG2, and CG3 are generated as groups to which the cheetah belongs.
- the cluster (group) is not fixed thereafter, and clustering is repeatedly performed every moment, and the cluster also changes each time. . That is, players belonging to each cluster can also change in real time.
- the group to which the player belongs for example, the group CG2 in FIG. 5
- the group to which the player belongs rapidly expands. Therefore, it is possible to grasp the possibility that an unknown cheat technique has appeared due to the change in the size of the cluster. That is, when the group CG2 of FIG. 5 suddenly appears or expands, it is easy to determine that each player belonging to the group CG2 is likely to cheat using an unknown cheat technique. it can.
- the clustering method used in the cheat suppression control of the present embodiment is a unique one that has not existed before. Therefore, in the following, this clustering method will be referred to as “responsive clustering (clustering that is responsive to changes in things)” in particular in order to compare with the conventional method.
- the present embodiment employs a method of generating feature values (metadata) for each player.
- a feature amount is represented as a vector as described above, such a vector is hereinafter referred to as a “metadata vector”. That is, the server 2 of this embodiment generates a metadata vector indicating the characteristics of each player from the operation data log in order to calculate the similarity of the operation data of the players.
- the server 2 reduces the importance of actions common to all players and increases the importance of actions common to only a few players when generating metadata vectors.
- first weighting control By this first weighting control, the behavior unique to the cheat tool, that is, the operation tendency is more appropriately extracted.
- the server 2 executes weighting control (hereinafter referred to as “second weighting control”) such that the latest operation data is strongly weighted and the past operation data is weakly weighted.
- second weighting control weighting control
- the following effects can be obtained. For example, if a normal player who is not a cheetah happens to temporarily use a cheat tool or suspects cheat (an act similar to cheat), as shown in FIG.
- the player is immediately classified into the cheetah group CG1 from the normal group UG1.
- the screen I3, the screen In, etc. of FIG. 4 are displayed on the player terminal 1 of the player.
- the player can immediately recognize that the only other player that can be viewed or linked is a cheetah, and therefore immediately stops cheats and acts suspected of being cheats (if there is an intention to stop them). be able to. In this case, after a certain period of time, the player can return from the cheetah group CG1 to the normal group UG1.
- the weighting is weak for the past operation data by the second weighting control, a weight value obtained by cumulatively applying the history information of the operation data of the cheat tool is obtained. For this reason, even if the cheetah with addictiveness stops using the cheat tool for a short period of time, it cannot escape from the cheetah group (group CG3 in the example of FIG. 5).
- the server 2 has a functional configuration as shown in FIG.
- the history information acquisition unit 101 As shown in FIG. 6, in the CPU 51 of the server 2, the history information acquisition unit 101, the feature information generation unit 102, the clustering unit 103, and the other player information transmission control unit 104 function.
- the feature information generation unit 102 As the feature information generation unit 102, a first weight control unit 111, a second weight control unit 112, and a weight calculation unit 113 function.
- the history information acquisition unit 101 executes, for each of a plurality of players, a process for acquiring history information of operation of a predetermined player during execution of a predetermined game from the player terminal 1 of the predetermined player. That is, the operation history information from each of the player terminals 1-0 to 1-m is acquired by the history information acquisition unit 101.
- the feature information generation unit 102 generates, for each of a plurality of players, feature information indicating the feature of the operation of the predetermined player based on a predetermined weight value obtained from the history information of the operation of the predetermined player.
- the feature information means the above-described metadata vector in this embodiment, but a specific example will be described later with reference to FIG.
- the first weight control unit 111 performs the first weight control described above. That is, the first weight control unit 111 performs control so that the weight value of the predetermined player becomes heavier when the operation tendency of the predetermined player becomes peculiar to the operation tendency of the set including at least a part of the plurality of players. .
- the second weight control unit 112 performs the second weight control described above. That is, the second weight control unit 112 controls the weight value of the predetermined player in accordance with the elapsed time from the operation point of the predetermined player.
- the operation time of a predetermined player refers to the time when the predetermined player operates for the first time from a preset time, such as when the predetermined player is launched for the first time after registration of the predetermined game.
- the weight calculation unit 113 calculates the weight value for each of the plurality of players based on the control results of the first weight control unit 111 and the second weight control unit 112, thereby obtaining feature information for each of the plurality of players ( Metadata vector).
- the clustering unit 103 clusters a plurality of players based on the feature information (metadata vector) for each of the plurality of players.
- the other player information transmission control unit 104 transmits the information of other players belonging to the same group to the player terminals 1-0 to 1-m of the plurality of players clustered by the clustering unit 103, and sends them to the other groups.
- the control which prohibits transmission of the information of the other player to which it belongs is performed.
- the information of other players is information that enables browsing of information of other players and cooperation with other players in the game, and a screen on the player terminal 1 side (screen I1 in the example of FIG. 4). To Im) is information that can be displayed.
- the terminals of players belonging to a predetermined group are player terminals 1-0, 1-m. Therefore, information of other players belonging to the same group is player terminals 1-0, 1-m.
- the other player terminals 1-1 to 1- (m-1) are prohibited from transmitting.
- FIG. 7 is a diagram illustrating a structure example of operation history information and feature information (metadata vector).
- the data structure of the history information of the operation of a predetermined player has a matrix structure.
- Such a matrix indicating the history information of the operation of the predetermined player is particularly referred to as “OLM (Operation Log Matrix)”.
- Each column (horizontal axis) of the OLM indicates the operation content of a predetermined player for each type of operation of the game.
- n is an arbitrary integer
- elements op [0] to op [n] indicating operation contents for these n + 1 types.
- each of the elements op [0] to op [n] stores “1” when the corresponding type of operation is performed, and stores “0” when the operation is not performed.
- Each row (vertical axis) of the OLM indicates the income timing of the history information of the operation of the predetermined player.
- operation history information is acquired at times t1 to tlast for each predetermined unit as time elapses.
- the predetermined unit (acquisition interval) of the acquisition timing is arbitrary, may be fixed or variable, and may be a unit of real time such as 1 second or 60 seconds, It may be a transaction unit in the game.
- a vector configured with each operation weight value as an element is generated as a metadata vector MV of the predetermined player.
- the metadata vector MV of a predetermined player is generated using not only the OLM of the predetermined player but also the OLMs of other players participating in the game. Since one OLM is accumulated as operation history information for one player, the entire system is implemented as a three-dimensional array.
- FIG. 8 shows an example of the structure of operation history information implemented as a three-dimensional array. In this example, since the game is being executed by m + 1 player terminals 1-0 to 1-m, that is, since m + 1 players are participating in the game, each of the player terminals 1-0 to 1-m.
- the operation history information is implemented as a three-dimensional array of m + 1 OLMs obtained from
- the feature information generation unit 102 generates a metadata vector MV indicating an operation tendency for each player based on the OLM implemented in this way. Specifically, as illustrated in FIG. 7, the feature information generation unit 102 executes a process of aggregating OLMs into one vector, that is, a metadata vector MV.
- the second weight control unit 112 controls the weight for each element value (weight value) of the OLM of the predetermined player in accordance with the elapsed time from the operation point of the predetermined player during the process of aggregation.
- the function for controlling the weight according to the elapsed time in this way is referred to as a “tweight () function”.
- FIG. 9 is a diagram illustrating an example of the tweight () function. As shown in FIG. 9, in the tweight () function, since the operation performed most recently is regarded as important, the weight increases as it is performed most recently, and the weight decreases as it goes back to the past.
- the weight reduction is stopped at a fixed time so that the history information values of the addictive cheetah operations are cumulatively applied. Further, in the tweight () function, the weight becomes 0 after a certain period (for example, 180 days in the example of FIG. 9) in order to discard the log accumulated more than a certain amount.
- the tweight () function is not particularly limited to the example of FIG. 9, and for example, a function that can perform weighting for a shorter time may be employed.
- the weight calculation unit 113 of the feature information generation unit 102 calculates the metadata vector MV of a predetermined player according to the following equation (1) using the tweight () function (second weighting control by the second weight control unit 112). .
- the expression (1) includes the first weighting control by the first weight control unit 111, and this limitation will be described later.
- u represents an ID of a player focused on as a calculation target (hereinafter referred to as “focused player”). That is, vec (u) indicates the metadata vector MV of the player u of interest.
- the last (u) of the numerator of each element indicates the last (most recent) acquisition timing of the operation history information for the player u of interest. If the OLM of FIGS.
- D [u, i, p] of the numerator of each element is the p-th type (p is an arbitrary integer value from 0 to n) corresponding to the i-th (time ti) history information of the player u of interest.
- the operation value (score) is indicated. For example, if the OLM of the player u of interest is as shown in FIG. 7, the element op [0] (the element op [0 at the upper left corner) at time t0 of the OLM in FIG. 7 is set as d [u, 0, 0].
- Last (j) of the denominator of each element indicates the acquisition timing of the last (most recent) of the operation history information about the player j.
- the denominator d [j, k, p] of each element indicates the value of the p-th type operation corresponding to the k-th (time tk) history information of the player j.
- FIG. 10 is a schematic diagram for explaining the contents of the expression (1).
- the vector vec (u) of the above equation (1) that is, the metadata vector MV of the player U of interest is shown.
- This metadata vector vec (u) is an element a1, etc., n + 1 It is composed of individual elements. One element is calculated by a fraction consisting of a denominator a2m and a numerator a2c.
- the denominator a2m of the p-th element is the accumulated value (score) from time t0 to tlast of the value of the p-th type operation (the stored value of the element op [1] in FIG. 7 in the example of FIG. 10).
- M + 1 is the total addition value for all players. That is, the denominator a2m of the p-th element indicates “generality” regarding the value of the p-th type of operation.
- This denominator a2m is composed of two aggregation operations. The first (right side of the formula) aggregation operation is to calculate the score by summing the values of the feature categories (values of the p-th type of operation) corresponding to the specific operation for each player. The second (left side of the formula) aggregation operation is to sum the scores of each player for all players.
- the numerator a2c calculates the score of the focused player u by accumulating the weighted values based on the tweight () function for the operation history information of the focused player u for the times t0 to tlast. is there.
- the weight calculation unit 113 divides the denominator a2m indicating the generality score derived from the total value of all players, with respect to the numerator a2c indicating the score (weighted score based on elapsed time) for the player of interest u. By doing so, the value (score) of an element indicating whether or not the player u of interest is performing a specific operation is calculated.
- the control for dividing the denominator a2m for the numerator a2c is the first weighting control by the first weight control unit 111.
- FIG. 11 is a graph of each element of the vector vec (u) of Expression (1), that is, the metadata vector MV of the player u of interest.
- an operation tendency of performing the operations of the 0th type and the 2nd type (the values of the elements op [0] and op [2] in each row of the OLM tend to be 1).
- an operation tendency to operate the first type and the third type (the values of the elements op [1] and op [3] in each row of the OLM tend to be 1).
- a certain cheat tool there is an operation tendency to operate the first type and the third type (the values of the elements op [1] and op [3] in each row of the OLM tend to be 1).
- FIG. 11A shows a metadata vector MV of a normal player who is not a cheetah. It is assumed that this player has accidentally used the cheat tool or suspected cheat in the past period. For this reason, past values are slightly reflected in each value (score) of the element op [1] and the element op [3] in the metadata vector MV.
- the player is classified into a cheetah group CG1 from a normal group UG1.
- the screen I3, the screen In, etc. of FIG. 4 are displayed on the player terminal 1 of the player.
- the player recognizes that the only other player that can be browsed and linked is the cheetah, and therefore, it is assumed that the cheat or the suspected cheat is immediately stopped. In this case, the player returns to the operation tendency of performing the operations of the 0th type and the 2nd type (the tendency that the values of the elements op [0] and op [2] in the most recent row of the OLM are 1). It will be.
- the second weight control based on the tweight () function is performed on the vector vec (u) of the expression (1) by the second weight control unit 112. That is, control is performed in which a strong weight is applied to the history information of the most recent operation and a weak weight is applied to the history information of the past operation.
- the vector vec (u) becomes a metadata vector MV that strongly reflects the most recent operation. That is, as shown in FIG. 11A, each value (score) of the element op [0] and the element op [2] in the metadata vector MV becomes a high value because the history information of the most recent operation is strongly reflected. . That is, it returns to the normal operation tendency that each value (score) of the element op [0] and the element op [2] in the metadata vector MV is high. As a result, the player can return from the cheetah group CG1 to the normal group UG1.
- FIG. 11B shows a cheetah metadata vector MV with addictiveness.
- the tweight () function although the weight applied to the history information of the past operation is weak, if the cheat tool is used regularly, each value (score) of the element op [1] and the element op [3] in the metadata vector MV Is inevitably high due to the accumulation of past routine operations. For this reason, even if an addictive cheetah stops using the cheat tool most recently, the elements op [1] and op [3] in the metadata vector MV are used for a short period of time.
- the operation tendency that each value (score) is high that is, the operation tendency specific to the cheetah does not change. As a result, the cheetah cannot exit the cheetah group (group CG3 in the example of FIG. 5).
- the clustering unit 103 performs a clustering process using the metadata vector MV of each player in order to generate a group of players. Therefore, the following advantages are taken for the metadata vector MV of each player, and a superiority in performance arises.
- the total number of players registered in the game is m
- the average number of actions recorded as the operation history information of each player is n
- the number of elements of the metadata vector MV vector Let k be the number of spatial features.
- the metadata vector MV is generated for all the players, it is necessary to repeat n ⁇ k + n ⁇ m ⁇ k times. This is because the common denominator a2m (see FIG. 10) is used in the calculation of the metadata vector MV of all the players, as shown in the above-described equation (1), and therefore the denominator only needs to be calculated once. It is.
- the feature information generation unit 102 can also execute this iterative process as an incremental calculation by caching an intermediate calculation result without executing it every time. Furthermore, with respect to past history information, the weighting value by the tweight () function is almost unchanged. Therefore, the calculation result may be reused without performing the weighting calculation every time.
- the numerator a2c see FIG.
- the feature information generation unit 102 generates the metadata vector MV every time a certain amount of operation history information is added, for example, 10 records. In this case, it may be repeated about 60 billion times (10 ⁇ 30,000 + 10 ⁇ 200,000 ⁇ 30,000). That is, the calculation of the metadata vector MV used for the clustering process by the clustering unit 103 can be performed at a speed about 100 times faster than the theoretical calculation cost described above, which is repeated about 60 trillion times.
- the clustering unit 103 performs a clustering process using each metadata vector MV generated as described above in order to generate a group of players.
- the clustering algorithm in this case is not particularly limited, and an arbitrary algorithm can be adopted.
- the K-Means method can be adopted.
- a node (metadata vector MV of each player) is recursively assigned to k randomly set cluster centroid candidates, thereby automatically and rapidly generating a cluster.
- the metadata vector MV is a vector in a multidimensional vector space, similarity between players can be calculated using a similarity calculation method in a vector space represented by cosine similarity. it can.
- the cosine similarity cos (a, b) of the vectors a and b can be defined by the following equation (2). ... (2)
- the other player information transmission control unit 104 generates other player information based on the result of clustering by the clustering unit 103.
- the other player information refers to information that allows a predetermined player to view information about other players and to cooperate with other players in the game.
- the other player information transmission control unit 104 controls the transmission of other player information so that the other players are limited to those belonging to the same group. This isolates the cheetah from good normal players. Therefore, a normal player can enjoy the game comfortably without feeling discomfort due to cheating. In other words, for a regular cheetah, a good normal player is isolated and only another cheetah using the same cheat tool is presented as another player.
- the cheetah recognizes that a service provider (such as a game operator) has detected a cheat action. As a result, the cheetah is expected to stop cheating. In this way, the cheat action itself can be suppressed.
- a service provider such as a game operator
- the CPU 51 of the server 2 further calculates the possibility of cheating (Cheat-Probability) for each group based on the status information of the classified players.
- the cheatability calculation method is not particularly limited, and for example, a different method may be adopted for each game title. Specifically, for example, when the status of each player rises in a short time, or when rare items can be acquired in a short time, a method of calculating the cheat possibility from the status change is adopted. May be. Further, for example, a method of calculating cheatability from the content of communication with the client may be employed.
- the CPU 51 of the server 2 further warns the service provider of the appearance of a new cheat method (which has been unknown so far). In this way, by monitoring the change in the cluster size, it becomes possible to make an emergency alert a service provider about the emergence of a cheat technique that has been unknown until now.
- FIG. 12 is a flowchart for explaining the processing flow of the server 2.
- step S1 the history information acquisition unit 101 of the server 2 acquires history information from each of the player terminals 1-0 to 1-m.
- step S2 the feature information generation unit 102 sets a player of interest.
- step S ⁇ b> 3 the first weight control unit 111 performs first weighting control for the player of interest.
- step S4 the second weight control unit 112 executes second weighting control for the player of interest.
- step S5 the weight calculation unit 113 generates a metadata vector MV as feature information of the player of interest based on the execution results of the first weighting control and the second weighting control.
- the first weight control is the division of the numerator a2c of each element of the equation (1) by the denominator a2m. It means the control of weighting by doing.
- the second weight control means weight control using the tweight () function in the numerator a2c (see FIG. 10) of the above formula (1). That is, the above-described steps S2 to S4 are substantially executed substantially simultaneously as the calculation of the above-described equation (1).
- step S ⁇ b> 6 the feature information generation unit 102 determines whether all the players have been set as the player of interest.
- “all players” may be all players registered in the game, but may be all active players in order to improve performance as described above. That is, “all players” means all of the players defined in advance according to a predetermined rule (for example, a rule such as being limited to active players). In other words, a set including at least a part of all players registered in the game is “all players” here.
- step S6 If there is a player who has not yet been set as the target player among all the players, it is determined NO in step S6, the process returns to step S2, and the subsequent processes are repeated.
- step S6 When all of the players are set as the player of interest and the metadata vector MV is generated as the feature information by the processes of steps S3 to S5, it is determined as YES in step S6, and the process proceeds to step S7. .
- step S7 the clustering unit 103 clusters each player based on the feature information.
- step S8 the other player information transmission control unit 104 generates other player information for each group.
- step S9 the other player information transmission control unit 104 transmits the other player information to the player terminals 1 belonging to the same group, and prohibits the transmission to the player terminals 1 belonging to the other group.
- step S10 the CPU 51 of the server 2 determines whether or not there is an instruction to end the process.
- an instruction to end the process is not particularly limited, but in this embodiment, power-off of the server 2 is adopted. That is, when the power is cut off in the server 2, it is determined as YES in step S10, and the processing of the server 2 is ended. On the other hand, unless the server 2 is powered off, it is determined NO in step S10, the process returns to step S1, and the subsequent processes are repeated.
- the CPU 51 of the server 2 performs cheat based on the classified player status information for each group clustered by the processing of step S7. Calculate what you are doing. Then, the CPU 51 compares the cheat possibility with the threshold value for each cluster (group). When the cluster whose cheat possibility exceeds the threshold is rapidly expanding, the CPU 51 gives the service provider a group of cheetahs using a new cheat method (unknown so far). Warning that there is.
- the functional configuration of FIG. 6 is merely an example, and is not particularly limited. That is, it is sufficient if the information processing system has a function capable of executing the above-described series of processing as a whole, and what functional block is used to realize this function is not particularly limited to the example of FIG. Further, the location of the functional block is not particularly limited to that shown in FIG.
- the functional block of the server 2 may be transferred to the player terminal 1 or the like, and conversely, the functional block of the terminal 1 may be transferred to the server 2 or the like.
- one functional block may be constituted by hardware alone, software alone, or a combination thereof.
- a program constituting the software is installed on a computer or the like from a network or a recording medium.
- the computer may be a computer incorporated in dedicated hardware.
- the computer may be a computer capable of executing various functions by installing various programs, for example, a general-purpose smartphone or personal computer other than a server.
- the recording medium including such a program is not only constituted by a removable medium (not shown) distributed separately from the apparatus main body in order to provide the program to the player, but is also provided to the player in a state of being preinstalled in the apparatus main body. It is composed of a provided recording medium or the like.
- the step of describing the program recorded on the recording medium is not limited to the processing performed in time series along the order, but is not necessarily performed in time series, either in parallel or individually.
- the process to be executed is also included.
- the term “system” means an overall apparatus configured by a plurality of devices, a plurality of means, and the like.
- an information processing system to which the present invention is applied can take various embodiments having the following configurations, including the information processing system as the embodiment of FIG. 1 described above. That is, an information processing system to which the present invention is applied includes a plurality of terminals (for example, player terminals 1-0 to 1-M in FIG. 1) that can receive the operations of a plurality of players and execute a game, and a server ( For example, an information processing system including the server 2) of FIG.
- the server History information acquisition means for example, history information acquisition unit 101 in FIG.
- the feature information generating means includes When the operation tendency of the predetermined player becomes peculiar to the operation tendency of the set including at least a part of the plurality of players, first weight control means (for example, controlling so that the weight value of the predetermined player becomes heavy) A first weight control unit 111) in FIG.
- Second weight control means for example, the second weight control unit 112 in FIG. 6) for controlling the weight value of the predetermined player according to the elapsed time from the operation point of the predetermined player;
- the feature information for each of the plurality of players is generated by calculating the weight value for each of the plurality of players based on the control results of the first weight control unit and the second weight control unit.
- Weight calculation means for example, weight calculation unit 113 in FIG. 6); including.
- the characteristic information (for example, the above-described metadata vector MV) of the predetermined player generated in this way is based on the first weighting control (the first weight control according to the commonality of many players based on the history information of the operation of the predetermined player. This is obtained as a result of integrating and executing the second weighting control (control by the second weight control means) according to time, and the control by the weight control means.
- the first condition is that there is no false positive (ie, false-positive), that is, an innocent player is mistakenly detected as a cheetah and no measures such as account suspension are performed.
- the second condition is to be able to cope with cheats that are difficult to distinguish from errors that may normally occur.
- the cheat tool transmits the data for the cheat in the form of misidentifying it as an error, the second condition is that even if it cannot be determined as a cheat, it can react immediately when an act suspected of being a cheat is executed. It is.
- the third condition is a condition that there is a real-time capability, that is, a response can be made immediately when a cheat or a suspected action is executed and a service provider can be notified.
- the fourth condition is that there is compatibility, that is, high compatibility with the existing operating system and anti-virus software, and the game system itself, and there is no possibility of impeding the execution of the existing software. It is a condition.
- the information processing system to which the present invention is applied can satisfy the first to fourth conditions.
- the weight value is decreased for an operation tendency common to many players, while the weight value is increased for a unique operation tendency common to only a few players.
- the second weighting control gives strong weighting to the history information of the most recent operation, while giving weak weighting to the history information of the past operation. Thereby, for example, even if the operation tendency is unprecedented, it can be easily monitored in real time from the viewpoint of the scale (size) of a player group with similar operation tendency.
- the service provider is immediately notified that a cheat (or suspected cheat) using an unknown cheat technique has appeared. be able to.
- the information processing system to which the present invention is applied can satisfy the second and third conditions.
- the service provider does not take measures such as account suspension for players who are determined to be cheating (or suspected cheating) by an unknown cheat technique, for example, normal operation tendency All you have to do is isolate it from other players. Accordingly, the player can recognize that he is being monitored as a person who is cheating (or suspected to be cheat) using an unknown cheat technique. If the player immediately stops cheat (or suspected cheat) and returns to normal operation, the history information of the most recent operation is heavily weighted by the second weighting control. Return to what shows normal operating tendency. As a result, the player is unlabeled as a cheat (or a suspected cheat). On the other hand, when the player does not stop the cheat, the history information of the operation of the cheat is accumulated cumulatively. Therefore, even if weak weighting is performed on the past operation history information by the second weight control, the feature information remains indicative of cheat operation tendency. Thus, the information processing system to which the present invention is applied can satisfy the first condition.
- the fourth condition can be satisfied.
- the information processing system to which the present invention is applied can satisfy the first to fourth conditions, and appropriately detects a cheat using an unknown cheat method or a cheat method that is difficult to detect, As a result, such a cheat can be dealt with immediately.
- a cheat can be dealt with immediately.
- cheetahs that use unknown cheat methods or cheat methods that are difficult to detect may be isolated so that they cannot be seen by general players, and the game operator may be warned of the appearance of the cheetah. It becomes possible.
- the method for determining whether or not a predetermined player is cheating is not particularly limited as long as it is a method using the characteristic information of the predetermined player.
- clustering is performed based on feature information It is preferable to introduce judgment on a group basis.
- the server preferably includes clustering means (for example, the clustering unit 103 in FIG. 6) for clustering the plurality of players based on the feature information for each of the plurality of players.
- the history information acquisition means of the server is For each of the plurality of players, processing for acquiring the history information of the operation of the predetermined player for each of a plurality of types of operations accepted in the game,
- the weight value calculating means includes: Calculating a plurality of weight values corresponding to each of the plurality of types of operations;
- the feature information including the plurality of weight values as elements can be generated for each of the plurality of players. Thereby, it can produce
- the similarity of feature information between players can be easily and appropriately calculated using distances in a multidimensional space, so that players with similar operation tendencies can be extracted easily and appropriately.
- the first weight control means includes Using the accumulated value of the time series of the operation history information of the predetermined player as a numerator, and using the total addition value of the time series accumulated values of the operation history information for each of the plurality of players as a denominator, Controlling the fractional value represented to be the weight value of the given player, Can be. Thereby, the first weighting control can be executed more appropriately.
- the second weight control means includes With respect to the time series of the history information of the operation of the predetermined player, weighting that decreases as the elapsed time from the operation time of the predetermined player becomes longer, It is possible to execute control such that the time series cumulative value of the history information of the operation after weighting is used as the numerator. Thereby, the second weighting control can be executed more appropriately.
- the second weight control means can also execute control to stop the decrease in weight when the elapsed time from the operation point of the predetermined player exceeds a certain time.
- the weight applied to the history information of past cheat operations is weak, the weight value inevitably becomes high because a number of cheat operations are accumulated in the usual case. For this reason, even if the cheetah has an addictive operation tendency, even if the cheat is stopped most recently, the operation tendency is unique to the cheetah for a short stop time. As a result, the cheetah cannot be removed from the label of a cheat (or a suspected cheat).
- the server transmits information of other players belonging to the same group to each terminal of the plurality of players clustered by the clustering means, and transmits information of other players belonging to the other group.
- Transmission control means for example, the other player information transmission control unit 104 in FIG. 6) for executing the prohibition control can be further provided.
- a measure to isolate the player who is determined to be cheating by an unknown cheat technique (or an act suspected of being cheat) from a player having a normal operation tendency is effectively applied.
- the player recognizes that he / she is being monitored by the service provider as a cheat (or an act suspected of being a cheat). This leads to suppression of the cheat itself.
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Business, Economics & Management (AREA)
- Computer Security & Cryptography (AREA)
- General Business, Economics & Management (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
Abstract
未知のチート手法や検出が困難なチート手法を用いたチートに対して即時対応が可能となる技術を確立すること。 履歴情報取得部101は、操作の履歴情報を、複数のプレイヤー端末1-0乃至1-mから取得する。特徴情報生成部102は、操作の履歴情報から得られる所定の重み値により、操作の特徴を示す特徴情報を複数のプレイヤー毎に生成する。クラスタリング部103は、複数のプレイヤー毎の特徴情報に基づいて、複数のプレイヤーをクラスタリングする。他プレイヤー情報送信制御部104は、クラスタリングされた複数のプレイヤーの夫々のプレイヤー端末1-0乃至1-mに対して、同一グループに属する他プレイヤーの情報を送信し、他グループに属する他プレイヤーの情報の送信を禁止する制御を実行する。
Description
本発明は、情報処理システム、サーバ及びプログラム、並びに端末及びプログラムに関する。
従来から、スマートフォン等の端末で実行可能なゲームとして、マルチバトル等複数のプレイヤーが参加可能なゲームが存在する(例えば特許文献1参照)。
このようなゲームでは、ゲームデータを改造する行為、例えば、レベルやステータスを異常に高める行為、グラフィックの変更行為、レアアイテムの獲得行為等を行う者の存在が問題になる。
なお、以下、このようなゲームデータを改造する行為を含め、ゲーム運営者の意図しない動作を発現させてゲームを不正に優位に進めようとする行為を広く「チート」と呼ぶ。例えば、不正なデータ通信をする行為もチートの一例である。また、このようなチートをする者を「チーター」と呼ぶ。
なお、以下、このようなゲームデータを改造する行為を含め、ゲーム運営者の意図しない動作を発現させてゲームを不正に優位に進めようとする行為を広く「チート」と呼ぶ。例えば、不正なデータ通信をする行為もチートの一例である。また、このようなチートをする者を「チーター」と呼ぶ。
そこで、従来においても、チート対策ソフトウェア(Anti-Cheat Software)が提供されている。この従来のチート対策ソフトウェアは、確実にチートとして判別できるものに限定して、チートを検出するものである。
また、チーターと思われるプレイヤーをグルーピングする技術が、特許文献1に開示されている。
しかしながら、近年のチート手法の多様化や複雑化に伴い、特許文献1に記載の技術や従来のチート対策ソフトウェアでは対応できないチートが多数行われている。また、未知のチート手法も逐次登場してきている。
従って、未知のチート手法や検出が困難なチート手法を用いたチートが行われた場合、特にそのようなチートの数が急激に増加した場合、チートを行わない一般のプレイヤーを保護すべく、ゲーム運営者は当該チートに対して即時対応をすることが求められている。
具体的には、即時対応として、未知のチート手法や検出が困難なチート手法を用いるチーターを、一般のプレイヤーから見えないように隔離すると共に、ゲーム運営者に当該チーターの出現を警告することが求められている。
従って、未知のチート手法や検出が困難なチート手法を用いたチートが行われた場合、特にそのようなチートの数が急激に増加した場合、チートを行わない一般のプレイヤーを保護すべく、ゲーム運営者は当該チートに対して即時対応をすることが求められている。
具体的には、即時対応として、未知のチート手法や検出が困難なチート手法を用いるチーターを、一般のプレイヤーから見えないように隔離すると共に、ゲーム運営者に当該チーターの出現を警告することが求められている。
本発明は、このような状況に鑑みてなされたものであり、未知のチート手法や検出が困難なチート手法を用いたチートに対して即時対応が可能となる技術の確立を目的とする。
具体的には、即時対応として、未知のチート手法や検出が困難なチート手法を用いるチーターを、一般のプレイヤーから見えないように隔離すると共に、ゲーム運営者に当該チーターの出現を警告することが可能となる技術の確立を目的とする。
具体的には、即時対応として、未知のチート手法や検出が困難なチート手法を用いるチーターを、一般のプレイヤーから見えないように隔離すると共に、ゲーム運営者に当該チーターの出現を警告することが可能となる技術の確立を目的とする。
上記目的を達成するため、本発明の一態様の情報処理システムは、
複数のプレイヤーの夫々の操作を受付けてゲームを実行し得る複数の端末と、サーバとを含む情報処理システムにおいて、
前記サーバは、
前記ゲームの実行中における所定プレイヤーの操作の履歴情報を、当該所定プレイヤーの端末から取得する処理を、前記複数のプレイヤー毎に実行する履歴情報取得手段と、
前記所定プレイヤーの前記操作の履歴情報から得られる所定の重み値により、当該所定プレイヤーの操作の特徴を示す特徴情報を、前記複数のプレイヤー毎に生成する特徴情報生成手段と、
を備え、
前記特徴情報生成手段は、
前記所定プレイヤーの操作傾向が、前記複数のプレイヤーの少なくとも一部を含む集合の操作傾向に対して特異になると、当該所定プレイヤーの重み値が重くなるように制御する第1重み制御手段と、
前記所定プレイヤーの操作時点からの経過時間に応じて、当該所定プレイヤーの重み値を制御する第2重み制御手段と、
前記第1重み制御手段と前記第2重み制御手段との各制御結果に基づいて、前記複数のプレイヤー毎に前記重み値を夫々演算することで、前記複数のプレイヤー毎の前記特徴情報を生成する重み演算手段と、
を含む。
複数のプレイヤーの夫々の操作を受付けてゲームを実行し得る複数の端末と、サーバとを含む情報処理システムにおいて、
前記サーバは、
前記ゲームの実行中における所定プレイヤーの操作の履歴情報を、当該所定プレイヤーの端末から取得する処理を、前記複数のプレイヤー毎に実行する履歴情報取得手段と、
前記所定プレイヤーの前記操作の履歴情報から得られる所定の重み値により、当該所定プレイヤーの操作の特徴を示す特徴情報を、前記複数のプレイヤー毎に生成する特徴情報生成手段と、
を備え、
前記特徴情報生成手段は、
前記所定プレイヤーの操作傾向が、前記複数のプレイヤーの少なくとも一部を含む集合の操作傾向に対して特異になると、当該所定プレイヤーの重み値が重くなるように制御する第1重み制御手段と、
前記所定プレイヤーの操作時点からの経過時間に応じて、当該所定プレイヤーの重み値を制御する第2重み制御手段と、
前記第1重み制御手段と前記第2重み制御手段との各制御結果に基づいて、前記複数のプレイヤー毎に前記重み値を夫々演算することで、前記複数のプレイヤー毎の前記特徴情報を生成する重み演算手段と、
を含む。
本発明の一態様のサーバは、
複数のプレイヤーの夫々の操作を受付けてゲームを実行し得る複数の端末の夫々と通信をするサーバにおいて、
前記ゲームの実行中における所定プレイヤーの操作の履歴情報を、当該所定プレイヤーの端末から取得する処理を、前記複数のプレイヤー毎に実行する履歴情報取得手段と、
前記所定プレイヤーの前記操作の履歴情報から得られる所定の重み値により、当該所定プレイヤーの操作の特徴を示す特徴情報を、前記複数のプレイヤー毎に生成する特徴情報生成手段と、
を備え、
前記特徴情報生成手段は、
前記所定プレイヤーの操作傾向が、前記複数のプレイヤーの少なくとも一部を含む集合の操作傾向に対して特異になると、当該所定プレイヤーの重み値が重くなるように制御する第1重み制御手段と、
前記所定プレイヤーの操作時点からの経過時間に応じて、当該所定プレイヤーの重み値を制御する第2重み制御手段と、
前記第1重み制御手段と前記第2重み制御手段との各制御結果に基づいて、前記複数のプレイヤー毎に前記重み値を夫々演算することで、前記複数のプレイヤー毎の前記特徴情報を生成する重み演算手段と、
を含む。
複数のプレイヤーの夫々の操作を受付けてゲームを実行し得る複数の端末の夫々と通信をするサーバにおいて、
前記ゲームの実行中における所定プレイヤーの操作の履歴情報を、当該所定プレイヤーの端末から取得する処理を、前記複数のプレイヤー毎に実行する履歴情報取得手段と、
前記所定プレイヤーの前記操作の履歴情報から得られる所定の重み値により、当該所定プレイヤーの操作の特徴を示す特徴情報を、前記複数のプレイヤー毎に生成する特徴情報生成手段と、
を備え、
前記特徴情報生成手段は、
前記所定プレイヤーの操作傾向が、前記複数のプレイヤーの少なくとも一部を含む集合の操作傾向に対して特異になると、当該所定プレイヤーの重み値が重くなるように制御する第1重み制御手段と、
前記所定プレイヤーの操作時点からの経過時間に応じて、当該所定プレイヤーの重み値を制御する第2重み制御手段と、
前記第1重み制御手段と前記第2重み制御手段との各制御結果に基づいて、前記複数のプレイヤー毎に前記重み値を夫々演算することで、前記複数のプレイヤー毎の前記特徴情報を生成する重み演算手段と、
を含む。
本発明の一態様のプログラムは、上述の本発明の一態様のサーバに対応するプログラムである。
本発明によれば、未知のチート手法や検出が困難なチート手法を用いたチートに対して即時対応が可能となる技術を確立することができる。
以下、本発明の実施形態について、図面を用いて説明する。
なお、以下において、単に「画像」と呼ぶ場合には、「動画像」と「静止画像」との両方を含むものとする。
また、「動画像」には、次の第1処理乃至第3処理の夫々により表示される画像を含むものとする。
第1処理とは、平面画像(2D画像)におけるオブジェクト(例えばゲームキャラクタ)の夫々の動作に対して、複数枚からなる一連の静止画像を時間経過と共に連続的に切り替えて表示させる処理をいう。具体的には例えば、2次元アニメーション、いわゆるパラパラ漫画的な処理が第1処理に該当する。
第2処理とは、立体画像(3Dモデルの画像)におけるオブジェクト(例えばゲームキャラクタ)の夫々の動作に対応するモーションを設定しておき、時間経過と共に当該モーションを変化させて表示させる処理をいう。具体的には例えば、3次元アニメーションが第2処理に該当する。
第3処理とは、オブジェクト(例えばゲームキャラクタ)の夫々の動作に対応した映像(即ち動画)を準備しておき、時間経過とともに当該映像を流していく処理をいう。
また、「動画像」には、次の第1処理乃至第3処理の夫々により表示される画像を含むものとする。
第1処理とは、平面画像(2D画像)におけるオブジェクト(例えばゲームキャラクタ)の夫々の動作に対して、複数枚からなる一連の静止画像を時間経過と共に連続的に切り替えて表示させる処理をいう。具体的には例えば、2次元アニメーション、いわゆるパラパラ漫画的な処理が第1処理に該当する。
第2処理とは、立体画像(3Dモデルの画像)におけるオブジェクト(例えばゲームキャラクタ)の夫々の動作に対応するモーションを設定しておき、時間経過と共に当該モーションを変化させて表示させる処理をいう。具体的には例えば、3次元アニメーションが第2処理に該当する。
第3処理とは、オブジェクト(例えばゲームキャラクタ)の夫々の動作に対応した映像(即ち動画)を準備しておき、時間経過とともに当該映像を流していく処理をいう。
図1は、本発明の一実施形態に係る情報処理システムの構成を示している。
図1に示す情報処理システムは、m+1人(mは1以上の任意の整数値)のプレイヤーの夫々により使用されるプレイヤー端末1-0乃至1-mと、サーバ2とを含むシステムである。プレイヤー端末1-0乃至1-mの夫々と、サーバ2とは、インターネット等の所定のネットワークNを介して相互に接続されている。
図1に示す情報処理システムは、m+1人(mは1以上の任意の整数値)のプレイヤーの夫々により使用されるプレイヤー端末1-0乃至1-mと、サーバ2とを含むシステムである。プレイヤー端末1-0乃至1-mの夫々と、サーバ2とは、インターネット等の所定のネットワークNを介して相互に接続されている。
サーバ2は、プレイヤー端末1-0乃至1-mの夫々に対してゲームの実行環境を提供し、プレイヤー端末1-0乃至1-mの夫々において実行されるゲームに関する各種各様のサービスを提供する。
なお、以下、プレイヤー端末1-0乃至1-mの夫々を個々に区別する必要がない場合、これらをまとめて「プレイヤー端末1」と呼ぶ。
図2は、図1の情報処理システムのうち、本発明の端末の一実施形態としてのプレイヤー端末1のハードウェア構成を示すブロック図である。
プレイヤー端末1は、スマートフォン等で構成される。
プレイヤー端末1は、CPU(Central Processing Unit)21と、ROM(Read Only Memory)22と、RAM(Random Access Memory)23と、バス24と、入出力インターフェース25と、タッチ操作入力部26と、表示部27と、入力部28と、記憶部29と、通信部30と、ドライブ31と、を備えている。
プレイヤー端末1は、CPU(Central Processing Unit)21と、ROM(Read Only Memory)22と、RAM(Random Access Memory)23と、バス24と、入出力インターフェース25と、タッチ操作入力部26と、表示部27と、入力部28と、記憶部29と、通信部30と、ドライブ31と、を備えている。
CPU21は、ROM22に記録されているプログラム、又は、記憶部29からRAM23にロードされたプログラムに従って各種の処理を実行する。
RAM23には、CPU21が各種の処理を実行する上において必要なデータ等も適宜記憶される。
RAM23には、CPU21が各種の処理を実行する上において必要なデータ等も適宜記憶される。
CPU21、ROM22及びRAM23は、バス24を介して相互に接続されている。このバス24にはまた、入出力インターフェース25も接続されている。入出力インターフェース25には、タッチ操作入力部26、表示部27、入力部28、記憶部29、通信部30及びドライブ31が接続されている。
タッチ操作入力部26は、例えば表示部27の表示面に積層される静電容量式又は抵抗膜式(感圧式)の位置入力センサにより構成され、タッチ操作がなされた位置の座標を検出する。
ここで、タッチ操作とは、タッチ操作入力部26に対する物体の接触又は近接の操作をいう。タッチ操作入力部26に対して接触又は近接する物体は、例えばプレイヤーの指やタッチペン等である。なお、以下、タッチ操作がなされた位置を「タッチ位置」と呼び、タッチ位置の座標を「タッチ座標」と呼ぶ。
表示部17は、液晶等のディスプレイにより構成され、ゲームに関する画像等、各種画像を表示する。
このように、本実施形態では、タッチ操作入力部26と表示部27とにより、タッチパネルが構成されている。
ここで、タッチ操作とは、タッチ操作入力部26に対する物体の接触又は近接の操作をいう。タッチ操作入力部26に対して接触又は近接する物体は、例えばプレイヤーの指やタッチペン等である。なお、以下、タッチ操作がなされた位置を「タッチ位置」と呼び、タッチ位置の座標を「タッチ座標」と呼ぶ。
表示部17は、液晶等のディスプレイにより構成され、ゲームに関する画像等、各種画像を表示する。
このように、本実施形態では、タッチ操作入力部26と表示部27とにより、タッチパネルが構成されている。
入力部28は、各種ハードウェア釦等で構成され、プレイヤーの指示操作に応じて各種情報を入力する。
記憶部29は、DRAM(Dynamic Random Access Memory)等で構成され、各種データを記憶する。
通信部30は、インターネットを含むネットワークNを介して他の装置(図1の例ではサーバ2や他のプレイヤー端末1)との間で行う通信を制御する。
記憶部29は、DRAM(Dynamic Random Access Memory)等で構成され、各種データを記憶する。
通信部30は、インターネットを含むネットワークNを介して他の装置(図1の例ではサーバ2や他のプレイヤー端末1)との間で行う通信を制御する。
ドライブ31は、必要に応じて設けられる。ドライブ31には、磁気ディスク、光ディスク、光磁気ディスク、或いは半導体メモリ等よりなる、リムーバブルメディア41が適宜装着される。ドライブ31によってリムーバブルメディア41から読み出されたプログラムは、必要に応じて記憶部29にインストールされる。また、リムーバブルメディア41は、記憶部29に記憶されている各種データも、記憶部29と同様に記憶することができる。
図3は、図1の情報処理システムのうち、本発明の一実施形態に係るサーバ2のハードウェア構成を示すブロック図である。
サーバ2は、CPU51と、ROM52と、RAM53と、バス54と、入出力インターフェース55と、出力部56と、入力部57と、記憶部58と、通信部59と、ドライブ60とを備えている。
サーバ2の構成は、プレイヤー端末1のタッチパネルを除いた構成と基本的に同様であるので、ここではその説明は省略する。
サーバ2の構成は、プレイヤー端末1のタッチパネルを除いた構成と基本的に同様であるので、ここではその説明は省略する。
このような図2のプレイヤー端末1及び図3のサーバ2の各種ハードウェアと各種ソフトウェアとの協働により、プレイヤー端末1でゲームの実行が可能になる。
本実施形態では、マルチバトル等の複数のプレイヤーが参加するゲームが対象である。
このため、本実施形態の情報処理システムは、ゲームに対する各種制御を実行できる。特に、情報処理システムは、ゲーム内でチーターを抑制する制御(以下、「チート抑制制御」と呼ぶ)として、次のような制御を実行することができる。
本実施形態では、マルチバトル等の複数のプレイヤーが参加するゲームが対象である。
このため、本実施形態の情報処理システムは、ゲームに対する各種制御を実行できる。特に、情報処理システムは、ゲーム内でチーターを抑制する制御(以下、「チート抑制制御」と呼ぶ)として、次のような制御を実行することができる。
即ち、チーターの多くは、ゲーム内でチートを可能にしてしまうプログラム等(以下、「チートツール」と呼ぶ)を用いて、チートを行っている。従って、同一のチートツールを使用するプレイヤーの操作データは、当該チートツール固有の振る舞いを共有することになる。即ち、同一のチートツールを使用するプレイヤー同士は、ゲーム内の操作傾向が類似する。
ここで、操作傾向とは、所定イベント等各種操作対象に対して夫々行ったプレイヤーの操作の履歴情報から得られる傾向であり、操作の方法や内容についての当該プレイヤーの特徴を示すものいう。
そこで、この「同一のチートツールを使用するプレイヤー同士は、ゲーム内の操作傾向が類似する」という点に着目して、本発明者により発明された制御が、チート抑制制御である。
ここで、操作傾向とは、所定イベント等各種操作対象に対して夫々行ったプレイヤーの操作の履歴情報から得られる傾向であり、操作の方法や内容についての当該プレイヤーの特徴を示すものいう。
そこで、この「同一のチートツールを使用するプレイヤー同士は、ゲーム内の操作傾向が類似する」という点に着目して、本発明者により発明された制御が、チート抑制制御である。
具体的には、プレイヤーを操作データの類似性に応じてグループ化するとともに、プレイヤー同士の情報の参照可能範囲を同一グループ内に限定するという制御が、チート抑制制御である。
プレイヤー同士の情報の参照可能範囲とは、他プレイヤーの情報を閲覧することや他プレイヤーとゲーム内で連携することができる範囲をいう。
プレイヤー同士の情報の参照可能範囲とは、他プレイヤーの情報を閲覧することや他プレイヤーとゲーム内で連携することができる範囲をいう。
さらに以下、図4及び図5を参照して、チート抑制制御について説明する。
図4は、チート抑制制御の結果の一例を示す模式図である。
図4の例では、チート抑制制御が実行された結果として、n個(図4の例ではnは4以上の任意の整数値)グループG1乃至Gnが形成されている。
図4は、チート抑制制御の結果の一例を示す模式図である。
図4の例では、チート抑制制御が実行された結果として、n個(図4の例ではnは4以上の任意の整数値)グループG1乃至Gnが形成されている。
グループG1,G2は、チートを行わない通常のプレイヤーが属するグループである。
グループG1,G2の差異は、操作傾向が類似するか否かである。
つまり、グループG1に属するプレイヤーは、同一のグループG1に属する他プレイヤーとは操作傾向が類似である一方、グループG2を含め他グループに属する他プレイヤーとは操作傾向が非類似である。
一方、グループG2に属するプレイヤーは、同一のグループG2に属する他プレイヤーとは操作傾向が類似である一方、グループG1を含め他グループに属する他プレイヤーとは操作傾向が非類似である。
グループG1,G2の差異は、操作傾向が類似するか否かである。
つまり、グループG1に属するプレイヤーは、同一のグループG1に属する他プレイヤーとは操作傾向が類似である一方、グループG2を含め他グループに属する他プレイヤーとは操作傾向が非類似である。
一方、グループG2に属するプレイヤーは、同一のグループG2に属する他プレイヤーとは操作傾向が類似である一方、グループG1を含め他グループに属する他プレイヤーとは操作傾向が非類似である。
グループG3は、同一のチートツールを使用するプレイヤーが分類されるグループである。
即ち、上述したように、所定のチートツールを使用するプレイヤー端末1からサーバ2に送信される操作データには、当該所定のチートツール固有の操作傾向が現れる。この操作傾向は、当該所定のチートツールを使用する複数のプレイヤー間で共通する。従って、自動的に、当該所定のチートツールを使用する複数のプレイヤーが属するグループG3が生成される。
即ち、上述したように、所定のチートツールを使用するプレイヤー端末1からサーバ2に送信される操作データには、当該所定のチートツール固有の操作傾向が現れる。この操作傾向は、当該所定のチートツールを使用する複数のプレイヤー間で共通する。従って、自動的に、当該所定のチートツールを使用する複数のプレイヤーが属するグループG3が生成される。
グループGnもまた、同一のチートツールを使用するプレイヤーが分類されるグループである。
グループG3,Gnの差異は、操作傾向が類似するか否かである。つまり、グループG3は、第1のチートツールを使用するプレイヤー群から構成されているのに対して、グループGnは、第1のチートツールとは別の第2のチートツールを使用するプレイヤー群から構成されている。
グループG3,Gnの差異は、操作傾向が類似するか否かである。つまり、グループG3は、第1のチートツールを使用するプレイヤー群から構成されているのに対して、グループGnは、第1のチートツールとは別の第2のチートツールを使用するプレイヤー群から構成されている。
図4に示すように、グループGk(kは1乃至nのうち任意の整数値)に属するプレイヤーのプレイヤー端末1には、他プレイヤーの情報を閲覧することや他プレイヤーとゲーム内で連携することができる画面として、他プレイヤーが同一グループGkに属する者に限定されている画面Ikが表示される。
つまり、画面I3には、第1のチートツールを使用する他プレイヤーのみが登場する。換言すると、第1のチートツールを使用するチーターは、同一の第1のチートツールを使用する他プレイヤー(多くの場合チーター)のみしか連携することができず、グループG1,G2に属する通常のプレイヤーから自動的に隔離されることになる。
これにより、第1のチートツールを使用するチーターは、類似の操作傾向の他プレイヤー、即ちチートを行っているため通常とは明らかに異なる操作傾向の他のチーターとしか連携できない。従って、第1のチートツールを使用するチーターは、サービス提供者(ゲームの運営者等)がチート行為を検出していることを認識することになる。その結果、当該チーターがチートを停止することが期待される。このようにして、チート自体を抑制することができる。
これにより、第1のチートツールを使用するチーターは、類似の操作傾向の他プレイヤー、即ちチートを行っているため通常とは明らかに異なる操作傾向の他のチーターとしか連携できない。従って、第1のチートツールを使用するチーターは、サービス提供者(ゲームの運営者等)がチート行為を検出していることを認識することになる。その結果、当該チーターがチートを停止することが期待される。このようにして、チート自体を抑制することができる。
また、本実施形態の情報処理システムは、上述したように操作傾向が類似するプレイヤーを自動的にグルーピングすることができるので、グルーピングのための事前の学習をする必要は特に無い。
これにより、例えば第2のチートツールが、未知のチートツールであったとしても、当該第2のチートツールを使用するプレイヤーは自動的にグループGnに分類される。
この場合も、グループG3と全く同様に、第2のチートツールを使用するチーターは、類似の操作傾向の他プレイヤー、即ちチートを行っているため通常とは明らかに異なる操作傾向の他のチーターとしか連携できない。従って、第2のチートツールを使用するチーターは、サービス提供者がチート行為を検出していることを認識することになる。その結果、当該チーターがチートを停止することが期待される。このようにして、未知の第2のチートツールが登場してきた場合であっても、自動的に、チート自体を抑制することができる。
これにより、例えば第2のチートツールが、未知のチートツールであったとしても、当該第2のチートツールを使用するプレイヤーは自動的にグループGnに分類される。
この場合も、グループG3と全く同様に、第2のチートツールを使用するチーターは、類似の操作傾向の他プレイヤー、即ちチートを行っているため通常とは明らかに異なる操作傾向の他のチーターとしか連携できない。従って、第2のチートツールを使用するチーターは、サービス提供者がチート行為を検出していることを認識することになる。その結果、当該チーターがチートを停止することが期待される。このようにして、未知の第2のチートツールが登場してきた場合であっても、自動的に、チート自体を抑制することができる。
図5は、チート抑制制御の実行時に行われるグルーピングを説明するための模式図である。
チート抑制制御においては、グルーピングは、プレイヤー同士のクラスタリングとして行われる。
このクラスタリングを実現するために、本実施形態では、各プレイヤーは、多次元ベクトル空間(図5の例では説明の便宜上3次元ベクトル空間)における1つのベクトルとして表現される。
つまり、サーバ2は、とあるプレイヤーの操作傾向と、他プレイヤーの操作傾向との類似度を、多次元ベクトル空間における距離として算出する。
例えば、ゲームにおいて、n+1種類(nは任意の整数値)のコマンドが存在するものとする。この場合、サーバ2は、コマンドの各種類を軸とするn+1次元のベクトル空間を構築し、当該ベクトル空間内に各プレイヤーのベクトルを配置させる。
この各プレイヤーのベクトルの要素数n+1は、ゲーム内容に応じて、数100乃至数1000になる場合がある。例えば、ゲーム内に1000種類のコマンドがある場合、1000個の要素からなるベクトルが、各プレイヤーのベクトルとして演算される。
このベクトル空間や各プレイヤーのベクトルは、ゲームタイトルに応じて変更することができる。即ち、チート抑制制御は、既存又は今後登場し得る任意のゲームジャンルに適用可能であり、例えば既存のものとしては、RPG、アクションRPG、シミュレーションゲーム等幅広いゲームジャンルに適用可能である。
チート抑制制御においては、グルーピングは、プレイヤー同士のクラスタリングとして行われる。
このクラスタリングを実現するために、本実施形態では、各プレイヤーは、多次元ベクトル空間(図5の例では説明の便宜上3次元ベクトル空間)における1つのベクトルとして表現される。
つまり、サーバ2は、とあるプレイヤーの操作傾向と、他プレイヤーの操作傾向との類似度を、多次元ベクトル空間における距離として算出する。
例えば、ゲームにおいて、n+1種類(nは任意の整数値)のコマンドが存在するものとする。この場合、サーバ2は、コマンドの各種類を軸とするn+1次元のベクトル空間を構築し、当該ベクトル空間内に各プレイヤーのベクトルを配置させる。
この各プレイヤーのベクトルの要素数n+1は、ゲーム内容に応じて、数100乃至数1000になる場合がある。例えば、ゲーム内に1000種類のコマンドがある場合、1000個の要素からなるベクトルが、各プレイヤーのベクトルとして演算される。
このベクトル空間や各プレイヤーのベクトルは、ゲームタイトルに応じて変更することができる。即ち、チート抑制制御は、既存又は今後登場し得る任意のゲームジャンルに適用可能であり、例えば既存のものとしては、RPG、アクションRPG、シミュレーションゲーム等幅広いゲームジャンルに適用可能である。
図5の例では、説明の便宜上3次元のベクトル空間が構築され、このベクトル空間上に各プレイヤーのベクトルが、黒丸の点として表されている。
このベクトル空間において、距離が近い点群により1つのグループが生成される。図5の例では、チート行為等を行わない通常のプレイヤーが属するグループとして、グループUG1,UG2,UG3が生成されている。また、チーターが属するグループとして、グループCG1,CG2,CG3が生成されている。
このベクトル空間において、距離が近い点群により1つのグループが生成される。図5の例では、チート行為等を行わない通常のプレイヤーが属するグループとして、グループUG1,UG2,UG3が生成されている。また、チーターが属するグループとして、グループCG1,CG2,CG3が生成されている。
本実施形態のチート抑制制御では、このようなクラスタリングが1回行われたらその後クラスタ(グループ)が固定となるわけではなく、時々刻々とクラスタリングが繰り返し行われ、その都度、クラスタも変化していく。即ち、各クラスタに属するプレイヤーもリアルタイムに変化し得る。
このようなクラスタリングがリアルタイムに行われることによって、とある特定の操作傾向が類似するプレイヤーが急激に増加した時に、当該プレイヤーが属するグループ(例えば図5のグループCG2)が急拡大する。従って、クラスタの大きさの変化により、未知のチート手法が出現した可能性を把握することができる。即ち、図5のグループCG2が急に登場したり急拡大した場合、当該グループCG2に属する各プレイヤーは、未知のチート手法を用いてチートをしている可能性が高いと判断することが容易にできる。
このように、本実施形態のチート抑制制御で用いられるクラスタリング手法は、従来にない独自なものである。そこで、以下、当該クラスタリング手法を、従来のものと比較すべく、特に「レスポンシブなクラスタリング(物事の変化に反応性のあるクラスタリング)」と呼ぶこととする。
このようなクラスタリングがリアルタイムに行われることによって、とある特定の操作傾向が類似するプレイヤーが急激に増加した時に、当該プレイヤーが属するグループ(例えば図5のグループCG2)が急拡大する。従って、クラスタの大きさの変化により、未知のチート手法が出現した可能性を把握することができる。即ち、図5のグループCG2が急に登場したり急拡大した場合、当該グループCG2に属する各プレイヤーは、未知のチート手法を用いてチートをしている可能性が高いと判断することが容易にできる。
このように、本実施形態のチート抑制制御で用いられるクラスタリング手法は、従来にない独自なものである。そこで、以下、当該クラスタリング手法を、従来のものと比較すべく、特に「レスポンシブなクラスタリング(物事の変化に反応性のあるクラスタリング)」と呼ぶこととする。
「レスポンシブなクラスタリング」を実現すべく、本実施形態では、各プレーヤ毎の特徴量(メタデータ)を生成する方式が採用されている。ここで、本実施形態では、特徴量は上述のようにベクトルとして示されるので、このようなベクトルを以下「メタデータベクトル」と呼ぶ。
即ち、本実施形態のサーバ2は、プレイヤーの操作データの類似性を演算すべく、操作データのログから各プレイヤーの特徴を示すメタデータベクトルを生成する。
即ち、本実施形態のサーバ2は、プレイヤーの操作データの類似性を演算すべく、操作データのログから各プレイヤーの特徴を示すメタデータベクトルを生成する。
詳細については後述するが、サーバ2は、メタデータベクトルの生成に際し、全てのプレイヤーに共通する行為の重要度を下げ、かつ、少数のプレイヤーのみに共通する行為の重要度を上げるような重み付け制御(以下、「第1重み付け制御」と呼ぶ)を実行する。この第1の重み付け制御により、チートツール固有の振る舞い、即ち操作傾向がより適切に抽出されることになる。
さらに、サーバ2は、直近の操作データに対しては強い重み付けをし、過去の操作データに対しては弱い重み付けをするといった重み付け制御(以下、「第2重み付け制御」と呼ぶ)を実行する。
このような第1重み付け制御及び第2重み付け制御により重み付けがなされた値(重み値)を用いることで、次のような効果を奏することができる。
例えば、チーターでない通常のプレイヤーが、たまたまチートツールを一時的に使用してしまったり、或いは、チートと疑われる行為(チートに類似する行為)をしてしまった場合、図5に示すように、当該プレイヤーは、即座に、通常のグループUG1からチーターのグループCG1に分類される。
この場合、当該プレイヤーのプレイヤー端末1には、図4の画面I3や画面In等が表示される。従って、当該プレイヤーは、閲覧や連携が可能な他プレイヤーはチーターのみであることを即座に認識することができるので、チートやチートと疑われる行為を(停止する意思があれば)即座に停止することができる。この場合、一定時間後に、当該プレイヤーは、チーターのグループCG1から通常のグループUG1に戻ることができる。
一方で、第2重み付け制御により過去の操作データに対しては弱い重み付けとなるものの、チートツールの操作データの履歴情報が累積的に作用した重み値が得られる。このため、常習性のあるチーターは、たとえ短期間のチートツールの使用を停止したとしても、チーターのグループ(図5の例ではグループCG3)を抜け出すことはできない。
このような第1重み付け制御及び第2重み付け制御により重み付けがなされた値(重み値)を用いることで、次のような効果を奏することができる。
例えば、チーターでない通常のプレイヤーが、たまたまチートツールを一時的に使用してしまったり、或いは、チートと疑われる行為(チートに類似する行為)をしてしまった場合、図5に示すように、当該プレイヤーは、即座に、通常のグループUG1からチーターのグループCG1に分類される。
この場合、当該プレイヤーのプレイヤー端末1には、図4の画面I3や画面In等が表示される。従って、当該プレイヤーは、閲覧や連携が可能な他プレイヤーはチーターのみであることを即座に認識することができるので、チートやチートと疑われる行為を(停止する意思があれば)即座に停止することができる。この場合、一定時間後に、当該プレイヤーは、チーターのグループCG1から通常のグループUG1に戻ることができる。
一方で、第2重み付け制御により過去の操作データに対しては弱い重み付けとなるものの、チートツールの操作データの履歴情報が累積的に作用した重み値が得られる。このため、常習性のあるチーターは、たとえ短期間のチートツールの使用を停止したとしても、チーターのグループ(図5の例ではグループCG3)を抜け出すことはできない。
以上説明したようなチート抑制制御を実行すべく、サーバ2は図6に示すような機能的構成を有している。
図6に示すように、サーバ2のCPU51においては、履歴情報取得部101と、特徴情報生成部102と、クラスタリング部103と、他プレイヤー情報送信制御部104とが機能する。
特徴情報生成部102として、第1重み制御部111と、第2重み制御部112と、重み演算部113とが機能する。
特徴情報生成部102として、第1重み制御部111と、第2重み制御部112と、重み演算部113とが機能する。
履歴情報取得部101は、所定のゲームの実行中における所定プレイヤーの操作の履歴情報を、当該所定プレイヤーのプレイヤー端末1から取得する処理を、複数のプレイヤー毎に実行する。即ち、プレイヤー端末1-0乃至1-mの夫々からの操作履歴情報が、履歴情報取得部101に取得される。
特徴情報生成部102は、所定プレイヤーの操作の履歴情報から得られる所定の重み値により、当該所定プレイヤーの操作の特徴を示す特徴情報を、複数のプレイヤー毎に生成する。ここで、特徴情報とは、本実施形態では上述したメタデータベクトルを意味するが、具体例については図7等を参照して後述する。
具体的には、第1重み制御部111は、上述の第1重み制御を実行する。即ち、第1重み制御部111は、所定プレイヤーの操作傾向が、複数のプレイヤーの少なくとも一部を含む集合の操作傾向に対して特異になると、当該所定プレイヤーの重み値が重くなるように制御する。
第2重み制御部112は、上述の第2重み制御を実行する。即ち、第2重み制御部112は、所定プレイヤーの操作時点からの経過時間に応じて、当該所定プレイヤーの重み値を制御する。ここで、所定プレイヤーの操作時点とは、当該所定プレイヤーが、所定ゲームの登録後初めて立ち上げたとき等、予め設定されたときからみて初めて操作した時点をいう。
重み演算部113は、第1重み制御部111と第2重み制御部112との各制御結果に基づいて、複数のプレイヤー毎に重み値を夫々演算することで、複数のプレイヤー毎の特徴情報(メタデータベクトル)を生成する。
第2重み制御部112は、上述の第2重み制御を実行する。即ち、第2重み制御部112は、所定プレイヤーの操作時点からの経過時間に応じて、当該所定プレイヤーの重み値を制御する。ここで、所定プレイヤーの操作時点とは、当該所定プレイヤーが、所定ゲームの登録後初めて立ち上げたとき等、予め設定されたときからみて初めて操作した時点をいう。
重み演算部113は、第1重み制御部111と第2重み制御部112との各制御結果に基づいて、複数のプレイヤー毎に重み値を夫々演算することで、複数のプレイヤー毎の特徴情報(メタデータベクトル)を生成する。
クラスタリング部103は、複数のプレイヤー毎の特徴情報(メタデータベクトル)に基づいて、複数のプレイヤーをクラスタリングする。
他プレイヤー情報送信制御部104は、クラスタリング部103によりクラスタリングされた複数のプレイヤーの夫々のプレイヤー端末1-0乃至1-mに対して、同一グループに属する他プレイヤーの情報を送信し、他グループに属する他プレイヤーの情報の送信を禁止する制御を実行する。
ここで、他プレイヤーの情報とは、他プレイヤーの情報を閲覧することや他プレイヤーとゲーム内で連携することが可能となる情報であり、プレイヤー端末1側で画面(図4の例では画面I1乃至Im)の表示が可能となる情報をいう。
図6の例では、所定のグループに属するプレイヤーの端末は、プレイヤー端末1-0,1-mであり、このため、同一グループに属する他プレイヤーの情報は、プレイヤー端末1-0,1-mに送信され、それ以外のプレイヤー端末1-1乃至1-(m-1)に対しては送信が禁止される。
他プレイヤー情報送信制御部104は、クラスタリング部103によりクラスタリングされた複数のプレイヤーの夫々のプレイヤー端末1-0乃至1-mに対して、同一グループに属する他プレイヤーの情報を送信し、他グループに属する他プレイヤーの情報の送信を禁止する制御を実行する。
ここで、他プレイヤーの情報とは、他プレイヤーの情報を閲覧することや他プレイヤーとゲーム内で連携することが可能となる情報であり、プレイヤー端末1側で画面(図4の例では画面I1乃至Im)の表示が可能となる情報をいう。
図6の例では、所定のグループに属するプレイヤーの端末は、プレイヤー端末1-0,1-mであり、このため、同一グループに属する他プレイヤーの情報は、プレイヤー端末1-0,1-mに送信され、それ以外のプレイヤー端末1-1乃至1-(m-1)に対しては送信が禁止される。
さらに以下、図7乃至図11を参照して、チート抑制制御を実行可能なサーバ2の機能的構成について説明する。
図7は、操作の履歴情報と特徴情報(メタデータベクトル)の構造例を示す図である。
図7の例では、所定プレイヤーの操作の履歴情報のデータ構造は、マトリクス構造となっている。このような所定プレイヤーの操作の履歴情報を示すマトリクスを、特にここでは「OLM(Operation Log Matrix)」と呼ぶ。
図7の例では、所定プレイヤーの操作の履歴情報のデータ構造は、マトリクス構造となっている。このような所定プレイヤーの操作の履歴情報を示すマトリクスを、特にここでは「OLM(Operation Log Matrix)」と呼ぶ。
OLMの各列(横軸)は、ゲームの各種類の操作に対する、所定プレイヤーの操作内容を示している。本例ではゲームの操作としてn+1種類(nは任意の整数)存在するものとして、これらn+1種類に対する操作内容を示す要素op[0]乃至op[n]が存在する。
本実施形態では各要素op[0]乃至op[n]の夫々には、対応する種類の操作が行われたときには「1」が格納され、操作が行われなかったときには「0」が格納されるものとする。なお、これは例示に過ぎず、例えば、所定のアルゴリズムに基づいて得られる「0.5」等の実数が格納されてもよい。
本実施形態では各要素op[0]乃至op[n]の夫々には、対応する種類の操作が行われたときには「1」が格納され、操作が行われなかったときには「0」が格納されるものとする。なお、これは例示に過ぎず、例えば、所定のアルゴリズムに基づいて得られる「0.5」等の実数が格納されてもよい。
OLMの各行(縦軸)は、所定プレイヤーの操作の履歴情報の所得タイミングを示している。
本例では、時間の経過に応じて、所定単位毎の時刻t1乃至tlastにて、操作の履歴情報が取得されている。取得タイミングの所定単位(取得の間隔)は、任意であり、固定であってもよいし可変であってもよく、例えば、1秒や60秒等の実時間の単位であってもよいし、ゲーム内のトランザクション単位であってもよい。
本例では、時間の経過に応じて、所定単位毎の時刻t1乃至tlastにて、操作の履歴情報が取得されている。取得タイミングの所定単位(取得の間隔)は、任意であり、固定であってもよいし可変であってもよく、例えば、1秒や60秒等の実時間の単位であってもよいし、ゲーム内のトランザクション単位であってもよい。
このような所定プレイヤーのOLMに基づいて、各操作の重み値を各要素として構成されるベクトルが、当該所定プレイヤーのメタデータベクトルMVとして生成される。
ただし、所定プレイヤーのメタデータベクトルMVは、当該所定プレイヤーのOLMのみならず、ゲームに参加する他プレイヤーのOLMも用いられて生成される。
1人のプレイヤーにつき1つのOLMが操作の履歴情報として蓄積されるため、システム全体では、3次元配列として実装される。
図8は、3次元配列として実装された、操作の履歴情報の構造例を示している。
本例では、m+1台のプレイヤー端末1-0乃至1-mによりゲームが実行されているので、即ちm+1人のプレイヤーがゲームに参加しているので、プレイヤー端末1-0乃至1-mの夫々から得られるm+1個のOLMの3次元配列として、操作の履歴情報が実装されることになる。
ただし、所定プレイヤーのメタデータベクトルMVは、当該所定プレイヤーのOLMのみならず、ゲームに参加する他プレイヤーのOLMも用いられて生成される。
1人のプレイヤーにつき1つのOLMが操作の履歴情報として蓄積されるため、システム全体では、3次元配列として実装される。
図8は、3次元配列として実装された、操作の履歴情報の構造例を示している。
本例では、m+1台のプレイヤー端末1-0乃至1-mによりゲームが実行されているので、即ちm+1人のプレイヤーがゲームに参加しているので、プレイヤー端末1-0乃至1-mの夫々から得られるm+1個のOLMの3次元配列として、操作の履歴情報が実装されることになる。
特徴情報生成部102は、このようにして実装されたOLMに基づいて、操作傾向を示すメタデータベクトルMVを各プレイヤー毎に生成する。
具体的には図7に示すように、特徴情報生成部102は、OLMを1つのベクトル、即ちメタデータベクトルMVへ集約する処理を実行する。
具体的には図7に示すように、特徴情報生成部102は、OLMを1つのベクトル、即ちメタデータベクトルMVへ集約する処理を実行する。
ここで、第2重み制御部112は、集約する処理の実行中において、所定プレイヤーの操作時点からの経過時間に応じて、当該所定プレイヤーのOLMの各要素値(重み値)に対する重みを制御する。
ここで、このように経過時間に応じて重みを制御する関数を、「tweight()関数」と呼ぶ。
図9は、tweight()関数の一例を示す図である。
図9に示すように、tweight()関数では、直近に行われた操作を重要視することから、直近に行われる程重みが大きくなり、過去に遡るにつれて重みが減少する。
ただし、tweight()関数では、常習性のチーターの操作の履歴情報の値を累積的に作用させるべく、重みの減少を一定時期で停止する。さらに、tweight()関数では、一定以上蓄積させたログを破棄すべく、一定期間(例えば図9の例では180日)経過したら、それ以降重みが0になる。
なお、tweight()関数は、図9の例に特に限定されず、例えばより短時間の重み付けを行えるような関数を採用してもよい。
ここで、このように経過時間に応じて重みを制御する関数を、「tweight()関数」と呼ぶ。
図9は、tweight()関数の一例を示す図である。
図9に示すように、tweight()関数では、直近に行われた操作を重要視することから、直近に行われる程重みが大きくなり、過去に遡るにつれて重みが減少する。
ただし、tweight()関数では、常習性のチーターの操作の履歴情報の値を累積的に作用させるべく、重みの減少を一定時期で停止する。さらに、tweight()関数では、一定以上蓄積させたログを破棄すべく、一定期間(例えば図9の例では180日)経過したら、それ以降重みが0になる。
なお、tweight()関数は、図9の例に特に限定されず、例えばより短時間の重み付けを行えるような関数を採用してもよい。
特徴情報生成部102の重み演算部113は、tweight()関数(第2重み制御部112による第2重み付け制御)を用いた次の式(1)に従って、所定プレイヤーのメタデータベクトルMVを演算する。なお、式(1)には、第1重み制御部111による第1重み付け制御も含まれているが、この制限については後述する。
・・・(1)
式(1)において、uは、演算対象として着目するプレイヤー(以下、「着目プレイヤー」と呼ぶ)のIDを示している。
つまり、vec(u)は、着目プレイヤーuのメタデータベクトルMVを示している。
各要素の分子のlast(u)は、着目プレイヤーuについての操作の履歴情報の最後(直近)の取得タイミングを示している。図7及び図8のOLMが用いられるならば、last(u)=lastである。つまり、i=0が、時刻t0のタイミングを示し、i=last(u)が、時刻tlastのタイミングを示している。
各要素の分子のd[u,i,p]は、着目プレイヤーuのi番目(時刻ti)の履歴情報に対応するp番目(pは、0乃至nのうちの任意の整数値)の種類の操作の値(スコア)を示している。例えば、着目プレイヤーuのOLMが図7に示されるものであった場合、d[u,0,0]として、図7のOLMの時刻t0における要素op[0](左上端の要素op[0])の格納値「0」が代入される。
各要素の分母のjは、プレイヤーのIDを示している。即ち、プレイヤー端末1-0乃至1-mの夫々を操作する各プレイヤーのIDが、j=0乃至mの夫々である。
各要素の分母のlast(j)は、プレイヤーjについての操作の履歴情報の最後(直近)の取得タイミングを示している。
各要素の分母のd[j,k,p]は、プレイヤーjのk番目(時刻tk)の履歴情報に対応するp番目の種類の操作の値を示している。
式(1)において、uは、演算対象として着目するプレイヤー(以下、「着目プレイヤー」と呼ぶ)のIDを示している。
つまり、vec(u)は、着目プレイヤーuのメタデータベクトルMVを示している。
各要素の分子のlast(u)は、着目プレイヤーuについての操作の履歴情報の最後(直近)の取得タイミングを示している。図7及び図8のOLMが用いられるならば、last(u)=lastである。つまり、i=0が、時刻t0のタイミングを示し、i=last(u)が、時刻tlastのタイミングを示している。
各要素の分子のd[u,i,p]は、着目プレイヤーuのi番目(時刻ti)の履歴情報に対応するp番目(pは、0乃至nのうちの任意の整数値)の種類の操作の値(スコア)を示している。例えば、着目プレイヤーuのOLMが図7に示されるものであった場合、d[u,0,0]として、図7のOLMの時刻t0における要素op[0](左上端の要素op[0])の格納値「0」が代入される。
各要素の分母のjは、プレイヤーのIDを示している。即ち、プレイヤー端末1-0乃至1-mの夫々を操作する各プレイヤーのIDが、j=0乃至mの夫々である。
各要素の分母のlast(j)は、プレイヤーjについての操作の履歴情報の最後(直近)の取得タイミングを示している。
各要素の分母のd[j,k,p]は、プレイヤーjのk番目(時刻tk)の履歴情報に対応するp番目の種類の操作の値を示している。
図10は、式(1)の内容を説明する模式図である。
図10の中央には、上述の式(1)のベクトルvec(u)、即ち、着目プレイヤーUのメタデータベクトルMVが示されている
このメタデータベクトルvec(u)は、要素a1等、n+1個の要素から構成されている。1つの要素は、分母a2mと分子a2cとからなる分数で演算される。
図10の中央には、上述の式(1)のベクトルvec(u)、即ち、着目プレイヤーUのメタデータベクトルMVが示されている
このメタデータベクトルvec(u)は、要素a1等、n+1個の要素から構成されている。1つの要素は、分母a2mと分子a2cとからなる分数で演算される。
第p番目の要素の分母a2mは、p番目の種類の操作の値(図10の例では、図7の要素op[1]の格納値)の時刻t0乃至tlastの累積値(スコア)についての、m+1人の全てのプレイヤーについての総加算値である。
つまり、第p番目の要素の分母a2mは、p番目の種類の操作の値についての「一般性」を示している。
この分母a2mは、2つの集約操作から構成されている。1つ目(数式右側)の集約操作は、各プレイヤー毎の特定の操作に対応する特徴カテゴリの値(p番目の種類の操作の値)を合計してスコアを算出するものである。2つ目(数式左側)の集約操作は、各プレイヤーのスコアを、全プレイヤー分だけ合計するものである。
つまり、第p番目の要素の分母a2mは、p番目の種類の操作の値についての「一般性」を示している。
この分母a2mは、2つの集約操作から構成されている。1つ目(数式右側)の集約操作は、各プレイヤー毎の特定の操作に対応する特徴カテゴリの値(p番目の種類の操作の値)を合計してスコアを算出するものである。2つ目(数式左側)の集約操作は、各プレイヤーのスコアを、全プレイヤー分だけ合計するものである。
分子a2cは、着目プレイヤーuの操作の履歴情報の値に対して、tweight()関数に基づく重み付けをした値を、時刻t0乃至tlast分だけ累積して、着目プレイヤーuのスコアを演算するものである。
つまり、重み演算部113は、着目プレイヤーuについてのスコア(経過時間に基づく重み付けをしたスコア)を示す分子a2cに対して、全プレイヤーの合計値から導き出される一般性のスコアを示す分母a2mを除算することで、着目プレイヤーuが特異な操作をしているか否かを示す要素の値(スコア)を算出している。
換言すると、このような分子a2cに対する分母a2mを除算する制御が、第1重み制御部111による第1重み付け制御であると把握することができる。即ち、所定プレイヤーの操作傾向(着目プレイヤーuについての分子a2cにより示される操作傾向)が、プレイヤー全体の集合の操作傾向(分母a2mより示される操作傾向)に対して特異になると、当該所定プレイヤーの重み値(スコア)が重くなるように、分子a2cに対する分母a2mを除算する制御が、第1重み付け制御として実行される。
換言すると、このような分子a2cに対する分母a2mを除算する制御が、第1重み制御部111による第1重み付け制御であると把握することができる。即ち、所定プレイヤーの操作傾向(着目プレイヤーuについての分子a2cにより示される操作傾向)が、プレイヤー全体の集合の操作傾向(分母a2mより示される操作傾向)に対して特異になると、当該所定プレイヤーの重み値(スコア)が重くなるように、分子a2cに対する分母a2mを除算する制御が、第1重み付け制御として実行される。
図11は、式(1)のベクトルvec(u)、即ち、着目プレイヤーuのメタデータベクトルMVの各要素をグラフ化したものである。
例えば、所定のゲームについて、一般的には、第0の種類及び第2の種類の操作をする操作傾向(OLMの各行の要素op[0],op[2]の値が1になる傾向)があるものとする。そして、とあるチートツールを用いると第1の種類及び第3の種類の操作をする操作傾向(OLMの各行の要素op[1],op[3]の値が1になる傾向)があるものとする。
例えば、所定のゲームについて、一般的には、第0の種類及び第2の種類の操作をする操作傾向(OLMの各行の要素op[0],op[2]の値が1になる傾向)があるものとする。そして、とあるチートツールを用いると第1の種類及び第3の種類の操作をする操作傾向(OLMの各行の要素op[1],op[3]の値が1になる傾向)があるものとする。
図11(A)は、チーターでない通常のプレイヤーのメタデータベクトルMVを示している。このプレイヤーは、過去の一時期に、たまたま上記チートツールを使用してしまったり、或いは、チートと疑われる行為をしてしまったものとする。このため、メタデータベクトルMVにおける要素op[1]と要素op[3]の各値(スコア)には、過去の累積値が若干反映されている。
図5を用いて上述したように、チートやチートと疑われる行為をした過去の時点では、当該プレイヤーは、通常のグループUG1からチーターのグループCG1に分類される。
この場合、当該プレイヤーのプレイヤー端末1には、図4の画面I3や画面In等が表示される。そこで、当該プレイヤーは、閲覧や連携が可能な他プレイヤーはチーターのみであることを認識したため、チートやチートと疑われる行為を即座に停止したものとする。
この場合、当該プレイヤーは、第0の種類及び第2の種類の操作をするという操作傾向(OLMの直近の行の要素op[0],op[2]の値が1になる傾向)に戻ることになる。
ここで、上述したように、式(1)のベクトルvec(u)は、第2重み制御部112により、tweight()関数に基づく第2重み付け制御がなされる。即ち、直近の操作の履歴情報に強い重みをかけ、過去の操作の履歴情報に弱い重みをかける制御が実行される。これにより、ベクトルvec(u)は、直近の操作を強く反映したメタデータベクトルMVとなる。
つまり、図11(A)に示すように、メタデータベクトルMVにおける要素op[0]と要素op[2]の各値(スコア)は、直近の操作の履歴情報が強く反映されて高値になる。即ち、メタデータベクトルMVにおける要素op[0]と要素op[2]の各値(スコア)が高いという通常の操作傾向に戻る。その結果、当該プレイヤーは、チーターのグループCG1から通常のグループUG1に戻ることができる。
図5を用いて上述したように、チートやチートと疑われる行為をした過去の時点では、当該プレイヤーは、通常のグループUG1からチーターのグループCG1に分類される。
この場合、当該プレイヤーのプレイヤー端末1には、図4の画面I3や画面In等が表示される。そこで、当該プレイヤーは、閲覧や連携が可能な他プレイヤーはチーターのみであることを認識したため、チートやチートと疑われる行為を即座に停止したものとする。
この場合、当該プレイヤーは、第0の種類及び第2の種類の操作をするという操作傾向(OLMの直近の行の要素op[0],op[2]の値が1になる傾向)に戻ることになる。
ここで、上述したように、式(1)のベクトルvec(u)は、第2重み制御部112により、tweight()関数に基づく第2重み付け制御がなされる。即ち、直近の操作の履歴情報に強い重みをかけ、過去の操作の履歴情報に弱い重みをかける制御が実行される。これにより、ベクトルvec(u)は、直近の操作を強く反映したメタデータベクトルMVとなる。
つまり、図11(A)に示すように、メタデータベクトルMVにおける要素op[0]と要素op[2]の各値(スコア)は、直近の操作の履歴情報が強く反映されて高値になる。即ち、メタデータベクトルMVにおける要素op[0]と要素op[2]の各値(スコア)が高いという通常の操作傾向に戻る。その結果、当該プレイヤーは、チーターのグループCG1から通常のグループUG1に戻ることができる。
これに対して、図11(B)は、常習性のあるチーターのメタデータベクトルMVを示している。
tweight()関数では、過去の操作の履歴情報にかけられる重みは弱いものの、常習的にチートツールを用いると、メタデータベクトルMVにおける要素op[1]と要素op[3]の各値(スコア)は、過去の常習的な操作の累積により必然的に高値になる。
このため、常習性のあるチーターがたとえチートツールの使用を直近で停止した場合であっても、停止時間が短時間の間は、メタデータベクトルMVにおける要素op[1]と要素op[3]の各値(スコア)が高いという操作傾向、即ちチーター特有の操作傾向は変わらない。その結果、当該チーターは、チーターのグループ(図5の例ではグループCG3)を抜け出すことはできない。
tweight()関数では、過去の操作の履歴情報にかけられる重みは弱いものの、常習的にチートツールを用いると、メタデータベクトルMVにおける要素op[1]と要素op[3]の各値(スコア)は、過去の常習的な操作の累積により必然的に高値になる。
このため、常習性のあるチーターがたとえチートツールの使用を直近で停止した場合であっても、停止時間が短時間の間は、メタデータベクトルMVにおける要素op[1]と要素op[3]の各値(スコア)が高いという操作傾向、即ちチーター特有の操作傾向は変わらない。その結果、当該チーターは、チーターのグループ(図5の例ではグループCG3)を抜け出すことはできない。
このように、式(1)のベクトルvec(u)、即ち、着目プレイヤーUのメタデータベクトルMVを用いることで、プレイヤーの直近の操作に素早く反応しながら、プレイヤーの基本的な行動の類似性を計量するクラスタリングが実現可能になる。
さらに以下、クラスタリング部103によるクラスタリングの具体例について説明する。
さらに以下、クラスタリング部103によるクラスタリングの具体例について説明する。
クラスタリング部103は、プレイヤーのグループを生成するために、各プレイヤーのメタデータベクトルMVを用いて、クラスタリング処理を実行する。
従って、各プレイヤーのメタデータベクトルMVについて、次のような措置を施すことで、パフォーマンス上の優位性が生じる。
従って、各プレイヤーのメタデータベクトルMVについて、次のような措置を施すことで、パフォーマンス上の優位性が生じる。
即ち、本段落においては、ゲームに登録されている総プレイヤー数をmとし、各プレイヤー-の操作の履歴情報として記録されているアクションの平均個数をnとし、メタデータベクトルMVの要素数(ベクトル空間の特徴の数)をkとする。
この場合、全てのプレイヤーに対してメタデータベクトルMVが生成されるものとすると、n×k+n×m×k回の繰り返し処理が必要になる。
これは、上述した式(1)に示すように、全てのプレイヤーのメタデータベクトルMVの演算において、共通の分母a2m(図10参照)を用いるため、分母の演算は1度だけ行えばよいからである。
例えば、m=100万人のプレイヤーが、平均個数n=2,000個の履歴情報を保持し、操作の種類等のメタデータベクトルMVの要素数k=30,000であるものとする。この場合、約60兆回(2,000×30,000+2,000×1,000,000×30,000)の繰り返しが必要となる。
ここで、特徴情報生成部102は、この繰り返し処理を、毎回実行せずに、途中の計算結果をキャッシュしておくことにより、増分計算として実行することもできる。
さらに、過去の履歴情報についてはtweight()関数による重みづけの値は、ほぼ変化しない。そこで、毎回重み付けの計算を行わずに、計算結果を再利用してもよい。
また、式(1)の分子a2c(図10参照)は、加算のみの演算であるため、新たに追加された履歴情報の値を、最後の計算結果に加算するだけで、毎回演算した場合と略同一の結果を得ることが可能になる。
また、休眠状態のプレイヤーについては、チーターとして検出する意味が存在しないため、アクティブプレイヤーのみを対象としてメタデータベクトルMVを算出してもよい。
以上の点から、特徴情報生成部102は、メタデータベクトルMVの演算において、途中計算結果のキャッシュと増分計算を用いることができる。
従って、実質的には、次のような計算コストで、クラスタリング部103によるクラスタリング処理に用いるメタデータベクトルMVの演算が可能になる。
即ち、例えばm=100万人のプレイヤーのうちアクティブプレイヤーは20万人であるとする。そして、操作の履歴情報が一定量、例えば10件追記されるごとに、特徴情報生成部102は、メタデータベクトルMVを生成するものとする。この場合、約600億回(10×30,000+10×200,000×30,000)の繰り返しでよい。即ち、約60兆回の繰り返しとした上述の理論上の計算コストに比較して、約100倍の高速で、クラスタリング部103によるクラスタリング処理に用いるメタデータベクトルMVの演算が可能になる。
この場合、全てのプレイヤーに対してメタデータベクトルMVが生成されるものとすると、n×k+n×m×k回の繰り返し処理が必要になる。
これは、上述した式(1)に示すように、全てのプレイヤーのメタデータベクトルMVの演算において、共通の分母a2m(図10参照)を用いるため、分母の演算は1度だけ行えばよいからである。
例えば、m=100万人のプレイヤーが、平均個数n=2,000個の履歴情報を保持し、操作の種類等のメタデータベクトルMVの要素数k=30,000であるものとする。この場合、約60兆回(2,000×30,000+2,000×1,000,000×30,000)の繰り返しが必要となる。
ここで、特徴情報生成部102は、この繰り返し処理を、毎回実行せずに、途中の計算結果をキャッシュしておくことにより、増分計算として実行することもできる。
さらに、過去の履歴情報についてはtweight()関数による重みづけの値は、ほぼ変化しない。そこで、毎回重み付けの計算を行わずに、計算結果を再利用してもよい。
また、式(1)の分子a2c(図10参照)は、加算のみの演算であるため、新たに追加された履歴情報の値を、最後の計算結果に加算するだけで、毎回演算した場合と略同一の結果を得ることが可能になる。
また、休眠状態のプレイヤーについては、チーターとして検出する意味が存在しないため、アクティブプレイヤーのみを対象としてメタデータベクトルMVを算出してもよい。
以上の点から、特徴情報生成部102は、メタデータベクトルMVの演算において、途中計算結果のキャッシュと増分計算を用いることができる。
従って、実質的には、次のような計算コストで、クラスタリング部103によるクラスタリング処理に用いるメタデータベクトルMVの演算が可能になる。
即ち、例えばm=100万人のプレイヤーのうちアクティブプレイヤーは20万人であるとする。そして、操作の履歴情報が一定量、例えば10件追記されるごとに、特徴情報生成部102は、メタデータベクトルMVを生成するものとする。この場合、約600億回(10×30,000+10×200,000×30,000)の繰り返しでよい。即ち、約60兆回の繰り返しとした上述の理論上の計算コストに比較して、約100倍の高速で、クラスタリング部103によるクラスタリング処理に用いるメタデータベクトルMVの演算が可能になる。
クラスタリング部103は、プレイヤーのグループを生成するために、上述のようにして生成された各メタデータベクトルMVを用いて、クラスタリング処理を実行する。
この場合のクラスタリングのアルゴリズムは、特に限定されず、任意のアルゴリズムを採用することができる。
具体的には例えば、K-Means法を採用することができる。K-Means法を採用することで、ランダムに設定したk個のクラスタ重心候補へ再帰的にノード(各プレイヤーのメタデータベクトルMV)を所属させることにより、自動的かつ高速にクラスタを生成することができる。
また、メタデータベクトルMVは、多次元ベクトル空間上のベクトルであることから、コサイン類似度に代表されるベクトル空間上の類似度演算の手法を用いて、プレイヤー間の類似性を計算することができる。
コサイン類似度は、ベクトル同士の成す角度の近さを表現するため、最大値が1であり、最大値「1」に近いほど類似しており、最小値「0」に近いほど類似性が低くなる。
ベクトルaとbのコサイン類似度cos(a,b)は、次の式(2)で定義することができる。
・・・(2)
具体的には例えば、K-Means法を採用することができる。K-Means法を採用することで、ランダムに設定したk個のクラスタ重心候補へ再帰的にノード(各プレイヤーのメタデータベクトルMV)を所属させることにより、自動的かつ高速にクラスタを生成することができる。
また、メタデータベクトルMVは、多次元ベクトル空間上のベクトルであることから、コサイン類似度に代表されるベクトル空間上の類似度演算の手法を用いて、プレイヤー間の類似性を計算することができる。
コサイン類似度は、ベクトル同士の成す角度の近さを表現するため、最大値が1であり、最大値「1」に近いほど類似しており、最小値「0」に近いほど類似性が低くなる。
ベクトルaとbのコサイン類似度cos(a,b)は、次の式(2)で定義することができる。
他プレイヤー情報送信制御部104は、クラスタリング部103によるクラスタリングの結果に基づいて、他プレイヤー情報を生成する。他プレイヤー情報とは、上述したように、所定プレイヤーが、他プレイヤーの情報を閲覧することや他プレイヤーとゲーム内で連携することが可能になる情報をいう。
ここで本実施形態では、他プレイヤー情報送信制御部104は、他プレイヤーが同一グループに属する者に限定されるように、他プレイヤー情報の送信を制御する。
これにより、善良な通常のプレイヤーから、チーターが隔離されることになる。従って、通常のプレイヤーは、チート行為による不快を覚えずに、快適にゲームを楽しむことができる。
換言すると、常習的なチーターにとっては、善良な通常のプレイヤーが隔離されて、同一のチートツールを使う別なチーターのみが他プレイヤーとして提示されることになる。このため、チーターは、サービス提供者(ゲームの運営者等)がチート行為を検出していることを認識することになる。その結果、当該チーターがチート行為を停止することが期待される。このようにして、チート行為自体を抑制することができる。
ここで本実施形態では、他プレイヤー情報送信制御部104は、他プレイヤーが同一グループに属する者に限定されるように、他プレイヤー情報の送信を制御する。
これにより、善良な通常のプレイヤーから、チーターが隔離されることになる。従って、通常のプレイヤーは、チート行為による不快を覚えずに、快適にゲームを楽しむことができる。
換言すると、常習的なチーターにとっては、善良な通常のプレイヤーが隔離されて、同一のチートツールを使う別なチーターのみが他プレイヤーとして提示されることになる。このため、チーターは、サービス提供者(ゲームの運営者等)がチート行為を検出していることを認識することになる。その結果、当該チーターがチート行為を停止することが期待される。このようにして、チート行為自体を抑制することができる。
ここで本実施形態では、サーバ2のCPU51は、さらに、各グループ毎に、分類されているプレイヤーのステータス情報を元いて、チートを行っている可能性(Cheat-Probability)を演算する。
このチート可能性の演算手法は、特に限定されず、例えばゲームタイトル毎に異なる手法を採用してもよい。
具体的には例えば、各プレイヤーのステータスが、短時間に上昇している場合や、希少なアイテムが短時間に獲得できている場合など、ステータスの変化からチート可能性を演算する手法を採用してもよい。
また例えば、クライアントとの通信内容からチート可能性を演算する手法を採用してもよい。
このチート可能性の演算手法は、特に限定されず、例えばゲームタイトル毎に異なる手法を採用してもよい。
具体的には例えば、各プレイヤーのステータスが、短時間に上昇している場合や、希少なアイテムが短時間に獲得できている場合など、ステータスの変化からチート可能性を演算する手法を採用してもよい。
また例えば、クライアントとの通信内容からチート可能性を演算する手法を採用してもよい。
ここで、チート可能性が閾値を超えるクラスタが急激に拡大している(分類されるプレイヤーの数が増加している)ときには、これまで未知であったチート手法が普及しつつある可能性を示している。
そこで、サーバ2のCPU51はさらに、サービス提供者に対して、(これまで未知であった)新たなチート手法の出現を警告する。
このように、クラスタサイズの変化をモニタリングすることにより、これまで未知であったチート手法が新たに出現したことについて、緊急の警報をサービス提供者にすることも可能になる。
そこで、サーバ2のCPU51はさらに、サービス提供者に対して、(これまで未知であった)新たなチート手法の出現を警告する。
このように、クラスタサイズの変化をモニタリングすることにより、これまで未知であったチート手法が新たに出現したことについて、緊急の警報をサービス提供者にすることも可能になる。
以上、チート抑制制御を実現するためのサーバ2の機能的構成について説明した。
次に、図12を参照して、このような機能的構成を有するサーバ2の処理の流れを説明する。
図12は、サーバ2の処理の流れを説明するフローチャートである。
次に、図12を参照して、このような機能的構成を有するサーバ2の処理の流れを説明する。
図12は、サーバ2の処理の流れを説明するフローチャートである。
ステップS1において、サーバ2の履歴情報取得部101は、各プレイヤー端末1-0乃至1-mから履歴情報を取得する。
ステップS2において、特徴情報生成部102は、着目プレイヤーを設定する。
ステップS3において、第1重み制御部111は、着目プレイヤーについて第1重み付け制御を実行する。
ステップS4において、第2重み制御部112とは、着目プレイヤーについて第2重み付け制御を実行する。
ステップS5において、重み演算部113は、第1重み付け制御及び第2重み付け制御の実行結果に基づいて、着目プレイヤーの特徴情報として、メタデータベクトルMVを生成する。
ステップS3において、第1重み制御部111は、着目プレイヤーについて第1重み付け制御を実行する。
ステップS4において、第2重み制御部112とは、着目プレイヤーについて第2重み付け制御を実行する。
ステップS5において、重み演算部113は、第1重み付け制御及び第2重み付け制御の実行結果に基づいて、着目プレイヤーの特徴情報として、メタデータベクトルMVを生成する。
ここで、メタデータベクトルMVとして、上述の式(1)のベクトルvec(u)が採用している場合、第1重み制御とは、式(1)の各要素の分子a2cを分母a2mで除算することによる重み付けの制御を意味する。また、第2重み制御とは、上述の式(1)の分子a2c(図10参照)におけるtweight()関数を用いた重み付けの制御を意味する。
即ち、上述のステップS2乃至S4は、実質的には、上述の式(1)の演算として略同時に実行される。
即ち、上述のステップS2乃至S4は、実質的には、上述の式(1)の演算として略同時に実行される。
ステップS6において、特徴情報生成部102は、全プレイヤーを着目プレイヤーに設定したか否かを判定する。
ここでいう「全プレイヤー」は、ゲームに登録している全プレイヤーでもよいが、上述したようにパフォーマンスを向上すべく、アクティブプレイヤーの全てであってもよい。即ち、「全プレイヤー」とは、所定のルール(例えばアクティブプレイヤーに限る等のルール)に従って予め定義されたプレイヤーの全てという意である。換言すると、ゲームに登録されているプレイヤー全体の少なくとも一部を含む集合が、ここでいう「全プレイヤー」である。
ここでいう「全プレイヤー」は、ゲームに登録している全プレイヤーでもよいが、上述したようにパフォーマンスを向上すべく、アクティブプレイヤーの全てであってもよい。即ち、「全プレイヤー」とは、所定のルール(例えばアクティブプレイヤーに限る等のルール)に従って予め定義されたプレイヤーの全てという意である。換言すると、ゲームに登録されているプレイヤー全体の少なくとも一部を含む集合が、ここでいう「全プレイヤー」である。
全プレイヤーの中に未だ着目プレイヤーに設定していないプレイヤーが存在する場合、ステップS6においてNOであると判定されて、処理はステップS2に戻され、それ以降の処理が繰り返される。
全プレイヤーの夫々が着目プレイヤーに設定されて、ステップS3乃至S5の処理により、特徴情報としてメタデータベクトルMVが生成された場合、ステップS6においてYESであると判定されて、処理はステップS7に進む。
全プレイヤーの夫々が着目プレイヤーに設定されて、ステップS3乃至S5の処理により、特徴情報としてメタデータベクトルMVが生成された場合、ステップS6においてYESであると判定されて、処理はステップS7に進む。
ステップS7において、クラスタリング部103は、各プレイヤーを特徴情報に基づいてクラスタリングする。
ステップS8において、他プレイヤー情報送信制御部104は、各グループ毎に、他プレイヤー情報を生成する。
ステップS9において、他プレイヤー情報送信制御部104は、他プレイヤー情報を、同一グループに属するプレイヤー端末1に送信し、他グループに属するプレイヤー端末1に送信を禁止する。
ステップS9において、他プレイヤー情報送信制御部104は、他プレイヤー情報を、同一グループに属するプレイヤー端末1に送信し、他グループに属するプレイヤー端末1に送信を禁止する。
ステップS10において、サーバ2のCPU51は、処理の終了指示が有ったか否かを判定する。ここで、処理の終了指示は、特に限定されないが、本実施形態ではサーバ2の電源遮断が採用されている。つまり、サーバ2において電源が遮断されると、ステップS10においてYESであると判定されて、サーバ2の処理は終了になる。
これに対して、サーバ2において電源が遮断されない限り、ステップS10においてNOであると判定されて処理はステップS1に戻され、それ以降の処理が繰り返される。
これに対して、サーバ2において電源が遮断されない限り、ステップS10においてNOであると判定されて処理はステップS1に戻され、それ以降の処理が繰り返される。
なお、図12には図示していないが、上述したように、サーバ2のCPU51は、ステップS7の処理によりクラスタリングされた各グループ毎に、分類されているプレイヤーのステータス情報を元いて、チートを行っている可能性を演算する。
そして、CPU51は、クラスタ(グループ)毎にチート可能性と閾値を比較する。
CPU51は、チート可能性が閾値を超えるクラスタが急激に拡大しているときには、サービス提供者に対して、当該クラスタを、(これまで未知であった)新たなチート手法を用いたチーターのグループである旨を警告する。
そして、CPU51は、クラスタ(グループ)毎にチート可能性と閾値を比較する。
CPU51は、チート可能性が閾値を超えるクラスタが急激に拡大しているときには、サービス提供者に対して、当該クラスタを、(これまで未知であった)新たなチート手法を用いたチーターのグループである旨を警告する。
以上本発明の一実施形態について説明したが、本発明は、上述の実施形態に限定されるものではなく、本発明の目的を達成できる範囲での変形、改良等は本発明に含まれるものである。
例えば、図6の機能的構成は例示に過ぎず、特に限定されない。即ち、上述した一連の処理を全体として実行できる機能が情報処理システムに備えられていれば足り、この機能を実現するためにどのような機能ブロックを用いるのかは特に図6の例に限定されない。また、機能ブロックの存在場所も、図6に特に限定されず、任意でよい。例えば、サーバ2の機能ブロックをプレイヤー端末1等に移譲させてもよいし、逆に端末1の機能ブロックをサーバ2等に移譲させてもよい。
また、1つの機能ブロックは、ハードウェア単体で構成してもよいし、ソフトウェア単体で構成してもよいし、それらの組み合わせで構成してもよい。
また、1つの機能ブロックは、ハードウェア単体で構成してもよいし、ソフトウェア単体で構成してもよいし、それらの組み合わせで構成してもよい。
各機能ブロックの処理をソフトウェアにより実行させる場合には、そのソフトウェアを構成するプログラムが、コンピュータ等にネットワークや記録媒体からインストールされる。
コンピュータは、専用のハードウェアに組み込まれているコンピュータであってもよい。また、コンピュータは、各種のプログラムをインストールすることで、各種の機能を実行することが可能なコンピュータ、例えばサーバの他汎用のスマートフォンやパーソナルコンピュータであってもよい。
コンピュータは、専用のハードウェアに組み込まれているコンピュータであってもよい。また、コンピュータは、各種のプログラムをインストールすることで、各種の機能を実行することが可能なコンピュータ、例えばサーバの他汎用のスマートフォンやパーソナルコンピュータであってもよい。
このようなプログラムを含む記録媒体は、プレイヤーにプログラムを提供するために装置本体とは別に配布される図示せぬリムーバブルメディアにより構成されるだけでなく、装置本体に予め組み込まれた状態でプレイヤーに提供される記録媒体等で構成される。
なお、本明細書において、記録媒体に記録されるプログラムを記述するステップは、その順序に沿って時系列的に行われる処理はもちろん、必ずしも時系列的に処理されなくとも、並列的或いは個別に実行される処理をも含むものである。
また、本明細書において、システムの用語は、複数の装置や複数の手段等より構成される全体的な装置を意味するものとする。
また、本明細書において、システムの用語は、複数の装置や複数の手段等より構成される全体的な装置を意味するものとする。
換言すると、本発明が適用される情報処理システムは、上述の図1の実施形態としての情報処理システムを含め、次のような構成を有する各種各様の実施形態を取ることができる。
即ち、本発明が適用される情報処理システムは、複数のプレイヤーの夫々の操作を受付けてゲームを実行し得る複数の端末(例えば図1のプレイヤー端末1-0乃至1-M)と、サーバ(例えば図1のサーバ2)とを含む情報処理システムである。
前記サーバは、
前記ゲームの実行中における所定プレイヤーの操作の履歴情報を、当該所定プレイヤーの端末から取得する処理を、前記複数のプレイヤー毎に実行する履歴情報取得手段(例えば図6の履歴情報取得部101)と、
前記所定プレイヤーの前記操作の履歴情報から得られる所定の重み値により、当該所定プレイヤーの操作の特徴を示す特徴情報を、前記複数のプレイヤー毎に生成する特徴情報生成手段(例えば図6の特徴情報生成部102)と、
を備える。
前記特徴情報生成手段は、
前記所定プレイヤーの操作傾向が、前記複数のプレイヤーの少なくとも一部を含む集合の操作傾向に対して特異になると、当-所定プレイヤーの重み値が重くなるように制御する第1重み制御手段(例えば図6の第1重み制御部111)と、
前記所定プレイヤーの操作時点からの経過時間に応じて、当該所定プレイヤーの重み値を制御する第2重み制御手段(例えば図6の第2重み制御部112)と、
前記第1重み制御手段と前記第2重み制御手段との各制御結果に基づいて、前記複数のプレイヤー毎に前記重み値を夫々演算することで、前記複数のプレイヤー毎の前記特徴情報を生成する重み演算手段(例えば図6の重み演算部113)と、
を含む。
即ち、本発明が適用される情報処理システムは、複数のプレイヤーの夫々の操作を受付けてゲームを実行し得る複数の端末(例えば図1のプレイヤー端末1-0乃至1-M)と、サーバ(例えば図1のサーバ2)とを含む情報処理システムである。
前記サーバは、
前記ゲームの実行中における所定プレイヤーの操作の履歴情報を、当該所定プレイヤーの端末から取得する処理を、前記複数のプレイヤー毎に実行する履歴情報取得手段(例えば図6の履歴情報取得部101)と、
前記所定プレイヤーの前記操作の履歴情報から得られる所定の重み値により、当該所定プレイヤーの操作の特徴を示す特徴情報を、前記複数のプレイヤー毎に生成する特徴情報生成手段(例えば図6の特徴情報生成部102)と、
を備える。
前記特徴情報生成手段は、
前記所定プレイヤーの操作傾向が、前記複数のプレイヤーの少なくとも一部を含む集合の操作傾向に対して特異になると、当-所定プレイヤーの重み値が重くなるように制御する第1重み制御手段(例えば図6の第1重み制御部111)と、
前記所定プレイヤーの操作時点からの経過時間に応じて、当該所定プレイヤーの重み値を制御する第2重み制御手段(例えば図6の第2重み制御部112)と、
前記第1重み制御手段と前記第2重み制御手段との各制御結果に基づいて、前記複数のプレイヤー毎に前記重み値を夫々演算することで、前記複数のプレイヤー毎の前記特徴情報を生成する重み演算手段(例えば図6の重み演算部113)と、
を含む。
このようにして生成される所定プレイヤーの特徴情報(例えば上述のメタデータベクトルMV)は、所定プレイヤーの操作の履歴情報に基づいて、多くのプレイヤーの共通性に応じた第1重み付け制御(第1重み制御手段による制御)と、時間に応じた第2重み付け制御(第2重み制御手段による制御)とが統合して実行された結果得られるものである。
このようなプレイヤーの特徴情報を用いることで、未知のチート手法でのチートも含めて、各種チートや、チートと疑われる行為を適切に検出する技術が実現可能になる。
このようなプレイヤーの特徴情報を用いることで、未知のチート手法でのチートも含めて、各種チートや、チートと疑われる行為を適切に検出する技術が実現可能になる。
即ち、未知のチート手法でのチートも含めて、各種チートや、チートと疑われる行為を適切に検出する技術を実現するためには、次の第1乃至第4の条件が必要になる。
第1の条件とは、偽陽性(False-ositive)がないこと、即ち、無実のプレイヤーをチーターと誤検知し、アカウント停止等の措置を行わないことという条件である。
第2の条件とは、通常起こり得るエラーとの判別が困難なチートに対応することができること。換言すると、チートツールは、チートのためのデータをエラーと誤認させる形で送信するため、チートと断定できなくとも、チートと疑われる行為が実行された時に即座に反応できることが、第2の条件である。
第3の条件とは、リアルタイム対応能力があること、即ちチートやそれと疑われる行為が実行されたときに即座に反応し、サービス提供者へ通知できることという条件である。
第4の条件とは、互換性があること、即ち既存のオペレーティングシステムやウィルス対策ソフトウェア、及び、ゲームシステムそのものとの高い互換性を有し、既存のソフトウェアの実行を妨げる可能性がないことという条件である。
第1の条件とは、偽陽性(False-ositive)がないこと、即ち、無実のプレイヤーをチーターと誤検知し、アカウント停止等の措置を行わないことという条件である。
第2の条件とは、通常起こり得るエラーとの判別が困難なチートに対応することができること。換言すると、チートツールは、チートのためのデータをエラーと誤認させる形で送信するため、チートと断定できなくとも、チートと疑われる行為が実行された時に即座に反応できることが、第2の条件である。
第3の条件とは、リアルタイム対応能力があること、即ちチートやそれと疑われる行為が実行されたときに即座に反応し、サービス提供者へ通知できることという条件である。
第4の条件とは、互換性があること、即ち既存のオペレーティングシステムやウィルス対策ソフトウェア、及び、ゲームシステムそのものとの高い互換性を有し、既存のソフトウェアの実行を妨げる可能性がないことという条件である。
従来の技術では、第1乃至第4の条件のうち、少なくとも1つの条件を満たすことができなかった。
例えば、[背景技術]の欄で上述した特許文献1の技術では、チーターと思われるプレイヤーをグルーピングする。
従って、チーターと思われるプレイヤーが無実のプレイヤーであった場合、チーターのグループから抜け出す措置を講じなければ、第1の条件を満たすことができない。しかしながら、適切な措置は特許文献には見受けられない。
また、通常起こり得るエラーとの判別が困難な、未知のチート手法のチートが行われた場合、リアルタイムに対応して、サービス提供者に通知することは、特許文献1の技術では困難である。つまり、第2及び第3の条件を満たすことは困難である。
従って、チーターと思われるプレイヤーが無実のプレイヤーであった場合、チーターのグループから抜け出す措置を講じなければ、第1の条件を満たすことができない。しかしながら、適切な措置は特許文献には見受けられない。
また、通常起こり得るエラーとの判別が困難な、未知のチート手法のチートが行われた場合、リアルタイムに対応して、サービス提供者に通知することは、特許文献1の技術では困難である。つまり、第2及び第3の条件を満たすことは困難である。
これに対して、本発明が適用される情報処理システムは、第1乃至第4の条件を満たすことができる。
即ち、第1重み付け制御により、多くのプレイヤーに共通する操作傾向では重み値が下げられる一方、少数のプレイヤーにのみ共通する特異な操作傾向では重み値が上げられる。これにより、既知のチート手法は勿論のこと未知のチート手法であっても、チート固有の振る舞い(操作傾向)をしているプレイヤーが適切に抽出可能になる。
さらに、第2重み付け制御により、直近の操作の履歴情報には強い重み付けがなされる一方、過去の操作の履歴情報には弱い重み付けがなされる。
これにより、例えばこれまでにはない操作傾向であっても、その操作傾向が類似するプレイヤー群の規模(大きさ)という観点でリアルタイムに監視することが容易にできる。従って、例えばこれまでにない操作傾向が類似するプレイヤー群の規模が増大してきた場合、未知のチート手法によるチート(或いはチートと疑われる行為)が現れた旨を即座に、サービス提供者に通知することができる。
このように、本発明が適用される情報処理システムは、第2及び第3の条件を満たすことができる。
さらに、第2重み付け制御により、直近の操作の履歴情報には強い重み付けがなされる一方、過去の操作の履歴情報には弱い重み付けがなされる。
これにより、例えばこれまでにはない操作傾向であっても、その操作傾向が類似するプレイヤー群の規模(大きさ)という観点でリアルタイムに監視することが容易にできる。従って、例えばこれまでにない操作傾向が類似するプレイヤー群の規模が増大してきた場合、未知のチート手法によるチート(或いはチートと疑われる行為)が現れた旨を即座に、サービス提供者に通知することができる。
このように、本発明が適用される情報処理システムは、第2及び第3の条件を満たすことができる。
ここで、サービス提供者は、未知のチート手法によるチート(或いはチートと疑われる行為)をしていると判断されたプレイヤーに対して、アカウント停止等の措置を取らずに、例えば通常の操作傾向のプレイヤーから隔離する措置を取るだけでよい。これにより、当該プレイヤーは、未知のチート手法によるチート(或いはチートと疑われる行為)をしている者として自分自身が監視されていると認識することができる。
当該プレイヤーが、チート(或いはチートと疑われる行為)を即座に停止し、通常の操作に戻った場合、第2重み付け制御により直近の操作の履歴情報には強い重み付けがなされるため、特徴情報は通常の操作傾向を示すものに戻る。その結果、当該プレイヤーは、チート(或いはチートと疑われる行為)をしている者というレッテルは外されることになる。
これに対して、当該プレイヤーがチートを停止しない場合、当該チートの操作の履歴情報は累積的に蓄積されていく。従って、第2重み制御により過去の操作の履歴情報に弱い重み付けがなされたとしても、特徴情報はチートの操作傾向を示すもののままである。
このように、本発明が適用される情報処理システムは、第1の条件を満たすことができる。
当該プレイヤーが、チート(或いはチートと疑われる行為)を即座に停止し、通常の操作に戻った場合、第2重み付け制御により直近の操作の履歴情報には強い重み付けがなされるため、特徴情報は通常の操作傾向を示すものに戻る。その結果、当該プレイヤーは、チート(或いはチートと疑われる行為)をしている者というレッテルは外されることになる。
これに対して、当該プレイヤーがチートを停止しない場合、当該チートの操作の履歴情報は累積的に蓄積されていく。従って、第2重み制御により過去の操作の履歴情報に弱い重み付けがなされたとしても、特徴情報はチートの操作傾向を示すもののままである。
このように、本発明が適用される情報処理システムは、第1の条件を満たすことができる。
また、本発明が適用される情報処理システムは、プレイヤーの操作の履歴情報を用いているだけなので、第4の条件を満たすことができる。
このように、本発明が適用される情報処理システムは、第1乃至第4の条件を満たすことができるので、未知のチート手法や検出が困難なチート手法を用いたチートを適切に検出し、その結果、このようなチートに対して即時対応が可能となる。具体的には、即時対応として、未知のチート手法や検出が困難なチート手法を用いるチーターを、一般のプレイヤーから見えないように隔離すると共に、ゲーム運営者に当該チーターの出現を警告することが可能になる。
ここで、所定プレイヤーがチート(或いはチートと疑われる行為)をしているか否かの判断をするための手法は、当該所定プレイヤーの特徴情報を用いる手法であれば足り、特に限定されない。
ただし、未知のチート手法によるチートの発生をリアルタイムに監視したり、チート(或いはチートと疑われる行為)をしている者を通常のプレイヤーから隔離するためには、特徴情報に基づいてクラスタリングを行い、グループ単位での判断を導入すると好適である。
即ち、サーバは、複数のプレイヤー毎の特徴情報に基づいて、前記複数のプレイヤーをクラスタリングするクラスタリング手段(例えば図6のクラスタリング部103)を備えると好適である。
ただし、未知のチート手法によるチートの発生をリアルタイムに監視したり、チート(或いはチートと疑われる行為)をしている者を通常のプレイヤーから隔離するためには、特徴情報に基づいてクラスタリングを行い、グループ単位での判断を導入すると好適である。
即ち、サーバは、複数のプレイヤー毎の特徴情報に基づいて、前記複数のプレイヤーをクラスタリングするクラスタリング手段(例えば図6のクラスタリング部103)を備えると好適である。
ここで、サーバの履歴情報取得手段は、
前記所定プレイヤーの操作の履歴情報を、前記ゲームで受け付けられる複数種類の操作毎に取得する処理を、前記複数のプレイヤー毎に実行し、
前記重み値演算手段は、
前記複数種類の操作の夫々に対応する複数の前記重み値を夫々演算し、
前記複数の重み値を要素として含む前記特徴情報を、前記複数のプレイヤー毎に生成することができる。
これにより、特徴情報として、操作の各種類を軸とする多次元空間上に存在するベクトル(上述のメタデータベクトル)として生成することができる。
その結果、各プレイヤー間の特徴情報の類似度として、多次元空間上の距離等を利用して容易かつ適切に演算することができるので、操作傾向の類似するプレイヤー同士を容易かつ適切に抽出することができる。つまり、チート(或いはチートと疑われる行為)の操作傾向のプレイヤー群と、通常の操作傾向のプレイヤー群とを容易かつ適切に区分できる。
これにより、未知のチート手法でのチートも含めて、各種チートや、チートと疑われる行為をより一段と適切に検出することが可能になる。
前記所定プレイヤーの操作の履歴情報を、前記ゲームで受け付けられる複数種類の操作毎に取得する処理を、前記複数のプレイヤー毎に実行し、
前記重み値演算手段は、
前記複数種類の操作の夫々に対応する複数の前記重み値を夫々演算し、
前記複数の重み値を要素として含む前記特徴情報を、前記複数のプレイヤー毎に生成することができる。
これにより、特徴情報として、操作の各種類を軸とする多次元空間上に存在するベクトル(上述のメタデータベクトル)として生成することができる。
その結果、各プレイヤー間の特徴情報の類似度として、多次元空間上の距離等を利用して容易かつ適切に演算することができるので、操作傾向の類似するプレイヤー同士を容易かつ適切に抽出することができる。つまり、チート(或いはチートと疑われる行為)の操作傾向のプレイヤー群と、通常の操作傾向のプレイヤー群とを容易かつ適切に区分できる。
これにより、未知のチート手法でのチートも含めて、各種チートや、チートと疑われる行為をより一段と適切に検出することが可能になる。
また、前記第1重み制御手段は、
前記所定プレイヤーの前記操作の履歴情報の時系列の累積値を分子として
前記複数のプレイヤー毎の前記操作の履歴情報の時系列の累積値の総加算値を分母として、
表される分数値を、当該所定プレイヤーの重み値となるように制御する、
ようにすることができる。
これにより、第1重み付け制御をより一段と適切に実行できるようになる。
前記所定プレイヤーの前記操作の履歴情報の時系列の累積値を分子として
前記複数のプレイヤー毎の前記操作の履歴情報の時系列の累積値の総加算値を分母として、
表される分数値を、当該所定プレイヤーの重み値となるように制御する、
ようにすることができる。
これにより、第1重み付け制御をより一段と適切に実行できるようになる。
また、前記第2重み制御手段は、
前記所定プレイヤーの前記操作の履歴情報の時系列に対して、当該所定プレイヤーの操作時点からの経過時間が長くなる程減少する重み付けをして、
重み付け後の前記操作の履歴情報の時系列の累積値を前記分子とするという制御を実行できる。
これにより、第2重み付け制御をより一段と適切に実行できるようになる。
前記所定プレイヤーの前記操作の履歴情報の時系列に対して、当該所定プレイヤーの操作時点からの経過時間が長くなる程減少する重み付けをして、
重み付け後の前記操作の履歴情報の時系列の累積値を前記分子とするという制御を実行できる。
これにより、第2重み付け制御をより一段と適切に実行できるようになる。
ここで、前記第2重み制御手段は、さらに、当該所定プレイヤーの操作時点からの経過時間が一定時間を超えると、重みの減少を停止させるという制御も実行できる。
これにより、過去のチートの操作の履歴情報にかけられる重みは弱いものの、常習的な場合には多数回のチートの操作が累積されるため、重み値は必然的に高値になる。
このため、常習性のあるチーターの操作傾向は、たとえ直近でチートを停止したとしても、停止時間が短時間の間は、チーター特有の操作傾向であることに変わらない。その結果、当該チーターは、チート(或いはチートと疑われる行為)をしている者というレッテルを外してもらうことはできない。
これにより、過去のチートの操作の履歴情報にかけられる重みは弱いものの、常習的な場合には多数回のチートの操作が累積されるため、重み値は必然的に高値になる。
このため、常習性のあるチーターの操作傾向は、たとえ直近でチートを停止したとしても、停止時間が短時間の間は、チーター特有の操作傾向であることに変わらない。その結果、当該チーターは、チート(或いはチートと疑われる行為)をしている者というレッテルを外してもらうことはできない。
また、サーバは、前記クラスタリング手段によりクラスタリングされた前記複数のプレイヤーの夫々の前記端末に対して、同一グループに属する他のプレイヤーの情報を送信し、他グループに属する他のプレイヤーの情報の送信を禁止する制御を実行する送信制御手段(例えば図6の他プレイヤー情報送信制御部104)をさらに備えることができる。
これにより、未知のチート手法によるチート(或いはチートと疑われる行為)をしていると判断されたプレイヤーに対して、通常の操作傾向のプレイヤーから隔離する措置が有効的に施される。
その結果、当該プレイヤーは、チート(或いはチートと疑われる行為)をしている者として自分自身がサービス提供者に監視されていることを認識することになる。これにより、チート自体の抑制につながる。
これにより、未知のチート手法によるチート(或いはチートと疑われる行為)をしていると判断されたプレイヤーに対して、通常の操作傾向のプレイヤーから隔離する措置が有効的に施される。
その結果、当該プレイヤーは、チート(或いはチートと疑われる行為)をしている者として自分自身がサービス提供者に監視されていることを認識することになる。これにより、チート自体の抑制につながる。
1、1-1乃至1-m・・・プレイヤー端末、2・・・サーバ、21・・・CPU、51・・・CPU、101・・・履歴情報取得部、102・・・特徴情報生成部、103・・・クラスタリング部、104・・・他プレイヤー情報送信制御部、111・・・第1重み制御部、112・・・第2重み制御部、113・・・重み演算部
Claims (9)
- 複数のプレイヤーの夫々の操作を受付けてゲームを実行し得る複数の端末と、サーバとを含む情報処理システムにおいて、
前記サーバは、
前記ゲームの実行中における所定プレイヤーの操作の履歴情報を、当該所定プレイヤーの端末から取得する処理を、前記複数のプレイヤー毎に実行する履歴情報取得手段と、
前記所定プレイヤーの前記操作の履歴情報から得られる所定の重み値により、当該所定プレイヤーの操作の特徴を示す特徴情報を、前記複数のプレイヤー毎に生成する特徴情報生成手段と、
を備え、
前記特徴情報生成手段は、
前記所定プレイヤーの操作傾向が、前記複数のプレイヤーの少なくとも一部を含む集合の操作傾向に対して特異になると、当該所定プレイヤーの重み値が重くなるように制御する第1重み制御手段と、
前記所定プレイヤーの操作時点からの経過時間に応じて、当該所定プレイヤーの重み値を制御する第2重み制御手段と、
前記第1重み制御手段と前記第2重み制御手段との各制御結果に基づいて、前記複数のプレイヤー毎に前記重み値を夫々演算することで、前記複数のプレイヤー毎の前記特徴情報を生成する重み演算手段と、
を含む情報処理システム。 - 複数のプレイヤーの夫々の操作を受付けてゲームを実行し得る複数の端末の夫々と通信をするサーバにおいて、
前記ゲームの実行中における所定プレイヤーの操作の履歴情報を、当該所定プレイヤーの端末から取得する処理を、前記複数のプレイヤー毎に実行する履歴情報取得手段と、
前記所定プレイヤーの前記操作の履歴情報から得られる所定の重み値により、当該所定プレイヤーの操作の特徴を示す特徴情報を、前記複数のプレイヤー毎に生成する特徴情報生成手段と、
を備え、
前記特徴情報生成手段は、
前記所定プレイヤーの操作傾向が、前記複数のプレイヤーの少なくとも一部を含む集合の操作傾向に対して特異になると、当該所定プレイヤーの重み値が重くなるように制御する第1重み制御手段と、
前記所定プレイヤーの操作時点からの経過時間に応じて、当該所定プレイヤーの重み値を制御する第2重み制御手段と、
前記第1重み制御手段と前記第2重み制御手段との各制御結果に基づいて、前記複数のプレイヤー毎に前記重み値を夫々演算することで、前記複数のプレイヤー毎の前記特徴情報を生成する重み演算手段と、
を含むサーバ。 - 前記履歴情報取得手段は、
前記所定プレイヤーの操作の履歴情報を、前記ゲームで受け付けられる複数種類の操作毎に取得する処理を、前記複数のプレイヤー毎に実行し、
前記重み値演算手段は、
前記複数種類の操作の夫々に対応する複数の前記重み値を夫々演算し、
前記複数の重み値を要素として含む前記特徴情報を、前記複数のプレイヤー毎に生成する
請求項2に記載のサーバ。 - 前記第1重み制御手段は、
前記所定プレイヤーの前記操作の履歴情報の時系列の累積値を分子として
前記複数のプレイヤー毎の前記操作の履歴情報の時系列の累積値の総加算値を分母として、
表される分数値を、当該所定プレイヤーの重み値となるように制御する、
請求項2又は3に記載のサーバ。 - 前記第2重み制御手段は、
前記所定プレイヤーの前記操作の履歴情報の時系列に対して、当該所定プレイヤーの操作時点からの経過時間が長くなる程減少する重み付けをして、
重み付け後の前記操作の履歴情報の時系列の累積値を前記分子とするという制御を実行する、
請求項4に記載のサーバ。 - 前記第2重み制御手段は、さらに、当該所定プレイヤーの操作時点からの経過時間が一定時間を超えると、重みの減少を停止させるという制御を実行する、
請求項5に記載のサーバ。 - 前記複数のプレイヤー毎の前記特徴情報に基づいて、前記複数のプレイヤーをクラスタリングするクラスタリング手段をさらに備える、
請求項2乃至6のうち何れか1項に記載のサーバ。 - 前記クラスタリング手段によりクラスタリングされた前記複数のプレイヤーの夫々の前記端末に対して、同一グループに属する他のプレイヤーの情報を送信し、他グループに属する他のプレイヤーの情報の送信を禁止する制御を実行する送信制御手段をさらに備える、
請求項7に記載のサーバ。 - 複数のプレイヤーの夫々の操作を受付けてゲームを実行し得る複数の端末の夫々と通信をするコンピュータに、
前記ゲームの実行中における所定プレイヤーの操作の履歴情報を、当該所定プレイヤーの端末から取得する処理を、前記複数のプレイヤー毎に実行する履歴情報取得ステップと、
前記所定プレイヤーの前記操作の履歴情報から得られる所定の重み値により、当該所定プレイヤーの操作の特徴を示す特徴情報を、前記複数のプレイヤー毎に生成する特徴情報生成ステップと、
を含む制御処理を実行させ、
前記特徴情報生成ステップとして、
前記所定プレイヤーの操作傾向が前記複数のプレイヤー全体の操作傾向に対して特異になると、当該所定プレイヤーの重み値が重くなるように制御する第1重み制御ステップと、
前記所定プレイヤーの操作時点からの経過時間に応じて、当該所定プレイヤーの重み値を制御するという第2重み制御ステップと、
前記第1重み制御ステップ及び前記第2重み制御ステップの夫々における各制御結果に基づいて、前記複数のプレイヤー毎に前記重み値を夫々演算することで、前記複数のプレイヤー毎の前記特徴情報を生成する重み値演算ステップと、
を含むプログラム。
Priority Applications (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201680028065.4A CN107614075B (zh) | 2015-05-20 | 2016-05-17 | 信息处理系统、服务器、介质和控制处理方法 |
US15/818,426 US10561939B2 (en) | 2015-05-20 | 2017-11-20 | Information processing system, server, and program |
HK18104206.2A HK1244742A1 (zh) | 2015-05-20 | 2018-03-27 | 信息處理系統、服務器和程序、以及終端和程序 |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2015102894A JP5936748B1 (ja) | 2015-05-20 | 2015-05-20 | 情報処理システム、サーバ及びプログラム、並びに端末及びプログラム |
JP2015-102894 | 2015-05-20 |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US15/818,426 Continuation US10561939B2 (en) | 2015-05-20 | 2017-11-20 | Information processing system, server, and program |
Publications (1)
Publication Number | Publication Date |
---|---|
WO2016186110A1 true WO2016186110A1 (ja) | 2016-11-24 |
Family
ID=56184665
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/JP2016/064610 WO2016186110A1 (ja) | 2015-05-20 | 2016-05-17 | 情報処理システム、サーバ及びプログラム、並びに端末及びプログラム |
Country Status (5)
Country | Link |
---|---|
US (1) | US10561939B2 (ja) |
JP (1) | JP5936748B1 (ja) |
CN (1) | CN107614075B (ja) |
HK (1) | HK1244742A1 (ja) |
WO (1) | WO2016186110A1 (ja) |
Families Citing this family (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108268886B (zh) * | 2017-01-04 | 2020-10-30 | 中国移动通信集团四川有限公司 | 用于识别外挂操作的方法及系统 |
CN109107163B (zh) * | 2018-07-20 | 2021-12-21 | 广州华多网络科技有限公司 | 模拟按键检测方法、装置、计算机设备及存储介质 |
CN109011582A (zh) * | 2018-07-24 | 2018-12-18 | 合肥爱玩动漫有限公司 | 一种用于游戏场景内游戏角色投诉封杀方法 |
KR102208314B1 (ko) * | 2019-08-21 | 2021-01-27 | 엔에이치엔 주식회사 | 네트워크를 통해 복수의 사용자 단말기들과 통신하는 네트워크 서버 및 그것의 동작 방법 |
CN111068332B (zh) * | 2019-12-03 | 2022-03-04 | 腾讯科技(深圳)有限公司 | 游戏对局管理方法、装置、电子设备及存储介质 |
US11400378B2 (en) * | 2020-06-30 | 2022-08-02 | Sony Interactive Entertainment LLC | Automatic separation of abusive players from game interactions |
CN113181637B (zh) * | 2021-05-10 | 2024-04-16 | 上海幻电信息科技有限公司 | 游戏回放方法和系统 |
CN113318455B (zh) * | 2021-05-24 | 2024-04-19 | 网易(杭州)网络有限公司 | 游戏数据的处理方法和装置 |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2004180951A (ja) * | 2002-12-03 | 2004-07-02 | Konami Co Ltd | ゲームシステム |
JP2006296769A (ja) * | 2005-04-21 | 2006-11-02 | Sega Corp | ゲームシステム |
JP2007058494A (ja) * | 2005-08-24 | 2007-03-08 | Hewlett-Packard Development Co Lp | 情報処理制御システムおよびその方法 |
JP2010167169A (ja) * | 2009-01-26 | 2010-08-05 | Konami Digital Entertainment Co Ltd | ゲーム装置、ゲーム処理方法、ならびに、プログラム |
US20140243077A1 (en) * | 2013-02-27 | 2014-08-28 | Electronics And Telecommunications Research Institute | Apparatus and method of analyzing game characteristics/attributes for cheating user detection using game characteristics/attributes |
Family Cites Families (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8360865B2 (en) * | 1997-03-21 | 2013-01-29 | Igt | Method and apparatus for providing a complimentary service to a player |
US8360838B2 (en) * | 2006-07-03 | 2013-01-29 | Igt | Detecting and preventing bots and cheating in online gaming |
US7881944B2 (en) * | 2002-05-20 | 2011-02-01 | Microsoft Corporation | Automatic feedback and player denial |
US8376855B2 (en) * | 2004-06-28 | 2013-02-19 | Winview, Inc. | Methods and apparatus for distributed gaming over a mobile device |
CN101218474B (zh) * | 2005-07-11 | 2011-04-06 | 松下电器产业株式会社 | 环境控制装置及环境控制方法 |
CN101114324A (zh) * | 2006-07-25 | 2008-01-30 | 珠海市西山居软件有限公司 | 可反外挂的网络游戏系统及网络游戏系统反外挂的方法 |
JP5037692B2 (ja) * | 2007-10-26 | 2012-10-03 | ソニー コンピュータ エンタテインメント アメリカ リミテッド ライアビリテイ カンパニー | オンラインリソースモニタリング |
US9317684B2 (en) * | 2008-12-23 | 2016-04-19 | Valve Corporation | Protecting against polymorphic cheat codes in a video game |
KR20110116562A (ko) * | 2010-04-19 | 2011-10-26 | 서울대학교산학협력단 | 대규모 다중 사용자 온라인 롤플레잉 게임에서 봇을 검출하는 방법 및 시스템 |
US9636589B2 (en) * | 2010-11-02 | 2017-05-02 | Sony Interactive Entertainment America Llc | Detecting lag switch cheating in game |
US9942609B2 (en) * | 2014-11-13 | 2018-04-10 | Comcast Cable Communications, Llc | Personalized content recommendations based on consumption periodicity |
-
2015
- 2015-05-20 JP JP2015102894A patent/JP5936748B1/ja active Active
-
2016
- 2016-05-17 WO PCT/JP2016/064610 patent/WO2016186110A1/ja active Application Filing
- 2016-05-17 CN CN201680028065.4A patent/CN107614075B/zh active Active
-
2017
- 2017-11-20 US US15/818,426 patent/US10561939B2/en active Active
-
2018
- 2018-03-27 HK HK18104206.2A patent/HK1244742A1/zh unknown
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2004180951A (ja) * | 2002-12-03 | 2004-07-02 | Konami Co Ltd | ゲームシステム |
JP2006296769A (ja) * | 2005-04-21 | 2006-11-02 | Sega Corp | ゲームシステム |
JP2007058494A (ja) * | 2005-08-24 | 2007-03-08 | Hewlett-Packard Development Co Lp | 情報処理制御システムおよびその方法 |
JP2010167169A (ja) * | 2009-01-26 | 2010-08-05 | Konami Digital Entertainment Co Ltd | ゲーム装置、ゲーム処理方法、ならびに、プログラム |
US20140243077A1 (en) * | 2013-02-27 | 2014-08-28 | Electronics And Telecommunications Research Institute | Apparatus and method of analyzing game characteristics/attributes for cheating user detection using game characteristics/attributes |
Also Published As
Publication number | Publication date |
---|---|
JP5936748B1 (ja) | 2016-06-22 |
CN107614075B (zh) | 2020-09-08 |
JP2016214556A (ja) | 2016-12-22 |
CN107614075A (zh) | 2018-01-19 |
US20180071625A1 (en) | 2018-03-15 |
US10561939B2 (en) | 2020-02-18 |
HK1244742A1 (zh) | 2018-08-17 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP5936748B1 (ja) | 情報処理システム、サーバ及びプログラム、並びに端末及びプログラム | |
US11837027B2 (en) | Activity recognition systems and methods | |
US10650226B2 (en) | False face representation identification | |
US11113842B2 (en) | Method and apparatus with gaze estimation | |
US11501001B2 (en) | Techniques to detect perturbation attacks with an actor-critic framework | |
US11837061B2 (en) | Techniques to provide and process video data of automatic teller machine video streams to perform suspicious activity detection | |
KR20150054995A (ko) | 사람의 활동 개요 생성 시스템 및 방법 | |
JP2013122755A (ja) | イベント検出装置及びその方法、動作認識装置及びその方法、プログラム | |
JP6950504B2 (ja) | 異常候補抽出プログラム、異常候補抽出方法および異常候補抽出装置 | |
JP2017215765A (ja) | 異常検知装置、異常検知方法及び異常検知プログラム | |
JPWO2010084839A1 (ja) | 尤度推定装置、コンテンツ配信システム、尤度推定方法および尤度推定プログラム | |
US11468270B2 (en) | Electronic device and feedback information acquisition method therefor | |
US20200401912A1 (en) | Granular binarization for extended reality | |
JP2020201939A (ja) | Mlモデルおよびaiモデルのために敵対的サンプルを軽減するためのシステム | |
Barra et al. | Continuous authentication on smartphone by means of periocular and virtual keystroke | |
JP7040065B2 (ja) | 検出プログラム、検出方法および検出装置 | |
WO2015001854A1 (ja) | 情報処理装置、表示制御プログラム、記録媒体及び情報処理方法 | |
KR20200027649A (ko) | 활동 데이터 분석을 통해 비정상 사용자 그룹을 탐지하는 방법 및 시스템 | |
JP7351571B2 (ja) | 画像追跡装置、画像追跡方法、及びプログラム | |
Acosta et al. | What's Fair is Fair: Detecting and Mitigating Encoded Bias in Multimodal Models of Museum Visitor Attention | |
Dau et al. | Genetic Programming for Channel Selection from Multi-stream Sensor Data with Application on Learning Risky Driving Behaviours |
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: 16796503 Country of ref document: EP Kind code of ref document: A1 |
|
NENP | Non-entry into the national phase |
Ref country code: DE |
|
122 | Ep: pct application non-entry in european phase |
Ref document number: 16796503 Country of ref document: EP Kind code of ref document: A1 |