A portion of the disclosure of this patent document contains material that is subject to copyright protection. The copyright owner has no objection to the facsimile reproduction by anyone of the patent document or the patent disclosure, as it appears in the Patent and Trademark Office patent files or records, but otherwise reserves all copyright rights whatsoever.
The present invention relates generally to the field of content and/or data delivery over a content distribution network. More particularly, the present invention is related in one exemplary aspect to apparatus and methods for assuring privacy of collected data related to usage of content delivered to various devices in a content distribution network.
Content delivery and distribution networks may have a large number of disparate users. In many situations, it is desirable that the preferences and behaviors of these disparate users be known to the operators of the network (as well as the content sources which generate the content for distribution over the network). Moreover, in cases where the users are subscribers or customers of the delivery network (e.g., as in a cable television, satellite, Hybrid Fiber over Copper (HFCu), or similar network), revenue, profit, and subscriber retention/addition are also critical concerns, since these factors effectively keep the network operator (and to some degree content producers) commercially viable. Accordingly, methods and apparatus are established to generate data records of a subscriber's interaction with content including their preferences, behaviors, etc. Further, billing systems and other support systems may be utilized within such networks in order to further take into account subscription level, access privileges, account status (e.g., payments, delinquency), requests for changes in service, and other related functions associated with the collected records.
The data relating to behaviors, preferences etc. of users in a network may be used, for example, to generate ratings of particular programs (or portions thereof) and statistics across a subsection of subscribers, geographic areas, programs, etc. “Nielsen Ratings” are a well known system of evaluating the viewing habits of cross-sections of the population. When collecting Nielsen ratings, companies use statistical techniques to sample a portion of the population to project a representative national population. Theoretically, the viewing habits of the sample population will substantially mirror the larger population. The companies then measure the populations viewing habits to identify, among other things, what programs the population is watching, as well as the time and frequency at which those programs are watched. This information is then extrapolated to gain insight on the viewing habits of the larger population to determine media consumption. Historically, the Nielsen system has been the primary source of audience measurement information in the television industry. The Nielsen system, therefore, affects various aspects of television including inter alia, advertising rates, schedules, viability of particular shows, etc. Other implementations for the collection of data relating to user interaction with content, however, have also been developed.
The Cable Privacy Act of 1984, and, more generally, privacy and consumer advocacy groups, require (either through specific mandate or threatened action) that without an explicit subscriber opt-in, data that could conceivably be used to trace back to subscriber personally identifiable information be strictly protected, and shared only in such a way as to mitigate the chance that such data could be used to derive subscriber personally identifiable information.
It is appreciated that the collection of such data may not be secure, regardless of any steps taken (such as at the data collection entity) to ensure the anonymity of the subscriber. Problems arise for example, when the sample of data is so small that the particular subscriber(s) to whom the data relates can be determined; i.e., where a party may determine the identity of subscribers via “derivative association”. For example, suppose a company has only one customer within a particular zip code. If that company shares “anonymous” information with a third party which includes the zip code, the only additional piece of information that the third party would have to know is who in that zip code is a customer of the company. This information may readily be obtained, such as through buying data from data aggregators such as Experian. With only these two pieces of information, the third party may now uniquely identify the household referred to in the “anonymous” data that the company provided.
The aforementioned logic is also readily extendable to other situations where, although a greater amount of seemingly “anonymous” data is provided to third parties, those parties, through joining the “anonymous” data with information obtained from additional data sources, can derive personally identifiable data.
Hence, what are needed are methods and apparatus for automatically “collapsing” or otherwise adjusting anonymous data sets generated for third parties in such a way as to minimize the probability that, through correlation to other data sources, a third party could associate the provided data to personally identifiable information in order to determine a unique identity of the user to which the data relates.
The present invention addresses the foregoing needs by disclosing, inter alia, apparatus and methods for ensuring data privacy in a content distribution network.
In a first aspect of the invention, a method for ensuring privacy of transmitted data is disclosed. The data relates, in one embodiment, to the interaction of individual ones of a plurality of subscribers in a content distribution network with content provided over the network. In one variant, the method comprises: receiving a plurality data, the plurality of data relating to interaction of the plurality of subscribers with the content, examining a cardinality of a subset of the plurality of subscribers having a first aspect reflected in respective ones of the individual ones of the plurality of data. If the cardinality meets or exceeds a predetermined threshold, the plurality of data is transmitted, and if the cardinality does not meet or exceed the predetermined threshold, the first aspect of the plurality of data is adjusted, and the adjusted data transmitted.
In another embodiment, the method comprises: receiving a plurality of anonymized data records, each of the plurality of anonymized data records describing interaction of an individual one of a plurality of users with content, the data records each having a plurality of fields, examining a first cardinality of a subset of the plurality of data records with respect to a first one of the plurality of fields, examining a second cardinality of a difference between the subset of the plurality of data records with respect to the first one of the plurality of fields and the plurality of data records, and if either the first or the second cardinality is not within a respective predetermined range, adjusting the first one of the plurality of fields by performing at least one of broadening, replacing or eliminating the first one of the plurality of fields.
In a second aspect of the invention, an apparatus for use in a content distribution network is disclosed. In one embodiment, the apparatus comprises: at least one interface configured to receive a plurality of tuning event records associated with a respective plurality of user devices in the content distribution network, a storage entity, and a data processor, the data processor configured to run at least one computer application thereon, the application configured to, when executed: determine whether a number of the received plurality of tuning event records having a first aspect is within an acceptable range, if the number is greater or less than the acceptable range, adjust a value of the first aspect of the plurality of tuning records, and transmit the plurality of tuning records to a remote entity.
In a third aspect of the invention, system for providing a plurality of data records relating to subscribers' interaction with content provided via a content distribution network is disclosed. In one embodiment, the system comprises a plurality of client devices, each of the plurality of client devices receiving content via the network and generating a plurality of information describing interaction therewith, and a headend entity in communication with the plurality of client devices and configured to receive the plurality of information therefrom. In one variant, the headend entity is further configured to run at least one computer program thereon, the at least one computer program configured to examine the plurality of information to determine whether an identity of an individual one of the client devices may be derived if the plurality of information is provided to an outside party, and if the identity may be derived, executing one or more data privacy enhancement protocols on the plurality of information.
In a fourth aspect of the invention, a computer readable apparatus comprising a storage medium, the medium having at least one program stored thereon is disclosed. In one embodiment, the program is configured to, when executed: access at least one data record relating to a subscribers' interaction with content provided via a content distribution network, examine the at least one record to determine whether an identity of the subscriber or their client device may be derived when the at least one data record is provided to an outside party, and if the identity may be derived, executing one or more data privacy enhancement protocols on the at least one record.
In a fifth aspect of the invention, methods of doing business including the collection and transmission of records describing user interactions with content are disclosed.
In a sixth aspect of the invention, consumer premises equipment (CPE) for operation within a content delivery network and interaction with content provided thereby is disclosed.
In a seventh aspect of the invention, a network apparatus for collection and processing of records describing user interaction with content is disclosed.
In another aspect of the present disclosure, a non-transitory computer-readable apparatus is disclosed. In one embodiment thereof, the computer-readable apparatus includes a storage medium, the storage medium having at least one computer program stored thereon, the at least one computer program including a plurality of instructions configured to, when executed by a processor apparatus, cause a computerized apparatus to: access a data record relating to an interaction of a subscriber of a content distribution network with at least portions of content provided via the content distribution network; evaluate the data record to determine whether a privacy measure is necessary to protect the data record from derivation of user data associated with the subscriber; and responsive to a determination that the privacy measure is necessary, execute a data privacy enhancement protocol on the data record to produce an adjusted data record.
In another aspect of the present disclosure, a computerized apparatus for use in a content distribution network is disclosed. In one embodiment, the computerized apparatus includes: at least one data interface configured to perform data communication with one or more service nodes in the content distribution network; storage apparatus including at least one computer program; and a processor apparatus configured to execute the at least one computer program, the at least one computer program including a plurality of instructions configured to, when executed, cause the computerized apparatus to: cause at least one service node to obtain a plurality of tuning data records; cause the at least one service node to determine whether an privacy measure is necessary to protect the user data from privacy attacks; enable the at least one service node to: responsive to a determination that the privacy measure is necessary, adjust at least a subset of values of the user data, and transmit the adjusted user data to the computerized apparatus; and responsive to a determination that the privacy measure is not necessary, transmit the user data to the computerized apparatus.
In another aspect of the present disclosure, a computerized method of ensuring privacy of data in a content distribution network is disclosed. In one embodiment, the computerized method includes: receiving a plurality of data representative of anonymized data records; algorithmically evaluating the plurality of data representative of anonymized data records to identify a susceptibility to derivative association, the identification being based at least on a cardinality associated with a subset of the data representative of anonymized data records; and in response to the identification of a susceptibility, algorithmically collapsing at least a portion of the subset of the data representative of anonymized data records.
These and other aspects of the invention shall become apparent when considered in light of the disclosure provided herein.
All Figures © Copyright 2010 Time Warner Cable, Inc. All rights reserved.
Reference is now made to the drawings wherein like numerals refer to like parts throughout.
As used herein, the term “application” refers generally to a unit of executable software that implements a certain functionality or theme. The themes of applications vary broadly across any number of disciplines and functions (such as on-demand content management, e-commerce transactions, brokerage transactions, home entertainment, calculator etc.), and one application may have more than one theme. The unit of executable software generally runs in a predetermined environment; for example, the unit could comprise a downloadable Java Xlet™ that runs within the JavaTV™ environment.
As used herein, the terms “client device” and “end user device” include, but are not limited to, set top boxes (e.g., DSTBs), personal computers (PCs), and minicomputers, whether desktop, laptop, or otherwise, and mobile devices such as handheld computers, PDAs, personal media devices (PMDs), and smartphones.
As used herein, the term “computer program” or “software” is meant to include any sequence or human or machine cognizable steps which perform a function. Such program may be rendered in virtually any programming language or environment including, for example, C/C++, Fortran, COBOL, PASCAL, assembly language, markup languages (e.g., HTML, SGML, XML, VoXML), and the like, as well as object-oriented environments such as the Common Object Request Broker Architecture (CORBA), Java™ (including J2ME, Java Beans, etc.) and the like.
The terms “Customer Premises Equipment (CPE)” and “host device” refer without limitation to any type of electronic equipment located within a customer's or user's premises and connected to a network.
As used herein, the term “display” means any type of device adapted to display information, including without limitation CRTs, LCDs, TFTs, plasma displays, LEDs, incandescent and fluorescent devices, or combinations/integrations thereof. Display devices may also include less dynamic devices such as, for example, printers, e-ink devices, and the like.
As used herein, the term “DOCSIS” refers to any of the existing or planned variants of the Data Over Cable Services Interface Specification, including for example DOCSIS versions 1.0, 1.1, 2.0 and 3.0. DOCSIS (version 1.0) is a standard and protocol for internet access using a “digital” cable network.
As used herein, the term “headend” refers generally to a networked system controlled by an operator (e.g., an MSO) that distributes programming to MSO clientele using client devices. Such programming may include literally any information source/receiver including, inter alia, free-to-air TV channels, pay TV channels, interactive TV, and the Internet.
As used herein, the terms “Internet” and “internet” are used interchangeably to refer to inter-networks including, without limitation, the Internet.
As used herein, the terms “microprocessor” and “digital processor” are meant generally to include all types of digital processing devices including, without limitation, digital signal processors (DSPs), reduced instruction set computers (RISC), general-purpose (CISC) processors, microprocessors, gate arrays (e.g., FPGAs), PLDs, reconfigurable compute fabrics (RCFs), array processors, and application-specific integrated circuits (ASICs). Such digital processors may be contained on a single unitary IC die, or distributed across multiple components.
As used herein, the terms “MSO” or “multiple systems operator” refer to a cable, satellite, or terrestrial network provider having infrastructure required to deliver services including programming and data over those mediums.
As used herein, the terms “network” and “bearer network” refer generally to any type of telecommunications or data network including, without limitation, hybrid fiber coax (HFC) networks, satellite networks, telco networks, and data networks (including MANs, WANs, LANs, WLANs, internets, and intranets). Such networks or portions thereof may utilize any one or more different topologies (e.g., ring, bus, star, loop, etc.), transmission media (e.g., wired/RF cable, RF wireless, millimeter wave, optical, etc.) and/or communications or networking protocols (e.g., SONET, DOCSIS, IEEE Std. 802.3, ATM, X.25, Frame Relay, 3GPP, 3GPP2, WAP, SIP, UDP, FTP, RTP/RTCP, H.323, etc.).
As used herein, the term “network interface” refers to any signal or data interface with a component or network including, without limitation, those of the FireWire (e.g., FW400, FW800, etc.), USB (e.g., USB2), Ethernet (e.g., 10/100, 10/100/1000 (Gigabit Ethernet), 10-Gig-E, etc.), MoCA, Coaxsys (e.g., TVnet™), radio frequency tuner (e.g., in-band or OOB, cable modem, etc.), Wi-Fi (802.11a,b,g,n), WiMAX (802.16), PAN (e.g., 802.15), or IrDA families.
As used herein, the term “QAM” refers to modulation schemes used for sending signals over cable networks. Such modulation scheme might use any constellation level (e.g. QPSK, 16-QAM, 64-QAM, 256-QAM, etc.) depending on details of a cable network. A QAM may also refer to a physical channel modulated according to the schemes.
As used herein, the term “server” refers to any computerized component, system or entity regardless of form which is adapted to provide data, files, applications, content, or other services to one or more other devices or entities on a computer network.
As used herein, the term “storage device” refers to without limitation computer hard drives, DVR device, memory, RAID devices or arrays, optical media (e.g., CD-ROMs, Laserdiscs, Blu-Ray, etc.), or any other devices or media capable of storing content or other information.
As used herein, the term “Wi-Fi” refers to, without limitation, any of the variants of IEEE-Std. 802.11 or related standards including 802.11a/b/g/n/v.
As used herein, the term “wireless” means any wireless signal, data, communication, or other interface including without limitation Wi-Fi, Bluetooth, 3G, HSDPA/HSUPA, TDMA, CDMA (e.g., IS-95A, WCDMA, etc.), FHSS, DSSS, GSM, PAN/802.15, WiMAX (802.16), 802.20, narrowband/FDMA, OFDM, PCS/DCS, analog cellular, CDPD, satellite systems, millimeter wave or microwave systems, acoustic, and infrared (i.e., IrDA).
Overview
The present invention discloses, inter alia, methods and apparatus for ensuring the privacy of the identity of the subscribers, users, and/or devices in a content delivery network from which data is collected and distributed. Interaction of users with content is recorded in one embodiment via the collection of tuning records. However, as noted above, it is often vital that the identity (or privacy) of the users and/or their devices be maintained. Hence, the architecture and methods described herein provide a protocol for adjusting information within the tuning records collected from the devices (e.g., such as by broadening or generalizing the data) so that these may not be used to derive an identity of a user and/or device. Although the root tuning records may be anonymized, they may still be susceptible to a determination of the identity thereof by derivative association or other techniques. The present methods and apparatus in one embodiment: (i) determine whether the number of provided records is comparatively small, thus creating an opportunity for derivative association with respect to the provided records, (ii) determine whether the number of provided records is comparatively large, thus creating an opportunity for derivative association with respect to the records which were not provided, and (iii) if it is determined that the records are comparatively too large or comparatively too small, collapsing or adjusting at least portions of the data. The determination of whether the number of provided records is improperly large or small in one embodiment utilizes an algorithm for determining, for each aspect described in the records, a cardinality of the group of records with respect to that aspect. Hence, tuning records may be collected regarding the users' interaction with content in the network without exposing the data to privacy attacks, such as by derivative association.
In one embodiment, the collapse or adjustments to the data within the tuning records comprises removing a first data value and replacing it with a second data value descriptive of the first data value. For example, a particular zip code may be replaced with a city or state to which the zip code relates. In another embodiment, the data may be collapsed by increasing a range for the value of the aspect. For example, if the value of the aspect is an age range from 20-25, the range may be increased to 20-30. Data may further be adjusted by generalizing the value of the aspect. For instance, the value listing a specific device model number may be generalized instead disclose the type of device that particular model is (e.g., HD, DVR, etc.). The data may be likewise collapsed by removal of the aspect all together.
Further processing of the collected tuning records may include, inter alia, validating the data (to ensure the reliability thereof), determining and accounting for latency, generating reports which filter the data, etc.
The herein described data collapse (and optional processing) may occur at e.g., a headend entity, a local service node, or at the user device itself. Furthermore, the collapsed (and processed) records may be provided to a data analyzing entity either within the MSO network, or remote thereto. It is appreciated that any number of architectures and topologies may implement the herein described methods and apparatus.
Business models and rules for the implementation of the aforementioned methods and for the identification of a need for enhanced privacy measures with respect to data relating to a user's interaction with content, and the implementation thereof are also described.
Exemplary embodiments of the apparatus and methods of the present invention are now described in detail. While these exemplary embodiments are described in the context of use with the aforementioned hybrid fiber (e.g., HFC) terrestrial delivery system or satellite network architecture having an multiple systems operator (MSO), digital networking capability, IP delivery capability, and plurality of client devices/CPE, the general principles and advantages of the invention may be extended to other types of networks and architectures, whether broadband, narrowband, wired or wireless, or otherwise, the following therefore being merely exemplary in nature. For instance, the invention may be adapted for use on so-called hybrid fiber copper (HFCu) networks, or WiMAX (IEEE Std. 802.16) wireless networks.
It will also be appreciated that while described generally in the context of a consumer (i.e., home) end user domain, the present invention may be readily adapted to other types of environments (e.g., commercial/enterprise, government/military, etc.) as well. Myriad other applications are possible.
Other features and advantages of the present invention will immediately be recognized by persons of ordinary skill in the art with reference to the attached drawings and detailed description of exemplary embodiments as given below.
Network—
The data/application origination point 102 comprises any medium that allows data and/or applications (such as a VOD-based or “Watch TV” application) to be transferred to a distribution server 104. This can include for example a third party data source, application vendor website, CD-ROM, external network interface, mass storage device (e.g., RAID system), etc. Such transference may be automatic, initiated upon the occurrence of one or more specified events (such as the receipt of a request packet or ACK), performed manually, or accomplished in any number of other modes readily recognized by those of ordinary skill.
The application distribution server 104 comprises a computer system where such applications can enter the network system. Distribution servers are well known in the networking arts, and accordingly not described further herein.
The VOD server 105 comprises a computer system where on-demand content can be received from one or more of the aforementioned data sources 102 and enter the network system. These servers may generate the content locally, or alternatively act as a gateway or intermediary from a distant source.
The CPE 106 includes any equipment in the “customers' premises” (or other locations, whether local or remote to the distribution server 104) that can be accessed by a distribution server 104.
Although not illustrated, a typical network headend 150 may further include e.g., various billing entities, subscriber management systems, cable modem termination system (CMTS)
It will also be appreciated that the network configuration depicted in
The exemplary headend 150 may further include a multiplexer-encrypter-modulator (MEM) adapted to process or condition content for transmission over the network. As previously described, information is carried across multiple channels. Thus, the headend 150 is adapted to acquire the information for the carried channels from various sources. Typically, the channels being delivered from the headend 150 to the CPE 106 (“downstream”) are multiplexed together in the headend, as previously described and sent to neighborhood hubs (
It will also be recognized, however, that the multiplexing operation(s) need not necessarily occur at the headend 150 (e.g., in the aforementioned MEM). As one alternative, a multi-location or multi-stage approach can be used, such as that described in U.S. Pat. No. 7,602,820, entitled “APPARATUS AND METHODS FOR MULTI-STAGE MULTIPLEXING IN A NETWORK” incorporated herein by reference in its entirety, which discloses inter alia improved multiplexing apparatus and methods that allow such systems to dynamically compensate for content (e.g., advertisements, promotions, or other programs) that is inserted at a downstream network node such as a local hub, as well as “feed-back” and “feed forward” mechanisms for transferring information between multiplexing stages.
Content (e.g., audio, video, data, files, etc.) is provided in each downstream (in-band) channel associated with the relevant service group. To communicate with the headend or intermediary node (e.g., hub server), the CPE 106 may use the out-of-band (OOB) or DOCSIS channels and associated protocols. The OCAP 1.0 (and subsequent) specification provides for exemplary networking protocols both downstream and upstream, although the invention is in no way limited to these approaches.
It will also be recognized that the multiple servers (broadcast, VOD, or otherwise) can be used, and disposed at two or more different locations if desired, such as being part of different server “farms”. These multiple servers can be used to feed one service group, or alternatively different service groups. In a simple architecture, a single server is used to feed one or more service groups. In another variant, multiple servers located at the same location are used to feed one or more service groups. In yet another variant, multiple servers disposed at different location are used to feed one or more service groups.
In addition to on-demand and broadcast content (e.g., video programming), the system of
The CPE 106 are each configured to monitor the particular assigned RF channel (such as via a port or socket ID/address, or other such mechanism) for IP packets intended for the subscriber premises/address that they serve.
“Switched” Networks—
Switching architectures allow improved efficiency of bandwidth use for ordinary digital broadcast programs. Ideally, the subscriber is unaware of any difference between programs delivered using a switched network and ordinary streaming broadcast delivery.
Co-owned U.S. patent application Ser. No. 09/956,688 filed Sep. 20, 2001 and entitled “TECHNIQUE FOR EFFECTIVELY PROVIDING PROGRAM MATERIAL IN A CABLE TELEVISION SYSTEM”, now U.S. Pat. No. 8,713,623, incorporated herein by reference in its entirety, describes one exemplary broadcast switched digital architecture useful with the present invention, although it will be recognized by those of ordinary skill that other approaches and architectures may be substituted.
Referring again to
The edge switch 194 forwards the packets receive from the CMTS 199 to the QAM modulator 189, which transmits the packets on one or more physical (QAM-modulated RF) channels to the CPE. The IP packets are typically transmitted on RF channels that are different than the RF channels used for the broadcast video and audio programming, although this is not a requirement. The CPE 106 are each configured to monitor the particular assigned RF channel (such as via a port or socket ID/address, or other such mechanism) for IP packets intended for the subscriber premises/address that they serve.
“Packetized” Networks—
While the foregoing network architectures described herein can (and in fact do) carry packetized content (e.g., IP over MPEG for high-speed data or Internet TV, MPEG2 packet content over QAM for MPTS, etc.), they are often not optimized for such delivery. Hence, in accordance with another embodiment of the present invention, a “packet optimized” delivery network is used for carriage of the packet content (e.g., IPTV content) when the request issues from an MSO network (see discussion of
Data Privacy Architecture—
Referring now to
As discussed above, content (such as movies, advertisements, data, applications, games, binary images, etc.) is provided to a plurality of user devices via a content distribution network. Users of the user devices interact with the content, such as by tuning in to or away from a particular station, channel, program etc., tuning out, and/or initiating trick mode operations (e.g., fast forward, rewind, pause, stop, etc.). “Tuning” records are created to describe the various users' interactions with the provided content. As used herein, tuning records refer without limitation to a collection of data files, each file containing information regarding a particular user's usage and interaction with particular content and/or data. It is also noted that the term “tuning records” is in no way limited to tuning events; other types of interactions are contemplated for use with the present invention as well, such as interaction with so-called “telescoping” advertisements, initiation of executable files, interaction with games, etc.
The tuning records utilized in the exemplary embodiment of the invention may comprise a plurality of types of data. For example, records may be collected relating to: (i) requests to receive specific content elements (e.g., movie, game, etc.) at particular devices such as CPE 106, PMD 107, etc. (e.g., “tune in” events), (ii) the number of times the content element is requested, (iii) other events or functions such as “trick mode” operations employed with respect to content including e.g., fast forward, rewind, pause, play, etc., (iv) requests to terminate viewing of specific content elements (e.g., “tune away” events), and/or (v) requests to terminate viewing altogether (e.g., “tune out” events), etc. This data may be analyzed with respect to the requesting devices, including e.g., the frequency requests for certain types of programming, the subscriber associated to the device, group of subscribers, devices, households, geographic or demographic areas, etc. Note that in certain variants, the records may aggregate data from multiple events; e.g., a request for the content, a tune in, and a tune out.
The tuning records (i.e., data regarding the user's interaction with content) may include interaction with at least portions of various different types or delivery modes of content. For example, data may be collected regarding the users interaction with linear and/or switched digital broadcast content, VOD/MVOD/FVOD (or other type of on-demand content), content from a personal video recorder (PVR) or digital video recorder (DVR), whether local to the premises or network-based, IPTV content, etc. Further, the requested/provided content may comprise, for example, so called “quick clips” content (described in co-owned U.S. Pat. No. 7,174,126 issued Feb. 6, 2007 and entitled “TECHNIQUE FOR EFFECTIVELY ACCESSING PROGRAMMING LISTING INFORMATION IN AN ENTERTAINMENT DELIVERY SYSTEM” incorporated herein by reference in its entirety), so-called “start-over” content (described in co-owned, co-pending U.S. Patent Publication No. 2005/0034171 entitled “TECHNIQUE FOR DELIVERING PROGRAMMING CONTENT BASED ON A MODIFIED NETWORK PERSONAL VIDEO RECORDER SERVICE” incorporated herein by reference in its entirety), so-called “lookback” content (as described in co-owned, co-pending U.S. patent application Ser. No. 10/913,064 filed Aug. 6, 2004 and entitled “TECHNIQUE FOR DELIVERING PROGRAMMING CONTENT BASED ON A MODIFIED NETWORK PERSONAL VIDEO RECORDER SERVICE” incorporated herein by reference in its entirety), and/or so-called “remote DVR” content (as discussed in co-owned U.S. Pat. No. 7,457,520 issued Nov. 25, 2008 and entitled “TECHNIQUE FOR PROVIDING A VIRTUAL DIGITAL VIDEO RECORDER SERVICE THROUGH A COMMUNICATIONS NETWORK” incorporated herein by reference in its entirety).
Still further, enhanced access to premium content which is not available to non-subscribers or which cannot be delivered across traditional transport may also be provided, such as e.g., behind the scenes outtakes, alternate endings, actor interviews, etc. and data collected relating thereto as well. In yet a further embodiment, the content may comprise interactive content such as that described in co-owned U.S. patent application Ser. No. 12/582,619 filed Oct. 20, 2009 and entitled “GATEWAY APPARATUS AND METHODS FOR DIGITAL CONTENT DELIVERY IN A NETWORK”, now U.S. Pat. No. 9,027,062, and in co-owned U.S. patent application Ser. No. 12/582,653 filed Oct. 20, 2009 and entitled “METHODS AND APPARATUS FOR ENABLING MEDIA FUNCTIONALITY IN A CONTENT-BASED NETWORK”, now U.S. Pat. No. 8,396,055, each of which is incorporated herein by reference in its entirety.
The architecture illustrated in
The CPE 106 in one embodiment comprises a gateway device such as that discussed in co-owned U.S. patent application Ser. No. 11/818,236 filed Jun. 13, 2007 and entitled “PREMISES GATEWAY APPARATUS AND METHODS FOR USE IN A CONTENT-BASED NETWORK”, now U.S. Pat. No. 7,954,131, which is incorporated herein by reference in its entirety. As discussed therein, the gateway acts as a unified proxy for all inbound (downstream) and outbound (upstream) communications with a network. In this way, various user devices within a premises may receive data and content via the gateway apparatus.
In another embodiment, the CPE 106 comprises a media bridge apparatus such as that discussed in co-owned U.S. patent application Ser. No. 12/480,597 filed Jun. 8, 2009 and entitled “MEDIA BRIDGE APPARATUS AND METHODS”, now U.S. Pat. No. 9,602,864, incorporated herein by reference in its entirety. As discussed therein, the CPE 106 may act as a connection between a portable media device (PMD) and a user's home network. Hence, the aforementioned tuning records may be collected regarding not only the CPE 106 itself, but also any connected devices.
The network data privacy entity 200 is configured to run at least a data collapse process 202 and a tuning record processing application 204 thereon. Although illustrated and described as comprising software running on a processor of the data privacy entity 200 (e.g., a server), it is appreciated that these processes 202, 204 may alternatively take the form of a hardware device or logic, combination of hardware and software, or any other form suitable to achieve the desired degree of automation and processing. Likewise, one or more of the aforementioned processes 202, 204 may be located at a different entity, whether at the headend 150 or elsewhere (even to include the CPE itself, such as where each CPE includes a process or application or middleware configured to process tuning event records). It is further appreciated that the data privacy entity 200 may be physically located at any other location whether within the network 101 or in a separate network (not shown) in communication therewith.
The tuning record processing application 204 may be used, in one embodiment, to cause tuning records to be generated regarding user interaction with content occurring at the CPE 106. The tuning record generation may occur at: (i) the processing application 204 itself, such as by using “raw” interaction data received from the CPE; (ii) at the CPE 106, or (iii) at another entity, such as e.g., an intermediary entity which aggregates data from two or more sources, and packages it appropriately. When generated at the CPE or other intermediary entity, these records are passed to the network data privacy entity 200, which collects and validates them via the tuning record processing application 204. The tuning record processing application 204 may further process the tuning records by identifying and characterizing network and/or device latencies. Still further, the tuning record processing application 204 may be utilized to generate one or more reports relating to the collected records. These and other functions of the data privacy entity 200 will be discussed in greater detail below.
In one embodiment, the tuning record processing application 204 may be of the type discussed in co-owned U.S. patent application Ser. No. 12/944,648 filed on Nov. 11, 2010 and entitled “APPARATUS AND METHODS FOR IDENTIFYING AND CHARACTERIZING LATENCY IN A CONTENT DELIVERY NETWORK”, now U.S. Pat. No. 8,930,979, previously incorporated herein. As discussed therein, the network entity 200 may further be adapted to take into account network and device specific latency and adjust tuning records accordingly. In another embodiment, the apparatus and methods of co-owned U.S. patent application Ser. No. 12/877,062 filed on Sep. 7, 2010 and entitled “METHODS AND APPARATUS FOR AUDIENCE DATA COLLECTION AND ANALYSIS IN A CONTENT DELIVERY NETWORK”, now U.S. Pat. No. 9,635,421, previously incorporated herein, may be utilized for providing tuning record generation and collection.
In a further embodiment, the tuning record processing application 204 may utilize the methods and apparatus of co-owned U.S. patent application Ser. No. 12/829,104 filed on Jul. 1, 2010 and entitled “APPARATUS AND METHODS FOR DATA COLLECTION, ANALYSIS AND VALIDATION INCLUDING ERROR CORRECTION IN A CONTENT DELIVERY NETWORK”, now U.S. Pat. No. 8,484,511, previously incorporated herein, for data validation as discussed herein below.
The aforementioned tuning records are, in one embodiment, anonymized using the methods and apparatus disclosed in U.S. patent application Ser. No. 12/877,062, now U.S. Pat. No. 9,635,421, previously incorporated herein. Alternatively, a cryptographic hash (e.g., MD5, SHA1, SHA2, HMAC) may be utilized to disguise the subscriber identity and/or CPE 106 identity. In one embodiment, the techniques for providing anonymity utilizing a cryptographic hash described in U.S. patent application Ser. No. 11/186,452 filed Jul. 20, 2005 and entitled “METHOD AND APPARATUS FOR BOUNDARY-BASED NETWORK OPERATION”, which is incorporated herein by reference in its entirety, may be utilized in conjunction with the present invention to provide the desired hash.
As discussed in greater detail below with respect to
The data in the architecture of
It is appreciated that the records may be provided thereto in the form of a report, whereby only selected ones of the entirety of collected records are provided to individual ones of a plurality of analyzer entities 206, each of the entities 206 (not shown) being associated with a different third party. For example, an analyzer 206 for a specific advertiser may be provided with tuning records relating only to users' interaction with the advertisements of that advertiser, and so forth. In another example, a programming content provider analyzer 206 may receive tuning records relating to all programming from that provider, programming during certain times (e.g., primetime, etc.), and/or from specific users (such as by demographic, geographic location, etc.). As noted above, the tuning record processing application 204 is configured to filter all the tuning records to generate reports with the aforementioned tuning records.
Referring now to
In the illustrated embodiment, the remaining functions (e.g., collection validation and reporting) are performed at the network data privacy entity 200, as in the architecture of
In another embodiment, rather than comprising separate entities, the functionality or processes 202, 204 of the network data privacy entity 200 are implemented as a series of distributed application portions located across various entities in the network.
According to this embodiment, the network and/or local node data collapse entities make the aforementioned determination regarding whether to collapse or adjust the data based at least in part on information received from CPE 106 in the network. This information can include for example a “test” record generated by the client application 210; e.g., one which is representative of and populated as it would be under actual use, yet with fictitious values. This test record is then received and analyzed by the network data collapse entity to determine if actual records of the same type would benefit from modification. Note that this test message functionality can be implemented according to any number of different schemes, such as for example: (i) once at the beginning of a user session (e.g., startup of the CPE); (ii) periodically (e.g., every X minutes); (iii) on each proposed record type change (e.g., if records of different types or lengths are to be sent from the CPE to the network entity, any proposed record having a change in type or length would be temporarily buffered or held at the CPE (or not generated yet), and a new test message of that same type generated and issued to the network for analysis before the actual message is sent); or even (iv) before each actual record is sent or generated.
It is further noted that when using the aforementioned test message approach, not all CPE that will be issuing records need send a test message. For example, in one implementation, so long as the record type/constitution is known (such as through use of controlled, uniform classes of records), a test message from one or a subset of all the CPE can be used as the basis of the analysis, with the assumption that similar type records from other CPE will be comparable.
In other variants, the determination regarding whether to collapse or adjust the data can be based at least in part on information received a posteriori by the CPE (or passed to the CPE by an intermediate entity) that is generated by a network, third-party, or external entity. For example, end-user or analyzer feedback can be used as an input to the client collapse application 210 to determine if modification of the records is beneficial, much as receiver bit error rate (BER) feedback is used in wireless networks to adjust transmission/encoding parameters at a transmitter. Specifically, in one variant, the “error rate” (here, loosely defined as the need for modification or adjustment of a record or record type based on the degree of privacy exposure or vulnerability) is determined by a receiver through use of an algorithm which attempts to determine user identity or other information which is not desired to be exposed, and based on this determination, communicates directly or indirectly with the CPE 106 (application 210) to adjust its data collapse parameters.
In yet another implementation, the CPE 106 can be fully functioned with the logic or intelligence to decide a priori whether data should be collapsed or otherwise modified indigenously, such as via an algorithm running on the CPE or within its middleware that applies predetermined rule sets to the records to ensure that they meet prescribed criteria for privacy. These rule sets can also in one variant be periodically updated via downloads from the network (e.g., entities 200 or 206).
The communication between the CPE 106 and the data analyzer 206 occurs via any number of different modes such as e.g., via IP packets carried over the Internet 111 (as illustrated). In one implementation, this communication “piggybacks” or extends an existing protocol for the transmission of data such as FTP or UDP, although a dedicated protocol specifically for this purpose may be used as well. The user devices communicate data to and from the Internet 111 via literally any wired (e.g., Ethernet, DSL, cable, fiber, and optical wireline connections) or wireless (e.g., Wi-Fi, WiMAX, WAN, PAN, MAN) networking standard.
The embodiment of
In yet another embodiment, the tuning record processing functionality may remain at the network (as discussed above with respect to
Data Privacy Methodology—
As shown in
Tuning records, as noted above, in the exemplary embodiment comprise information which is used to describe each action taken at a user device. For example, when a user requests to access programming, a tune-in record is created. Similarly, when a user changes a channel (i.e., requests different programming), a tune-away record is created (with respect to the first requested channel), and when the user turns off his device, a tune-out record is created. Additionally, records may be created which indicate activity with respect to trick modes functions such as fast forward, rewind, pause, etc. (e.g., time of invocation of the command, duration of the command, number of repeat or similar commands in a given time period, etc.). The tuning records may include for example the precise time at which the event of interest (e.g., user action) was performed or occurred, one or more channel or other program identifiers (e.g., tuned from Channel X, or tuned from Channel X to Channel Y), a device identifier, and an identifier of the action take (e.g., tune-in, tune-out, tune-away, etc.). Various other alternative tuning record data constructs useful as part of the invention will also be recognized by those of ordinary skill given the present disclosure.
As noted above, tuning records may be generated by each of the devices across an entire MSO footprint, or within selected portions or subsets thereof. In one embodiment, the methods and apparatus discussed in co-owned U.S. patent application Ser. No. 12/877,062 filed on Sep. 7, 2010 and entitled “METHODS AND APPARATUS FOR AUDIENCE DATA COLLECTION AND ANALYSIS IN A CONTENT DELIVERY NETWORK”, now U.S. Pat. No. 9,635,421, previously incorporated herein, may be utilized for generating the aforementioned tuning records which are received at the data privacy entity 200.
The tuning records are in one embodiment collected across all available platforms (including for example VOD consumption, interactive consumption, linear/broadcast consumption, DVR usage, EPG interaction, etc.) in order to gather user/audience information in real-time or near-real time, with associated actions of actual users or viewers.
Next, at step 304, it is determined whether additional privacy measures are needed to protect the data records from e.g. derivative association or other such attacks. As noted above, the data records are in one embodiment received after having been anonymized. However, it may still be possible for an outside party to uniquely identify a user or device by the tuning record when combined with additional data. In such cases, the data is adjusted to increase the privacy thereof (step 306). If however, it is determined that the data is sufficiently anonymized as received, then at step 308, the data is transmitted.
Various methods for adjusting the data in order to increase privacy (step 306) are discussed herein. It is noted that once the data is adjusted (if necessary), it may be transmitted e.g., to a data analyzer 206. In another embodiment, the data is adjusted at e.g., the CPE 106 itself and/or a local service node 182. Accordingly, the adjusted data is transmitted (step 308) from these entities to a headend entity for further processing and/or directly to a third party analyzer 206.
Consider a set of tuning events, S. Each individual event, S, will itself be composed of a set of fields, F. Some of these fields, F, may be demographic in nature (zip code, education level, ethnicity, etc.). Some of these fields, F, may be behavioral (network, start time, duration, etc.). Yet others may be service related (whether the household in which the CPE is located which transmitted a specific tuning event, S, either has or does not have HSD service or phone service; the CPE itself may or may not have DVR capabilities). The fields may be (i) continuous (e.g., distance in miles or kilometers from London, England), (ii) continuous over a range (e.g., age between 23 and 42), (iii) “fuzzy” logic variables, such as “low”, “medium” or “high”, or “poor”, “fair”, “good”, or “excellent”), and/or (iv) one of a set of possible discrete values (e.g., animal type—“cat”, “human”, “dog”, “pig”, etc.). Notice that any set of tuning events, S, that is constructed is finite (at the very least, the set is bounded by the most recent tuning event, S, received when the set is considered). Notice also the any set of fields, F, chosen will also be finite. Note that the foregoing statements are useful subsequently herein when describing exemplary embodiments of the algorithm for automatically collapsing a data set.
One can imagine selecting a subset of tuning event records, S, in such a way as to ensure that certain fields are identical for all selected events. For example, one could select from the set of all tuning events, S, only those from zip code 28114 and from households with HSD and voice service. Hence, the identity of a particular user or device may be derived in certain instances (although the data is anonymized), this is termed “derivative association”. Mathematically, this selection process can be described as follows:
Select an S′⊂S and an F′⊂F such that:
∀za∈S′ and zb∈S′ and f∈F′,zzp=zbp Eqn. 1
The problem of derivative association arises in one of two scenarios:
The first scenario discusses that if the cardinality of the subset, S′, is less than a predetermined threshold value, m1, the data is vulnerable to derivative association. In other words, if a subset is too small, the identity of the members of the subset becomes relatively easy to determine. In one embodiment, the threshold value which the cardinality of the subset is greater than, m1, is 25, although it will be appreciated that this value is purely but one example value of many that could be chosen.
An example of scenario (1) might extend from the discussion above. Assume that S′ is constructed of those records from homes in zip code 28114 and with both HSD and voice service. Further assume that only 10 households are actually represented in this set (i.e., there are only 10 so-called “triple-play” (voice, video and HSD) subscribers in zip code 28114). With only 10 households, an “attacker” with access to e.g., the operators billing system, could quite easily get the list of the 10 subscribers in zip code 28114 with voice, video, and HSD service. Then, it would be a relatively simple manner to conduct research against these households to specifically and uniquely to tie each to one of the 10 “anonymous” subscribers in S′. Thus, it seems reasonable that in this theoretical application, m1 should be larger than 10. One can observe that, in the above scenario, if the field “zip code” did not exist at all in the set, S, it would have been much harder to construct a subset with such a low cardinality. This fact is forms a salient part of the exemplary embodiments of automatic collapsing system described herein.
Scenario (2) represents a situation where the subset the exclusive disjunction of the entire set, S, an the subset of “anonymous” subscribers, S′ is less than a predetermined value m2. In other words, if the subset, S′, is too large, the identity of the members in the set, S, which are not in the subset, S′, becomes relatively easy to determine. Stated differently, if the cardinality of a difference between the entire data set, S, and a first subset of data, S′, is less than a predetermined threshold value, m2, the data is vulnerable to derivative association.
Before discussing the algorithm for automatic data collection in greater detail, two additional concepts are introduced, those of precedence and “collapsing rules”. One can imagine that a requestor of a data set places relatively more importance on certain fields than others. One requestor may grade “ethnicity” relatively high, but care little for “household income”. Another, by contrast, may care a great deal about “household income”, but have relatively less interest in “service mix”. These qualitative statements are examples of what is meant by the term “precedence” in the present context, which can be loosely defined as the activity of a data consumer giving specific instructions or information as to what data is relatively more important than other data. Collapsing rules, on the other hand, are the mechanism whereby fields are “generalized” to make it more difficult to construct subsets, S′, with low enough cardinality to make derivative association likely. There are generally four “types” of collapsing rules possible:
With this background in mind, the basic framework to describe the algorithm for automatic data collapse has been built. In one embodiment, the system may be configured as follows:
When a set of anonymous tuning events, S, is going to be extracted, the requestor describes exactly which fields the requestor wishes. Additionally, the requestor indicates a collapsing precedence hierarchy (call itci
With these preliminaries, the automatic collapse algorithm becomes:
The method of
At step 402 of the method of
At step 404 of the exemplary method, it is next determined whether the cardinality of the subset is less than the preset threshold, m1. If the cardinality of the subset is not less than the preset threshold value, m1, the method continues to step 408. If the cardinality of the subset is less than the threshold value (i.e., is smaller than desired), the data is adjusted or collapsed to ensure privacy (step 406). As will be discussed below in greater detail with respect to
Next it is determined at step 408 whether the cardinality of the difference between the group and the subset is less than a preset threshold. In one embodiment, the same threshold value may be used for each step 404 and 408. Alternatively, different values may be prescribed. If the cardinality of the difference is not less than the preset threshold value, m2, the method continues to step 412. If the cardinality of the subset is less than the threshold value (i.e., the subset is larger than desired), the data is adjusted or collapsed to ensure privacy of those not in the subset (step 410).
In another embodiment of the method of
The method may repeat to determine the vulnerability of the data with respect to additional aspect of a data set as well.
Data Collapse Methodology—
Referring now to
A second value is identified which describes the removed value at step 506. Continuing the example from above, the second value may comprise a geographic location to which the zip code belongs. Specifically, the zip code 78221 may be identified for collapse and removed (steps 502 and 504). The descriptive value “San Antonio, TX” or “Bexar County” (the foregoing which each have more than one zip code associated therewith, thereby increasing the ambiguity of which zip code the record is actually based) may then be identified at step 506 to describe the removed value (zip code 78221).
At step 508, the identified second value is inserted in place of the removed first value. Hence, “San Antonio, TX” or “Bexar County” replaces zip code 78221 in each of the data records of the subset of records previously having the 78221 zip code.
Referring now to
Next, at step 514, a range is determined for the value of the aspect. Suppose for example, that the identified aspect is an age group (e.g., 25-30 inclusive). The range for the age group is identified as 6 years (step 514). Per step 516, the range is increased. Continuing the example above, the age range may be increased e.g., from 6 to 11 years, by a certain percentage, etc. Hence, the range 25-30 may be increased in each of the tuning records to e.g., 20-30 or 25-35 or 23-33, etc.
Referring now to
A value of the identified aspect is determined at step 524, and generalized at step 526. In one example, the value of the identified aspect may comprise a specific set top box type (such as a model number); this value may then be replaced with a general description of the device (such as by its features). Accordingly, tuning records having data relating to Cisco™ device model number CHS 435HDC may have the specific data replaced with e.g., “HD DVR” to generally describe that the device is HD compatible and contains a digital video recorder (DVR).
Referring now to
Although
It is also recognized that an underlying principle of the foregoing methods is that values as modified are generally not misdescriptive (e.g., the wrong zip code, or the wrong equipment description). That being said, the present invention contemplates that certain forms of “misdescription” may be employed if desired. For instance, in one variant, the actual value may be encoded or altered according to an algorithm or scheme known to both the encoder and the recipient (decoder). In one example, the zip codes could be permuted or logically shifted/wrapped x places to the left or right (e.g., 78221 becomes 12287 under a “mirror” permutation scheme, or 22178 under the second scheme, where x=2). As yet another alternative, a cryptogram encoding scheme may be applied, wherein each letter of the alphabet (and optionally each number) is assigned an alternate letter/number value (e.g., A=F, F=T, etc.). The foregoing are merely very simple examples of such encoding, and hence more elaborate and difficult to decode schemes will be recognized by those of ordinary skill given the present disclosure. When a data record that has been encoded is received by a decoding entity, the decoding entity merely applies the decoding algorithm (inverse of encoder) to retrieve the “actual” data.
In another variant, multiple encoding schemes may be employed by a data source (e.g., MSO). The foregoing “encoding” schemes provide the advantage of maintaining with 100% fidelity the original information as collected (i.e., a user or recipient of the encoded data can retrieve exactly what was reflected in the original data without having it “watered down” by generalization or removal of data in prior embodiments. However, it also suffers from the drawback that if the encoding scheme is surreptitiously obtained, the user's privacy is jeopardized, whereas under the prior generalization/removal embodiments, no such jeopardization is possible.
Data Collapse Implementations—
Various operational rules may be utilized when implementing the data privacy mechanisms of the invention discussed herein.
In one embodiment, one or more of the above methods for data collapse (
In a further embodiment, various ones of the above-described data collapse methods may be used in conjunction with one another to obtain a desired result. For example, it may be experimentally determined that adjustments which (i) replace a specific aspect (see
It is further appreciated that all of the tuning records, not only those having the identified aspect may be adjusted or collapsed according to the methods of
In yet another embodiment, an MSO (or other third party entity or operator) may be provided with one or more mechanisms to enable selection of particular aspects for collapse. In other words, the operator or other third party may actively control which ones of the aspects (e.g., fields) within the tuning records should be adjusted or collapsed. The operator (or other party) may further identify aspects (e.g., fields) within the tuning records which may not be collapsed or otherwise adjusted. For example, if a third party is particularly interested in a specific age range (such as 20-25), the operator may indicate that this aspect may not under any circumstances be altered. According to this embodiment, if it occurs that the data cannot be certified as no longer being vulnerable to e.g., derivative association, the operator may be notified, and the data held until further operator adjustments are made.
Still further, the MSO operator or other entity may be provided with a means to manually select the type(s) of collapse or adjustments to be performed on certain data. For example, a third party may be interested in a particular aspect of the data set, such as geographic area; however, the particular zip code may not be crucial to that party. Accordingly, the operator may indicate that the field for zip codes within the tuning records should not be eliminated (as discussed at
Data Collection and Tuning Record Generation—
The herein described data privacy apparatus and methods are used in one embodiment to ensure the privacy of a plurality of tuning records collected at e.g., a tuning record collection entity (not shown) whether located at the network headend 150, local service node 182 or the CPE 106 themselves. Additionally, as previously described, the actual generation of tuning records may occur at one entity, while control thereof (including initiation, termination, determination of the collected data fields, etc.) may occur at a separate entity. In one embodiment, the CPE 1060 are configured to generate tuning records, while a headend entity controls the generation thereof, such as by initializing record generation, designating which fields will be present in the collected tuning records, etc.
As noted above, data may be collected across all or a subset of platforms (linear broadcast, on demand, DVR, etc.), and from all or a subset of the devices, in a content delivery network (such as a cable, satellite, or HFCu network). In one embodiment, tuning records are generated using the audience data collection and analysis apparatus and methods discussed in co-owned U.S. patent application Ser. No. 12/877,062, now U.S. Pat. No. 9,635,421, previously incorporated herein. As discussed therein data may be collected from various data sources, such as inter alia, a device/user data source, an switched digital video (SDV) data source, a subscriber data source, a video on-demand (VOD) data source, an application server (AS) data source, an advertisement data source, and an electronic program guide (EPG) data source. Collected data is transmitted to a data collection system, where the records are collected, processed and used to generate files for delivery to a subscriber data analysis (SDA) system, the delivered data being used for detailed analysis of user preferences, activity, and/or behavior. Information may also be collected under the present invention from the use of interactive applications (e.g., “iTV” or similar interactive applications).
It is further appreciated that the herein described methods and apparatus may also be utilize to ensure data privacy in other audience data collection systems such as those disclosed in co-owned U.S. patent application Ser. No. 12/503,749 filed on Jul. 15, 2009 and entitled “METHODS AND APPARATUS FOR EVALUATING AN AUDIENCE IN A CONTENT-BASED NETWORK”, now U.S. Pat. No. 9,178,634, which is incorporated herein by reference in its entirety. As discussed therein, audience or viewer qualities are identified, created and distributed to an advertisement management system and/or an advertisement decision maker in real-time (or near-real time). Additionally, the audience activities are monitored regarding, inter alia, broadcast, VOD, and DVR content. According to this embodiment, the data files containing information relating to audience or viewer qualities may be collapsed or otherwise adjusted prior to being distributed to the advertisement management system, advertisement decision maker, or other entity whether within the network or an outside party. Thus, the privacy of the subscribers and/or devices is secured prior to transmission thereof.
Anonymization—
As noted above, the collected data is particular to or identified with a particular subscriber, user, or user device. In one embodiment, the data may be anonymized by inter alia, the use of a cryptographic (e.g., one-way) hash to protect the privacy of the identified subscriber, user, and/or device. This may occur prior to or after the herein described data collapse. Furthermore, the anonymization process discussed herein may occur at e.g., the entity collecting the tuning records, the entity generating the tuning records, or a separate entity (i.e., at, inter alia, the CPE 106, PMD 107, or other user device, and/or the data privacy entity 200).
Exemplary techniques for providing anonymity utilizing a cryptographic hash described in U.S. patent application Ser. No. 11/186,452 filed Jul. 20, 2005 and entitled “METHOD AND APPARATUS FOR BOUNDARY-BASED NETWORK OPERATION”, previously incorporated herein may be utilized in conjunction with the present invention to provide the aforementioned anonymization, although other techniques may be used with equal success. As disclosed therein, the identity of a CPE or subscriber is anonymized by using a cryptographic hash coupled with an optional “opaque” variable which carries information relating to the CPE of the hash with which it is associated. The hash and opaque variable frustrate de-encryption or reverse-engineering of the individual subscriber's identity or specific location.
In another embodiment, in order to protect subscriber anonymity, customer identifiers (e.g., MAC address, subscriber account numbers, customer account numbers) are made anonymous after being correlated with generic demographic information prior to delivery according to the methods discussed in co-owned U.S. patent application Ser. No. 12/877,062, now U.S. Pat. No. 9,635,421, previously incorporated herein.
Data Validation—
As discussed above, one embodiment of the invention uses the tuning record processing application 204 to process the tuning records prior to being transmitted to the data analyzer 206. In one variant, this processing includes inter alia a validation process to validate the tuning records and ensure the data contained therein is not missing, incorrect, or otherwise unable to be relied upon.
The validation process may be for example of the type disclosed in co-owned U.S. patent application Ser. No. 12/829,104, now U.S. Pat. No. 8,484,511, previously incorporated herein. As discussed therein, audience information is obtained directly from customer's premises equipment (e.g., set top boxes, cable modems, PCs, PMDs, IP devices, etc.) for each individual device, or even on a per-user basis where possible, thereby allowing a content provider or other analytical entity to gather specific information in large quantities across a broad geographical area, or demographic/psychographic slice. Advantageously, multiple sources of content to which viewership behavior relates can be simultaneously monitored, and subscriber anonymity or privacy maintained (i.e., no use is made of personally identifiable information). It is appreciated that the methods and apparatus of the present invention may further insure the privacy of this collected data.
In one embodiment, statistical methods (e.g., linear regression, log linear regression) are used to arrive at an expected value for one or more of the various fields and records of the collected data. Collected data is compared to the derived (e.g., average) or expected value, and if the data meets one or more prescribed criteria (e.g., is a given number of standard deviations away from the expected value or more) indicating that the data quality may be unacceptable, an error message is generated and the data optionally excluded. The criteria used to judge the data (e.g., number of standard deviations which the data is permitted to vary from the expected value) may be determined by the network operator, or an algorithm/computer program. This enables monitoring of an entire system proactively using a statistical or other method to alert the network operator only in the instance erroneous data meeting the test(s) of significance is received. Accordingly, a network operator may assess a large volume of data (in a comparatively contracted period of time) without requiring manual monitoring and/or error correction.
As noted above, the data can be collected across multiple platforms. That is, data regarding a users interaction with content may be collected and utilized regardless of the device or delivery paradigm over which the content is received or requested, the source of the content, the type of content (e.g., linear, VOD, DVR, high speed data, etc.), etc.
Latency Compensation—
The tuning record processing application 204 processes the tuning records before these are transmitted to the data analyzer 206. In one embodiment, this processing includes inter alia identifying and compensating for network and/or device latency to produce data which is reliable up to the second and descriptive of user interaction with content.
In one embodiment, the apparatus and methods disclosed in co-owned U.S. patent application Ser. No. 12/944,648, filed on Nov. 11, 2010 and entitled “APPARATUS AND METHODS FOR IDENTIFYING AND CHARACTERIZING LATENCY IN A CONTENT DELIVERY NETWORK”, now U.S. Pat. No. 8,930,979, previously incorporated herein, may be utilized to provide identification and characterization of, and compensation for, latency that may be present in a content delivery network. As discussed therein, the timing of the tuning records collected from the devices is adjusted or “normalized”, such as to a predetermined time base or reference. Once the records are so normalized, they may be relied upon as being accurate representations of subscriber interaction with content to a high level of granularity; e.g., on a second-by-second basis. In one embodiment, the amount of time which is accounted for (i.e., the amount by which the timing of the tuning records is adjusted) is determined by first determining a device-specific latency, which depends on the hardware and software features of the device. The device-specific latency is added to the latency inflicted by the network during transmission of data therein from the source to the premises.
The foregoing latency compensation provides a significant enhancement to inter alia the end-user of the tuning records described herein. Specifically, the end user may, by making use of the latency compensated records, correlate the behavior of one or more users to a specific point in “demographic/psychographic-time-content-event space”. That is, the end user can literally pinpoint what action was taken by what type of subscriber at what point in time when viewing a given content element. This has appreciable utility to e.g., and advertiser, in that the advertiser can correlate on a second-by-second basis the reaction of an anonymous target demographic/psychographic user (or users) to particular aspects of an advertisement; e.g., as soon as Actor A was introduced, the user tuned away, thereby inferring that the user did not like Actor A. Moreover, this “pinpoint” subscriber behavioral data can be evaluated statistically, such as where tuning records from a number of different anonymous users of the same demographic/psychographic are evaluated as a whole to divine trends or patterns in the overall group behavior. The fact that this information can be presented anonymously (i.e., with the data collapsed or expanded) to third parties has great utility; the anonymized records can be bought or sold or transferred as a valuable commodity, yet with no possibility of subscriber identity or data compromise, which could be quite deleterious to the source (e.g., MSO).
Reporting—
As is also discussed above, the tuning record processing application 204 may be configured to further process the tuning records (prior to the transmission of the records to the data analyzer 206) by e.g., generating reports. In one embodiment, the reports may relate to the number of requests by one or more subscribers, devices, households, geographic zones, demographics/psychographics, etc. or over a particular time period. In this way, data regarding a plurality of users' interaction with content, which would generally tend to be too voluminous and detailed to be useful, may be summarized to produce useful and manageable data.
The analyzed data may also be utilized to support any number of business models, including e.g., to make business or operational decisions, make programming or advertising selection and/or insertion decisions “on the fly”, etc.
In yet another embodiment, the tuning record processing reporting application 204 disposed at the network data privacy entity 200 may be configured to sort through the collected data, and parse this data into usable segments. For example, the data may be segmented or filtered to reflect (i) all usage for a particular premises, organization (e.g., enterprise), or device, (ii) usage across all or a subset of subscribers for a particular program or advertisement, (iii) usage across all users for a particular type of event, irrespective of the content to which it relates (e.g., tune-away events as a function of time of day), and so forth. Reports may also be generated on a per-user, per-household, per-content element, per demographic/psychographic variable, and/or per-device basis.
For example, using the methods and apparatus described herein, a single report may be generated illustrating (across a certain demographic of viewers of an advertisement) the number of viewers which tuned away, and precise times during the advertisement when the viewers did so. Using this information, an advertiser is able to determine e.g., overall penetration of an advertisement by determining the difference between the number of viewers tuned in at the beginning of the advertisement and the number which tuned away.
As will be discussed below, various business rules may be applied in generating reports, including generating certain reports as a purchasable commodity.
The “reports” may be rendered in literally any form, including as computer files, graphical representations, streams of data (e.g., periodically updated databases), GUI “dashboards”, printed reports, etc.
Data Analysis—
As noted previously, the tuning records are analyzed at e.g., the data analyzer 206 of
In one embodiment, the analyzer 206 is associated with a content provider (e.g., a programming content or advertising content provider), and the tuning records are analyzed in a manner similar to Nielson analysis, so as to determine viewership for a particular program, network, time of day, day of the week, etc. prior to the herein-described data collapse for privacy. The tuning records may also be analyzed “on the fly” for the purpose of providing targeted secondary content insertion opportunities. For example, if the collected data indicates that user or subscriber devices registered to the 92123 zip code often view (or are currently viewing) particular programming, then the network tuning record processing entity 200 (or other entity receiving the normalized and validated tuning records) may indicate to an entity providing advertising or other secondary content to the users in that zip code (such as e.g., a data analyzer 206 thereof) that targeted advertising may be provided to these devices during the particular programming. Such targeted advertising might address their common geography (e.g., a local upcoming event or service), a common demographic within that geography, and so forth.
Other data analysis may be performed at the data analyzer 206, the foregoing being merely illustrative of the broader concepts of the invention. For example, the tuning records may be analyzed to determine patterns of behavior for an individual subscriber, and/or a group of subscribers (such as a household, geographic group, demographic group, etc.). Viewership statistics or ratings may also be generated from the tuning records by the data analyzer in order determine monetary value of secondary content insertion opportunities, determine market penetration for advertisements, etc.
Exemplary User Device—
As shown in
The CPE 106 of
In another embodiment, the CPE 106 comprises a converged premises device, such as for example that described in co-owned U.S. patent application Ser. No. 11/378,129 filed Mar. 16, 2006 and entitled “METHODS AND APPARATUS FOR CENTRALIZED CONTENT AND DATA DELIVERY”, now U.S. Pat. No. 8,347,341, incorporated herein by reference in its entirety. In yet another embodiment, the CPE 106 may comprise a gateway device such as that discussed in previously referenced, co-owned U.S. patent application Ser. No. 11/818,236 filed Jun. 13, 2007 and entitled “PREMISES GATEWAY APPARATUS AND METHODS FOR USE IN A CONTENT-BASED NETWORK”, now U.S. Pat. No. 7,954,131.
In yet another embodiment, the CPE 106 comprises a media bridge apparatus such as that discussed in U.S. patent application Ser. No. 12/480,597, now U.S. Pat. No. 9,602,864, previously incorporated herein. As discussed therein, the CPE 106 may act as a connection between a portable media device (PMD) and a user's home network. This bridging apparatus may be used, for example, to convert content stored on the PMD (e.g., an MP3 player such as an iPod®) to a format capable of being presented on a user's set-top box or other client device. The media bridging apparatus (e.g., CPE 106) can also work within a premises network or trusted domain for media content, thereby allowing a subscriber total mobility in the premises network. For example, media content from the PMD may be accessed via extant networks for distribution to any STB, PC, mobile device, or other PMD. The media bridging device may also utilize the existing premises network (including a network defined by coaxial cable in the premises, such as a MoCA-enabled network) to allow devices and DVRs to provide media content to the PMD. According to this embodiment, tuning records may be obtained from the CPE and other client devices interacting with content from the PMD. Likewise, the tuning records may further relate to user interaction on the PMD with content received from the CPE or client devices. The privacy of the subscriber and/or the device from which the records were taken (e.g., the CPE or PMD) may be protected using the aforementioned data collapse methods.
As previously noted, in one embodiment, the CPE 106 of
The CPE 106 may also comprise a client tuning record processing application 212 also running as a software application on the processor 604. According to this embodiment, the CPE 106 may, via the client tuning record processing application 212, (i) collect data regarding user- or device-specific activities such as tuning or activity logs, power on/off times/duration, PPV/VOD requests, frequency of use of other ancillary functions associated with the CPE, DVR or monitor operation and use (such as via communications from a connected DVR or monitor device), etc., (ii) process the data (including validate, determine and/or apply a latency, anonymize, etc.), (iii) generate reports relating to the collected data, and (iv) transmit the tuning records and/or reports to the data analyzer 206.
Alternatively, additional applications may be provided to run on the client device 106 to perform one or more of the aforementioned functions. The client application may also be integrated with other applications or software running on the CPE 106 if desired.
The foregoing diversity of possible configurations of the CPE 106 illustrates the general network-agnosticism of the present invention; i.e., user events of interest may span literally from cable or satellite or HFCu content delivery networks, to unmanaged IP networks, to MAN or longer range networks (e.g., WiMAX), to local or personal area networks, to ad hoc wireless networks. A “tune” event may comprise e.g., a linear broadcast channel change via a front-panel function or remote on a DSTB, or selection of an IPTV stream on a PC or other IP-enabled device, or selection of a VOD or PPV program, or invocation of a VoIP call, or selection of a hyperlink, startup or termination of an application, an error condition or event, or yet other types of activities as will be readily appreciated by those of ordinary skill given the present disclosure.
Network Data Privacy Entity—
Referring now to
The data privacy entity 200 generally comprises a network interface 702 for communication with the network 101, a processor subsystem 704 and associated storage 706, as well as additional interfaces 708 for communication with other entities.
The processor subsystem 704 is further configured to run a data collapse application 202 and a tuning record processing application 204 thereon. As noted previously, the foregoing may comprise e.g., distributed applications at a headend or third party entity, or yet other configurations of software known in the arts.
In one embodiment, the data collapse application 202 run on the processor 704 of the illustrated entity 200 may, as discussed above with respect to
The tuning record processing application 204, when executed, enables inter alia the request and/or receipt of tuning records from the user devices. The application 204 processes the received records such as by validating the data, identifying and applying a latency value to the records, anonymizing the records, and analyzing the data to generate reports therefrom.
It is appreciated that the network data privacy entity 200 may comprise additional components (not shown) and functionality well known to those of ordinary skill in the network and embedded system fields, and accordingly not described further herein. For example, management or supervisory processes, and/or business rules software (described in greater detail below) may be run on the data privacy entity 200. Fail-over protection, additional physical or network security mechanisms, etc. may also be implemented.
Business/Operational Rules Engine—
In another aspect of the invention, the aforementioned data privacy entity 200 and/or the CPE 106 (e.g., including one or more computer programs for providing the above-mentioned functionalities thereof) optionally include an entity having an operations and/or business rules “engine”. This engine comprises, in an exemplary embodiment, a series of software routines that are adapted to control the determination of whether the data collapse or adjustment functions as described herein should be performed, and to control the performance of these functions (or other functions described herein). These rules may also be fully integrated within the aforementioned one or more computer programs, and controlled via the entity on which the program is run, or remotely if desired. In effect, the rules engine comprises a supervisory entity which monitors and selectively controls the aforementioned functions at a higher level, so as to implement desired operational or business rules of the MSO or other parties of interest (e.g., content sources or advertisers).
The rules engine can be considered an overlay of sorts to the algorithms of the previously described computer applications. For example, the exemplary computer application may invoke certain operational protocols or decision processes based on data received (e.g., historical activity or user data, subscriber preferences, etc.), as well as network operational or historical data, demographic data, geographic data, etc. However, these processes may not always be compatible with higher-level business or operational goals, such as maintaining privacy, maximizing profit on a network-wide basis, or system reliability and/or flexibility. Moreover, the computer application being “supervised” may be operating on a per-CPE, per-household, or per-request basis (i.e., the collected data may be collected for individual CPE effectively in isolation, and analysis may be performed without considering larger patterns or decisions being made in the same service group, or network as a whole).
Hence, when imposed, the business/operational rules of the engine can be used to dynamically (or manually) control the operation of the aforementioned processes in conjunction with the data collapse determination, data collection, data processing (including validation, latency application, anonymization, etc.), analysis and transmission functions previously described.
For example, one rule implemented by the rules engine may comprise selectively performing the above functions resulting in collected viewership data only for certain users; e.g., those who have agreed to have their viewership data collected (whether for consideration or otherwise). Accordingly, only those users who affirmatively “opt in” will have data collected about their household or devices.
In another variant, certain content access, delivery or utilization features (e.g., enhanced functionality such as interactive programming, special features, advanced trailers, etc.) may only be provided to users who agree to have their tuning data collected.
In another variant, information regarding the end user of the content is provided to the engine for use in prioritizing data collection and event record generation. For example, in one implementation, if particular advertisements are associated with respective advertisers, then the MSO's profitability associated with each of these advertisers can be considered in the prioritization process. Specifically, if Advertiser A pays a higher rate for reports than Advertiser B, or Advertiser A pays a higher advertisement placement rate than Advertiser B, the rules engine might decide that collection of tuning data relating to the advertisement of Advertiser A is prioritized over that of Advertiser B. Such prioritization might include, for example: (i) under instances of competition for limited resources, Advertiser A is selected over Advertiser B; (ii) the level or granularity of data collected for Advertiser A is breater than that of Advertiser B; (iii) tuning data for Advertiser B is only collected when there are no outstanding needs or requests associated with Advertiser A, and so forth. Simply stated, the MSO may decide to devote its tuning records collection and management assets preferentially to those content sources who generate the most revenue and/or profit for the MSO.
Another business rule relates to distribution of the privacy enhanced tuning records; i.e., they may only be provided to particular parties (e.g., third parties such as third party data analyzers 206) who meet certain criteria. For instance, these criteria might relate to (i) reliability and/or quality standards; (ii) profitability or revenue potential; (iii) pre-qualification or certification by the MSO (irrespective of whether they would add revenue or profit for the MSO), such as for sufficient security for the data, sufficient processing capability, etc.; or (iv) the ability to provide certain time or quality or service (QoS) guarantees, etc., so that the MSO may ensure that the data will be protected and used efficiently and properly.
As previously noted, the “event” data obtained using the present invention (in various stages of processing, ranging from being merely latency-corrected to being validated, latency corrected, filtered, and enriched with ancillary data) may form a commodity of sorts which can be bought, sold, or bartered under any number of different business models. As can be appreciated, the ability to accurately yet anonymously characterize the behavior of millions of different users (many of whose demographics are known a priori) with respect to explicit events or portions of perceived content is a highly valuable commodity, especially for purposes of increasing advertising penetration and effectiveness (e.g., by proper placement and timing of advertisements, removal of objectionable or ineffective advertisements, etc.), and increasing MSO subscriber satisfaction (e.g., by giving subscribers a user experience which most closely tailors to their individual desires and needs). Hence, the present invention contemplates that the aforementioned tuning records may be sold as commodities, and even develop a secondary market of sorts for buying, selling and trading based on factors such as the demographics the data represents (i.e., very wealthy individuals or those who make frequent purchases historically), the type of events captured (e.g., certain events may be difficult to obtain data on, and hence more highly valued), the “half life” of the data and/or how long ago it was collected (i.e., certain types of data may only be relevant or useful for a certain limited period of time), and so forth.
In another aspect of the invention, the value or price of the records may relate to the granularity of the data. For instance, under prior art techniques, anonymization so that subscriber or user privacy was unequivocally protected might entail deleting data that would otherwise be useful or valuable to the end consumer of the data/report. Under the mechanisms of the present invention, data may be “collapsed” or otherwise processed so as to maintain at least some detail on this information, rather than simply deleting it (e.g., modification of the zip code from an explicit numerical value to a more generalized area designation). The degree of modification or generalization (consistent with still maintaining source privacy) might support different price points, products or views since more specific data is generally more useful to end users.
Many other approaches and combinations of various operational and business paradigms are envisaged consistent with the invention, as will be recognized by those of ordinary skill when provided this disclosure.
It will be recognized that while certain aspects of the invention are described in terms of a specific sequence of steps of a method, these descriptions are only illustrative of the broader methods of the invention, and may be modified as required by the particular application. Certain steps may be rendered unnecessary or optional under certain circumstances. Additionally, certain steps or functionality may be added to the disclosed embodiments, or the order of performance of two or more steps permuted. All such variations are considered to be encompassed within the invention disclosed and claimed herein.
While the above detailed description has shown, described, and pointed out novel features of the invention as applied to various embodiments, it will be understood that various omissions, substitutions, and changes in the form and details of the device or process illustrated may be made by those skilled in the art without departing from the invention. The foregoing description is of the best mode presently contemplated of carrying out the invention. This description is in no way meant to be limiting, but rather should be taken as illustrative of the general principles of the invention.
The scope of the invention should be determined with reference to the claims.
This application is a continuation of and claims the benefit of priority to co-owned U.S. patent application Ser. No. 12/944,985 of the same title filed Nov. 12, 2010 and issuing as U.S. Pat. No. 10,148,623 on Dec. 4, 2018, which is incorporated herein by reference in its entirety. This application is related to co-owned U.S. patent application Ser. No. 12/829,104 filed on Jul. 1, 2010 and entitled “APPARATUS AND METHODS FOR DATA COLLECTION, ANALYSIS AND VALIDATION INCLUDING ERROR CORRECTION IN A CONTENT DELIVERY NETWORK”, issued as U.S. Pat. No. 8,484,511, co-owned U.S. patent application Ser. No. 12/944,648 filed on Nov. 11, 2010 and entitled “APPARATUS AND METHODS FOR IDENTIFYING AND CHARACTERIZING LATENCY IN A CONTENT DELIVERY NETWORK”, issued as U.S. Pat. No. 8,930,979, and co-owned U.S. patent application Ser. No. 12/877,062 filed on Sep. 7, 2010 and entitled “METHODS AND APPARATUS FOR AUDIENCE DATA COLLECTION AND ANALYSIS IN A CONTENT DELIVERY NETWORK”, issued as U.S. Pat. No. 9,635,421, each of which is incorporated herein by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
5528284 | Iwami et al. | Jun 1996 | A |
5708961 | Hylton et al. | Jan 1998 | A |
5719938 | Haas et al. | Feb 1998 | A |
5758257 | Herz et al. | May 1998 | A |
5796423 | Robbins et al. | Aug 1998 | A |
5818438 | Howe et al. | Oct 1998 | A |
5862140 | Shen et al. | Jan 1999 | A |
5897635 | Torres et al. | Apr 1999 | A |
5988078 | Levine | Nov 1999 | A |
6029045 | Picco et al. | Feb 2000 | A |
6052145 | Macrae et al. | Apr 2000 | A |
6088722 | Herz et al. | Jul 2000 | A |
6133910 | Stinebruner | Oct 2000 | A |
6167432 | Jiang | Dec 2000 | A |
6181697 | Nurenberg et al. | Jan 2001 | B1 |
6198744 | Huggins et al. | Mar 2001 | B1 |
6219710 | Gray et al. | Apr 2001 | B1 |
6252634 | Yuen et al. | Jun 2001 | B1 |
6259701 | Shur et al. | Jul 2001 | B1 |
6389538 | Gruse et al. | May 2002 | B1 |
6446261 | Rosser | Sep 2002 | B1 |
6460182 | Buabbud | Oct 2002 | B1 |
6463585 | Hendricks et al. | Oct 2002 | B1 |
6486907 | Farber et al. | Nov 2002 | B1 |
6487721 | Safadi | Nov 2002 | B1 |
6519062 | Yoo | Feb 2003 | B1 |
6523696 | Saito et al. | Feb 2003 | B1 |
6539548 | Hendricks et al. | Mar 2003 | B1 |
6608837 | Brodigan | Aug 2003 | B1 |
6640145 | Hoffberg et al. | Oct 2003 | B2 |
6694145 | Riikonen et al. | Feb 2004 | B2 |
6697376 | Son et al. | Feb 2004 | B1 |
6698020 | Zigmond et al. | Feb 2004 | B1 |
6728269 | Godwin et al. | Apr 2004 | B1 |
6760537 | Mankovitz | Jul 2004 | B2 |
6785904 | Franken et al. | Aug 2004 | B1 |
RE38600 | Mankovitz et al. | Sep 2004 | E |
6788676 | Partanen et al. | Sep 2004 | B2 |
6788775 | Simpson | Sep 2004 | B1 |
6799326 | Boylan et al. | Sep 2004 | B2 |
6807676 | Robbins et al. | Oct 2004 | B1 |
6873622 | Dodson et al. | Mar 2005 | B1 |
6925257 | Yoo | Aug 2005 | B2 |
6944150 | McConnell et al. | Sep 2005 | B1 |
7003670 | Heaven et al. | Feb 2006 | B2 |
7006881 | Hoffberg et al. | Feb 2006 | B1 |
7009972 | Maher et al. | Mar 2006 | B2 |
7027460 | Iyer et al. | Apr 2006 | B2 |
7039048 | Monta et al. | May 2006 | B1 |
7039932 | Eldering | May 2006 | B2 |
7054902 | Toporek et al. | May 2006 | B2 |
7068639 | Varma et al. | Jun 2006 | B1 |
7085287 | Chapman | Aug 2006 | B1 |
7099308 | Merrill et al. | Aug 2006 | B2 |
7099348 | Warwick | Aug 2006 | B1 |
7106382 | Shiotsu | Sep 2006 | B2 |
7149772 | Kalavade | Dec 2006 | B1 |
7174126 | McElhatten et al. | Feb 2007 | B2 |
7174127 | Otten et al. | Feb 2007 | B2 |
7174385 | Li | Feb 2007 | B2 |
7185353 | Schlack | Feb 2007 | B2 |
7188085 | Pelletier | Mar 2007 | B2 |
7209458 | Ahvonen et al. | Apr 2007 | B2 |
7213036 | Apparao et al. | May 2007 | B2 |
7242960 | Van et al. | Jul 2007 | B2 |
7242988 | Hoffberg et al. | Jul 2007 | B1 |
7254608 | Yeager et al. | Aug 2007 | B2 |
7325073 | Shao et al. | Jan 2008 | B2 |
7330483 | Peters, Jr. et al. | Feb 2008 | B1 |
7359375 | Lipsanen et al. | Apr 2008 | B2 |
7363643 | Drake et al. | Apr 2008 | B2 |
7376386 | Phillips et al. | May 2008 | B2 |
7383243 | Conkwright et al. | Jun 2008 | B2 |
7444655 | Sardera | Oct 2008 | B2 |
7457520 | Rosetti et al. | Nov 2008 | B2 |
7486869 | Alexander et al. | Feb 2009 | B2 |
7567983 | Pickelsimer et al. | Jul 2009 | B2 |
7592912 | Hasek et al. | Sep 2009 | B2 |
7602820 | Helms et al. | Oct 2009 | B2 |
7650319 | Hoffberg et al. | Jan 2010 | B2 |
7690020 | Lebar | Mar 2010 | B2 |
7693171 | Gould | Apr 2010 | B2 |
7716668 | Moore et al. | May 2010 | B2 |
7721314 | Sincaglia et al. | May 2010 | B2 |
7742074 | Minatogawa | Jun 2010 | B2 |
7768546 | Boehringer, Jr. | Aug 2010 | B1 |
7770200 | Brooks et al. | Aug 2010 | B2 |
7809942 | Baran et al. | Oct 2010 | B2 |
7873660 | Wong | Jan 2011 | B1 |
7878660 | Yang et al. | Feb 2011 | B2 |
7889765 | Brooks et al. | Feb 2011 | B2 |
7900052 | Jonas et al. | Mar 2011 | B2 |
7954131 | Cholas et al. | May 2011 | B2 |
8078669 | Ladd et al. | Dec 2011 | B2 |
8099757 | Riedl et al. | Jan 2012 | B2 |
8244909 | Hanson et al. | Aug 2012 | B1 |
8347341 | Markley et al. | Jan 2013 | B2 |
8484511 | Engel et al. | Jul 2013 | B2 |
8855469 | Maharajh et al. | Oct 2014 | B2 |
9213538 | Ladd et al. | Dec 2015 | B1 |
20010004768 | Hodge et al. | Jun 2001 | A1 |
20010033583 | Rabenko et al. | Oct 2001 | A1 |
20020007491 | Schiller et al. | Jan 2002 | A1 |
20020024943 | Karaul et al. | Feb 2002 | A1 |
20020027883 | Belaiche | Mar 2002 | A1 |
20020032754 | Logston et al. | Mar 2002 | A1 |
20020056125 | Hodge et al. | May 2002 | A1 |
20020059619 | Lebar | May 2002 | A1 |
20020066033 | Dobbins et al. | May 2002 | A1 |
20020078444 | Krewin et al. | Jun 2002 | A1 |
20020087976 | Kaplan et al. | Jul 2002 | A1 |
20020104002 | Nishizawa | Aug 2002 | A1 |
20020123928 | Eldering et al. | Sep 2002 | A1 |
20020133513 | Townsend et al. | Sep 2002 | A1 |
20020144260 | Devara | Oct 2002 | A1 |
20020147771 | Traversat et al. | Oct 2002 | A1 |
20020152299 | Traversat et al. | Oct 2002 | A1 |
20020166120 | Boylan et al. | Nov 2002 | A1 |
20020178446 | Sie et al. | Nov 2002 | A1 |
20020188744 | Mani | Dec 2002 | A1 |
20020188869 | Patrick | Dec 2002 | A1 |
20030002577 | Pinder | Jan 2003 | A1 |
20030016627 | Melampy et al. | Jan 2003 | A1 |
20030016701 | Hinson | Jan 2003 | A1 |
20030023983 | Pidgeon et al. | Jan 2003 | A1 |
20030028888 | Hunter et al. | Feb 2003 | A1 |
20030056217 | Brooks | Mar 2003 | A1 |
20030115267 | Hinton et al. | Jun 2003 | A1 |
20030126611 | Chernock et al. | Jul 2003 | A1 |
20030126618 | Wright | Jul 2003 | A1 |
20030149975 | Eldering et al. | Aug 2003 | A1 |
20030165241 | Fransdonk | Sep 2003 | A1 |
20030166401 | Combes et al. | Sep 2003 | A1 |
20030208767 | Williamson et al. | Nov 2003 | A1 |
20030213001 | Yuen et al. | Nov 2003 | A1 |
20030217137 | Roese et al. | Nov 2003 | A1 |
20030217365 | Caputo | Nov 2003 | A1 |
20030220100 | McElhatten et al. | Nov 2003 | A1 |
20030221191 | Khusheim | Nov 2003 | A1 |
20030225777 | Marsh | Dec 2003 | A1 |
20040015398 | Hayward | Jan 2004 | A1 |
20040024880 | Elving et al. | Feb 2004 | A1 |
20040034877 | Nogues | Feb 2004 | A1 |
20040040035 | Carlucci et al. | Feb 2004 | A1 |
20040045032 | Cummings et al. | Mar 2004 | A1 |
20040045035 | Cummings et al. | Mar 2004 | A1 |
20040045037 | Cummings et al. | Mar 2004 | A1 |
20040133923 | Watson et al. | Jul 2004 | A1 |
20040137918 | Varonen et al. | Jul 2004 | A1 |
20040148625 | Eldering et al. | Jul 2004 | A1 |
20040158858 | Paxton et al. | Aug 2004 | A1 |
20040181800 | Rakib et al. | Sep 2004 | A1 |
20040213389 | Ljubicich | Oct 2004 | A1 |
20040226043 | Mettu et al. | Nov 2004 | A1 |
20040230994 | Urdang et al. | Nov 2004 | A1 |
20040250273 | Swix et al. | Dec 2004 | A1 |
20050022247 | Bitran et al. | Jan 2005 | A1 |
20050034171 | Benya | Feb 2005 | A1 |
20050049886 | Grannan et al. | Mar 2005 | A1 |
20050055220 | Lee et al. | Mar 2005 | A1 |
20050055685 | Maynard et al. | Mar 2005 | A1 |
20050060742 | Riedl et al. | Mar 2005 | A1 |
20050086334 | Aaltonen et al. | Apr 2005 | A1 |
20050086683 | Meyerson | Apr 2005 | A1 |
20050108763 | Baran et al. | May 2005 | A1 |
20050114900 | Ladd et al. | May 2005 | A1 |
20050125824 | Bienstock | Jun 2005 | A1 |
20050177855 | Maynard et al. | Aug 2005 | A1 |
20050187823 | Howes | Aug 2005 | A1 |
20050190794 | Krause et al. | Sep 2005 | A1 |
20050198686 | Krause et al. | Sep 2005 | A1 |
20050216933 | Black | Sep 2005 | A1 |
20050228725 | Rao et al. | Oct 2005 | A1 |
20050235307 | Relan et al. | Oct 2005 | A1 |
20050289618 | Hardin | Dec 2005 | A1 |
20060017846 | Kim et al. | Jan 2006 | A1 |
20060020786 | Helms et al. | Jan 2006 | A1 |
20060021004 | Moran et al. | Jan 2006 | A1 |
20060041905 | Wasilewski | Feb 2006 | A1 |
20060047957 | Helms et al. | Mar 2006 | A1 |
20060074875 | Faunce | Apr 2006 | A1 |
20060095940 | Yearwood | May 2006 | A1 |
20060117354 | Schutte et al. | Jun 2006 | A1 |
20060130099 | Rooyen | Jun 2006 | A1 |
20060130101 | Wessel et al. | Jun 2006 | A1 |
20060130107 | Gonder et al. | Jun 2006 | A1 |
20060130113 | Carlucci et al. | Jun 2006 | A1 |
20060136964 | Diez et al. | Jun 2006 | A1 |
20060149624 | Baluja et al. | Jul 2006 | A1 |
20060149850 | Bowman | Jul 2006 | A1 |
20060156332 | Kendall | Jul 2006 | A1 |
20060161635 | Lamkin et al. | Jul 2006 | A1 |
20060168609 | Chen | Jul 2006 | A1 |
20060171390 | La | Aug 2006 | A1 |
20060171423 | Helms et al. | Aug 2006 | A1 |
20060187900 | Akbar | Aug 2006 | A1 |
20060206712 | Dillaway et al. | Sep 2006 | A1 |
20060209799 | Gallagher et al. | Sep 2006 | A1 |
20060218604 | Riedl et al. | Sep 2006 | A1 |
20060225118 | Rolls et al. | Oct 2006 | A1 |
20060233372 | Shaheen et al. | Oct 2006 | A1 |
20060248553 | Mikkelson et al. | Nov 2006 | A1 |
20060248556 | Yuen et al. | Nov 2006 | A1 |
20060251097 | Chapman et al. | Nov 2006 | A1 |
20060259927 | Acharya et al. | Nov 2006 | A1 |
20060287915 | Boulet et al. | Dec 2006 | A1 |
20060291506 | Cain | Dec 2006 | A1 |
20070019645 | Menon | Jan 2007 | A1 |
20070022459 | Gaebel et al. | Jan 2007 | A1 |
20070022469 | Cooper et al. | Jan 2007 | A1 |
20070033531 | Marsh | Feb 2007 | A1 |
20070049245 | Lipman | Mar 2007 | A1 |
20070055984 | Schiller et al. | Mar 2007 | A1 |
20070061023 | Hoffberg et al. | Mar 2007 | A1 |
20070067851 | Fernando et al. | Mar 2007 | A1 |
20070076728 | Rieger et al. | Apr 2007 | A1 |
20070094691 | Gazdzinski | Apr 2007 | A1 |
20070121678 | Brooks et al. | May 2007 | A1 |
20070124488 | Baum et al. | May 2007 | A1 |
20070136777 | Hasek et al. | Jun 2007 | A1 |
20070157262 | Ramaswamy et al. | Jul 2007 | A1 |
20070180230 | Cortez | Aug 2007 | A1 |
20070186228 | Ramaswamy et al. | Aug 2007 | A1 |
20070198839 | Carle et al. | Aug 2007 | A1 |
20070204314 | Hasek et al. | Aug 2007 | A1 |
20070209059 | Moore et al. | Sep 2007 | A1 |
20070217436 | Markley et al. | Sep 2007 | A1 |
20070219910 | Martinez | Sep 2007 | A1 |
20070245376 | Svendsen | Oct 2007 | A1 |
20070250880 | Hainline | Oct 2007 | A1 |
20070261116 | Prafullchandra et al. | Nov 2007 | A1 |
20070276926 | LaJoie et al. | Nov 2007 | A1 |
20070280298 | Hearn et al. | Dec 2007 | A1 |
20070288715 | Boswell et al. | Dec 2007 | A1 |
20080022012 | Wang | Jan 2008 | A1 |
20080059804 | Shah et al. | Mar 2008 | A1 |
20080066112 | Bailey et al. | Mar 2008 | A1 |
20080091805 | Malaby et al. | Apr 2008 | A1 |
20080091807 | Strub et al. | Apr 2008 | A1 |
20080098212 | Helms et al. | Apr 2008 | A1 |
20080112405 | Cholas et al. | May 2008 | A1 |
20080120667 | Zaltsman | May 2008 | A1 |
20080133551 | Wensley et al. | Jun 2008 | A1 |
20080155059 | Hardin et al. | Jun 2008 | A1 |
20080162353 | Tom et al. | Jul 2008 | A1 |
20080170551 | Zaks | Jul 2008 | A1 |
20080172287 | Tien et al. | Jul 2008 | A1 |
20080177998 | Apsangi et al. | Jul 2008 | A1 |
20080201386 | Maharajh et al. | Aug 2008 | A1 |
20080201731 | Howcroft | Aug 2008 | A1 |
20080209489 | Joyce et al. | Aug 2008 | A1 |
20080222684 | Mukraj et al. | Sep 2008 | A1 |
20080235746 | Peters et al. | Sep 2008 | A1 |
20080273591 | Brooks et al. | Nov 2008 | A1 |
20080279534 | Buttars | Nov 2008 | A1 |
20080282299 | Ko et al. | Nov 2008 | A1 |
20080306903 | Larson et al. | Dec 2008 | A1 |
20090083813 | Dolce et al. | Mar 2009 | A1 |
20090086643 | Kotrla et al. | Apr 2009 | A1 |
20090098861 | Kalliola et al. | Apr 2009 | A1 |
20090100459 | Riedl et al. | Apr 2009 | A1 |
20090100493 | Jones et al. | Apr 2009 | A1 |
20090133048 | Gibbs et al. | May 2009 | A1 |
20090150917 | Huffman et al. | Jun 2009 | A1 |
20090150926 | Schlack | Jun 2009 | A1 |
20090172776 | Makagon et al. | Jul 2009 | A1 |
20090185576 | Kisel et al. | Jul 2009 | A1 |
20090201917 | Maes et al. | Aug 2009 | A1 |
20090210912 | Cholas et al. | Aug 2009 | A1 |
20090217318 | Versteeg et al. | Aug 2009 | A1 |
20090217326 | Hasek | Aug 2009 | A1 |
20090225760 | Foti | Sep 2009 | A1 |
20090228569 | Kalmanje et al. | Sep 2009 | A1 |
20090249421 | Liu et al. | Oct 2009 | A1 |
20090282241 | Prafullchandra et al. | Nov 2009 | A1 |
20090282444 | Laksono | Nov 2009 | A1 |
20090293101 | Carter et al. | Nov 2009 | A1 |
20100005527 | Jeon | Jan 2010 | A1 |
20100027560 | Yang et al. | Feb 2010 | A1 |
20100030578 | Siddique et al. | Feb 2010 | A1 |
20100042478 | Reisman | Feb 2010 | A1 |
20100083329 | Joyce et al. | Apr 2010 | A1 |
20100106846 | Noldus et al. | Apr 2010 | A1 |
20100115091 | Park et al. | May 2010 | A1 |
20100115113 | Short et al. | May 2010 | A1 |
20100122276 | Chen | May 2010 | A1 |
20100125658 | Strasters | May 2010 | A1 |
20100131973 | Dillon et al. | May 2010 | A1 |
20100138900 | Peterka et al. | Jun 2010 | A1 |
20100169977 | Dasher et al. | Jul 2010 | A1 |
20100199299 | Chang et al. | Aug 2010 | A1 |
20100211967 | Ramaswamy et al. | Aug 2010 | A1 |
20100211982 | Lee et al. | Aug 2010 | A1 |
20100218231 | Frink et al. | Aug 2010 | A1 |
20100251305 | Kimble et al. | Sep 2010 | A1 |
20100280641 | Harkness et al. | Nov 2010 | A1 |
20100287209 | Hauser | Nov 2010 | A1 |
20100287609 | Gonzalez et al. | Nov 2010 | A1 |
20100313225 | Cholas et al. | Dec 2010 | A1 |
20110015989 | Tidwell et al. | Jan 2011 | A1 |
20110016479 | Tidwell et al. | Jan 2011 | A1 |
20110016482 | Tidwell et al. | Jan 2011 | A1 |
20110029507 | Au | Feb 2011 | A1 |
20110071841 | Fomenko et al. | Mar 2011 | A1 |
20110090898 | Patel et al. | Apr 2011 | A1 |
20110093900 | Patel et al. | Apr 2011 | A1 |
20110099017 | Ure | Apr 2011 | A1 |
20110103374 | Lajoie et al. | May 2011 | A1 |
20110110515 | Tidwell et al. | May 2011 | A1 |
20110126018 | Narsinh et al. | May 2011 | A1 |
20110138064 | Rieger et al. | Jun 2011 | A1 |
20110173045 | Jaine | Jul 2011 | A1 |
20110178943 | Motahari et al. | Jul 2011 | A1 |
20110213688 | Santos et al. | Sep 2011 | A1 |
20110219229 | Cholas et al. | Sep 2011 | A1 |
20110265116 | Stern et al. | Oct 2011 | A1 |
20110267952 | Ko et al. | Nov 2011 | A1 |
20110283311 | Luong | Nov 2011 | A1 |
20120005527 | Engel et al. | Jan 2012 | A1 |
20120008786 | Cronk et al. | Jan 2012 | A1 |
20120011567 | Cronk et al. | Jan 2012 | A1 |
20120030363 | Conrad | Feb 2012 | A1 |
20120079518 | Wan et al. | Mar 2012 | A1 |
20120124606 | Tidwell et al. | May 2012 | A1 |
Number | Date | Country |
---|---|---|
2005519365 | Jun 2005 | JP |
2005519501 | Jun 2005 | JP |
2005339093 | Dec 2005 | JP |
2008015936 | Jan 2008 | JP |
2009211632 | Sep 2009 | JP |
2010502109 | Jan 2010 | JP |
2010079902 | Apr 2010 | JP |
2012505436 | Mar 2012 | JP |
2012523614 | Oct 2012 | JP |
WO-2005015422 | Feb 2005 | WO |
WO-2012021245 | Feb 2012 | WO |
Entry |
---|
Cantor, et al., Bindings for the OASIS Security Assertion Markup Language (SAML) V2.0, OASIS Standard, Mar. 2005, Document ID saml-bindings-2.0-os ,(http://docs.oasis-open.org/security/saml/v2.0/saml-bindings-2.0-os.pdf). |
Denning, et al., Cryptography and Data Security, Addison-Wesley Publishing Company, ISBN 0-201-10150-5, 1982, pp. 62. |
DLNA (Digital Living Network Alliance) protocols described in DLNA Networked Device Interoperability Guidelines Expanded, Mar. 2006 and subsequent expanded version dated Oct. 2006. |
UTF-32, IBM, retrieved from http://publib.boulder.ibm.com/infocenter/iseries/v5r3/index.jsp?topic=%2Fnls%2Frbagsutf32.htm on Aug. 28, 2013. |
Number | Date | Country | |
---|---|---|---|
20190182218 A1 | Jun 2019 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12944985 | Nov 2010 | US |
Child | 16208299 | US |