- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我尝试了 apriori 算法,这段代码是我从 google 获得的,是 4 年前上传的。然后,当我尝试运行时,我只会在 Android Nougat 版本中运行。并且在其他android版本上出现错误。我应该怎么办?任何人都可以帮助我。我是新来的。谢谢
@RequiresApi(api = Build.VERSION_CODES.N)
private void apriori() {
aprioriReference.removeValue();
AprioriFrequentItemsetGenerator<String> generator =
new AprioriFrequentItemsetGenerator<>();
List<Set<String>> itemsetList = new ArrayList<>();
databaseReference.addValueEventListener(new ValueEventListener() {
@Override
public void onDataChange(@NonNull DataSnapshot dataSnapshot) {
itemsetList.clear();
for (DataSnapshot dataSnapshot1:dataSnapshot.getChildren()){
Set<String> set=new HashSet<>();
for(DataSnapshot dataSnapshot11:dataSnapshot1.child("trProduct").getChildren()){
set.add(dataSnapshot11.child("productId").getValue().toString());
}
itemsetList.add(set);
}
FrequentItemsetData<String> data = generator.generate(itemsetList, 0.2);
int i = 0;
for (Set<String> itemset : data.getFrequentItemsetList()) {
logs.append((i++)+":\t"+itemset+" with support "+data.getSupport(itemset)+"\n");
aprioriReference.child(String.valueOf(i)).child("itemSet").setValue(itemset.toString());
aprioriReference.child(String.valueOf(i)).child("support").setValue(data.getSupport(itemset));
}
}
@Override
public void onCancelled(@NonNull DatabaseError databaseError) {
}
});
FrequentItemsetData.java
package site.team2dev.adminag;
import java.util.List;
import java.util.Map;
import java.util.Set;
public class FrequentItemsetData<I> {
private final List<Set<I>> frequentItemsetList;
private final Map<Set<I>, Integer> supportCountMap;
private final double minimumSupport;
private final int numberOfTransactions;
FrequentItemsetData(List<Set<I>> frequentItemsetList,
Map<Set<I>, Integer> supportCountMap,
double minimumSupport,
int transactionNumber) {
this.frequentItemsetList = frequentItemsetList;
this.supportCountMap = supportCountMap;
this.minimumSupport = minimumSupport;
this.numberOfTransactions = transactionNumber;
}
public List<Set<I>> getFrequentItemsetList() {
return frequentItemsetList;
}
public Map<Set<I>, Integer> getSupportCountMap() {
return supportCountMap;
}
public double getMinimumSupport() {
return minimumSupport;
}
public int getTransactionNumber() {
return numberOfTransactions;
}
public double getSupport(Set<I> itemset) {
return 1.0 * supportCountMap.get(itemset) / numberOfTransactions;
}
}
AprioriFrequentItemsetGenerator.java
package site.team2dev.adminag;
import android.os.Build;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.Set;
import androidx.annotation.RequiresApi;
public class AprioriFrequentItemsetGenerator<I> {
/**
* Generates the frequent itemset data.
*
* @param transactionList the list of transactions to mine.
* @param minimumSupport the minimum support.
* @return the object describing the result of this task.
*/
@RequiresApi(api = Build.VERSION_CODES.N)
public FrequentItemsetData<I> generate(List<Set<I>> transactionList,
double minimumSupport) {
Objects.requireNonNull(transactionList, "The itemset list is empty.");
checkSupport(minimumSupport);
if (transactionList.isEmpty()) {
return null;
}
// Maps each itemset to its support count. Support count is simply the
// number of times an itemset appeares in the transaction list.
Map<Set<I>, Integer> supportCountMap = new HashMap<>();
// Get the list of 1-itemsets that are frequent.
List<Set<I>> frequentItemList = findFrequentItems(transactionList,
supportCountMap,
minimumSupport);
// Maps each 'k' to the list of frequent k-itemsets.
Map<Integer, List<Set<I>>> map = new HashMap<>();
map.put(1, frequentItemList);
// 'k' denotes the cardinality of itemsets processed at each iteration
// of the following loop.
int k = 1;
do {
++k;
// First generate the candidates.
List<Set<I>> candidateList =
generateCandidates(map.get(k - 1));
for (Set<I> transaction : transactionList) {
List<Set<I>> candidateList2 = subset(candidateList,
transaction);
for (Set<I> itemset : candidateList2) {
supportCountMap.put(itemset,
supportCountMap.getOrDefault(itemset,
0) + 1);
}
}
map.put(k, getNextItemsets(candidateList,
supportCountMap,
minimumSupport,
transactionList.size()));
} while (!map.get(k).isEmpty());
return new FrequentItemsetData<>(extractFrequentItemsets(map),
supportCountMap,
minimumSupport,
transactionList.size());
}
/**
* This method simply concatenates all the lists of frequent itemsets into
* one list.
*
* @param map the map mapping an itemset size to the list of frequent
* itemsets of that size.
* @return the list of all frequent itemsets.
*/
private List<Set<I>>
extractFrequentItemsets(Map<Integer, List<Set<I>>> map) {
List<Set<I>> ret = new ArrayList<>();
for (List<Set<I>> itemsetList : map.values()) {
ret.addAll(itemsetList);
}
return ret;
}
/**
* This method gathers all the frequent candidate itemsets into a single
* list.
*
* @param candidateList the list of candidate itemsets.
* @param supportCountMap the map mapping each itemset to its support count.
* @param minimumSupport the minimum support.
* @param transactions the total number of transactions.
* @return a list of frequent itemset candidates.
*/
private List<Set<I>> getNextItemsets(List<Set<I>> candidateList,
Map<Set<I>, Integer> supportCountMap,
double minimumSupport,
int transactions) {
List<Set<I>> ret = new ArrayList<>(candidateList.size());
for (Set<I> itemset : candidateList) {
if (supportCountMap.containsKey(itemset)) {
int supportCount = supportCountMap.get(itemset);
double support = 1.0 * supportCount / transactions;
if (support >= minimumSupport) {
ret.add(itemset);
}
}
}
return ret;
}
/**
* Computes the list of itemsets that are all subsets of
* {@code transaction}.
*
* @param candidateList the list of candidate itemsets.
* @param transaction the transaction to test against.
* @return the list of itemsets that are subsets of {@code transaction}
* itemset.
*/
private List<Set<I>> subset(List<Set<I>> candidateList,
Set<I> transaction) {
List<Set<I>> ret = new ArrayList<>(candidateList.size());
for (Set<I> candidate : candidateList) {
if (transaction.containsAll(candidate)) {
ret.add(candidate);
}
}
return ret;
}
/**
* Generates the next candidates. This is so called F_(k - 1) x F_(k - 1)
* method.
*
* @param itemsetList the list of source itemsets, each of size <b>k</b>.
* @return the list of candidates each of size <b>k + 1</b>.
*/
private List<Set<I>> generateCandidates(List<Set<I>> itemsetList) {
List<List<I>> list = new ArrayList<>(itemsetList.size());
for (Set<I> itemset : itemsetList) {
List<I> l = new ArrayList<>(itemset);
Collections.<I>sort(l, ITEM_COMPARATOR);
list.add(l);
}
int listSize = list.size();
List<Set<I>> ret = new ArrayList<>(listSize);
for (int i = 0; i < listSize; ++i) {
for (int j = i + 1; j < listSize; ++j) {
Set<I> candidate = tryMergeItemsets(list.get(i), list.get(j));
if (candidate != null) {
ret.add(candidate);
}
}
}
return ret;
}
/**
* Attempts the actual construction of the next itemset candidate.
* @param itemset1 the list of elements in the first itemset.
* @param itemset2 the list of elements in the second itemset.
*
* @return a merged itemset candidate or {@code null} if one cannot be
* constructed from the input itemsets.
*/
private Set<I> tryMergeItemsets(List<I> itemset1, List<I> itemset2) {
int length = itemset1.size();
for (int i = 0; i < length - 1; ++i) {
if (!itemset1.get(i).equals(itemset2.get(i))) {
return null;
}
}
if (itemset1.get(length - 1).equals(itemset2.get(length - 1))) {
return null;
}
Set<I> ret = new HashSet<>(length + 1);
for (int i = 0; i < length - 1; ++i) {
ret.add(itemset1.get(i));
}
ret.add(itemset1.get(length - 1));
ret.add(itemset2.get(length - 1));
return ret;
}
private static final Comparator ITEM_COMPARATOR = new Comparator() {
@Override
public int compare(Object o1, Object o2) {
return ((Comparable) o1).compareTo(o2);
}
};
/**
* Computes the frequent itemsets of size 1.
*
* @param itemsetList the entire database of transactions.
* @param supportCountMap the support count map to which to write the
* support counts of each item.
* @param minimumSupport the minimum support.
* @return the list of frequent one-itemsets.
*/
private List<Set<I>> findFrequentItems(List<Set<I>> itemsetList,
Map<Set<I>, Integer> supportCountMap,
double minimumSupport) {
Map<I, Integer> map = new HashMap<>();
// Count the support counts of each item.
for (Set<I> itemset : itemsetList) {
for (I item : itemset) {
Set<I> tmp = new HashSet<>(1);
tmp.add(item);
if (supportCountMap.containsKey(tmp)) {
supportCountMap.put(tmp, supportCountMap.get(tmp) + 1);
} else {
supportCountMap.put(tmp, 1);
}
map.put(item, map.getOrDefault(item, 0) + 1);
}
}
List<Set<I>> frequentItemsetList = new ArrayList<>();
for (Map.Entry<I, Integer> entry : map.entrySet()) {
if (1.0 * entry.getValue() / map.size() >= minimumSupport) {
Set<I> itemset = new HashSet<>(1);
itemset.add(entry.getKey());
frequentItemsetList.add(itemset);
}
}
return frequentItemsetList;
}
private void checkSupport(double support) {
if (Double.isNaN(support)) {
throw new IllegalArgumentException("The input support is NaN.");
}
if (support > 1.0) {
throw new IllegalArgumentException(
"The input support is too large: " + support + ", " +
"should be at most 1.0");
}
if (support < 0.0) {
throw new IllegalArgumentException(
"The input support is too small: " + support + ", " +
"should be at least 0.0");
}
}
}
最佳答案
getOrDefault
用于检查null,如果为null则返回默认值。
它是从牛轧糖引入的。
因此您可以通过手动检查 null 并分配默认值来删除它。
关于Java Android 代码将在 Nougat 上运行。如何在其他安卓上运行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62481777/
我想将 EditText 始终设置为 LTR,我该怎么做?android:textDirection 似乎确实是答案,我无法让项目使用该指令进行编译 最佳答案 为 editText 使用引力 andr
我希望我的应用在每次打开时都显示登录屏幕。使用 android:clearTaskOnLaunch="true" 一切正常。但是有一个错误,只有在手机关机并且应用程序首先使用小部件启动时才会发生。 I
实际上我的要求是我想将动态文件加载到像图像一样的网页中。视频,音频等,它来自 Assets 或应用程序自己的文件目录,这不是问题。 我尝试使用以下两种方式。 方式一 这是我的 html 文件在 ass
我正在触发一个 DatePickerDialog,在 api 22 (Android 5.1) 之前它一直在工作并显示良好,我在上面设置混合和最大日期(最小 = 当前日期,最大 = 从当前日期开始的
我有一个 ListView ,我在其中将标题 View 添加到该列表。一切都很好,但是当滚动列表 headerview 也随着列表移动时,所以我想避免 headerview 滚动,我的意思是当我列表到
虽然我在android上做过一些app,但我还是一头雾水。是否可以使用 SDK 4.0 中的功能,并在 android 2.1 或更低版本上运行该应用程序? 我尝试了你们提到的方法,但出现错误 - F
您好,我正在开发小型 android 应用程序,我想在其中显示带有一些元素的简单 gridview。它工作正常。唯一的问题是即使有空间,它也总是只显示两列。它平均将屏幕分成 2 列并仅显示两个元素。如
我正在使用 Android 2.3.3 API 构建一个应用程序。我需要识别方向的变化并执行一些操作。所以我在 Android Manifest 中添加了以下内容, android:configCha
我正在尝试在“点击”包含特定 MIME 类型的 nfc 标签时开始一项 Activity 。我制作了一个 mime 类型为“text/plain”的标签,并将其添加到 list 中:
我可以将一些数据保存到文件中 val byteArrayOutputStream = ByteArrayOutputStream() byteArrayOutputStream.wri
我正在尝试解析一个包含复杂阿拉伯字母的 XML 文件.. 当我在 android 2.3.7 上测试时,并不是所有的阿拉伯字母都被支持,仍然有一些复杂的显示为方 block .. 但是在 androi
我需要编写一个方法来确定设备是平板电脑还是手机。我不需要根据这个显示不同的用户界面。我只需要有关设备的信息,以便将来我可以将其发送到指标。 在互联网上,我找到了很多方法来确定设备是否是平板电脑。我已经
我正在玩文字转语音,让我的测试应用程序更有趣。它适用于模拟器,但不适用于我的手机,因为我的默认语言环境不是英语。 但是,文本是英文的,所以 tts 当然应该使用英文。据我所知,我可以实现一个自动安装,
我正在使用 MVVM 和整洁的架构编写应用程序。在其中一个屏幕上,我需要使用 pagination 实现 RecyclerView。我将使用库 Paging3。 Android 开发者推荐在存储库层使
这个问题在这里已经有了答案: I lost my .keystore file? (12 个回答) 4年前关闭。 当我以前的操作系统损坏并安装新的(7 月 3 日)时,以前的 android_key_
我正在使用 MVVM 和整洁的架构编写应用程序。在其中一个屏幕上,我需要使用 pagination 实现 RecyclerView。我将使用库 Paging3。 Android 开发者推荐在存储库层使
在我的 v27\style.xml 中,我有以下代码来设置白色导航栏: @color/colorPrimary @color/colorPrimaryDark @color/
我想通过发送电子邮件 startActivity(Intent.createChooser(new Intent(android.content.Intent.ACTION_SEND))) 我知道要将
我实现了一个自定义 ListView ,它看起来像 Twitter 时间线。 adapter = new MyClickableListAdapter(this, R.layout.timeline,
我有一个显示启动画面的自定义对话框; mSplashDialog = new Dialog(MyActivity.this,R.layout.splash); mSplashDialog.setCon
我是一名优秀的程序员,十分优秀!