JP5232304B2 - 類似性データに基づいてプレイリストを生成するシステム及び方法 - Google Patents

類似性データに基づいてプレイリストを生成するシステム及び方法 Download PDF

Info

Publication number
JP5232304B2
JP5232304B2 JP2011526131A JP2011526131A JP5232304B2 JP 5232304 B2 JP5232304 B2 JP 5232304B2 JP 2011526131 A JP2011526131 A JP 2011526131A JP 2011526131 A JP2011526131 A JP 2011526131A JP 5232304 B2 JP5232304 B2 JP 5232304B2
Authority
JP
Japan
Prior art keywords
media
data
similarity
library
program
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
JP2011526131A
Other languages
English (en)
Other versions
JP2012502361A (ja
Inventor
パトリック ゲイツ,
リチャード, フレドリック ワグナー,
ジェレミー ワーナー,
アンドリュー ウェディッキ,
ジョシュ フラワーズ,
スティーブン, エー. デイビス,
ジェフリー, エス. ミラー,
ダナ, ジェイ. デュボワ,
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Apple Inc
Original Assignee
Apple Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Apple Inc filed Critical Apple Inc
Priority claimed from PCT/US2009/055589 external-priority patent/WO2010027961A1/en
Publication of JP2012502361A publication Critical patent/JP2012502361A/ja
Application granted granted Critical
Publication of JP5232304B2 publication Critical patent/JP5232304B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/40Information retrieval; Database structures therefor; File system structures therefor of multimedia data, e.g. slideshows comprising image and additional audio data
    • G06F16/43Querying
    • G06F16/438Presentation of query results
    • G06F16/4387Presentation of query results by the use of playlists
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11BINFORMATION STORAGE BASED ON RELATIVE MOVEMENT BETWEEN RECORD CARRIER AND TRANSDUCER
    • G11B27/00Editing; Indexing; Addressing; Timing or synchronising; Monitoring; Measuring tape travel
    • G11B27/10Indexing; Addressing; Timing or synchronising; Measuring tape travel
    • G11B27/102Programmed access in sequence to addressed parts of tracks of operating record carriers
    • G11B27/105Programmed access in sequence to addressed parts of tracks of operating record carriers of operating discs
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/60Information retrieval; Database structures therefor; File system structures therefor of audio data
    • G06F16/63Querying
    • G06F16/635Filtering based on additional data, e.g. user or group profiles
    • G06F16/637Administration of user profiles, e.g. generation, initialization, adaptation or distribution
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/60Information retrieval; Database structures therefor; File system structures therefor of audio data
    • G06F16/63Querying
    • G06F16/632Query formulation
    • G06F16/634Query by example, e.g. query by humming
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/60Information retrieval; Database structures therefor; File system structures therefor of audio data
    • G06F16/63Querying
    • G06F16/638Presentation of query results
    • G06F16/639Presentation of query results using playlists
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/60Information retrieval; Database structures therefor; File system structures therefor of audio data
    • G06F16/68Retrieval characterised by using metadata, e.g. metadata not derived from the content or metadata generated manually
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/60Information retrieval; Database structures therefor; File system structures therefor of audio data
    • G06F16/68Retrieval characterised by using metadata, e.g. metadata not derived from the content or metadata generated manually
    • G06F16/683Retrieval characterised by using metadata, e.g. metadata not derived from the content or metadata generated manually using metadata automatically derived from the content
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/953Querying, e.g. by the use of web search engines
    • G06F16/9535Search customisation based on user profiles and personalisation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/40Information retrieval; Database structures therefor; File system structures therefor of multimedia data, e.g. slideshows comprising image and additional audio data
    • G06F16/43Querying
    • G06F16/432Query formulation
    • G06F16/433Query formulation using audio data

Description

本発明は、メディア類似性データに関し、特に、メディア類似性データに基づいてメディアプレイリストを生成することに関する。
長い間、消費者製品のような物品間の関係を規定することは有用な仕事であると考えられてきた。初期の例は商標だろう。商標は、既に所有している別の製品を製造している同一企業による製品が同様の規格に従うだろうという消費者の期待に対する基準を提供する。今日、類似性関係が単純なブランド名をはるかに超えて発展している。いくつかのストアは、類似性データを使用して顧客が購入すべき又は少なくとも検討すべき新しいアイテムを提案する。そのようなストアは、ユーザが同一のショッピングセッションで閲覧する傾向にある製品又は同一ユーザにより頻繁に購入された製品を判定するためにユーザデータを追跡する。この目的で類似性データを使用するシステムは、各ファイル内の特性を識別し、それらのファイルを類似しているものとして識別する。
類似性データを生成するこれらの各方法は、最適である可能性のある類似性データの生成を達成できないかあるいはそのようなデータの可能性を最大限に利用することを達成できない。類似性データを生成する既存の方法が達成できない1つの点は、従来の類似性データが新しい購入決定にのみ基づくためである。ユーザが既に所有しているものに関する情報は、ユーザが将来欲しいと考えるものの最も信頼できる標識であるが、ストアはその情報に注意を払っていない。
デジタルオーディオプレーヤの出現により、ユーザはデジタルメディアの膨大なライブラリを蓄積している。多くの場合、パーソナルメディアライブラリは、CD、SACD及びDVD−A等の物理媒体から追加された曲を含む。2003年4月〜2008年6月までに50億曲を上回る曲が販売されたことから分かるように、ITUNES Store及び他のオンラインメディアプロバイダの紹介により、更に多くのユーザはデジタルメディアのオンライン購入を経験している。デジタルオーディオプレーヤによりユーザはどこでもメディアを実質的に楽しむことができるが、その一方で、益々成長するメディアライブラリは効果的に管理するのが益々困難になっている。音楽の場合、プレイリストは効果的に管理し且つ特定の曲をフィルタリングする1つの方法である。種々のデジタルメディアプレーヤにより、順序付けられた再生を行うために曲のグループ化を選択することでプレイリストを作成できる。
プレイリストを手作業で作成することは、一般に、適切な曲を見つけるためにメディアの長いリストを探索し、所望の曲を選択し且つ望ましくない曲を無視するという冗長な処理を含む。
音楽プレイリストは、ジャンル、アーティスト及びアルバム等の共通の音楽トラック属性に基づいて自動的に生成される。これらの自動的に生成されたプレイリストは、作成するのが単純であり且つ迅速であるが、大雑把にプレイリストを仕上げる。それらは含む曲が多すぎたり且つ/又は少なすぎたりすることが多い。更にそのような自動的な方法は、全ての関連するトラック属性が各メディアに対して入手可能であり且つ正確であることを前提とする。自動プレイリストを生成する1つの方法は、「スマート」プレイリストと呼ばれる。スマートプレイリストにより、ユーザは探索条件を指定し、探索条件にマッチングする曲をプレイリストに追加し、曲が条件を満たすか又は満たさない時にプレイリストを自動的に更新できる。スマートプレイリストは、メディアライブラリを管理するのに強力なツールである。しかし、スマートプレイリストも効果的なスマートプレイリストクエリを作成する際にユーザの音楽の熟知度、ライブラリ及び技術により制限される。ユーザは、音楽のスタイルに精通していない可能性がある。精通していないことにより、関連するアーティスト又は曲を除外してしまう可能性がある。ユーザのライブラリは不完全であるかもしれず、それによりそうでなければ完全であるスマートプレイリストとの差ができる。ユーザは、全ての所望の曲を含むように十分に広範にスマートプレイリストクエリを作成しない可能性がある。スマートプレイリストが全ての意図する曲を含むことを検証することは、第一にプレイリストを手作業で生成するより冗長になることが多い。
メディアプレイリストを生成する従来の各方法の主な欠点は、互いに類似するメディアアイテムを判定することである。プレイリストを手作業で作成する時、ユーザは1つのメディアアイテムと別のメディアアイテムとの間の類似性を引き出す責任がある。自動化プレイリストジェネレータはプレイリストを構築するための条件に依存するが、これらの条件は広範すぎることが多い。同一の作者、アーティストによるメディア、あるいは同一の種類又はジャンルのメディアでさえは、所望のプレイリストを生成するほど十分に類似していないことが多い。スマートプレイリストは、メディアのより詳細な特性に基づいてこれらの問題の多くを解決しようとするものであるが、容易に定義できないユーザの好みを考慮していない。
メディアライブラリが成長し、容量が益々増加するデジタルメディアプレーヤが入手可能であるため、これらのプレイリストに関する問題は悪化する可能性が高い。更にメディアライブラリが大きいほど、ユーザが各ファイルのコンテンツ及び特徴を記憶することは不可能であるため、類似するアイテムをグループ化するシステムが必要とされる。従って、従来技術において必要とされることは、メディアファイル間の類似性データを生成し且つプレイリストを作成及び管理するためにそのようなデータを使用する改善された方法である。
本明細書で開示される概念の更なる特徴及び利点は以下の説明に示され、その説明から部分的に明らかになるか又は説明する技術を実施することにより学習されるだろう。概念の特徴及び利点は、特に添付の請求の範囲で指摘される機器及び組み合わせにより実現され且つ取得されるだろう。説明した技術のそれらの特徴及び他の特徴は、以下の説明及び添付の請求の範囲からより完全に明らかとなるか、あるいは本明細書で示すように開示した概念を実施することにより学習されるだろう。
本発明は、多数のプログラム参加者により提供されたメディアライブラリ一覧情報に少なくとも部分的に基づいて、プログラム参加者に対するメディアプレイリストの生成を容易にする方法及び構成を説明する。この状況において、個人が参加している例示的なプログラム又はシステムは、有料で音楽トラックダウンロードを販売するストア等のオンラインメディアストアである。プログラム参加者になることを決定した個人は、ライブラリに類似する音楽又は同一の音楽を有するプログラムへの他の参加者の母集団から導出されたデータに少なくとも部分的に基づいて音楽を編成、維持及び再生することに興味がある。プログラム参加者になるために、個々の音楽保有者はプログラム参加者のメディア一覧を表すデータを送出する必要があり、オンライン音楽ストアはそれを受信する必要がある。このデータは、一般に、特に個々のメディアアイテム(曲)のソースに関係なく参加者のメディアライブラリに現在含まれている個々のメディアアイテムの識別データを含む。すなわち、アイテムは購入されていてもよく、CDから追加されていてもよく、あるいは取得され且つリスナーのライブラリ又は音楽の一覧に含まれていてもよい。この情報から、システム又はプログラムは、異なるプログラム参加者のメディアライブラリの個々のメディアアイテムのペアが同時に存在することを判定する。これは、数人のユーザにより特定された音楽アイテムのペアについて、様々な参加者についてそのペアが存在するライブラリの数が記録(カウント)されることを意味する。この判定に基づいて、類似性評価は、異なるプログラム参加者のメディアライブラリにおいて判定された同時に存在することに基づいて個々のメディアアイテム(曲)のペアの間に割り当てられる。すなわち、特定のメディアアイテム(曲)のペアがプログラムにおいて表現される多くのライブラリのうち10個のライブラリに存在すると判定(計算)される場合、そのペアの類似性評価が値として割り当てられうる。
類似性評価の解析及び割り当ては、有意義なものになるように、複数のプログラム参加者のメディアライブラリ、すなわちシステムの全体の一覧に含まれた個々のメディアアイテムの少なくとも大部分の間でまとめられる。
システム又はプログラムは、個々の参加者のメディアライブラリに含まれるアイテムに限定される、個々の参加者のための類似性評価をまとめられる。この情報は、多くの場合にMP3プレーヤと呼ばれるようなパーソナルデジタル音楽再生装置等においてエンドユーザとしてユーザのメディアのプレイリストを順序付けるために使用される。このように、個々のプレイリストは、多くのプログラム参加者により導かれた類似性データに基づいて生成される。
異なるが関連する態様において、本発明は、多くのプログラム参加者により提供されたメディアライブラリ一覧情報に少なくとも部分的に基づくメディアプレイリストの生成を容易にするためにオンラインストアと協働するクライアント装置の観点から方法及び構成を更に説明する。本実施形態は、プログラム参加者のメディアライブラリのメディア一覧を表し且つ個々のメディアアイテムのソースに関係なくメディアライブラリ一覧に現在含まれている個々のメディアアイテムの識別データを含むデータをプログラム参加者のクライアント装置から(一般には、オンラインメディアストアのオンラインデータ処理センターとして本明細書において例示的に説明されるプログラムホストに対して)送信する方法、構成及びコンピュータプログラムに焦点を当てる。メディアアイテムのソースの例は、オンライン購入、購入したCDからの追加トラック及び他のソースからのダウンロードを含む。
本実施形態において、次にプログラム参加者のクライアント装置は、複数(2人以上)のプログラム参加者から収集された累積データに基づいてまとめられたメディアアイテム類似性評価を受信する。ここで、累積データは、個々のメディアアイテムのソースに関係なくプログラム参加者のメディアライブラリに含まれた個々のメディアアイテムの識別データを含んでいる。この点に関して、ソースに基づくメディアアイテムとの間の主な差異は、各アイテムと関連付けられた記述的な識別メタデータの量及び品質である。
上述のように、受信した類似性評価のまとめは、異なるプログラム参加者のメディアライブラリの個々のメディアアイテムのペアが同時に存在することを判定するために累積データを処理し且つ異なるプログラム参加者のメディアライブラリにおける判定された同時に存在することに基づいて個々のメディアアイテムのペアの間の類似性評価の割り当てを行うことを含む。本明細書で説明するように、この処理及びまとめは、以下に更に詳細に説明するようにプログラムホストのオンラインデータ処理センターにより例示的に実行される。
類似性評価は、参加者のメディアライブラリに含まれた複数の個々のメディアアイテムに対してプログラム参加者のクライアント装置により受信される。それに基づいて、プログラム参加者のメディアライブラリに含まれた個々のメディアアイテムを含むメディアプレイリストが生成され、メディアアイテムは一般にはプログラム参加者により参加者のメディアライブラリから選択されたシード・メディアアイテムに対する類似性評価を有する。
一例として、シード・メディアアイテムの選択は、選択するシード・メディアアイテムを提示するためにクライアント装置でスクロールホイール装置を操作し、選択ボタンを作動させることでクライアント装置のディスプレイ上のシード・メディアアイテムを選択することにより行われうる。
別の例において、シード・メディアアイテムの選択は、所望のシード・メディアアイテムが表示されるまでタッチスクリーン上に表示されたメディアアイテムのリストをスクロールするために指をスイープする動作を使用してプログラム参加者のクライアント装置上のタッチスクリーンを操作し、シード・メディアアイテムにタッチして離すことでシード・メディアアイテムを選択することにより行われうる。
メディアプレイリストは、特にポータブルパーソナルメディア再生装置又はパーソナルコンピュータの形態をとってもよいプログラム参加者のクライアント装置で生成されうる。
プログラム参加者は、参加者による直前のデータアップロード以降に参加者のメディアライブラリに追加された追加のメディアアイテムの識別データを含むメディアライブラリ中のプログラム参加者の現在のメディア一覧を表す更新データを送信できる。同様に、更新データは、直前のデータ更新以降に参加者のメディアライブラリからメディアアイテムが除去されて存在しないことを示せる。更新データは、メディアアイテムに与えられた評価、再生回数及びスキップ回数等のメディアアイテムの使用に関する情報を含むことができるが、その情報はこれらに限定されない。これに基づいて、プログラム参加者はこの更新データを考慮してまとめられた更新済み類似性評価を受信する。このように、現在生成されたプレイリストは、新しく取得したメディアアイテムを含むことができ、最近削除されたメディアアイテムを考慮しない。
更なる関連する態様において、本発明は、多くのプログラム参加者により提供されたメディアライブラリ一覧情報に少なくとも部分的に基づくメディアプレイリストを生成するためにプログラムホストのオンラインデータ処理センターと協働する1つ以上のクライアント装置を含む統合システム、方法及びコンピュータプログラムを更に説明する。データは、プログラム参加者のクライアント装置からプログラムホストのオンラインデータ処理センターに送信される。データは、クライアント装置上のメディアライブラリのメディア一覧を表し、クライアント装置上のメディアライブラリ一覧に現在含まれている個々のメディアアイテムの識別データを含む。プログラムホストのオンラインデータ処理センターにおいて、各プログラム参加者のメディア一覧を表すデータが複数のプログラム参加者から受信され、これは、上述したように個々のメディアアイテムのソースに関係なく各参加者のメディアライブラリに現在含まれている個々のメディアアイテムの識別データを含む。異なるプログラム参加者のメディアライブラリにおける個々のメディアアイテムのペアが同時に存在することが判定され、類似性評価は異なるプログラム参加者のメディアライブラリにおける判定された同時に存在することに基づいて個々のメディアアイテムのペアの間に割り当てられる。類似性評価は、クライアント装置上のメディアライブラリ一覧に含まれた複数の個々のメディアアイテムに対してプログラムホストのオンラインデータ処理センターからプログラム参加者のクライアント装置に送信される。クライアント装置上のメディアライブラリ一覧に含まれた個々のメディアアイテムを含むメディアプレイリストが生成され、メディアアイテムはクライアント装置上のメディアアイテム一覧から選択されたシード・メディアアイテムに対する類似性評価を有する。
一般に、異なるプログラム参加者のメディアライブラリにおける個々のメディアアイテムのペアが同時に存在することは、プログラムホストのオンラインデータ処理センターにおいて判定され、個々のメディアアイテムのペアの間の類似性評価は、プログラムホストのオンラインデータ処理センターにおいて割り当てられる。
個々のプログラム参加者に対する類似性評価データのまとめは、プログラム参加者のメディアライブラリに含まれた個々のメディアアイテム間の類似性評価データに限定される。このように、データセットは使用可能なデータセットに限定される。すなわち、実際にプログラム参加者のライブラリに含まれたメディアアイテムのみを含むプレイリストの生成に限定される。
異なる参加者のメディアライブラリに含まれた実質的に同一のメディアアイテム間の直接の関連付け許可することを補助するものとして、プログラムに由来する識別子が参加者のメディアライブラリに含まれた個々のメディアアイテムに割り当てられる。すなわち、音楽トラックを一例として使用すると、アメリカの「Horse With No Name」のスタジオバージョンの全てのインスタンスには迅速に且つ効率的に処理するシステムに基づく短いIDが割り当てられる。類似性評価の計算を更に容易にするために、類似するメディアアイテムには同一の識別子が割り当てられうる。例えばアメリカの歌「Horse With No Name」のライブ録音したものには、全体のデータベース中の他のメディアアイテムに対する類似性を判定する時に、処理するシステムに基づく同一のIDが割り当てられうる。
更に特定のメディアアイテムと関連付けられた情報は、第三者データソースから取得された追加のデータを関連付けることにより充実しうる。音楽を一例として使用すると、「ジャンル」は多くの場合に特定の音楽アイテムと関連付けられる特徴である。識別データが特定の音楽のタイトルに対してプログラム参加者から受信されるが、ジャンルタイプを含まない場合、そのような情報を関連付けた第三者の意見を聞くことができ、特定の音楽アイテムに対して第三者により供給されたジャンルタイプはプレイリスト生成処理において後で利用するためにデータと関連付けられる。
このプログラム又はシステム全体の独自の態様は、メディア供給者(オンライン音楽ストア)のサーバ、参加者のメディア再生装置及び多くの場合は再生装置とオンラインストアのコンピュータシステムとの間の通信に対応するユーザのパーソナルコンピュータ等の中間機能において行われる。
上述した実施形態が実現される方法を最適に説明し且つ本発明の他の利点及び特徴を規定するために、更に詳細な説明を以下に提供し、添付の図面に示す。図面は本発明の例示的な実施形態のみを示すが本発明の範囲を限定するものではなく、添付の図面を使用して追加の特性及び詳細を伴ってそれらの例を説明する。
システムの一実施形態を示す図である。 方法の一実施形態を示すフローチャートである。 関連データを判定する方法を示す図である。 サンプルの購入マトリクスを示す図である。 マスタ類似性テーブルの列を示す図である。 個々の類似性テーブルを示す図である。 システムの一実施形態を示す図である。 方法の一実施形態を示すフローチャートである。 システムの一実施形態を示す図である。 メディア及び類似性テーブルをデジタルメディアプレーヤに同期させるシステムの一例を示す図である。 プレイリストの生成を開始するソフトウェアインタフェースの一例を示す図である。 方法の一実施形態を示すフローチャートである。 ユーザインタフェースの一例を示す図である。 ユーザインタフェースの一例を示す図である。 方法の一実施形態を示すフローチャートである。 購入するアイテムを推薦する方法の一実施形態を示すフローチャートである。 参加するためのユーザインタフェースの例を示す図である。 ユーザインタフェースの例を示す図である。 推薦データを表示するためのユーザインタフェースの例を示す図である。
開示する方法及び構成の種々の実施形態について、以下に詳細に説明する。特定の実現例を説明するが、例示する目的でのみ説明することが理解されるべきである。他の構成要素、構成及びステップが本発明の趣旨の範囲から逸脱せずに使用されてもよいことが当業者には理解されるだろう。
図1を参照すると、例示的なシステムは、処理装置(CPU)120と読み出し専用メモリ(ROM)140及びランダムアクセスメモリ(RAM)150等のシステムメモリを含む種々のシステム構成要素を処理装置120と結合するシステムバス110とを含む汎用演算装置100を含む。他のシステムメモリ130も使用可能であってもよい。システムは、2つ以上のCPU120を有する演算装置又はより高い処理能力を提供するために共にネットワーク化された演算装置のグループ又はクラスタで動作してもよい。システムバス110は、メモリバス又はメモリコントローラ、周辺バス及び種々のバスアーキテクチャのうちのいずれかを使用するローカルバスを含むいくつかの種類のバス構造のうちのいずれの構造であってもよい。ROM140等に格納された基本入出力(BIOS)は、起動中等に演算装置100内の要素間で情報を転送するのを助長する基本ルーチンを提供してもよい。演算装置100は、ハードディスクドライブ160、磁気ディスクドライブ、光ディスクドライブ又はテープドライブ等の記憶装置を更に含む。記憶装置160は、ドライブインタフェースによりシステムバス110に接続される。ドライブ及び関連するコンピュータ可読媒体は、演算装置100に対してコンピュータ可読命令、データ構造、プログラムモジュール及び他のデータの不揮発性記憶装置を提供する。1つの側面において、特定の機能を実行するハードウェアモジュールは、機能を実行するためにCPU、バス及びディスプレイ等の必要なハードウェア構成要素と関連して有形のコンピュータ可読媒体に格納されたソフトウェア構成要素を含む。基本構成要素は当業者には既知であり、適切な変形例は、装置が小型のハンドヘルド演算装置であるか、デスクトップコンピュータであるか又は大型のコンピュータサーバであるか等装置の種類に依存して考慮される。
本明細書で説明する例示的な環境がハードディスクを採用するが、コンピュータによりアクセス可能なデータを格納できる磁気カセット、フラッシュメモリカード、デジタル汎用ディスク、カートリッジ、ランダムアクセスメモリ(RAM)、読出し専用メモリ(ROM)、ビットストリームを含む有線又は無線信号等の他の種類のコンピュータ可読媒体が例示的な動作環境において使用されてもよいことが当業者には理解されるべきである。
演算装置100とのユーザ対話を可能にするために、入力装置190は、音声のためのマイク、ジェスチャ又は図形入力のための接触感知スクリーン、キーボード、マウス、モーション入力及び音声等の任意の数の入力機構を表す。入力は、音声検索クエリの開始を示すために提供者により使用されてもよい。装置出力170は、当業者には既知の1つ以上の複数の出力機構であってもよい。いくつかの例において、マルチモーダルシステムは、ユーザが演算装置100と通信するために複数の種類の入力を提供できるようにする。一般に通信インタフェース180は、ユーザ入力及びシステム出力を制御及び管理する。いかなる特定のハードウェア構成においても動作する開示された方法及び装置には制限がないため、基本的な特徴は、それらの発展に伴って改善されたハードウェア又はファームウェア構成と容易に置換できる。
説明を分かり易くするために、例示するシステムの実施形態は、個々の機能ブロック(「プロセッサ」とラベル付けされた機能ブロックを含む)を含むものとして提示される。これらのブロックが表す機能は、共用ハードウェア又は専用ハードウェアを使用して提供されてもよい。共用ハードウェア又は専用ハードウェアは、ソフトウェアを実行できるハードウェアを含むがそれに限定されない。例えば図1に提示される1つ以上のプロセッサの機能は、単一の共用プロセッサ又は複数のプロセッサにより提供されてもよい。(「プロセッサ」という用語の使用は、ソフトウェアを実行できるハードウェアのみを示すものとして解釈されるべきではない。)図示する実施形態は、マイクロプロセッサ及び/又はデジタル信号プロセッサ(DSP)ハードウェア、以下に説明する動作を実行するソフトウェアを格納する読み出し専用メモリ(ROM)、並びに結果を格納するランダムアクセスメモリ(RAM)を含んでもよい。超大規模集積回路(VLSI)ハードウェアの実施形態、並びに汎用DSP回路と組み合わされたカスタムVLSI回路の実施形態が更に提供されてもよい。
種々の実施形態の論理動作は、(1)汎用コンピュータ内のプログラマブル回路上で実行し且つコンピュータにより実現されるステップ、動作又は手順のシーケンス、(2)専用プログラマブル回路上で実行し且つコンピュータにより実現されるステップ、動作又は手順のシーケンス、並びに/あるいは(3)プログラマブル回路内の相互接続されたマシンモジュール又はプログラムエンジンとして実現される。
上述した演算装置は、多くのユーザから導出された類似性データを生成及び使用するのに特に有用である。統計的類似性は、複数のユーザのライブラリにわたる2つ以上の曲の関連の発生率を判定するための数学的解析に基づいて判定される。この類似性データは、特に、高品質のプレイリストを生成すること、購入することをユーザに推薦する提案製品を決定すること、曲を新たに選択してユーザのメディア装置を最新にしておくことを含む種々の有用な機能に対して使用されうる。一例において、ユーザは、広範なユーザがアクセスできるサーバに対して自身のメディアデータベース全体のコンテンツに関連する情報をアップロードしてもよい。全体のユーザのライブラリにおいて2つ以上のメディアアイテムが同時に存在する頻度に基づいて、メディアアイテムは互いに関連し、類似するものとして記録される。この類似性に基づいて、サーバはシードトラックの選択に基づいて1つ以上の類似する曲を含むようにプレイリストを作成できるか、あるいはサーバはユーザのライブラリにない類似する曲の購入を推薦できる。システムのこれらの特徴及び他の特徴について、以下に更に詳細に説明する。説明した技術及び製品の多くの特徴はApple Inc.のITUNES Store等のオンライン音楽ストアを参照して説明するが、その一方でシステムはシステムの好適な実施形態を実行するためにどのようなメディア販売であれ全く必要としないことが理解されるべきである。更に、一部の説明は1つの特定の形態のメディアのみを参照するかもしれないが、本明細書で説明する原理はオーディオ、ビデオ、静止画、文書及び他の種類のデータファイル等のいかなるメディアにも適用可能である。
・サーバ
・アップロード
図2は、類似性データを生成する方法の一実施形態を示す。方法は、プログラム参加者のパーソナルメディア一覧に関連するユーザデータをサーバにより受信すること(202)を含む。ユーザデータは、通常はメタデータの形式であるユーザのライブラリ中の個々のメディアアイテムに関する識別情報を含む。ユーザのライブラリ内のメディアアイテムの発生元は、本システムと関連していない。説明される本方法が音楽コンテンツストアにより採用される場合であっても、本実施形態は、サーバがソースに基づいてファイル情報を区別しないため、すなわち全てのメディアアイテムが同一のものとして処理されるため、ユーザのファイルが音楽ストアに由来することを要求しない。方法は、CD、DVD又はHD−DVD等の物理媒体、並びに物理媒体がデジタル形式にコード変換され且つユーザのメディアライブラリに入力される例に同等に適用される。好適な一実施形態において、サーバは、ユーザがライブラリ中の全てのメディアアイテムに関する情報をアップロードすることを要求せず、限られた数のメディアアイテムのみに関する情報又はメディアアイテムに関する部分情報のみがサーバにより受け入れられる。
・ユーザデータの識別
方法は、ユーザデータを特定のメディアアイテムとして識別すること(203)を含む。このステップは、ファイル名、メタデータを検査すること含む複数の方法のうちのいずれか1つの方法で達成されてもよく、あるいはファイルの一部分の詳細な解析を介して達成されてもよい。音楽トラックの例において、サーバは種々の機構を介して音楽トラックを識別できる。例えば約8分の長さのLed ZepplinのStairway to Heaven等の所定のトラックは、アーティスト、曲名、ジャンル、トラックの長さ、アルバム名、トラック番号等を識別するファイル名又はメタデータを含むファイルと関連付けられた種々のデータを有することができる。このデータの一部分は、サーバがアルバムLed Zepplin IVのLed ZepplinのStairway to Heavenとしてファイルを識別するのに十分である。あるいは、ファイルを識別するために、市販の曲識別サービスが使用可能である。音楽トラックの一部分をサンプリングすることにより又は購入ストアから一意の識別子を認識することにより、あるいは曲のデジタル・フィンガプリントを認識することにより、トラックを識別できる。例えばサーバ又はサービスは、曲がITUNES Storeから購入されたこと及びファイルのメタデータがITUNES Store専用の一意の識別子を含むことを認識できる。サーバはその識別子によりメディアアイテムを識別できる。メディアアイテムを認識する多くの他の可能な方法が既知であり、それらの全ての方法が開示される方法及び構成により含まれることが理解されるべきである。
・関連付け
各メディアアイテムは、ステップ204において一意の識別子と関連付けられ、ステップ205でテーブルに格納される。サーバが以前にその曲に遭遇したことがない場合、サーバはそのトラックに新しい識別子を割り当てる。しかし、殆どのメディアアイテムの場合、識別子は既に割り当てられており、メディアはその識別子と関連付けられることのみが必要である。Stairway to Heavenの例を継続すると、メディアアイテムが1度トラックとして識別されると、サーバはそのトラックに対する一意の識別データをルックアップできる。この処理は、サーバにより受信されたメディアアイテム毎に繰り返される。
サーバは殆どの曲と関連付ける識別子を既に有しているが、場合によっては、メディアアイテムはサーバにとって全く新しいものであるか又は少なくとも全く新しいものとして認識される。そのような場合、サーバは新しい識別子を発行し且つそれをメディアアイテムに割り当てる。例えば、新しいアーティスト又はガレージバンドがサーバにより認識されない場合がある。しかし、サーバはそのアーティストのトラックに対して新しい識別子を発行し、異なるユーザのライブラリで同一のトラックに遭遇した時に以前に発行されたのと同一の識別子をそのトラックに割り当てる。
サーバは、サーバにとって新しいメディアアイテムに対して新しい識別子を供給しない場合がある。例えば、メディアアイテムはユーザのライブラリにおける独自のものである可能性があり、従って、そのアイテムについて同時に存在することはないため、識別子を提供することは何の価値もないかもしれない。従って、システムは全ての新しいアイテムに対して一意の識別子を供給する必要がない。システムは、他のユーザがライブラリにそのメディアアイテムを有する場合、後でそのトラックに対して一意の識別子を供給でき且つそのアイテムに対して類似性データを供給できる。
・マスタ購入マトリクス
ステップ205において、各メディアアイテムはマスタ購入マトリクスに格納される。マスタ購入マトリクスの一例を図4に示す。購入マトリクス402は、テーブル中の一意の各メディアアイテムに対応する列404を含むテーブルである。テーブルがITUNES Store等の音楽コンテンツ販売側によりホストされる実施形態において、購入マトリクスは、ITUNES Storeから購入することが可能な全てのメディアアイテムをまた含むだろう。マスタ購入マトリクス402の行は、一意のユーザ識別番号406と関連付けられる。この識別コードは、システムではなくユーザが知っている可能性がある匿名識別コードによりユーザを表す。従って、マスタ購入マトリクスは、参加する全てのユーザからプログラムサーバにより受信された全てのファイルのレコードを含む。
購入マトリクスが全てのプログラム参加者及び各プログラム参加者のライブラリ中の全てのメディアに対応するため、購入マトリクス402は非常に大きい可能性が高い。例えば、音楽ストアは約225万のユーザを有し且つ500万を上回る曲を有する。そのようなオンラインストアに対する購入マトリクスは約225万行×500万列のテーブル、すなわち1兆1,250億個の個別のセルから成るテーブルになる。ITUNES Storeは、5,000万を超える登録ユーザを有し且つ1,000万を超える曲を含む。そのようなオンラインストアに対する購入マトリクスは、約5,000万行×1,000万列のテーブル、すなわち500兆個の個別のセルから成るテーブルになる。
ユーザのライブラリ中の曲の場合、そのユーザ及びその曲に対応するマトリクス中のセルがマーク付けされる。マーク付けは、ブーリアンのように単純なデータタイプで行われてもよい。1は購入408を示し、0は未購入410を示す。ブーリアン・データタイプが許可するより多くのデータが格納される必要がある場合、他のデータタイプが使用されてもよい。マトリクスが非常に大きくなる可能性があるが、殆どのユーザが自身のライブラリに相対的に少ない曲(500万と比較して)を有するため、マトリクスは非常に密度が低い。各ユーザ行は少ないエントリのみを含むかもしれないが、その一方で、各曲列は数十、数百、数千又はより人気のある曲に対しては数百万個のエントリを含んでもよいが、購入マトリクスの大部分は空である。
マスタ購入マトリクス又はテーブルは、ライブラリへの新しい曲の追加、ファイルメタデータの変更又はファイルの削除等ユーザライブラリの変更に伴って更新を必要とすることが理解されるべきである。購入マトリクスはリアルタイムに更新されてもよく、あるいは後日挿入するためにトランザクションがキューに入れられてもよい。キューに入れるための1つの構成は、毎日午後11:30等、定期的に購入マトリクスにトランザクションを挿入する。キューに入れる別の構成は、ある最小の数のトランザクションの挿入準備が整った場合に購入マトリクスにトランザクションを挿入する。
購入テーブルに対する更新は、全てのメディアアイテムに対してステップ203及び204を繰り返すことを必要としない。既に識別され且つプログラムに基づく識別番号と関連付けられたメディアアイテムは、識別及び関連付けステップを必要としない。これは、ユーザのデータが最初にテーブルに所属されられた時に識別及び関連付けステップが既に実行されたためである。一実施形態において、サーバは、メディアアイテムをその識別データと関連付けると、識別データをメタデータに格納するためにユーザに再度送出できる。将来のサーバとの通信において、サーバは関連した識別データを有するメディアアイテムに対する更新データを受信でき、それによりステップ204を再度行なう必要がなくなる。
いくつかの実施形態において、購入マトリクスは、販売の時間及び日付、メディアの形式、メディアが高精細であるか又は標準品位であるか、トランザクションがギフトであるか又は支払われたものであるか、再生することを許可された装置、等の各トランザクションに関する追加の情報を含むより大きいテーブル又はマトリクスの一部であってもよい。購入マトリクスは、離散的な別個のテーブル群であってもよく、あるいはより大きなテーブル又はマトリクスに完全に統合されてもよい。
更に別の実施形態において、マスタ購入マトリクスは、ユーザのメディア一覧に関するアップロードされた情報を含む必要がない。マスタ購入マトリクスは、購入情報で本質的に構成される。購入情報は、ユーザによりオンラインストアから購入されたアイテムのみであってもよく、あるいは追加の情報を含むことができる。本実施形態において、テーブルは、各ユーザにより購入された全てのアイテムのリストを含むことができる。依然として、マスタ購入マトリクスは、ユーザのメディア一覧のコンテンツに関する類似性データの少なくとも制限された集合を含む可能性が高い。
・協調フィルタリングエンジン
図2に示す方法は、ステップ206においてマスタ購入マトリクス上で協調フィルタリングエンジンを実行して類似性データを生成し、ステップ207において類似性データをマスタ類似性テーブルに格納することを含む。類似性データは、マスタテーブルのいくつかの他のメディアアイテムと同時に存在するメディアアイテムの発生率から導出される。ユーザが同一の2つのメディアアイテムを有する場合、それらのメディアアイテムは同時に発生すると考えられる。複数のユーザのライブラリにおいてそのように同時に発生することは、2つのメディアアイテムが「類似する」ことを示す。2つのメディアアイテムがより頻繁にプログラム参加者のライブラリで同時に発生する程、メディアアイテムはより類似すると考えられる。
協調フィルタリングエンジン308は、マスタ購入テーブルの個々のメディアアイテム間の類似性を計算する。一実施形態において、協調フィルタリングエンジンは、データベース中の曲のペアがプログラム参加者のライブラリで同時に存在する回数を記録するプログラムのように単純である可能性がある。
一実施形態において、協調フィルタリングエンジンは、多次元ベクトル空間において各アイテムをベクトルとして表すことにより2つの異なるメディアアイテム間の類似性を計算できる。次元数は、購入マトリクス306におけるユーザ数と等しい。アイテム間の関連は、ベクトル間の距離を計算することにより行われる。純粋な三角関数又は変更した三角関数(例えば、余弦関数又は正弦関数)は、ベクトル間の距離を計算するために使用される。2つのベクトルが小さな角度を有する場合、それらのベクトルは類似すると考えられ、2つのベクトルが大きな角度を有する場合、それらのベクトルはより低い類似性を有すると考えられる。この処理は、マスタ購入マトリクスの各曲をマスタ購入マトリクスの他の全ての曲と比較することにより実行される。
別の実施形態において、協調フィルタリングエンジンは、同時に存在するデータの発生率以上のものを考慮に入れることができる。例えば、類似性評価において全体の発生率を考慮に入れることができる。例えば曲A及びBは、曲A及びCと同一の頻度で同時に存在するかもしれないが、曲Bが全体的により普及している場合、曲A及びBは曲A及びCより高い類似性スコアを有することができる(すなわち、より類似していると考えられる)。種々の曲の人気を判定する1つの方法は、各曲が全体のデータセットにおいて発生する頻度を測定することである。
同様に、使用のついての入力等の類似性スコアに影響を及ぼす協調フィルタリングエンジンへの他の入力が存在する。例えば、メディアアイテムに与えられた評価、再生数及びスキップ数は全て、メディアアイテム間の類似性を判定する協調フィルタリングエンジンへの入力でありうる。
図3は、各曲をベクトルとして表す概念を示す。図3aにおいて、マスタテーブルにおけるメディアID629に対するベクトルはユーザ2、899、1,343及び2,000のライブラリにおける曲の存在に基づいてマッピングされている。同様に、マスタテーブルにおけるメディアID1,263,999に対して、ベクトルは、ユーザ2、12、444、1,343のライブラリにおける曲の存在に基づいてマッピングされている。これらの2つのベクトル間の角度は、20°であると測定され、約0.939の余弦値を計算する。余弦値は、メディアID629とメディアID1,263,999との間の関連値を表す。図3bは、メディアID629とメディアID15との間の関連を判定するための別の関連計算を表す。この例において、ライブラリにメディアID629及びメディアID15の双方を有するユーザはいないため、これらの2つのベクトル間の余弦値は約−0.707である。スコアが低い程、メディアID629及び15が互いに密接に関連付けられないことを示す。
別の実施形態において、アイテム間の類似性スコアを計算するために、他の関数が使用可能である。例として、類似性スコアは、特定のアイテムにより構成される、アイテムの合計の同時存在回数のパーセント比を考慮に入れる方法で計算される。例えばアイテムAはアイテム1〜5と同時に発生し、アイテムAの合計の同時存在回数はアイテム1〜5との同時存在回数の合計である。例えばアイテムAがアイテム1と2回同時に存在し、アイテム2と2回同時に存在し、アイテム3と2回同時に存在し、アイテム4と10回同時に存在し且つアイテム5と2回同時に存在した場合、アイテムAは合計で18回の同時存在回数を有する。特定のペアによる合計の同時存在回数のパーセント比を学ぶことは有用である。例えばアイテム4は、アイテムAの全ての同時存在回数の約55%であるため、Aの同時存在回数の合計のわずか約11%を表す他のどのアイテムより強くアイテムAと関連付けられる。このデータは、類似性データを判定するために使用される。類似性データを計算する2つの特定の方法が上記で示されるが、2つのアイテム間の類似性を計算する任意の数の他の方法が使用可能であることは理解されるだろう。
上記処理は、全てのアイテムと全ての他のアイテムとの間で定期的に計算される。この処理は、時間が過度にかかる可能性があるため、一般にオフラインで実行される。これは、月に1回、週に1回、1日に1回、又は計算能力が許す頻度で実行される。
・類似性テーブル
図2のステップ207において、協調フィルタリングエンジンによりまとめられた関連データは、マスタ類似性テーブルを生成するために使用される。図5は、マスタ類似性テーブル502に格納されたデータを示す。所定のメディアアイテムに対して、プログラムに由来する識別データ504によりメディアアイテムを特定するエントリがマスタ類似性テーブルに存在する。更に、そのメディアアイテムに類似するか又は関連すると考えられる他の各メディアアイテムがテーブル508に一覧表示される。このように、テーブル502はマスタ購入マトリクス402の各メディアアイテムに類似する全てのメディアのリストを管理する。
アイテムは、メディアアイテムに類似するか又は関連すると考えられるのに十分なスコアを有する場合、マスタ類似性テーブルに含まれる。どの所定のアイテムに対しても、他のアイテムの殆どは全く類似しない。類似性スコアが十分に低い場合、類似性テーブルに含まれない。類似性スコアが十分に低いか又は高いかを判定するための閾値は、動的であっても静的であってもよい。例えば類似性スコアが−1〜1の範囲である場合、閾値は静的に0.5に設定されてもよい。尚、−1は全く類似しないことを示し、1は非常に類似することを示す。閾値は、マスタ購入テーブルの曲の存在回数に基づいて動的に設定されてもよい。例えば、曲の発生が100回未満である場合は閾値0.9であり、曲の発生が5,000回未満である場合は閾値0.7であり、曲の発生が25,000回未満である場合は閾値0.6であり、曲の発生が25,000回以上である場合は閾値0.5である。閾値は、利用可能な記憶容量又は他のどのパラメータに基づいてもよい。
換言すると、マスタ類似性テーブル502は、類似性スコアの全て又は一部を取り入れてもよい。マスタ類似性テーブルがある特定の記憶サイズに適合するように制約される必要がある場合、最適な類似性又は最強の類似性のみが含まれ、残りは除かれる。同様に、十分なプログラム参加者がメディア一覧にアイテムを有さない場合、そのアイテムは除外される。これに対する1つの変形例は、アイテムがマスタ類似性テーブルに含まれるのに適当であるためにはユーザのライブラリにおいて最低限度の回数発生することを要求することである。例えば2つのアイテムが5回以下の同時存在回数を有する場合、すなわち5人以下のユーザが双方のアイテムを有する場合、システムは残りのスコアを計算しない。
別の実施形態において、マスタ類似性テーブルは等価関係を更に格納できる。例えばテーブル502のメディアID17は、1990年に演奏されたLuciano Pavarottiによる「O Sole Mio」に対応してもよい。Enrico Caruso及びMario Lanza等のアーティストによる「O Sole Mio」の複数の演奏がオンラインストアで入手可能であり、等価なメディア506であると考えられる。他の注目すべき種類の等価なメディアは、公式のアルバムトラック、生楽器によるアコースティックトラック、ライブコンサートトラック、他のバンドによるカバートラック及び同一曲の外国語トラックを含む。単一の曲は列挙された全ての形式及びさらなる形式で存在しうる。等価であるかの判定は、手動で実行可能であり、あるいは実際のメディアコンテンツ、メタデータ及び/又は他の入手可能なデータに基づいて自動的に実行可能である。各々に対する等価なメディアIDは、メディアID504と一緒に提示され、それらの各々が同一であると考えられること及びそれらが共にカウントされることを特定する。
マスタ類似性テーブルのIDは、メディアに索引を付けるために購入マトリクス306で使用されるIDと同一であってもよく、あるいは完全に異なる方式に基づいてもよい。2つのIDがそろっていない場合、一方のIDを他方のIDに変換するために変換機能又は参照変換テーブルが提供される。2つのIDの間で共有される共通のID空間は、性能を犠牲にせずに管理することが最も容易で単純である可能性が高い。
・ユーザ類似性テーブル
マスタ類似性テーブルは類似するメディアの集合を含むが、パーソナルメディアライブラリは類似するメディアの集合のより小さいサブセットをほぼ確実に含む。従って、制約された集合、すなわち個別類似性テーブルが生成される。制約は、所定のライブラリにおけるメディアの利用可能性に適応される。制約された集合は、メディアライブラリで見つけられない類似するメディアに対する参照を更に含んでもよい。これは、あるユーザを提案されたメディアの購入のターゲットとするために行われる。共通のメディアの好みを有する他のユーザが提案された購入品を自身のライブラリに既に有するため、そのようにターゲットされた提案された購入品はそのユーザにとって更に魅力的であるだろう。
マスタ類似性テーブル502が計算され且つ所属が行われると、個別類似性テーブル602が生成される。図6は、個別類似性テーブルを示す。個別類似性テーブル602は、個人のメディアライブラリに含まれた各曲に対するメディアID604及びそのメディアIDと関連付けられたメディアを含む。関連付けられたメディア606を中括弧で示す。個別類似性テーブル中の関連付けられたメディアは、アイテムのマスタ類似性テーブルに配置されソートされた類似するアイテム508のリスト全体のサブセットである。どのメディアが個人のメディアライブラリに存在するかに基づいて、サブセットは選択される。換言すると、個人のライブラリ中の曲毎に、個人のライブラリに含まれる類似するメディアのリストが生成される。
個別類似性テーブルは、サーバにおいてサーバにより生成され且つクライアント装置によりダウンロードされるか、あるいはユーザのメディア一覧のアイテムに対する類似性データのみをダウンロードすることによりクライアントにより作成される。類似性テーブルが作成される場所に関係なく、処理は同一である。メディアアイテムは、アイテムのプログラムに由来する類似性識別データによりマスタ類似性テーブルにおいてルックアップされる。次に、システムはそのメディアアイテムに対する類似性データの場所を索引でルックアップできる。システムは、ルックアップ動作の結果に基づいて類似するアイテムを検索できる。これらのアイテムは、ユーザのメディアライブラリのメディアアイテムと更に比較され、ユーザのメディアライブラリに存在するアイテムのみが個別類似性テーブルに格納される。更なる一実施形態において、ある非常に類似するトラックは、個別類似性テーブルに記録され、ユーザに対して購入を提案するために使用されうる。
好適な一実施形態において、ライブラリ毎に少なくとも1つの個別類似性テーブルがサーバにより生成可能である。クライアントは、サーバにライブラリデータを送出でき、サーバは、ライブラリのアイテムを識別でき、そのライブラリのアイテムに関するマスタ類似性テーブルから類似性データを抽出することによりそのライブラリに対する個別類似性テーブルを生成できる。結果として得られた個別類似性テーブルは、プレイリストを生成する際に使用するためにクライアントにダウンロードされる。同一の個別類似性テーブルは、周辺装置に対する個別類似性テーブルを作成するためにクライアントにより使用される。
ユーザは、これらの個別類似性テーブルを使用して、ユーザの母集団全体から導出されたデータにより利益を得る。ユーザは、プレイリストの作成、新しいメディア購入に対する提案及び種々の他の可能性を受信するために類似性データを使用できる。
・協調フィルタリングに影響を及ぼすユーザデータ
プレイリストが類似性データに基づいて生成される実施形態において、ユーザはプレイリスト中の聴きたくない曲をスキップすることによりフィードバックを提供できるか又はシステムはフィードバックを要求できる。あるいは、ユーザはプレイリスト中の聴くことを楽しんだメディアアイテムにポジティブな評価を与えられる。そのようなデータは、クライアント装置からアップロードされ且つサーバにより受信される。フィードバックデータは、マスタ購入インデックス内又は別個のテーブル内等の任意の数の種々の様式で格納される。フィードバックは、ITUNES Store等のオンライン音楽ストアからも導出可能である。本実施形態において、オンラインストア304におけるユーザ活動により、フィードバックデータが生成される。オンラインストアにおけるユーザ活動は、メディアアイテムの購入、メディアアイテムのプレビュー、特定のメディアアイテムタイトルの探索、特定のメディアアイテムアーティストの探索又は特定のメディアアイテムジャンルの探索を含むことができる。フィードバックデータは、アイテム間の関連スコアを変更するために協調フィルタリングエンジンにより使用可能である。
母集団からのフィードバックデータは、削除しない場合には存在する関連を削除しうる。例えば、Simon and Garfunkelによる曲Mrs. Robinsonは、Lemonheads又はFrank Sinatraによる同一曲との強い関連性を受け入れてもよいが、Simon and Garfunkelのバージョンに基づいてプレイリストを生成しようとするユーザは、異なるバージョンを好まない可能性があり、これは異なるジャンルのカバー曲であるからかもしれない。ある期間にわたり、曲のスキップ又はプレイリストからのアイテムの除去等のフィードバックデータは、関連されたアイテムのリストから一方又は双方のカバーバージョンを削除するために使用される。
他の実施形態において、更にユーザフィードバックは、協調フィルタリングエンジンにより使用されるために、最初にサーバにフィードバックを送出せずにクライアント装置上で直接類似性データを変更するために使用されうる。これらの実施形態において、ユーザフィードバックデータは、最初に同期することなく、クライアント装置上の個別類似性テーブルに格納された関係に直接影響を及ぼすことができる。あるいは、類似性テーブルは変更されないが、制約がユーザフィードバックデータに基づいて生成されうる。例えばユーザが類似するアイテムを頻繁にスキップする場合、クライアント自体は、個別類似性テーブルからそのアイテムを除去することによりそのアイテムを類似するものと考えなくなってもよく、あるいはプレイリストアルゴリズムにおける制約等の他の手段により頻繁にスキップされたアイテムの追加がプレイリストに含まれることを防止できる。
・類似性テーブルの更新
時間とともに、アーティストが新しい音楽を作成し、及び新しいアーティストが登場すると、新しいメディアアイテムはオンラインストア及び更にはマスタ購入テーブルに追加される。従って、オンラインストア304の既存のアイテムとオンラインストアの新しく追加されたアイテムとの間の関連性が形成されてもよい。例えばユーザが自身のメディアライブラリに曲Aを有し、その後オンラインストア304で最近紹介された新しく追加された曲Bを購入する場合、曲Aと新しく追加された曲Bとの間の新しい関連性が形成されてもよい。ユーザが新しく追加された曲Bを購入する場合、トランザクションが購入マトリクス306に記録され、更新された購入マトリクス306が生成される。あるいは、曲BはCDからトラックをコピーすることによりユーザのライブラリに追加されていてもよい。そのような状況において、結果は同一でありうる。曲A及び曲Bの双方がユーザのメディアライブラリにある限り、この同時存在は、更新されたマスタ購入マトリクスに記録される。
協調フィルタリングエンジン308は、上述したようにアイテム316の更新されたマスタ類似性テーブルを生成するために、更新済み購入マトリクス306からの情報を使用する。その後、更新済みの個別類似性テーブル322は、更新済みマスタ類似性テーブル316の更新されたアイテムのみを抽出することによりユーザ毎に生成される。あるいは、完全に新しい個別類似性テーブルが、新しいデータに基づいて作成可能である。
・システムの概要
図7は、上述した実施形態を実行できる1つのシステム300の一例を示す。購入マトリクス306は、各ユーザのライブラリの全てのメディアアイテムに関するデータを格納する。協調フィルタリングエンジン308は、他のメディアの各々に対して各メディアアイテムが同時に存在することを、購入マトリクス306のデータを使用して判定する。協調フィルタリングエンジン308は、プログラム参加者の母集団にわたるユーザの好みに従って類似性スコアを調整するために、オブジェクト324及び326に格納されたフィードバックデータをオプションとして使用できる。協調フィルタリングエンジンの出力は、所定のメディアアイテム318に類似すると考えられる全てのメディアアイテム320を格納することによりマスタ類似性テーブルに格納される。類似するメディアアイテム320は、関連性の最も高いアイテムから関連性の最も低いアイテムの順序で提示されるようにソートされる。
オンライン管理ツール304は、クライアント側302及びサーバ側301に対するインタフェースとしての役割を果たす。好適な一実施形態において、オンライン管理ツール304は、オンラインストアと関連付けられる。一実施形態において、オンラインストアは、類似性データを生成する際に協調フィルタリングエンジン308により使用されるデータ310を生成してもよい。しかし、クライアント302は、クライアント302に格納されたメディアアイテムに関する情報をアップロードし且つサーバ301から類似性データをダウンロードするように働く。クライアントに固有の類似性データは、クライアント装置302で個別類似性テーブル322を生成するためにオンライン管理ツール304を使用してマスタ類似性テーブル316から直接ダウンロードされてもよい。あるいは、個別類似性テーブルは、サーバ301により生成され且つクライアント装置302にダウンロードされてもよい。更にクライアント装置は、より適切な類似性データを生成するのを助けるためにオンライン管理ツール304を介して協調フィルタ308にフィードバックデータを通信できる。
・クライアント
図7に示すように、クライアント装置302は、様々な形態のうちいずれか1つの形態をとれる。クライアント装置302は、ポータブルデジタルオーディオプレーヤ、ポータブルデジタルビデオプレーヤ、スマートフォン、デスクトップコンピュータ、ラップトップコンピュータ、テレビセットトップボックス及びメディアを再生できる他の何らかの装置等の装置を含む。クライアント装置は、デスクトップコンピュータ又は他の中間装置を介してオンラインストア304と同期するオフラインポータブル装置、例えばケーブル接続を介してデスクトップコンピュータと同期するIPODデジタルオーディオプレーヤ、無線ルータを介して無線で同期するIPOD TOUCHデジタルオーディプレーヤ又はセルラ接続を介して無線で同期するスマートフォン等を含むことができる。上記説明から明らかであるように、クライアント装置は種々のメディアアイテムの一覧を含む。クライアント装置のユーザが類似性データの使用により利益を得たい場合、ユーザはオンラインインタフェースを介してサービスにアクセスする。あるいは、クライアント装置は、インターネットを介してリモートサーバと通信するITUNESデスクトップアプリケーション等のクライアントアプリケーションを介して類似性データサービスにアクセスできる。
オンラインストア304は、クライアント装置がデジタルメディアを購入できるようにする単一のサーバ又はサーバのクラスタであってもよい。オンラインストアは、他の補助メディア管理機能へのアクセス権を付与してもよい。
図15は、類似性データをクライアントにダウンロードする方法の一実施形態を示す。これがクライアントの初めての協調プログラムへのアクセスである(842)場合、クライアントはプログラムを選択すること(844)により参加することを選択する必要がある。ステップ846において、クライアントは専用ユーザ識別コードを与えられる。サーバはクライアントのライブラリと関連付けるためにこのコードを使用するが、クライアントのみが追加の識別情報を有している。サーバは、クライアント装置又はユーザ(プログラム参加者)に関するパーソナル情報又は識別情報を認識しない。専用識別コードが割り当てられると、クライアント装置は、メディアライブラリに関する情報をアップロードできる(848)。好適な一実施形態において、ユーザはサーバと共有するメディアアイテムを選択してもよい。
ステップ842の結果が、ユーザが既に協調プログラムの参加者であることを示す場合、ステップ850において、クライアントは専用識別コードを使用してサーバにログインできる。ステップ852において、サーバはメディアライブラリに対する変更に関するクライアントからの情報を要求してもよく、あるいはクライアントは最初に要求されることなくこの情報を共有してもよい。ライブラリに対する変更が行なわれた場合、クライアントは変更に関する情報をアップロードする(854)。変更は、編集されたメタデータ、新しいアイテム、削除済みアイテム等の形式をとってもよい。クライアントのメディアライブラリに関する最新情報がサーバに送出されると、ステップ856において、クライアントはサーバから新しい類似性データを要求できる。あるいは、サーバは新しい類似性データ又は更新済み類似性データの送信を開始してもよい。
別の実施形態において、クライアントは、上記ステップをスキップし、ライブラリを特定する必要なくマスタ類似性テーブルから更新済み結果を単純に要求できる。例えばクライアントは、識別番号により自身を特定せず且つクライアントのメディアライブラリ一覧に対する変更をサーバに通知せずに、特定のアイテム又はアイテムのリストに対する更新を要求できる。
ステップ858において、類似性データがダウンロードされる。類似性データはサーバにより先に作成されたテーブルの形式でダウンロードされるか、あるいは、情報はリアルタイムにダウンロードされ且つ個別類似性データテーブルへとフォーマットされる。
プレイリストは、個別類似性テーブルに基づいて生成される。プレイリストは、クライアント側302、オンラインストア304又は協調フィルタリングエンジン308で生成されうる。プレイリストは、1曲又は複数曲に対する統計的類似性に基づいて生成されうる。クライアント装置が個別類似性テーブルに基づくプレイリストを採用する場合、特定の曲は、ユーザが期待した曲ではない可能性があるか又はユーザが満足するものではない可能性がある。ユーザが統計的類似性に基づいてプレイリストに入れられた曲を頻繁にスキップする場合、システムはその曲に「ペナルティを科し」、類似性値を減少し、より少ない頻度でプレイリストに含め、最終的にプレイリストから完全に放棄できる。これは、ユーザが曲をスキップした時に報告することにより実現される。その動作は、クライアント装置に記録され、オンラインストアにフィードバックとして送信される。オンラインストアは、このフィードバックを協調フィルタリングエンジンに送出し、協調フィルタリングエンジンは、それをネガティブ関連テーブル326に格納する。ネガティブ関連テーブルは、類似性のネガティブ指標を格納する。このように、各ユーザは、曲が類似性テーブルから除かれるまで個別に何度も曲をスキップする必要がない。累積したネガティブフィードバックは、グループの挙動に基づいてユーザグループに人気のない曲を除去する。従って、これらのプレイリストはユーザの母集団の変化するメディアの好みに適合するように進化する生物のように動作する。
例えば、多くのユーザがプレイリストの特定の曲を常にスキップする場合、あるいは多くのユーザがプレイリストからその曲を削除する場合、その情報は記録され、マスタ類似性テーブルの生成に影響を及ぼすように重みを割り当てられる。重みは、報告されたネガティブ関連の数又はユーザ対話の他の態様に基づいてもよい。逆に、特定の曲に対する肯定的なユーザ対話はポジティブ関連を提供する。例えば、多くのユーザが既存のプレイリストに同一の曲を追加する場合、あるいは多くのユーザが特定の曲中に音量を上げた場合、これらのポジティブ関連はオンラインインタフェースを介してサーバに報告され、ポジティブ関連テーブルに格納される。
クライアントは、サーバとの対話に加えて他のクライアント又は周辺装置と対話してもよい。好適な一実施形態において、クライアントは、IPODポータブル音楽プレーヤ等のポータブル音楽プレーヤと対話するパーソナルコンピュータであってもよい。そのような例において、クライアント装置は周辺装置において使用する個別類似性テーブルを準備できる。サーバがクライアントのライブラリのメディアアイテムのみに対する情報を含む個別類似性テーブルをクライアントに対して準備できるのと同様に、クライアントは周辺装置のライブラリのメディアアイテムのみに対する情報を含む周辺装置に対して個別類似性テーブルを準備できる。クライアントは、他の任意データアイテムをロードするように、個別類似性テーブルを周辺装置にロードできる。
・周辺装置
クライアントがサーバを使用して動作するのと同様に、周辺装置はクライアントを使用して動作しようとする。例えば周辺装置は、コンテンツに対する変更をクライアントに通知し、それらのコンテンツに対する類似性データを要求できる。更に好適な一実施形態において、ITUNESデスクトップアプリケーションを実行するパーソナルコンピュータがIPODポータブルメディア装置を管理するのと同様に、周辺装置はクライアントにより管理される。本実施形態において、一般にクライアントは、周辺装置のコンテンツに対する変更に影響を及ぼすツールであることによりそれらの変更を既に認識しているため、それらの変更により更新される必要はない。本実施形態において、クライアントは、クライアントの個別類似性テーブルにおける利用可能なデータに基づいて周辺装置の類似性テーブルを最新状態に維持できる。更に周辺装置は、後でサーバに送信するためにフィードバックデータをクライアントに通信できる。
更に別の実施形態において、周辺装置は、クライアント装置自体としてサーバと直接対話できる。益々多くのポータブルメディアプレーヤがインターネットにアクセスする機能を有するため、ポータブル装置は、最新の類似性データをダウンロードするため又はマスタ購入マトリクスを更新するためにサーバと直接対話できる。そのような一実施形態において、周辺装置は、クライアントの全ての機能を有することができる。
・プレイリストの生成
上述したように、本明細書で説明された方法により生成された類似性データの1つの用途は、プレイリストを生成するために類似性データを使用することである。プレイリストを生成することが、個別類似性テーブルの全ての類似するアイテムを再生することと同じくらい単純でありうる一方で、最適な結果はプレイリスト生成モジュールを使用して取得される可能性が高い。図8は、プレイリストを生成する方法の一実施形態を示す。1つ以上のシードトラックが、ステップ802において選択され、ステップ804においてプレイリストに追加される。ステップ806において、シードトラックに対する類似性データが個別類似性テーブルにおいてルックアップされ、ステップ808において、類似するトラックが候補リストに追加される。候補は、プレイリストに追加される可能性があるトラックのリストである。候補がプレイリストに追加されるかは、一連の制約について候補を評価することにより判定される。
制約は、曲がプレイリストに追加されるかに関して制限する。殆どの場合、制約はプレイリストの品質を向上させる。1つの制約は、プレイリストにおいて特定の間隔を要求してもよい。例えば、アーティスト間隔制約が有効である場合、Radioheadによる2曲は連続して再生されない。同様の一例において、制約は、同一のアルバム又は曲のタイトルの曲がプレイリストにおいて互いの所定の曲数内で発生しないようにしてもよい。別の制約は、互いに相容れないジャンルの曲が同一のプレイリストにおいて再生されないようにする。更に別の制約は「ジッタ」機能であってもよい。ジッタは、受け入れ可能である曲がプレイリストに追加されることをランダムに防止できる。ジッタは、同一のシードトラックの選択に基づいて同一のプレイリストが毎回生成されるのを防止するためにプレイリストにランダム性を提供する。更に別の制約はスキップ回数制約であってもよく、この場合所定の回数を超えてスキップされたどの曲も制約を満たさずプレイリストに含まれない。
制約は、容易に変動する特定のパラメータ又は変数に依存することが理解されるべきである。例えば同一アルバム又はアーティストの2つの曲の間に入ることが要求される曲数は変動する可能性がある。同様に、トラックを除外するのに必要なスキップ回数又は互いに相容れるジャンルのメンバは変動する可能性がある。一実施形態において、そのような変数の設定はユーザにより設定される。別の実施形態において、そのような設定は、サーバにより選択され且つサーバから発行され、クライアントが更新済み類似性データをダウンロードするために接続する度にサーバにより調整されてもよい。
ポジティブ制約も考慮されることが理解されるべきである。高い再生率又は高い評価を有する曲は、プレイリストに移動されるか、あるいはジッタ機能又は他のネガティブ制約の影響を受けない。更に多くの制約を加え、制約を除去し、制約をより厳しくするか又は緩和することにより多くの変形例が可能である。各変形例は、本明細書で説明される方法により意図されている。
ステップ810において、考慮される次の候補が選択され、ステップ812において、そのメタデータが検索される。メタデータは、制約を評価する際に必要とされる候補に関する情報を提供する。ステップ814、815及び816において、トラックは制約により評価される。図8において3つの制約のみが示されるが、任意の数の可能な制約が存在してもよいことが意図されている。ステップ818において全ての制約を満たすまで、曲が1つの制約を満たした場合、次の制約に渡され、そしてトラックはプレイリストに追加される。その後、ステップ820に進み、プレイリストの新しい曲に対する類似性データを取り出す。この類似性データは、プレイリストに含めるかを考慮するために候補リストに付加される。
トラックが制約を満たさない場合、ステップ830に飛び、評価する追加の候補がリストにある場合はステップ810に戻る。しかし、追加の候補がリストにない場合、全ての候補が制約を満たさないか又はプレイリストにあることを意味し、ステップ832は、制約がデフォルト値に設定されているかを判定するために制約をチェックする。デフォルト値に設定されている場合、1つ以上の制約を緩和することにより、先に拒否された候補がステップ826において再度考慮された際にプレイリストに追加されることが許可されることを期待して、ステップ828において制約が緩和される。全ての候補が再度制約を満たさない場合、ステップ832は、制約が既に緩和されていたと判定し、処理を終了する。
制約を緩和することは、種々の形態のうちいずれか1つの形態をとれる。いくつかの例において、1つの制約のみが緩和される。他の例において、複数の制約が緩和される。例えば第1の制約が、同一アーティストの2曲が互いの4曲以内に再生されないことを要求する場合、制約は、間に1曲のみ入ることを要求するように緩和されるか又は制約は完全に除去される。いくつかの実施形態において、全ての制約が緩和されるわけではない。一例はジャンルの制約である。特定のジャンルは互いに全く相容れない場合があるため、ジャンルの制約は追加のジャンルを含むようには緩和されないだろう。
ステップ826に戻ると、候補トラックが制約を満たさず且つ追加の候補が入手可能でない場合において、制約は緩和される。緩和された制約のために、候補が全ての制約を満たしてプレイリストに追加される場合、ステップ822及び824において制約は標準に戻される。ステップ822は、制約が緩和されるか又はデフォルト設定になっているかを判定するために制約をチェックする。制約がデフォルト設定になっている場合、ステップ810に戻り、リスト中の次のトラックを考慮する。しかし、制約が緩和されているとステップ822が判定する場合、ステップ824に進み、制約を標準に戻し、ステップ810に戻り、リスト中の次の候補を考慮する。この処理は、候補が緩和された制約を満たさなくなるまで継続し、ルーチンはステップ834で終了する。
曲は、最も類似するものから最も類似しないものの順番でプレイリストに追加される必要はない。曲はランダム化アルゴリズム又は他のロジックを使用してどんな順序で追加されてもよい。
生成されたプレイリストは、静的であっても動的であってもよい。動的なプレイリストは、類似性データが進化し且つ新しいアイテムがユーザのライブラリに追加されるのに伴い時間とともに更新される。あるいは、ユーザが楽しみ且つユーザは変更せずに保持したいプレイリストが生成される場合、ユーザは類似性データに影響を受けない別個の静的なプレイリストとしてそのプレイリストを保存できる。このように、生成された特定のプレイリストが「完璧」であるとユーザが感じている場合、そのプレイリストは、サーバを介して類似性テーブルにおいて反映された一般大衆の変化する好みにより損なわれずに維持される。
・装置を同期させるための類似性データの使用
プレイリストが生成可能であるのと同様に、類似性データは、ポータブル音楽プレーヤ等の周辺装置をユーザのメディアライブラリの新しい音楽又は異なる音楽により更新するために使用可能である。多くのポータブルメディアプレーヤは、制限された容量の影響を受けるため、ユーザのメディアライブラリの全てがIPODポータブルメディアプレーヤ等のポータブル装置に格納できるわけではない。そのような例において、多くの場合、ユーザはポータブル装置に格納するメディアアイテムの一部分を選択する必要がある。一部のユーザは、この処理を煩わしいと考え、またユーザは、ポータブル装置に現在格納されているメディアアイテムに退屈していることに気付くかもしれない。
上記で示された問題に対する1つの解決策は、ポータブル装置が新しいメディアアイテムで更新されるように類似性データを使用することである。本実施形態において、ユーザはポータブル装置に保持したい音楽の種類を表す特定の数のシードトラックを選択する。プレイリストがシードトラックから生成可能であるのと同様に、ユーザのライブラリのデータアイテムもポータブルメディアプレーヤに含むために選択可能である。類似性データが変更され、新しい曲がユーザのライブラリに追加されると、類似性データはポータブル装置を新しいトラックにより最新の状態に維持するために使用される。
・購入の推薦
類似性データは、ユーザが購入する新しいアイテムを推薦するために使用されうる。マスタ類似性テーブルに存在するがユーザのライブラリに存在しないアイテムは、システムによって購入することを推薦される。一実施形態において、オンラインストアはユーザのライブラリ又はシードトラックの選択に基づいて購入の推薦を行える。オンラインストアは、最近の購入品をシードトラックとして使用しながら購入するアイテムを推薦できる。別の実施形態において、プレイリストモジュールは、曲がユーザのライブラリの一部であったとしたらプレイリストのどこに含まれるであろうかをユーザに通知することにより、購入する曲を推薦できる。購入の推薦は、サーバからクライアント、そしてポータブルメディアプレーヤまでのシステムのどのレベルでも行える。
いくつかの実施形態において、推薦されるアイテムは、関連付けられた類似性データをまだ有していない新しいアイテムであってもよい。そのような例において、類似性スコアは、新しいアイテムがユーザにより購入されることを推薦されるようにオンラインストアの管理者により提供されうる。提供された類似性スコアは、同時存在又は他の実施形態に基づく類似性データが入手可能になるまで存続可能である。
同様に、映画のレンタル又は購入が推薦されうる。殆どの実施形態が曲に関して説明されたが、メディアアイテムはビデオ又は映画を含むいかなるファイルであってもよい。本実施形態において、ユーザはシードアイテムの選択に基づいて類似する映画を要求できる。あるいは、システムは以前のレンタルに基づいて映画を推薦できる。類似性データは、ユーザが後で見るために新しい映画をクライアント又はポータブルメディアプレーヤに自動的にダウンロードするために使用できることが意図される。本実施形態は課金サービスの一部であってもよく、あるいはユーザは映画を見ないことを選択してレンタル料が発生しないようにできる。
図16は、類似性データが購入するメディアアイテムを推薦するために使用される方法の一実施形態を示す。ステップ1002において、シードトラックが選択される。プレイリストがシードトラックに基づいて生成されるのと同様に、購入の推薦はシードトラックに基づく。しかし、少なくとも1つの実施形態において、購入の推薦は、ユーザのライブラリ全体に最も類似するコンテンツに基づいてもよい。
シードトラックが選択されると、ステップ1004において、図示された方法は次に個別類似性テーブルからそのシードトラックに対する類似性データをルックアップする。本実施形態において、個別類似性テーブルは、ユーザのライブラリにないが類似性データによりユーザのメディアライブラリに存在するアイテムと関連付けられるメディアアイテムを更に含むことが理解されるだろう。別の実施形態において、購入の推薦は、ローカルに格納された類似性テーブルではなくサーバから直接行われる。マスタ類似性テーブルからの類似性リストは類似性データを提供でき、サーバ又はクライアントはユーザのライブラリから識別されたトラックを除くことができる。購入の推薦が含まれる必要はなく、全てのユーザが推薦目的のためのマスタテーブルを共有するため、本実施形態は、最小でありうる個別類似性テーブルを生成するという利点を有する。
既にユーザのライブラリにあるアイテムが購入されることを推薦されないようにするために、ステップ1006は、ステップ1004で検索された類似性データからユーザのメディアライブラリに既に存在するアイテムを除去する。場合によっては、メディアアイテムはユーザにより既に購入されているが、それらのアイテムはユーザのメディアライブラリに存在しない。これは、任意の数の理由のためである。例えば、ユーザがその曲を好きではなく削除したためであり、ユーザがメディアアイテムを別のライブラリに格納したためであり、あるいはユーザがメディアアイテムを購入したがまだダウンロードしていないためである。少なくともこれらの例において、これらのメディアアイテムを購入することを推薦することは望ましくなく、これらのメディアアイテムもステップ1008において除去される。ステップ1010は、購入するように推薦されたアイテムを表示する。
当然、方法はユーザにより現在選択されている全ての曲に対して繰り返される。いくつかの実施形態において、ユーザは、購入の推薦を断定的に要求する必要はない。そのような実施形態において、購入の推薦は、メディアアイテムが再生のために選択される度にメディアオーガナイザ又はメディアストア内に表示される。メディアアイテムが再生されると、グラフィカルユーザインタフェースは、購入するように推薦された他のメディアアイテム又はアルバム等のメディアアイテムのグループを表示できる。好適な一実施形態において、メディアアイテムは入力装置を使用して推薦自体を選択することにより直接購入可能であり、あるいは、メディアアイテムがオンラインストアから購入可能であるように、推薦はオンラインストアにハイパーリンクすることが少なくとも可能である。
別の実施形態において、購入の推薦は、選択が可能でない方法を使用して示される。例えばリスナーが指定した購入済みのアーティストによる上位の曲を表示するView An Artistページにおいて、システムは既にユーザのライブラリに存在するアイテムの推薦を除去するようにフィルタリングされた推薦を表示できる。
・サーバ>クライアント>IPOD
特に好適な一実施形態において、1つの場所で有用な方法はシステムの各場所で同等に適用可能である。図9はこの概念を示す。類似性テーブル908及びプレイリストモジュール914を含むオンライン音楽ストア902が示される。類似性テーブル908は、サーバのメディア一覧のアイテムのそれぞれについての全ての関係を含む。プレイリストモジュール914は、システムの他のどのクライアント又はポータブルメディアプレーヤとも同様に、類似性テーブルのデータに基づいて動作する。同様に、サーバより小さいメディア一覧を含むクライアント904が示され、クライアントのメディア一覧の各アイテムの類似性データは類似性テーブル910に格納される。プレイリストモジュール916は、ポータブルメディアプレーヤ906又は音楽ストア902と同様にローカルの類似性テーブル910のデータに基づいて動作する。最後に、クライアント904より小さいメディア一覧を含むポータブルメディアプレーヤ906を示す。類似性テーブル912はポータブルメディアプレーヤ906のメディア一覧のアイテムに関連した情報を格納し、プレイリストモジュール918はそのデータに基づいて動作する。
図9は、クライアントがポータブルメディアプレーヤのグループに対してサーバのように挙動でき又はより大きいクライアントがより小さいクライアントに対してサーバとして挙動できるという概念を示す。これらの全ては本明細書で意図される。
殆どの実施形態において、サーバはマスタ購入マトリクス及びマスタ類似性テーブルを維持する唯一の場所であるが、ローカルの類似性テーブルの生成はサーバから導出されたデータに基づいてどの装置においても行える。サーバにより行われる可能性が高い別の機能は更新である。殆どの実施形態において、サーバは類似性データ更新のソースであるだけでなく、サーバはシステムのプレイリストモジュール又はソフトウェア構成要素を更新できる。
本明細書で説明した全ての処理がリアルタイムで行われる必要はないことが理解されるだろう。多くの場合、処理リソースを節約し且つ特定のタスクをオフラインで実行するのが望ましい。例えば協調フィルタリングエンジンは、マスタ類似性データテーブルを生成するためにスケジュールされた時間にのみ実行してもよい。オフライン処理の必要性は、技術の進歩によりなくなる可能性があることが更に考えられる。そのような例において、現在オフラインで実行されるのが好ましい処理はリアルタイムで実行できるだろう。
別の実施形態において、各装置は特定の機能をローカルで実行できるにもかかわらず、特定のタスクをサーバに実行させるのが望ましいかもしれない。例えばサーバは、クライアントに対する個別類似性テーブルを生成できるか、あるいはクライアントに対するプレイリストを生成できる。これは、大きな処理のために望まれる処理リソースが一般に不足しているポータブルメディアプレーヤに対するそれらのタスクをクライアントが実行するために多用されてもよい。別の例において、サーバがプレイリストの生成の際に使用されるいくつかの制約を実行し且つ結果を類似性テーブルデータに取り入れることは有利であるかもしれない。例えば緩和されることがないであろうジャンル制約の場合、サーバはアイテムの類似性データから互いに相容れないジャンルのメディアアイテムを除外してもよい。このように、サーバが制約を満たさないアイテムを個別類似性テーブルから既に除外しているであろうから、プレイリストモジュールはプレイリストを生成する時に制約を実行する必要はない。
図10は、メディア及び類似性テーブルをデジタルメディアプレーヤに同期させるシステムの一例を示す。通信媒体920は、インターネットである可能性が最も高いが、装置が互いに通信できるようにするいかなるチャネルも含むことができる。オンラインストア922は、オンラインストアと通信及び対話するためにインストールされた特別なソフトウェアを使用して一般にパーソナルコンピュータであるクライアント924と通信する。AppleのIPODメディアプレーヤ等のポータブルメディアプレーヤ926は、一般に30ピンUSBコネクタを介して、オンラインストア922に接続されたパーソナルコンピュータ924と同期する。ポータブルメディアプレーヤ926をパーソナルコンピュータ924に接続する他の方法は、USB、Firewire、802.11シリーズ又はBluetooth無線接続を含む。オンラインストアは、メディア930のマスタライブラリ及びマスタ類似性テーブル932を有する。ポータブルメディアプレーヤ926が同期されると、ローカルメディア934のメタデータ及びローカルのサブセット類似性テーブル936はパーソナルコンピュータ924及び通信媒体920を介してオンラインストア922に送信される。尚、メタデータのみが送信され、実際のメディアが送信されないことに留意することが重要である。オンラインストアは、メディアのコピーを必要とせず、ポータブルメディアプレーヤ926に配置されるメディアを明確に識別するのに十分な情報のみを必要とする。オンラインストアは、適切な情報を生成及び/又は検索し、その情報を装置に送出し返すことができ、それにより、ローカルに格納されたメディア934に対応する新しいデータによりローカルのサブセット類似性テーブル936を更新する。ローカルのサブセット類似性テーブルは、オンラインストアレベル、コンピュータレベル及び/又は装置自体において個々のプレイリストを生成するために使用される。
別の実施形態において、ポータブルメディアプレーヤ926はサーバ922からデータを直接取得できる。そのような一実施形態において、ポータブルメディアプレーヤは、802.11シリーズの通信(Wi−Fi)又は移動電話網等を介してオンラインストアに接続するための種々の機能を備えることができる。ポータブルメディアプレーヤは、サーバに直接接続でき、クライアント装置が上記例において動作するように動作できる。ポータブルメディアは、一意の識別番号を割り当てられるか、あるいはライブラリがクライアント装置と関連付けられる場合はポータブルメディアプレーヤはクライアント装置と同一の識別番号を使用できる。とにかく、ポータブルメディアプレーヤは、ライブラリに格納されたメディアアイテムに関する情報をアップロードし且つ同一のアイテムに関する類似性データをダウンロードできる。ポータブルメディアプレーヤは、サーバに接続する方法を2つ以上有することができることが理解されるべきである。ポータブルメディアプレーヤは、オンラインストアに接続する機構を複数有することができるだけでなく、クライアント装置と同期し且つオンラインストアと直接通信する機能も有することができる。
・ユーザインタフェース−概要
図11は、プレイリストの生成を開始するためのソフトウェアインタフェースの一例を示す。ソフトウェアインタフェース702は、メディアを再生し、メディア及びメディアプレイリストを管理し、オンラインストアからメディアを購入することを可能にし、他のメディア関連機能を実行するアプリケーションについて描かれている。ソフトウェアインタフェース702は、メディアのリスト704及び一部又は全ての関連メタデータを表示できる。オンラインストアを介して受信した個別類似性テーブルを使用してプレイリストを生成するために、ユーザは、1つ以上のメディアを選択して、ボタンをクリックするか、あるいは選択したシードトラックに基づいてプレイリストを生成するコマンドをコンピュータに与える。考えられる適切なユーザインタフェースは、キーボードにおけるキーシーケンス、マウスジェスチャ、タッチによる入力、音声コマンド、あるいはこれらのヒューマンコンピュータインタフェース及び他の適切なヒューマンコンピュータインタフェースのいずれかの組み合わせ等の形を含む。ソフトウェアアプリケーションは、開始されると、選択したメディアシードトラックに対する類似性テーブルを検索し、類似性テーブルに基づいてプレイリストを生成する。アプリケーションは、プレイリストのコンテンツをユーザに対して表示してもしなくてもよい。アプリケーションは、現在再生しているトラック、あるいは直前のメディア、現在再生しているメディア及び次のキューに入れられたメディア等のプレイリストコンテンツの他のサブセットのみを表示してもよい。
図11に示した陰影をつけたエントリ等の2曲以上がプレイリストを生成するために選択される場合、プレイリストは、2つのエントリのそれぞれの個別の類似性データを単に組み合わせることにより生成される。あるいは、その2つをマージするためにより高度なアルゴリズムが使用されてもよい。例えば、選択した曲の間で共通のメディアにより高い重要度を割り当て、選択した双方の曲に類似しないと考えられる曲により低い重要度を割り当てるか又はそれらの曲を削除する。プレイリストを生成するために複数の選択した曲を処理する時のアプリケーションの挙動及び/又はアルゴリズムは、ユーザにより制御されるか又はアプリケーション内で事前に設定される。
プレイリストがリフレッシュされるか又は再作成される実施形態において、生成されたプレイリストの各々を時間順に1つずつ実行する戻る/進む機能性が提供される。例えば、ユーザがプレイリストを作成し且つ別のプレイリストを作成する場合、ユーザは、ブラウザの戻るボタン及び進むボタンのように、コンテンツ及び順番を含む先のプレイリストに戻ることができ、その後新しく作成したプレイリストに戻ることができる。
プレイリストは、いかなる曲も選択せずに作成できる。ユーザは、「Choose For Me」タイプボタン706を単純に選択でき、その結果、システムはユーザに対してシードトラックを選択する。一実施形態において、シードトラックは無作為に選択されてもよい。別の実施形態において、システムは、最近再生されたアイテムのリスト、再生回数が最高のアイテムのリスト、最高の評価をされたアイテム、最近追加又は購入されたアイテム、ジャンル、あるいはアイテムを選択するのに使用された他のあらゆる属性からトラックを選択できる。シードトラックの選択方法に関係なく、プレイリストは類似性データに基づいて作成される。
・ユーザインタフェース−IPOD/IPHONE/IPOD TOUCH
図12は、ユーザの視点で類似性データからプレイリストを作成する方法を示す。図12は、2つの可能な開始点720及び731を示す。ユーザは、ステップ720においてプレイリストモジュールに対してシードトラックとなるメディアアイテムを選択できるか、あるいはユーザが現在聴いているアイテムに基づいてプレイリストを作成することを決定できる(731)。ユーザは、メニューが表示される(724)ようにするコマンドを入力する(722)。コマンドは、ボタン、タッチスクリーン又はポインタ等のあらゆるユーザインタフェースオブジェクトにより入力可能である。メニューが表示されると、ステップ726において、ユーザはプレイリストジェネレータオプション727(図13Aを参照)を選択するためにカーソルをナビゲートし、それを選択する。ステップ728において確認画面が示され、ユーザが確認すると、ステップ730においてプレイリストが生成される。
図13A及び図13Bは、プレイリスト生成プログラムを開始する2つの異なるコンテキストメニューを示す。ユーザがメディアアイテム(例えば、曲のリスト中の1曲又は現在再生している画面)に関して中央のボタン723を長押しした場合、コンテキストメニューが表示される。コンテキストメニューは、特にプレイリストジェネレータ(Playlist Generator)開始コマンドを含むことができる。ユーザは、プレイリストジェネレータ項目を強調表示するためにスクロールホイール719を使用して時計回り又は反時計回りに指を動かすことによりナビゲートし、強調表示された領域を選択するために中央のボタン723を押下してもよい。
図13Cは、ユーザがコンテキストメニューにおいてプレイリストジェネレータプログラムを選択した場合又はユーザが例えばメディア再生中に所定の回数だけ中央のボタン723を押下した場合に表示される画面を示す。この画面は、スクロールホイール入力719が矢印729を開始場所に移動させるのを待つことによりプレイリストジェネレータがユーザにより起動されることを要求する。ユーザは、メニューボタンを押下することによりプログラムから抜けられる。
図13Dはプレイリストの一例を示す。エネルギーシンボル325は、プレイリストが生成された時のシード(トラック)を表す。リフレッシュ(Refresh)327は、シードに基づいて新しいプレイリストを作成する。プレイリスト保存(Save Playlist)329は、プレイリストを保存し、プレイリストは(メニュー構造の最上層の)ミュージックの下のプレイリストサブメニューから検索されるか又は(メニュー構造の最上層において)プレイリストジェネレータプログラムを選択することにより検索される。
図14は、プレイリストジェネレータを使用するための別のインタフェースを示す。図14Aは、プレイリストジェネレータモジュールがタッチスクリーンを使用して選択されるプレイリストメニューを示す。ユーザは、メニュー項目を指でタップすることにより又はメニュー項目上で指を動かしてタッチスクリーンから指を離すことによりプレイリストジェネレータプログラム(又は他のいずれかのメニュー項目)を選択できる。
図14Bは、プレイリストモジュールがプレイリストを作成する際のメディアアイテムをユーザが選択できるシードトラック選択画面を示す。ユーザは、指のタッチを用いてスクロールすることによりメディアアイテムのリストをナビゲートできる。ユーザは、上下の指をスイープする動作を使用してアルファベットの昇順又は降順にリストをスクロールできる。あるいは、ユーザは、アルファベットのリストの所望の部分に対応する文字を選択することによりそのリストのその部分に飛べる。
曲「Abram」に基づいて生成されたサンプルプレイリストを図14Cに示す。図14Dは、再生されているプレイリストの第1のトラックを示す。図14Cに戻ると、リフレッシュ(Refresh)ボタン740は、類似性テーブルの新しいデータから新しいプレイリストを作成するために使用される。図14Eは、リフレッシュされたプレイリストの再生を示す。
図14Fは、リフレッシュされたリストを静的プレイリストとして保存するために選択される保存(Save)ボタン742を示す。保存されたプレイリストは、図14Gのプレイリストメニューで見られる。保存したプレイリストであっても編集できる。サンプルプレイリスト編集画面を図14Hに示す。他の実施形態において、例えばユーザが現在のシードトラックのプレイリストを終了し、現在再生しているトラックに基づいて新しいプレイリストを作成したい場合、プレイリスト内の曲がシートトラックとして選択できる。
別の実施形態において、曲が購入されることができ、プレイリストはクライアント装置を制御するリモートを使用して作成されることができる。
・ユーザインタフェース−ITUNES
図17A及び図17Bは、ユーザ選択ページの2つの可能な実現例を示す。ユーザ選択画面は、パーソナル音楽ライブラリに関するデータがサービスに送出されることをユーザに通知し、ユーザが参加ボタン1026をクリックすることによりプログラムに参加することを要求する。ユーザは、ボタン1027を選択することによりこのオプションを拒否できる。
図17Bに示したグラフィカルユーザインタフェースは、プレイリスト生成プログラムを開始できる選択可能な項目1020及び1024を示す。選択可能な項目1022は、メディアアイテム推薦機能を開始できる。好適な一実施形態において、項目1022は、購入することを推薦するアイテムをユーザに提示するグラフィカルユーザインタフェース内でフレーム1025を開ける。
図18は、ユーザのメディアライブラリに関する情報をアップロードし且つローカルメディアライブラリのコンテンツに対する類似性データを受信する間に表示される1つのありうるグラフィカルユーザインタフェースを一般的に示す。図18Aは、図18Bに示す画面が表示されている間にサーバに送信されるユーザのメディアライブラリに関する情報のプログラムが収集している間に示される1つのありうる画面を示す。図18Cは、このクライアント装置についての個別類似性テーブルに格納される情報をダウンロードしている間に示される1つのありうる画面を示す。図18Dは、ユーザが本明細書で説明されるプレイリスト生成処理及びメディア推薦処理を現在使用できることを示す処理完了画面を示す。ユーザは、情報を収集、アップロード及びダウンロードしている間にこれらの画面を閲覧する必要はない。少なくとも1つの好適な実施形態において、ユーザはこの処理中にグラフィカルユーザインタフェースの他の機能を使用し続けられる。
・ユーザインタフェース−ITUNES/サイドバー
図19は、類似性データに基づいて購入することを推薦するメディアアイテムを表示する1つのグラフィカルユーザインタフェースを一般的に示す。図19Aを参照すると、図はより大きいグラフィカルユーザインタフェースに組み込まれるか又はスタンドアロンインタフェースでありうるグラフィカルユーザインタフェース1038を示す。インタフェース1038内にアルバムに関する類似性データが示される。この例において、White Stripes Albumの曲が選択され、インタフェース1038はこのメディアアイテムに対する類似性データを表示する。モジュール1040は、購入の推薦の1つの形式を含む。モジュール1040内の項目は、同一アーティストによるアルバムを表し、これは指定されたメディアアイテムを含むアルバムを含む。いくつかの実施形態において、このインタフェースでアルバムを選択することにより、アルバムの全てのトラックを表示するリストに拡大する。推薦されたアルバムは、まだダウンロードできない可能性があるが、リリース前に購入されうる。ユーザがライブラリ又は購入履歴にアルバムの全ての曲を既に有している場合、そのアルバムは、最も関連するアルバムであっても表示されないことが重要である。しかし、ユーザがアルバムの一部の曲のみを所有している場合、アルバムは既に所有している曲が表された状態で示されうる。インタフェース1038は、ユーザのライブラリ又は購入履歴に存在しないメディアアイテムのみを表示する。
モジュール1042は、ユーザのメディアライブラリ又は購入履歴に存在しない同一アーティストの曲を表示する。モジュール1044は、選択される曲に対する類似性データに基づいてメディアアイテムを推薦する。いくつかの曲に対して、システムは関連する推薦を提供できないが、そのような状況においてはユーザの聴き方及び購入の仕方に適応され且つユーザが既に有しているものについてはフィルタリングされている、更に広範な推薦がユーザに与えられうることが理解される。
各モジュール1040、1042及び1044は、任意の数のアイテムを含むことができ、図に表された数である必要はない。いくつかの例において、インタフェースが1度に表示できる数より多くの推薦が得られてもよい。そのような一例において、インタフェースは追加の推薦されたアイテムを閲覧するためのスクロールバー又はリンクを含むことができる。
個別の各メディアアイテムは、アイコン1041を選択することによりプレビューされうる。このアイコンを選択することにより、ユーザは推薦された個々のメディアアイテムを好きであるか否かを判断するためにそのメディアアイテムをプレビューできる。いくつかの実施形態において、アイコン1041は、アイテムがプレビュー可能であることをより適切に示すために再生ボタンに変更されてもよい。ユーザがメディアアイテムを購入したい場合、ユーザはアイコン1043を選択でき、それによりユーザは選択したアイテムを購入及び取得できる。アイテムが購入されると、購入を示すアイコン又は他の手段が表示される。別の実施形態において、アイテムが購入されると、そのアイテムはさらなる推薦のためのシードトラックとなることができる。
図19Bは、インタフェース1038についての別のレイアウトを示す。このレイアウトにおいては、ボックス1040及び1044のみが表示される。インタフェースにおいてさらなる利用可能な空間をとるために、追加のメディアアイテムは推薦ボックス1044に追加された。少なくとも1つの実施形態において、空の無駄な空間を有することはユーザを苛立たせる可能性があるため、全ての利用可能な空間を推薦で満たすのが望ましい。
図19Cは、選択されたメディアアイテムに対して入手可能な類似性データが存在しない一実施形態を示す。本実施形態において、ボックス1048は、マッチングするものがないことをユーザに指示し、選択したメディアアイテムと同一又は同様のジャンルの上位のアルバムを推薦するためにモジュール1043及び1046を使用する。
図19Dは、入手可能な類似性データが存在せず且つ入手可能なジャンル情報がない(又はジャンルに基づく推薦がない)一実施形態を示す。ここでも、選択したメディアアイテムに対してマッチングするものが返されなかったことをユーザに通知するメッセージがボックス1048に表示される。モジュール1045は、選択したメディアアイテムに類似する上位のメディアアイテムを表示できる。モジュール1046は、オンラインストアの上位のアルバムを表示できる。
更に図19Eは、ユーザがプログラムに参加していないため又はサーバが類似性データを発行するのに利用可能でないために入手可能な推薦が存在しない一実施形態を示す。マッチングするものがないことを示すメッセージはモジュール1048に表示される。モジュール1050は、類似性データの代わりにシードトラックと同一アーティストによる他の曲及びアルバムを表示できる。本実施形態において、ユーザのメディアライブラリにあるアイテムが表示されてもよい。モジュール1052は、ストア購入情報から導出されたストアアイテムを表示する。
図19Fは、推薦が利用可能でなく且つそれを示すメッセージがモジュール1048に表示される一実施形態を示す。インタフェースは、推薦の代わりにオンラインストアのトップセールスチャートをモジュール1054及び1046に示す。
本発明の範囲内の実施形態は、コンピュータ実行可能命令又はデータ構造を保持するか又は格納するコンピュータ可読媒体を更に含んでもよい。そのようなコンピュータ可読媒体は、汎用コンピュータ又は専用コンピュータによりアクセスされる利用可能などんな媒体であってもよい。例として、そのようなコンピュータ可読媒体は、RAM、ROM、EEPROM、CD−ROM又は他の光ディスク記憶装置、磁気ディスク記憶装置又は他の磁気記憶装置、あるいはコンピュータ実行可能命令又はデータ構造の形式で所望のプログラムコード手段を保持又は格納するために使用可能な他のいかなる媒体も含むことができるが、これらに限定されない。情報がネットワーク又は別の通信接続(ハードワイヤード、無線又はそれらの組み合わせ)を介してコンピュータに転送又は提供される場合、コンピュータは接続をコンピュータ可読媒体として正しく考える。従って、そのようないかなる接続も正しくコンピュータ可読媒体と呼ばれる。上記の組合せもコンピュータ可読媒体の範囲内に含まれるべきである。
例えばコンピュータ実行可能命令は、汎用コンピュータ、専用コンピュータ又は専用処理装置に特定の機能又は機能群を実行させる命令及びデータを含む。コンピュータ実行可能命令は、スタンドアロン又はネットワーク環境でコンピュータにより実行されるプログラムモジュールを更に含む。一般にプログラムモジュールは、特定のタスクを実行するか又は特定の抽象データタイプを実現するルーチン、プログラム、オブジェクト、構成要素及びデータ構造を含む。コンピュータ実行可能命令、関連するデータ構造及びプログラムモジュールは、本明細書で開示された方法のステップを実行するためのプログラムコード手段の例である。そのような実行可能命令又は関連するデータ構造の特定のシーケンスは、そのようなステップで説明された機能を実現するための対応する動作の例である。
本発明の他の実施形態は、パーソナルコンピュータ、ハンドヘルド装置、マルチプロセッサシステム、マイクロプロセッサを使用する消費者電子機器、プログラマブル消費者電子機器、ネットワークPC、ミニコンピュータ及びメインフレームコンピュータ等を含む多くの種類のコンピュータシステム構成を有するネットワークコンピューティング環境で実現されてもよいことが当業者には理解されるだろう。実施形態は、通信ネットワークを介してリンクされる(有線リンク、無線リンク又はそれらの組合せにより)ローカル処理装置及びリモート処理装置によりタスクが実行される分散コンピューティング環境で実現されてもよい。分散コンピューティング環境において、プログラムモジュールは、ローカルメモリ記憶装置及びリモートメモリ記憶装置の双方に配置されてもよい。
説明したシステムの種々の段階における通信は、ローカルエリアネットワーク、トークンリングネットワーク、インターネット、企業イントラネット、802.11シリーズ無線信号、光ファイバネットワーク、無線又はマイクロ波伝送等のネットワーククラウド328を介して実行されうる。基礎となる通信技術が変更されてもよいが、本明細書で説明した基本的な原理は依然として適用可能である。
上述した種々の実施形態は、例として提供され、本発明を限定するものとして解釈されるべきではない。例えば本明細書の原理は、ポータブルメディア再生装置又はネットワークに物理的に接続されたパーソナルコンピュータにより無線でアクセスできるオンラインストアに適用されてもよい。本明細書で図示して説明した実施形態の例及び応用例に従わないが、本発明の趣旨の範囲からは逸脱しない、本発明に対して行われうる種々の変形及び変更を、当業者は容易に認識できるだろう。
本願は、全てが2008年9月30日に出願された米国特許出願シリアル番号12/242,728、12/242,735、12/242,758、及び12/242,768の優先権を主張し、2008年9月8日に出願された"SYSTEM AND METHOD FOR PLAYLIST GENERATION BASED ON SIMILARITY DATA(類似性データに基づくプレイリスト生成システム及び方法)"と題するUS仮特許出願番号61/095,289の利益を主張し、これらの全ては参照によりその全体が明白に本明細書に組み込まれる。

Claims (18)

  1. メディアプレイリストの生成を促進するために、コンピュータによって実行される、プログラム参加者のメディアライブラリ内のメディアアイテムの相対的な類似性を確立する方法であって、
    サーバの通信インタフェースが、複数のプログラム参加者から、それぞれの参加者のメディアライブラリに現在含まれているそれぞれの個別メディアアイテムの識別データを含み、それぞれのプログラム参加者のメディアライブラリ一覧を示すデータを受信する工程と、
    サーバのプロセッサを用いて、異なるプログラム参加者のメディアライブラリ間で、個別メディアアイテムのペアが同時に存在していることを判定する工程と、
    前記サーバのプロセッサを用いて、前記異なるプログラム参加者のメディアライブラリにおいて同時に存在していることの前記判定に基づいて、前記個別メディアアイテムのペア間の類似性評価を割り当てる工程と、
    前記サーバのプロセッサを用いて、プログラム参加者のメディアライブラリに含まれる複数の個別メディアアイテムについての、当該プログラム参加者のメディアライブラリに含まれる他のメディアアイテムに対する類似性評価を、前記割り当てられた類似性評価に基づいてまとめる工程と、
    前記サーバの通信インタフェースを用いて、プログラム参加者のメディアライブラリに含まれる複数の個別メディアアイテムについての類似性評価を含むデータを、当該プログラム参加者のデバイスへと送信する工程であって、これによって当該データからの類似するメディアライブラリ・アイテムのプレイリストの前記生成を促進する工程と、
    を備えることを特徴とする方法。
  2. 前記プログラム参加者のメディアライブラリに含まれる複数の個別メディアアイテムについての前記類似性評価はそれぞれが、前記プログラム参加者のメディアライブラリ内のシード・メディアアイテムに類似する、前記プログラム参加者のメディアライブラリ内のメディアアイテムのリストの形をとことを特徴とする、請求項に記載の方法。
  3. プログラム参加者の母集団から収集される累積データは、前記類似性評価がまとめられるオンラインメディア供給ソースによって収集されることを特徴とする、請求項に記載の方法。
  4. 前記オンラインメディア供給ソースは、前記プログラム参加者が各音楽トラックを購入したオンライン音楽ストアであることを特徴とする、請求項に記載の方法。
  5. 前記サーバのプロセッサが、各識別データの解析に基づいて前記参加者のメディアライブラリに含まれる個別メディアアイテムに対してプログラムに由来する識別子を割り当てる工程であって、これによって異なる参加者の前記メディアライブラリに含まれる実質的に同一のメディアアイテム同士を直接に関係付けることを可能とする工程をさらに含むことを特徴とする、請求項に記載の方法。
  6. 前記サーバの通信インタフェースが、前記プログラム参加者のメディアライブラリ一覧に現在含まれている指定されたメディアアイテムに類似するものとして評価されている購入推薦メディアアイテムに基づいて選択された、少なくとも1つの購入推薦メディアアイテムの指定を、前記プログラム参加者のデバイスへと送信する工程をさらに備え、
    前記評価は、他の参加者のメディアライブラリにおいて前記購入推薦メディアアイテムが前記指定されたメディアアイテムと同時に存在する頻度を示すことを特徴とする、請求項1に記載の方法。
  7. メディアプレイリストを生成するシステムであって、
    それぞれのプログラム参加者の個別メディアアイテムのメディアライブラリをそれぞれが含むストレージ・メディア・デバイスを、それぞれ有する少なくとも2つのクライアントデバイスと、
    複数のプログラム参加者のクライアントデバイスから受信したデータを格納する手段と、
    複数のプログラム参加者のクライアントデバイスから受信したデータを格納する前記手段から代表データを受信する類似性データ生成プログラムを実行する手段と、
    前記クライアントデバイスとデータ処理センターとの間で通信する手段と、を備え、
    前記代表データは、複数のプログラム参加者の各メディアライブラリ一覧に由来し、かつ個別メディアアイテムのソースに関係なく前記各参加者のメディアライブラリに現在含まれている個別メディアライブラリ・アイテムの識別データを含み、
    前記通信する手段は、前記個別メディアアイテムのソースに関係なく前記メディアライブラリ内の前記個別メディアアイテムを表す識別データを前記クライアントデバイスから送信し、前記クライアントデバイスへ類似性評価データを送信する
    ことを特徴とするシステム。
  8. 少なくとも1つの前記クライアントデバイス上の前記ストレージ・メディアは、前記各クライアントデバイス上に格納される個別メディアアイテムを特定するデータと、前記アイテムの少なくともいくつかを、同一の前記各クライアントデバイス上に格納されている他の個別メディアアイテムのサブセットに類似しているものとして関連付けるデータと、を備える類似性テーブルをさらに格納していることを特徴とする、請求項に記載のシステム。
  9. 選択されたシードトラックに類似するものとして特定されたメディアアイテムが所属しているプレイリストを、クライアントデバイス上に生成する手段をさらに備えることを特徴とする、請求項に記載のシステム。
  10. ストレージ・メディア・デバイスと信号を通信するプロセッサを備えるメディアプレイリスト生成デバイスであって、
    前記ストレージ・メディア・デバイスは、複数のプログラム参加者から収集された累積データに基づいてまとめられたメディアアイテム類似性評価に関する類似性データを格納し、
    前記累積データは、それぞれの個別メディアアイテムのソースに関係なく、前記プログラム参加者の前記メディアライブラリに含まれる個別メディアアイテムの識別データを含み、
    前記プロセッサは、前記ストレージ・メディア・デバイスから類似性評価データを受信し、前記類似性評価データにおいて特定された前記メディアアイテムから選択された候補メディアアイテムからプレイリストを生成するプレイリスト生成プログラムを少なくとも実行するように構成されている
    ことを特徴とするデバイス。
  11. 前記ストレージ・メディア・デバイスは、格納された個別メディアアイテムをさらに含むことを特徴とする、請求項10に記載のデバイス。
  12. 前記類似性データは、各プログラム参加者のメディアライブラリ内の前記個別メディアアイテムに関する類似性データに限られることを特徴とする、請求項10に記載のデバイス。
  13. ストレージ・メディア・デバイスに格納された複数の個別メディアアイテムについての前記類似性データはそれぞれが、前記ストレージ・メディア・デバイス上のシード・メディアアイテムに類似する、前記ストレージ・メディア・デバイス上のメディアアイテムのリストの形をとることを特徴とする、請求項11に記載のデバイス。
  14. 前記類似性評価の前記まとめは、異なるプログラム参加者のメディアライブラリにおいて個別メディアアイテムのペアが同時に存在していることを判定するために前記累積データを処理することと、前記異なるプログラム参加者のメディアライブラリにおいて同時に存在していることの前記判定に基づいて、個別メディアアイテムの前記ペア間に類似性評価を割り当てることと、を含むことを特徴とする、請求項10に記載のデバイス。
  15. 前記プロセッサは、前記プログラム参加者のメディアライブラリに含まれ、前記参加者のメディアライブラリから選択されたシード・メディアアイテムに対する類似性評価を有する個別メディアアイテムのみからなるメディアプレイリストを生成するようにさらに構成されていることを特徴とする、請求項12に記載のデバイス。
  16. 前記プロセッサは、前記プログラム参加者のメディアライブラリに含まれ、前記プログラム参加者のメディアライブラリから選択されるシード・メディアアイテムに対して類似性評価を有する個別メディアアイテムを含むメディアプレイリストを生成するようにさらに構成されていることを特徴とする、請求項12に記載のデバイス。
  17. 前記メディアプレイリストは前記メディアプレイリスト生成デバイス上で生成され、前記デバイスは可搬パーソナルメディア再生デバイス又はパーソナルコンピュータの形をとることを特徴とする、請求項10に記載のデバイス。
  18. 前記プログラム参加者の前記メディアライブラリ一覧に現在含まれている指定メディアアイテムに類似しているものとして評価された購入推薦メディアアイテムに基づいて選択された、少なくとも1つの購入推薦メディアアイテムの指定を、前記サーバから受信するように構成された通信インタフェースをさらに備え、
    前記評価は、他の参加者のメディアライブラリにおいて、前記指定メディアアイテムと前記購入推薦メディアアイテムとが同時に存在する頻度を表す
    ことを特徴とする、請求項12に記載のデバイス。
JP2011526131A 2008-09-08 2009-09-01 類似性データに基づいてプレイリストを生成するシステム及び方法 Active JP5232304B2 (ja)

Applications Claiming Priority (11)

Application Number Priority Date Filing Date Title
US9528908P 2008-09-08 2008-09-08
US61/095,289 2008-09-08
US12/242,735 US8966394B2 (en) 2008-09-08 2008-09-30 System and method for playlist generation based on similarity data
US12/242,758 US8914384B2 (en) 2008-09-08 2008-09-30 System and method for playlist generation based on similarity data
US12/242,768 2008-09-30
US12/242,728 2008-09-30
US12/242,768 US8601003B2 (en) 2008-09-08 2008-09-30 System and method for playlist generation based on similarity data
US12/242,735 2008-09-30
US12/242,728 US9496003B2 (en) 2008-09-08 2008-09-30 System and method for playlist generation based on similarity data
US12/242,758 2008-09-30
PCT/US2009/055589 WO2010027961A1 (en) 2008-09-08 2009-09-01 System and method for playlist generation based on similarity data

Publications (2)

Publication Number Publication Date
JP2012502361A JP2012502361A (ja) 2012-01-26
JP5232304B2 true JP5232304B2 (ja) 2013-07-10

Family

ID=42008364

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2011526131A Active JP5232304B2 (ja) 2008-09-08 2009-09-01 類似性データに基づいてプレイリストを生成するシステム及び方法

Country Status (6)

Country Link
US (4) US8601003B2 (ja)
EP (1) EP2662789A3 (ja)
JP (1) JP5232304B2 (ja)
KR (1) KR101318015B1 (ja)
CN (2) CN102187338B (ja)
AU (1) AU2009288147B2 (ja)

Families Citing this family (142)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8686272B2 (en) * 2002-10-03 2014-04-01 Polyphonic Human Media Interface, S.L. Method and system for music recommendation based on immunology
US11106425B2 (en) 2003-07-28 2021-08-31 Sonos, Inc. Synchronizing operations among a plurality of independently clocked digital data processing devices
US8234395B2 (en) 2003-07-28 2012-07-31 Sonos, Inc. System and method for synchronizing operations among a plurality of independently clocked digital data processing devices
US8290603B1 (en) 2004-06-05 2012-10-16 Sonos, Inc. User interfaces for controlling and manipulating groupings in a multi-zone media system
US11294618B2 (en) 2003-07-28 2022-04-05 Sonos, Inc. Media player system
US11106424B2 (en) 2003-07-28 2021-08-31 Sonos, Inc. Synchronizing operations among a plurality of independently clocked digital data processing devices
US11650784B2 (en) 2003-07-28 2023-05-16 Sonos, Inc. Adjusting volume levels
US8086752B2 (en) 2006-11-22 2011-12-27 Sonos, Inc. Systems and methods for synchronizing operations among a plurality of independently clocked digital data processing devices that independently source digital data
US9207905B2 (en) 2003-07-28 2015-12-08 Sonos, Inc. Method and apparatus for providing synchrony group status information
EP2317449A3 (en) * 2004-01-16 2011-07-13 Hillcrest Laboratories, Inc. Metadata brokering server and methods
US9374607B2 (en) 2012-06-26 2016-06-21 Sonos, Inc. Media playback system with guest access
US9977561B2 (en) 2004-04-01 2018-05-22 Sonos, Inc. Systems, methods, apparatus, and articles of manufacture to provide guest access
US8868698B2 (en) 2004-06-05 2014-10-21 Sonos, Inc. Establishing a secure wireless network with minimum human intervention
US8326951B1 (en) 2004-06-05 2012-12-04 Sonos, Inc. Establishing a secure wireless network with minimum human intervention
US9552141B2 (en) 2004-06-21 2017-01-24 Apple Inc. Methods and apparatuses for operating a data processing system
US7669121B2 (en) * 2005-01-19 2010-02-23 Microsoft Corporation Transcode matrix
US8612483B2 (en) 2006-05-31 2013-12-17 Red Hat, Inc. Link swarming in an open overlay for social networks and online services
US8615550B2 (en) 2006-05-31 2013-12-24 Red Hat, Inc. Client-side data scraping for open overlay for social networks and online services
US7792903B2 (en) 2006-05-31 2010-09-07 Red Hat, Inc. Identity management for open overlay for social networks and online services
US9165282B2 (en) * 2006-05-31 2015-10-20 Red Hat, Inc. Shared playlist management for open overlay for social networks and online services
US8688742B2 (en) 2006-05-31 2014-04-01 Red Hat, Inc. Open overlay for social networks and online services
US8483853B1 (en) 2006-09-12 2013-07-09 Sonos, Inc. Controlling and manipulating groupings in a multi-zone media system
US8788080B1 (en) 2006-09-12 2014-07-22 Sonos, Inc. Multi-channel pairing in a media system
US9202509B2 (en) 2006-09-12 2015-12-01 Sonos, Inc. Controlling and grouping in a multi-zone media system
US8984442B2 (en) 2006-11-17 2015-03-17 Apple Inc. Method and system for upgrading a previously purchased media asset
US20080172614A1 (en) * 2007-01-08 2008-07-17 Varia Mobil Llc Action-based menus for a portable media device
WO2009073741A1 (en) * 2007-12-03 2009-06-11 Pearl Enterprises Llc System and method for music and compatibility matching
EP2304597A4 (en) * 2008-05-31 2012-10-31 Apple Inc ADAPTIVE RECOMMENDATION DEVICE TECHNOLOGY
US20100153846A1 (en) * 2008-12-17 2010-06-17 Qnx Software Systems Gmbh & Co. Kg Playlist management system
US20100198823A1 (en) * 2009-02-05 2010-08-05 Tsoukalas Kathleen J Systems and methods to automatically generate enhanced information associated with a selected web table
US20100205222A1 (en) * 2009-02-10 2010-08-12 Tom Gajdos Music profiling
US8234572B2 (en) * 2009-03-10 2012-07-31 Apple Inc. Remote access to advanced playlist features of a media player
JP5171718B2 (ja) * 2009-03-31 2013-03-27 株式会社東芝 コンテンツ推薦装置、方法、及びプログラム
CN101867800A (zh) * 2009-04-15 2010-10-20 华为技术有限公司 节目推荐方法、终端设备及网络系统
US8473367B2 (en) * 2009-05-11 2013-06-25 Rahul U. Shah Computer based media access method and system
US10108934B2 (en) * 2009-07-10 2018-10-23 Microsoft Technology Licensing, Llc Items selection via automatic generalization
US8225206B2 (en) * 2010-02-22 2012-07-17 Robert Bosch Gmbh User preference based collecting of music content
US20110225496A1 (en) * 2010-03-12 2011-09-15 Peter Jeffe Suggested playlist
US20120023403A1 (en) * 2010-07-21 2012-01-26 Tilman Herberger System and method for dynamic generation of individualized playlists according to user selection of musical features
US8990727B2 (en) * 2010-07-21 2015-03-24 Sybase, Inc. Fisheye-based presentation of information for mobile devices
US8868564B1 (en) * 2010-08-15 2014-10-21 John W. Ogilvie Analytic comparison of libraries and playlists
US8826134B2 (en) * 2010-09-10 2014-09-02 Sony Computer Entertainment America Llc Pivot command for playlist
US11265652B2 (en) 2011-01-25 2022-03-01 Sonos, Inc. Playback device pairing
US11429343B2 (en) 2011-01-25 2022-08-30 Sonos, Inc. Stereo playback configuration and control
US8468164B1 (en) * 2011-03-09 2013-06-18 Amazon Technologies, Inc. Personalized recommendations based on related users
US20130080968A1 (en) * 2011-09-27 2013-03-28 Amazon Technologies Inc. User interface with media content prediction
US9817986B1 (en) 2011-11-09 2017-11-14 Amazon Technologies, Inc. Discovering availability of digital media from multiple sources
US9576050B1 (en) * 2011-12-07 2017-02-21 Google Inc. Generating a playlist based on input acoustic information
US8868481B2 (en) * 2011-12-14 2014-10-21 Google Inc. Video recommendation based on video co-occurrence statistics
US9460390B1 (en) * 2011-12-21 2016-10-04 Emc Corporation Analyzing device similarity
US9654821B2 (en) 2011-12-30 2017-05-16 Sonos, Inc. Systems and methods for networked music playback
US9603033B2 (en) * 2011-12-31 2017-03-21 International Business Machines Corporation Online and distributed optimization framework for wireless analytics
CN103327400B (zh) * 2012-03-22 2016-08-31 鸿富锦精密工业(深圳)有限公司 用户端设备及其创建社交视频频道的方法
US8762324B2 (en) * 2012-03-23 2014-06-24 Sap Ag Multi-dimensional query expansion employing semantics and usage statistics
US9659093B1 (en) * 2012-04-02 2017-05-23 Google Inc. Adaptive recommendations of user-generated mediasets
US9729115B2 (en) 2012-04-27 2017-08-08 Sonos, Inc. Intelligently increasing the sound level of player
US8908879B2 (en) 2012-05-23 2014-12-09 Sonos, Inc. Audio content auditioning
US9927952B2 (en) * 2012-05-23 2018-03-27 Microsoft Technology Licensing, Llc Utilizing a ribbon to access an application user interface
WO2013184018A1 (en) * 2012-06-07 2013-12-12 Google Inc. User curated collections for an online application environment
US9674587B2 (en) 2012-06-26 2017-06-06 Sonos, Inc. Systems and methods for networked music playback including remote add to queue
US9225307B2 (en) 2012-06-28 2015-12-29 Sonos, Inc. Modification of audio responsive to proximity detection
US9501477B2 (en) 2012-08-21 2016-11-22 Roovy, Inc. Global media lists for mobile devices
US9189802B2 (en) * 2012-08-23 2015-11-17 Seoul National University R&Db Foundation Method for contents recommendation
US20140074783A1 (en) * 2012-09-09 2014-03-13 Apple Inc. Synchronizing metadata across devices
US9397844B2 (en) 2012-09-11 2016-07-19 Apple Inc. Automated graphical user-interface layout
US9218118B2 (en) 2012-09-11 2015-12-22 Apple Inc. Media player playlist management
US9558278B2 (en) * 2012-09-11 2017-01-31 Apple Inc. Integrated content recommendation
US9008330B2 (en) 2012-09-28 2015-04-14 Sonos, Inc. Crossover frequency adjustments for audio speakers
US10215434B2 (en) 2012-11-07 2019-02-26 Think Automatic, LLC Adaptive trigger sequencing for site control automation
KR102017746B1 (ko) * 2012-11-14 2019-09-04 한국전자통신연구원 유사도 산출 방법 및 그 장치
US20140188920A1 (en) * 2012-12-27 2014-07-03 Sangita Sharma Systems and methods for customized content
US9886166B2 (en) * 2012-12-29 2018-02-06 Nokia Technologies Oy Method and apparatus for generating audio information
US9031954B1 (en) 2012-12-31 2015-05-12 Google Inc. Methods, system, and media for recommending media content
US20140229828A1 (en) * 2013-02-11 2014-08-14 Google Inc. Creating playlists
US20140249906A1 (en) * 2013-03-01 2014-09-04 Apple Inc. Media item collection pre-order fulfillment
US20140280239A1 (en) * 2013-03-15 2014-09-18 Sas Institute Inc. Similarity determination between anonymized data items
US10540385B2 (en) * 2013-03-15 2020-01-21 Spotify Ab Taste profile attributes
US9501533B2 (en) 2013-04-16 2016-11-22 Sonos, Inc. Private queue for a media playback system
US9361371B2 (en) 2013-04-16 2016-06-07 Sonos, Inc. Playlist update in a media playback system
US9247363B2 (en) 2013-04-16 2016-01-26 Sonos, Inc. Playback queue transfer in a media playback system
US9495076B2 (en) 2013-05-29 2016-11-15 Sonos, Inc. Playlist modification
US9798510B2 (en) 2013-05-29 2017-10-24 Sonos, Inc. Connected state indicator
US9735978B2 (en) 2013-05-29 2017-08-15 Sonos, Inc. Playback queue control via a playlist on a mobile device
US9953179B2 (en) 2013-05-29 2018-04-24 Sonos, Inc. Private queue indicator
US9684484B2 (en) 2013-05-29 2017-06-20 Sonos, Inc. Playback zone silent connect
US9703521B2 (en) 2013-05-29 2017-07-11 Sonos, Inc. Moving a playback queue to a new zone
US10715973B2 (en) 2013-05-29 2020-07-14 Sonos, Inc. Playback queue control transition
US9298415B2 (en) 2013-07-09 2016-03-29 Sonos, Inc. Systems and methods to provide play/pause content
US20150039644A1 (en) * 2013-08-05 2015-02-05 Aliphcom System and method for personalized recommendation and optimization of playlists and the presentation of content
JP6475744B2 (ja) * 2013-10-21 2019-02-27 アマゾン テクノロジーズ インコーポレイテッド メディアコンテンツ管理
US20150161270A1 (en) * 2013-12-05 2015-06-11 Sony Corporation Computer ecosystem identifying surprising but relevant content using abstract visualization of user profiles
US10108619B2 (en) * 2013-12-19 2018-10-23 Gracenote, Inc. Station library creaton for a media service
US10015251B2 (en) * 2014-01-31 2018-07-03 Nbcuniversal Media, Llc Fingerprint-defined segment-based content delivery
US9226087B2 (en) 2014-02-06 2015-12-29 Sonos, Inc. Audio output balancing during synchronized playback
US9226073B2 (en) 2014-02-06 2015-12-29 Sonos, Inc. Audio output balancing during synchronized playback
US20150301718A1 (en) * 2014-04-18 2015-10-22 Google Inc. Methods, systems, and media for presenting music items relating to media content
CN111782129B (zh) * 2014-06-24 2023-12-08 苹果公司 用于在用户界面中导航的列界面
US9942612B2 (en) * 2014-08-29 2018-04-10 Nxp Usa, Inc. Television receiver, television set, and method for updating program schedule information in a television receiver
CN104408051B (zh) * 2014-10-28 2019-04-09 广州酷狗计算机科技有限公司 歌曲推荐方法及装置
KR101637282B1 (ko) * 2014-12-09 2016-07-07 현대자동차 주식회사 음악 플레이리스트 생성방법, 및 음악 플레이리스트 생성장치
US10083232B1 (en) * 2014-12-15 2018-09-25 Amazon Technologies, Inc. Weighting user feedback events based on device context
US9891880B2 (en) 2015-03-31 2018-02-13 Sonos, Inc. Information display regarding playback queue subscriptions
US10248376B2 (en) 2015-06-11 2019-04-02 Sonos, Inc. Multiple groupings in a playback system
CN105138370A (zh) * 2015-08-25 2015-12-09 百度在线网络技术(北京)有限公司 一种刷新播放列表的方法及装置
US10546016B1 (en) 2015-11-06 2020-01-28 Gracenote, Inc. Audiovisual content curation system
US10394884B1 (en) 2015-11-16 2019-08-27 Pandora Media, Llc Selecting media for a social event according to specified event parameters
US9798823B2 (en) 2015-11-17 2017-10-24 Spotify Ab System, methods and computer products for determining affinity to a content creator
US9589237B1 (en) 2015-11-17 2017-03-07 Spotify Ab Systems, methods and computer products for recommending media suitable for a designated activity
US10866705B2 (en) * 2015-12-03 2020-12-15 Clarifai, Inc. Systems and methods for updating recommendations on a user interface in real-time based on user selection of recommendations provided via the user interface
US10097632B2 (en) * 2016-01-08 2018-10-09 International Business Machines Corporation Proximity based playlist merging
US10832303B2 (en) * 2016-03-11 2020-11-10 Ebay Inc. Removal of listings based on similarity
CN107193832A (zh) * 2016-03-15 2017-09-22 北京京东尚科信息技术有限公司 相似度挖掘方法及装置
EP3433858A1 (en) * 2016-03-25 2019-01-30 Tristan Jehan Transitions between media content items
CN106095949A (zh) * 2016-06-14 2016-11-09 东北师范大学 一种基于混合推荐的数字化图书馆资源个性化推荐方法与系统
US10515292B2 (en) * 2016-06-15 2019-12-24 Massachusetts Institute Of Technology Joint acoustic and visual processing
WO2017221408A1 (ja) * 2016-06-24 2017-12-28 ヤマハ株式会社 配信先指定装置、配信先指定方法及び配信先指定プログラム
CN107564553B (zh) * 2016-06-30 2020-07-03 上海博泰悦臻网络技术服务有限公司 一种音频播放列表的控制方法、系统及一种音频播放系统
US10860646B2 (en) 2016-08-18 2020-12-08 Spotify Ab Systems, methods, and computer-readable products for track selection
US10601953B2 (en) * 2016-09-22 2020-03-24 Adobe Inc. Decomposing media content accounts for persona-based experience individualization
US10712997B2 (en) 2016-10-17 2020-07-14 Sonos, Inc. Room association based on name
US11086936B2 (en) * 2016-12-30 2021-08-10 Spotify Ab Media content item recommendation system
US9992523B1 (en) * 2017-01-05 2018-06-05 Hulu, LLC Selecting recommendations in a video delivery system using diversity and relevance
CN107229696A (zh) * 2017-05-23 2017-10-03 维沃移动通信有限公司 一种查找相似歌曲的方法及移动终端
US11328010B2 (en) * 2017-05-25 2022-05-10 Microsoft Technology Licensing, Llc Song similarity determination
US10803120B1 (en) * 2017-05-31 2020-10-13 Snap Inc. Geolocation based playlists
US10545720B2 (en) 2017-09-29 2020-01-28 Spotify Ab Automatically generated media preview
CN110309405B (zh) * 2018-03-08 2022-09-30 腾讯科技(深圳)有限公司 一种项目推荐方法、装置及存储介质
JP7409628B2 (ja) * 2018-04-05 2024-01-09 株式会社サウスポイント 結婚式における音楽選曲のための自動選曲システム
US11853306B2 (en) 2018-06-03 2023-12-26 Apple Inc. Techniques for personalizing app store recommendations
CN110610393A (zh) * 2018-06-15 2019-12-24 阿里巴巴集团控股有限公司 一种信息推荐的方法和装置
CN109036417B (zh) * 2018-07-03 2020-06-23 百度在线网络技术(北京)有限公司 用于处理语音请求的方法和装置
CN109754316B (zh) * 2018-12-29 2022-07-29 深圳Tcl新技术有限公司 产品推荐方法、产品推荐系统及存储介质
US11605117B1 (en) * 2019-04-18 2023-03-14 Amazon Technologies, Inc. Personalized media recommendation system
US11799930B2 (en) 2019-06-25 2023-10-24 Spotify Ab Providing related content using a proxy media content item
US20200413134A1 (en) * 2019-06-27 2020-12-31 Nanning Fugui Precision Industrial Co., Ltd. System and method for effective advertising on a client device
CN110377784A (zh) * 2019-07-24 2019-10-25 广州酷狗计算机科技有限公司 歌单更新方法、装置、终端及存储介质
US11500923B2 (en) * 2019-07-29 2022-11-15 Meta Platforms, Inc. Systems and methods for generating interactive music charts
US11361021B2 (en) 2019-08-01 2022-06-14 Meta Platform, Inc. Systems and methods for music related interactions and interfaces
CN112528070A (zh) * 2019-09-17 2021-03-19 惠州迪芬尼声学科技股份有限公司 播放音乐的方法及具有播放音乐功能的计算机
CN112035758A (zh) 2020-08-31 2020-12-04 北京字节跳动网络技术有限公司 音乐推送方法、装置、电子设备以及存储介质
CN112256233A (zh) * 2020-10-22 2021-01-22 北京字节跳动网络技术有限公司 音乐播放方法及装置
CN113672807B (zh) * 2021-08-05 2024-03-05 杭州网易云音乐科技有限公司 推荐方法、装置、介质、装置和计算设备

Family Cites Families (210)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH0789363B2 (ja) 1983-05-25 1995-09-27 株式会社東芝 文字認識装置
US4996642A (en) * 1987-10-01 1991-02-26 Neonics, Inc. System and method for recommending items
US6345288B1 (en) 1989-08-31 2002-02-05 Onename Corporation Computer-based communication system and method using metadata defining a control-structure
US5355302A (en) 1990-06-15 1994-10-11 Arachnid, Inc. System for managing a plurality of computer jukeboxes
US5375235A (en) 1991-11-05 1994-12-20 Northern Telecom Limited Method of indexing keywords for searching in a database recorded on an information recording medium
US5469206A (en) 1992-05-27 1995-11-21 Philips Electronics North America Corporation System and method for automatically correlating user preferences with electronic shopping information
US5464946A (en) 1993-02-11 1995-11-07 Multimedia Systems Corporation System and apparatus for interactive multimedia entertainment
US5583763A (en) 1993-09-09 1996-12-10 Mni Interactive Method and apparatus for recommending selections based on preferences in a multi-user system
US5724521A (en) 1994-11-03 1998-03-03 Intel Corporation Method and apparatus for providing electronic advertisements to end users in a consumer best-fit pricing manner
US5758257A (en) 1994-11-29 1998-05-26 Herz; Frederick System and method for scheduling broadcast of and access to video programs and other data using customer profiles
US5616876A (en) 1995-04-19 1997-04-01 Microsoft Corporation System and methods for selecting music on the basis of subjective content
US6112186A (en) 1995-06-30 2000-08-29 Microsoft Corporation Distributed system for facilitating exchange of user information and opinion using automated collaborative filtering
US5950176A (en) 1996-03-25 1999-09-07 Hsx, Inc. Computer-implemented securities trading system with a virtual specialist function
JPH1031637A (ja) 1996-07-17 1998-02-03 Matsushita Electric Ind Co Ltd エージェント通信装置
US5890152A (en) 1996-09-09 1999-03-30 Seymour Alvin Rapaport Personal feedback browser for obtaining media files
JP3917616B2 (ja) 1997-07-07 2007-05-23 株式会社東芝 多画面表示方法および多画面表示装置
US5974412A (en) * 1997-09-24 1999-10-26 Sapient Health Network Intelligent query system for automatically indexing information in a database and automatically categorizing users
ES2397501T3 (es) 1997-11-25 2013-03-07 Motorola Mobility, Llc Métodos, sistemas y elementos fabricados de reproducción de contenido audio
US6000044A (en) 1997-11-26 1999-12-07 Digital Equipment Corporation Apparatus for randomly sampling instructions in a processor pipeline
US6108686A (en) 1998-03-02 2000-08-22 Williams, Jr.; Henry R. Agent-based on-line information retrieval and viewing system
US8396824B2 (en) * 1998-05-28 2013-03-12 Qps Tech. Limited Liability Company Automatic data categorization with optimally spaced semantic seed terms
US6266649B1 (en) 1998-09-18 2001-07-24 Amazon.Com, Inc. Collaborative recommendations using item-to-item similarity mappings
US6317722B1 (en) 1998-09-18 2001-11-13 Amazon.Com, Inc. Use of electronic shopping carts to generate personal recommendations
US6577716B1 (en) 1998-12-23 2003-06-10 David D. Minter Internet radio system with selective replacement capability
AU3349500A (en) 1999-01-22 2000-08-07 Tuneto.Com, Inc. Digital audio and video playback with performance complement testing
US6347313B1 (en) * 1999-03-01 2002-02-12 Hewlett-Packard Company Information embedding based on user relevance feedback for object retrieval
US20050210101A1 (en) 1999-03-04 2005-09-22 Universal Electronics Inc. System and method for providing content, management, and interactivity for client devices
US7082407B1 (en) 1999-04-09 2006-07-25 Amazon.Com, Inc. Purchase notification service for assisting users in selecting items from an electronic catalog
US6963850B1 (en) 1999-04-09 2005-11-08 Amazon.Com, Inc. Computer services for assisting users in locating and evaluating items in an electronic catalog based on actions performed by members of specific user communities
US20050038819A1 (en) 2000-04-21 2005-02-17 Hicken Wendell T. Music Recommendation system and method
US7013301B2 (en) * 2003-09-23 2006-03-14 Predixis Corporation Audio fingerprinting system and method
US7181438B1 (en) 1999-07-21 2007-02-20 Alberti Anemometer, Llc Database access system
US6965868B1 (en) 1999-08-03 2005-11-15 Michael David Bednarek System and method for promoting commerce, including sales agent assisted commerce, in a networked economy
US6487539B1 (en) 1999-08-06 2002-11-26 International Business Machines Corporation Semantic based collaborative filtering
US6532469B1 (en) * 1999-09-20 2003-03-11 Clearforest Corp. Determining trends using text mining
US6526411B1 (en) 1999-11-15 2003-02-25 Sean Ward System and method for creating dynamic playlists
US7213005B2 (en) * 1999-12-09 2007-05-01 International Business Machines Corporation Digital content distribution using web broadcasting services
US6727914B1 (en) * 1999-12-17 2004-04-27 Koninklijke Philips Electronics N.V. Method and apparatus for recommending television programming using decision trees
WO2001052173A1 (en) 2000-01-13 2001-07-19 Erinmedia, Inc. Privacy compliant multiple dataset correlation system
US6434747B1 (en) 2000-01-19 2002-08-13 Individual Network, Inc. Method and system for providing a customized media list
US7051352B1 (en) 2000-02-04 2006-05-23 Koninklijke Philips Electronics N.V. Adaptive TV program recommender
US7133924B1 (en) 2000-03-08 2006-11-07 Music Choice Personalized audio system and method
US20020002899A1 (en) 2000-03-22 2002-01-10 Gjerdingen Robert O. System for content based music searching
US6865546B1 (en) * 2000-04-19 2005-03-08 Amazon.Com, Inc. Methods and systems of assisting users in purchasing items
US7979880B2 (en) * 2000-04-21 2011-07-12 Cox Communications, Inc. Method and system for profiling iTV users and for providing selective content delivery
US20060217828A1 (en) * 2002-10-23 2006-09-28 Hicken Wendell T Music searching system and method
US8352331B2 (en) 2000-05-03 2013-01-08 Yahoo! Inc. Relationship discovery engine
US7206775B2 (en) * 2000-07-06 2007-04-17 Microsoft Corporation System and methods for the automatic transmission of new, high affinity media
US6748395B1 (en) 2000-07-14 2004-06-08 Microsoft Corporation System and method for dynamic playlist of media
US6615208B1 (en) 2000-09-01 2003-09-02 Telcordia Technologies, Inc. Automatic recommendation of products using latent semantic indexing of content
US20060015904A1 (en) 2000-09-08 2006-01-19 Dwight Marcus Method and apparatus for creation, distribution, assembly and verification of media
US7392212B2 (en) 2000-09-28 2008-06-24 Jpmorgan Chase Bank, N.A. User-interactive financial vehicle performance prediction, trading and training system and methods
US7667123B2 (en) 2000-10-13 2010-02-23 Phillips Mark E System and method for musical playlist selection in a portable audio device
US7277852B2 (en) 2000-10-23 2007-10-02 Ntt Communications Corporation Method, system and storage medium for commercial and musical composition recognition and storage
JP2002320203A (ja) 2001-04-19 2002-10-31 Matsushita Electric Ind Co Ltd 映像信号記録装置および映像信号再生装置
US6933433B1 (en) 2000-11-08 2005-08-23 Viacom, Inc. Method for producing playlists for personalized music stations and for transmitting songs on such playlists
US7925967B2 (en) 2000-11-21 2011-04-12 Aol Inc. Metadata quality improvement
US20030170630A1 (en) * 2000-12-21 2003-09-11 Alsobrook John P. Proteins and nucleic acids encoding same
US7139982B2 (en) 2000-12-21 2006-11-21 Xerox Corporation Navigation methods, systems, and computer program products for virtual three-dimensional books
US7021836B2 (en) * 2000-12-26 2006-04-04 Emcore Corporation Attenuator and conditioner
US6690918B2 (en) 2001-01-05 2004-02-10 Soundstarts, Inc. Networking by matching profile information over a data packet-network and a local area network
EP1231788A1 (en) 2001-02-12 2002-08-14 Koninklijke Philips Electronics N.V. Arrangement for distributing content, profiling center, receiving device and method
US6647371B2 (en) 2001-02-13 2003-11-11 Honda Giken Kogyo Kabushiki Kaisha Method for predicting a demand for repair parts
US6751574B2 (en) 2001-02-13 2004-06-15 Honda Giken Kogyo Kabushiki Kaisha System for predicting a demand for repair parts
US6950804B2 (en) 2001-02-26 2005-09-27 Pika Media Systems and methods for distributing targeted multimedia content and advertising
DE10119067A1 (de) 2001-04-18 2002-10-31 Bosch Gmbh Robert Verfahren zum Abspielen von Multimediadaten mit einem Unterhaltungsgerät
US8260656B1 (en) * 2001-04-19 2012-09-04 Amazon.Com, Inc. Mining of user-generated playlists for data regarding relationships between digital works
US7574513B2 (en) 2001-04-30 2009-08-11 Yahoo! Inc. Controllable track-skipping
US20060206478A1 (en) * 2001-05-16 2006-09-14 Pandora Media, Inc. Playlist generating methods
US6993532B1 (en) 2001-05-30 2006-01-31 Microsoft Corporation Auto playlist generator
US8972481B2 (en) 2001-07-20 2015-03-03 Audible Magic, Inc. Playlist generation method and apparatus
US7877438B2 (en) * 2001-07-20 2011-01-25 Audible Magic Corporation Method and apparatus for identifying new media content
US20040254659A1 (en) 2001-08-20 2004-12-16 Mark Bolas Playlist radio
AU2002323413A1 (en) * 2001-08-27 2003-03-10 Gracenote, Inc. Playlist generation, delivery and navigation
JP4086780B2 (ja) * 2001-09-10 2008-05-14 トムソン ライセンシング オーディオ・データ・プレーヤーにプレイリストを供給する方法
US7457862B2 (en) 2001-10-22 2008-11-25 Avaya, Inc. Real time control protocol session matching
BR0206453A (pt) 2001-11-16 2004-01-13 Koninkl Philips Electronics Nv Método para atualizar, cliente compartilhador de arquivo arranjado para atualizar, servidor arranjado papa atualizar, um banco de dados compreendendo uma impressão digital de, e, um conjunto de metadados associado para cada um de, um número de objetos de multimìdia, e, rede de compartilhamento de arquivo
KR20040065260A (ko) 2001-12-13 2004-07-21 코닌클리케 필립스 일렉트로닉스 엔.브이. 매체 시스템상의 매체 콘텐츠 추천
US20030120630A1 (en) * 2001-12-20 2003-06-26 Daniel Tunkelang Method and system for similarity search and clustering
US7280974B2 (en) * 2001-12-21 2007-10-09 International Business Machines Corporation Method and system for selecting potential purchasers using purchase history
US20030126096A1 (en) * 2001-12-28 2003-07-03 Daniel Pelletier Graduated revenue business model for content creators and recommenders
US7159000B2 (en) 2002-03-21 2007-01-02 Microsoft Corporation Methods and systems for repairing playlists
US7096234B2 (en) 2002-03-21 2006-08-22 Microsoft Corporation Methods and systems for providing playlists
US7797446B2 (en) 2002-07-16 2010-09-14 Apple Inc. Method and system for updating playlists
US9715500B2 (en) 2004-04-27 2017-07-25 Apple Inc. Method and system for sharing playlists
US7680849B2 (en) 2004-10-25 2010-03-16 Apple Inc. Multiple media type synchronization between host computer and media device
US7174126B2 (en) 2002-05-03 2007-02-06 Time Warner Interactive Video Group Inc. Technique for effectively accessing programming listing information in an entertainment delivery system
US6987221B2 (en) * 2002-05-30 2006-01-17 Microsoft Corporation Auto playlist generation with multiple seed songs
US20030229689A1 (en) 2002-06-06 2003-12-11 Microsoft Corporation Method and system for managing stored data on a computer network
US20050021470A1 (en) 2002-06-25 2005-01-27 Bose Corporation Intelligent music track selection
US20040003392A1 (en) 2002-06-26 2004-01-01 Koninklijke Philips Electronics N.V. Method and apparatus for finding and updating user group preferences in an entertainment system
US7228054B2 (en) * 2002-07-29 2007-06-05 Sigmatel, Inc. Automated playlist generation
US7136866B2 (en) 2002-08-15 2006-11-14 Microsoft Corporation Media identifier registry
US8103589B2 (en) 2002-09-16 2012-01-24 Touchtunes Music Corporation Digital downloading jukebox system with central and local music servers
US8151304B2 (en) 2002-09-16 2012-04-03 Touchtunes Music Corporation Digital downloading jukebox system with user-tailored music management, communications, and other tools
US20040073924A1 (en) 2002-09-30 2004-04-15 Ramesh Pendakur Broadcast scheduling and content selection based upon aggregated user profile information
US8053659B2 (en) 2002-10-03 2011-11-08 Polyphonic Human Media Interface, S.L. Music intelligence universe server
JP4302967B2 (ja) 2002-11-18 2009-07-29 パイオニア株式会社 楽曲検索方法、楽曲検索装置及び楽曲検索プログラム
US8667525B2 (en) 2002-12-13 2014-03-04 Sony Corporation Targeted advertisement selection from a digital stream
US7415181B2 (en) 2005-07-29 2008-08-19 Corning Cable Systems Llc Fiber optic cables and assemblies for fiber to the subscriber applications
JP2004221999A (ja) 2003-01-15 2004-08-05 Canon Inc 画像処理方法
US20050004873A1 (en) 2003-02-03 2005-01-06 Robin Pou Distribution and rights management of digital content
TWI300352B (en) 2003-06-05 2008-09-01 G & E Herbal Biotechnology Co Ltd Water soluble extract from plant of solanum genus and the preparation process thereof, and pharmaceutical composition containing the water soluble extract
US20040267715A1 (en) 2003-06-26 2004-12-30 Microsoft Corporation Processing TOC-less media content
WO2005013141A1 (en) 2003-07-28 2005-02-10 Limelight Networks, Llc Consistent browser file download
US7082573B2 (en) 2003-07-30 2006-07-25 America Online, Inc. Method and system for managing digital assets
US20050060350A1 (en) 2003-09-15 2005-03-17 Baum Zachariah Journey System and method for recommendation of media segments
JPWO2005031611A1 (ja) * 2003-09-26 2006-12-07 ソニー株式会社 情報送信装置、端末装置及びその方法
JP3712071B2 (ja) 2003-10-02 2005-11-02 ソニー株式会社 ファイル管理装置、ファイル管理方法、ファイル管理方法のプログラム及びファイル管理方法のプログラムを記録した記録媒体
US20050102610A1 (en) * 2003-11-06 2005-05-12 Wei Jie Visual electronic library
US7345232B2 (en) 2003-11-06 2008-03-18 Nokia Corporation Automatic personal playlist generation with implicit user feedback
US20050108754A1 (en) 2003-11-19 2005-05-19 Serenade Systems Personalized content application
US8544050B2 (en) 2003-12-30 2013-09-24 Aol Inc. Rule-based playlist engine
KR20070007047A (ko) * 2004-01-20 2007-01-12 코닌클리케 필립스 일렉트로닉스 엔.브이. 통합형 플레이리스트 생성기
WO2005072405A2 (en) 2004-01-27 2005-08-11 Transpose, Llc Enabling recommendations and community by massively-distributed nearest-neighbor searching
US20050193054A1 (en) 2004-02-12 2005-09-01 Wilson Eric D. Multi-user social interaction network
US20050210507A1 (en) 2004-03-17 2005-09-22 Sony Corporation System and method for multimedia playlist
US7403769B2 (en) 2004-03-23 2008-07-22 Nokia Corporation System and method for music synchronization in a mobile device
US20050235811A1 (en) 2004-04-20 2005-10-27 Dukane Michael K Systems for and methods of selection, characterization and automated sequencing of media content
CN1950908B (zh) 2004-05-05 2012-04-25 皇家飞利浦电子股份有限公司 用于从项目集合中选择项目的方法和设备
US7127143B2 (en) 2004-05-24 2006-10-24 Corning Cable Systems Llc Distribution cable assembly having overmolded mid-span access location
US20070110074A1 (en) 2004-06-04 2007-05-17 Bob Bradley System and Method for Synchronizing Media Presentation at Multiple Recipients
US20050276570A1 (en) 2004-06-15 2005-12-15 Reed Ogden C Jr Systems, processes and apparatus for creating, processing and interacting with audiobooks and other media
JP4583218B2 (ja) 2004-07-05 2010-11-17 インターナショナル・ビジネス・マシーンズ・コーポレーション 対象コンテンツを評価する方法、コンピュータ・プログラム、システム
BRPI0512181A (pt) * 2004-07-22 2008-02-19 Akoo International Inc método e aparelho para seleção de conteúdo em um dispositivo de reprodução áudio-visual digital e aperfeiçoamento em um aparelho de play-back de mìdia audiovisual digital
US7325005B2 (en) * 2004-07-30 2008-01-29 Hewlett-Packard Development Company, L.P. System and method for category discovery
US20060059225A1 (en) 2004-09-14 2006-03-16 A9.Com, Inc. Methods and apparatus for automatic generation of recommended links
US8099482B2 (en) 2004-10-01 2012-01-17 E-Cast Inc. Prioritized content download for an entertainment device
US20060080356A1 (en) 2004-10-13 2006-04-13 Microsoft Corporation System and method for inferring similarities between media objects
US20080313222A1 (en) 2004-10-14 2008-12-18 Koninklijke Philips Electronics, N.V. Apparatus and Method For Visually Generating a Playlist
US7644077B2 (en) * 2004-10-21 2010-01-05 Microsoft Corporation Methods, computer readable mediums and systems for linking related data from at least two data sources based upon a scoring algorithm
US7302468B2 (en) 2004-11-01 2007-11-27 Motorola Inc. Local area preference determination system and method
JP2008530632A (ja) 2004-11-04 2008-08-07 ロカモダ, インコーポレイテッド 双方向性のマーケティングのためのシステムおよび方法
US7777125B2 (en) * 2004-11-19 2010-08-17 Microsoft Corporation Constructing a table of music similarity vectors from a music similarity graph
US20060155754A1 (en) 2004-12-08 2006-07-13 Steven Lubin Playlist driven automated content transmission and delivery system
EP1825473A2 (en) 2004-12-10 2007-08-29 Koninklijke Philips Electronics N.V. Multiuser playlist generation
US20060173916A1 (en) 2004-12-22 2006-08-03 Verbeck Sibley Timothy J R Method and system for automatically generating a personalized sequence of rich media
WO2006075032A1 (es) 2005-01-05 2006-07-20 Musicstrands, S.A.U. Sistema y método para recomendar elementos multimedia
US7536565B2 (en) 2005-01-07 2009-05-19 Apple Inc. Techniques for improved playlist processing on media devices
JP4329697B2 (ja) 2005-01-12 2009-09-09 ヤマハ株式会社 音楽再生装置および同装置に適用されるコンピュータ読み取り可能な音楽再生プログラム
US7693887B2 (en) 2005-02-01 2010-04-06 Strands, Inc. Dynamic identification of a new set of media items responsive to an input mediaset
US7734569B2 (en) * 2005-02-03 2010-06-08 Strands, Inc. Recommender system for identifying a new set of media items responsive to an input set of media items and knowledge base metrics
WO2006084269A2 (en) 2005-02-04 2006-08-10 Musicstrands, Inc. System for browsing through a music catalog using correlation metrics of a knowledge base of mediasets
US7818350B2 (en) 2005-02-28 2010-10-19 Yahoo! Inc. System and method for creating a collaborative playlist
EP1869574A4 (en) 2005-03-04 2009-11-11 Resonance Media Services Inc BROWSER TO CREATE MUSIC LISTINGS
KR100656207B1 (ko) 2005-03-14 2006-12-13 삼성전자주식회사 ―vr포맷에서 북마크를 이용해 자동으로 재생목록을 생성하는 것이 가능한 영상 기록/재생 장치 및 그 재생목록 생성방법
JP4670438B2 (ja) * 2005-04-01 2011-04-13 ソニー株式会社 コンテンツおよびそのプレイリストの提供方法
EP1926027A1 (en) 2005-04-22 2008-05-28 Strands Labs S.A. System and method for acquiring and aggregating data relating to the reproduction of multimedia files or elements
US8214264B2 (en) 2005-05-02 2012-07-03 Cbs Interactive, Inc. System and method for an electronic product advisor
US20060277098A1 (en) 2005-06-06 2006-12-07 Chung Tze D Media playing system and method for delivering multimedia content with up-to-date and targeted marketing messages over a communication network
US20060282311A1 (en) 2005-06-09 2006-12-14 Jianfeng Jiang Targeted advertisement network that integrates with store-shopping
US20060288367A1 (en) 2005-06-16 2006-12-21 Swix Scott R Systems, methods and products for tailoring and bundling content
US20070016507A1 (en) 2005-07-12 2007-01-18 Wally Tzara System for analysis and prediction of financial and statistical data
US7580932B2 (en) 2005-07-15 2009-08-25 Microsoft Corporation User interface for establishing a filtering engine
DE602006013666D1 (de) * 2005-09-29 2010-05-27 Koninkl Philips Electronics Nv Verfahren und vorrichtung zum automatischen erstellung einer abspielliste durch segmentweisen merkmalsvergleich
US20090070267A9 (en) * 2005-09-30 2009-03-12 Musicstrands, Inc. User programmed media delivery service
US7877387B2 (en) 2005-09-30 2011-01-25 Strands, Inc. Systems and methods for promotional media item selection and promotional program unit generation
EP1949218A4 (en) * 2005-10-04 2009-12-02 Strands Inc METHOD AND DEVICES FOR VISUALIZING A MUSIC LIBRARY
US20070089057A1 (en) * 2005-10-14 2007-04-19 Yahoo! Inc. Method and system for selecting media
US20070100690A1 (en) 2005-11-02 2007-05-03 Daniel Hopkins System and method for providing targeted advertisements in user requested multimedia content
US8341158B2 (en) 2005-11-21 2012-12-25 Sony Corporation User's preference prediction from collective rating data
US8131718B2 (en) 2005-12-13 2012-03-06 Muse Green Investments LLC Intelligent data retrieval system
BRPI0620084B1 (pt) 2005-12-19 2018-11-21 Apple Inc método para identificar usuários individuais em uma comunidade definida de usuários, com base na comparação do perfil do primeiro usuário com outros perfis de usuário, para um primeiro membro da comunidade e método para medir similaridade de usuários individuais para um primeiro usuário em uma comunidade definida de usuários
US20070162546A1 (en) 2005-12-22 2007-07-12 Musicstrands, Inc. Sharing tags among individual user media libraries
US7765212B2 (en) 2005-12-29 2010-07-27 Microsoft Corporation Automatic organization of documents through email clustering
US7814040B1 (en) * 2006-01-31 2010-10-12 The Research Foundation Of State University Of New York System and method for image annotation and multi-modal image retrieval using probabilistic semantic models
US20070244880A1 (en) 2006-02-03 2007-10-18 Francisco Martin Mediaset generation system
US20070203865A1 (en) * 2006-02-09 2007-08-30 Hirsch Martin C Apparatus and methods for an item retrieval system
BRPI0621315A2 (pt) 2006-02-10 2011-12-06 Strands Inc entretenimento interativo dinámico
WO2007095272A2 (en) 2006-02-10 2007-08-23 Strands, Inc. Systems and methods for prioritizing mobile media player files
US20070220566A1 (en) 2006-03-03 2007-09-20 Comcast Cable Holdings, Llc Method and system of distributing media content and generating playlists
US7653761B2 (en) 2006-03-15 2010-01-26 Microsoft Corporation Automatic delivery of personalized content to a portable media player with feedback
US20070219996A1 (en) * 2006-03-17 2007-09-20 Vervelife System and method for creating custom playlists based on user inputs
US20070250429A1 (en) 2006-04-19 2007-10-25 Clinical Futures Llc Prediction markets for assessing clinical probabilities of success
US20070271286A1 (en) 2006-05-16 2007-11-22 Khemdut Purang Dimensionality reduction for content category data
US7774288B2 (en) 2006-05-16 2010-08-10 Sony Corporation Clustering and classification of multimedia data
US20070288470A1 (en) 2006-06-08 2007-12-13 Hannu Kauniskangas Selection of media for public rendering via user devices
US20080010266A1 (en) * 2006-07-10 2008-01-10 Brunn Jonathan F A Context-Centric Method of Automated Introduction and Community Building
US7529740B2 (en) * 2006-08-14 2009-05-05 International Business Machines Corporation Method and apparatus for organizing data sources
US8271266B2 (en) * 2006-08-31 2012-09-18 Waggner Edstrom Worldwide, Inc. Media content assessment and control systems
JP4910582B2 (ja) 2006-09-12 2012-04-04 ソニー株式会社 情報処理装置および方法、並びに、プログラム
EP2069965A1 (en) * 2006-09-20 2009-06-17 Google, Inc. Digital audio file management
US20080091717A1 (en) 2006-09-27 2008-04-17 Zachary Adam Garbow Generation of Collaborative Playlist Based Upon Musical Preference Data from Multiple Digital Media Players
US20080126384A1 (en) 2006-09-27 2008-05-29 Toms Mona L Method of automatically generating music playlists based on user-selected tempo pattern
US20100328312A1 (en) 2006-10-20 2010-12-30 Justin Donaldson Personal music recommendation mapping
US20080115173A1 (en) 2006-11-10 2008-05-15 Guideworks Llc Systems and methods for using playlists
US7574422B2 (en) 2006-11-17 2009-08-11 Yahoo! Inc. Collaborative-filtering contextual model optimized for an objective function for recommending items
US9405827B2 (en) * 2006-11-30 2016-08-02 Red Hat, Inc. Playlist generation of content gathered from multiple sources
US8463893B2 (en) * 2006-11-30 2013-06-11 Red Hat, Inc. Automatic playlist generation in correlation with local events
TWI338846B (en) 2006-12-22 2011-03-11 Univ Nat Pingtung Sci & Tech A method for grid-based data clustering
BRPI0811424A2 (pt) * 2007-03-30 2019-09-24 Knewco Inc estrutura de dados, sistema e método de conhecimento da navegação e descoberta
US8073854B2 (en) 2007-04-10 2011-12-06 The Echo Nest Corporation Determining the similarity of music using cultural and acoustic information
US10176258B2 (en) * 2007-06-28 2019-01-08 International Business Machines Corporation Hierarchical seedlists for application data
US20090037399A1 (en) * 2007-07-31 2009-02-05 Yahoo! Inc. System and Method for Determining Semantically Related Terms
US20090037415A1 (en) * 2007-08-03 2009-02-05 Charles Ramberg Data analysis
US8341065B2 (en) * 2007-09-13 2012-12-25 Microsoft Corporation Continuous betting interface to prediction market
US8229824B2 (en) 2007-09-13 2012-07-24 Microsoft Corporation Combined estimate contest and prediction market
US20090083278A1 (en) * 2007-09-26 2009-03-26 Yihong Zhao System and method for discovering and presenting social relationships between internet users and content
CA2605662A1 (en) 2007-09-28 2009-03-28 International Business Machines Corporation System and method for automated stock market operation
US7974889B2 (en) 2007-10-19 2011-07-05 Raimbeault Sean M Social networking interactive shopping system
US8375131B2 (en) 2007-12-21 2013-02-12 Yahoo! Inc. Media toolbar and aggregated/distributed media ecosystem
US8060525B2 (en) * 2007-12-21 2011-11-15 Napo Enterprises, Llc Method and system for generating media recommendations in a distributed environment based on tagging play history information with location information
CN101236567A (zh) * 2008-02-04 2008-08-06 上海升岳电子科技有限公司 一种实现在线网络多媒体应用的方法和终端设备
US8145676B2 (en) 2008-02-11 2012-03-27 International Business Machines Corporation Shared inventory item donation in a virtual universe
EP2288986A4 (en) 2008-04-28 2013-01-09 Strands Inc SYSTEMS FOR DISTRIBUTING PERSONALIZED RECOMMENDATIONS OF FINANCIAL PRODUCTS BASED ON USER DATA
EP2304597A4 (en) 2008-05-31 2012-10-31 Apple Inc ADAPTIVE RECOMMENDATION DEVICE TECHNOLOGY
US20090299945A1 (en) 2008-06-03 2009-12-03 Strands, Inc. Profile modeling for sharing individual user preferences
WO2010011637A1 (en) 2008-07-21 2010-01-28 Strands, Inc Ambient collage display of digital media content
US8332406B2 (en) 2008-10-02 2012-12-11 Apple Inc. Real-time visualization of user consumption of media items
US20100169328A1 (en) 2008-12-31 2010-07-01 Strands, Inc. Systems and methods for making recommendations using model-based collaborative filtering with user communities and items collections

Also Published As

Publication number Publication date
US20100076958A1 (en) 2010-03-25
AU2009288147A1 (en) 2010-03-11
US8966394B2 (en) 2015-02-24
KR101318015B1 (ko) 2013-10-14
CN102187338B (zh) 2014-06-18
US20100070917A1 (en) 2010-03-18
US20100076983A1 (en) 2010-03-25
CN102187338A (zh) 2011-09-14
US8601003B2 (en) 2013-12-03
EP2662789A3 (en) 2014-09-17
US8914384B2 (en) 2014-12-16
JP2012502361A (ja) 2012-01-26
US20100076982A1 (en) 2010-03-25
EP2662789A2 (en) 2013-11-13
KR20110066168A (ko) 2011-06-16
US9496003B2 (en) 2016-11-15
CN104102729B (zh) 2018-03-16
CN104102729A (zh) 2014-10-15
AU2009288147B2 (en) 2012-06-14

Similar Documents

Publication Publication Date Title
JP5232304B2 (ja) 類似性データに基づいてプレイリストを生成するシステム及び方法
JP5044001B2 (ja) 類似性データに基づくメディアアイテムのクラスタリング
US10469549B2 (en) Device for participating in a network for sharing media consumption activity
US7680959B2 (en) P2P network for providing real time media recommendations
US9292179B2 (en) System and method for identifying music content in a P2P real time recommendation network
US7970922B2 (en) P2P real time media recommendations
US8583791B2 (en) Maintaining a minimum level of real time media recommendations in the absence of online friends
EP2161668A1 (en) System and method for playlist generation based on similarity data
US20090138457A1 (en) Grouping and weighting media categories with time periods
JP2001209660A (ja) コンテンツ検索・推奨システム
CN101460918A (zh) 音乐或者其它内容的一击选择

Legal Events

Date Code Title Description
A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20130221

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20130301

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20130322

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20160329

Year of fee payment: 3

R150 Certificate of patent or registration of utility model

Free format text: JAPANESE INTERMEDIATE CODE: R150

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250