本文整理汇总了Java中vnreal.algorithms.utils.NodeLinkAssignation.isMappable方法的典型用法代码示例。如果您正苦于以下问题:Java NodeLinkAssignation.isMappable方法的具体用法?Java NodeLinkAssignation.isMappable怎么用?Java NodeLinkAssignation.isMappable使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类vnreal.algorithms.utils.NodeLinkAssignation
的用法示例。
在下文中一共展示了NodeLinkAssignation.isMappable方法的6个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: analyze
import vnreal.algorithms.utils.NodeLinkAssignation; //导入方法依赖的package包/类
/**
* This method creates the candidates list
*
* @return true if everything is ok, false if there is one node without a candidate
*/
private boolean analyze(VirtualNetwork vNet) {
//Walk through any vNode and check the substrate for fitting nodes
for(VirtualNode vn : vNet.getVertices()) {
ArrayList<SubstrateNode> tmpCandidates = new ArrayList<SubstrateNode>();
for(SubstrateNode sn : sNet.getVertices()) {
if(NodeLinkAssignation.isMappable(vn, sn)) {
tmpCandidates.add(sn);
}
}
//Check if the list is empty
if(tmpCandidates.isEmpty()) {
System.out.println("Fail(Analyze): "+vn.getName()+":"+MLSUtils.getMLSDemand(vn).toString());
count_abort_analyze++;
return false; //then no candiates for this node
}
//Add the list to our global list
candidates.put(vn, tmpCandidates);
}
return true;
}
示例2: analyze
import vnreal.algorithms.utils.NodeLinkAssignation; //导入方法依赖的package包/类
/**
* This method creates the candidates list
*
* @return true if everything is ok, false if there is one node without a candidate
*/
private boolean analyze(VirtualNetwork vNet) {
//Walk through any vNode and check the substrate for fitting nodes
for(VirtualNode vn : vNet.getVertices()) {
ArrayList<SubstrateNode> tmpCandidates = new ArrayList<SubstrateNode>();
for(SubstrateNode sn : super.sNet.getVertices()) {
if(NodeLinkAssignation.isMappable(vn, sn)) {
tmpCandidates.add(sn);
}
}
//Check if the list is empty
if(tmpCandidates.isEmpty()) {
System.out.println("Fail(Analyze): "+vn.getName()+":"+MLSUtils.getMLSDemand(vn).toString());
count_abort_analyze++;
return false; //then no candiates for this node
}
//Add the list to our global list
candidates.put(vn, tmpCandidates);
}
return true;
}
示例3: findCandidates
import vnreal.algorithms.utils.NodeLinkAssignation; //导入方法依赖的package包/类
/**
* Returns a list of possible Candidates for this Node
* @param vn {@link VirtualNode}
* @param flexibility if Levelflexibility should be used
* @return {@link ArrayList} of {@link SubstrateNode}
*/
private ArrayList<SubstrateNode> findCandidates(SubstrateNetwork sNet, VirtualNode vn, boolean flexibility) {
ArrayList<SubstrateNode> tmpCandidates = new ArrayList<SubstrateNode>();
//If flexibility is wanted decrement the level, only allow one decrement per node
if(flexibility && !flexNodes.contains(vn)) {
//decrement the demanded Security
MLSDemand dem = MLSUtils.getMLSDemand(vn);
int demLevel = dem.getDemand();
//If the level is 0, stop, we can't decrement it
if(demLevel != 0) {
demLevel--;
//set the new Level to the MLSDemand
dem.setDemand(demLevel);
//System.out.println("Set: "+demLevel);
flexNodes.add(vn); //mark the node as flexible
}
}
for(SubstrateNode sn : sNet.getVertices()) {
if(NodeLinkAssignation.isMappable(vn, sn) && isAvailable(sn)) {
tmpCandidates.add(sn);
}
}
return tmpCandidates;
}
示例4: findCandidates
import vnreal.algorithms.utils.NodeLinkAssignation; //导入方法依赖的package包/类
/**
* Returns a list of possible Candidates for this Node
* @param vn {@link VirtualNode}
* @param flexibility if Levelflexibility should be used
* @return {@link ArrayList} of {@link SubstrateNode}
*/
private ArrayList<SubstrateNode> findCandidates(VirtualNode vn, boolean flexibility) {
ArrayList<SubstrateNode> tmpCandidates = new ArrayList<SubstrateNode>();
//If flexibility is wanted decrement the level, only allow one decrement per node
if(flexibility && !flexNodes.contains(vn)) {
//decrement the demanded Security
MLSDemand dem = MLSUtils.getMLSDemand(vn);
int demLevel = dem.getDemand();
//If the level is 0, stop, we can't decrement it
if(demLevel != 0) {
demLevel--;
//set the new Level to the MLSDemand
dem.setDemand(demLevel);
//System.out.println("Set: "+demLevel);
flexNodes.add(vn); //mark the node as flexible
}
}
for(SubstrateNode sn : super.sNet.getVertices()) {
if(NodeLinkAssignation.isMappable(vn, sn) && isAvailable(sn)) {
tmpCandidates.add(sn);
}
}
return tmpCandidates;
}
示例5: nodeMapping
import vnreal.algorithms.utils.NodeLinkAssignation; //导入方法依赖的package包/类
@Override
protected boolean nodeMapping(SubstrateNetwork sNet, VirtualNetwork vNet) {
/*
* Node ranking calculation for virtual and substrate network
* see (Algorithm 1 and 2)
*
* X. Cheng, S. Su, Z. Zhang, H. Wang, F. Yang, Y. Luo, J. Wang, Virtual network embedding
* through topology-aware node ranking, SIGCOMM Comput. Commun. Rev. 41 (2011) 38--47.
*
*/
Map<Node<?>, Double> SortedNodeNR_i_opt_subs = MiscelFunctions
.sortByValue(MiscelFunctions.create_NR(sNet, epsilon));
Map<Node<?>, Double> SortedNodeNR_i_opt_virt = MiscelFunctions
.sortByValue(MiscelFunctions.create_NR(vNet, epsilon));
boolean mappingPerformed;
for (Iterator<Node<?>> vNode = SortedNodeNR_i_opt_virt.keySet()
.iterator(); vNode.hasNext();) {
VirtualNode toMapvNode = (VirtualNode) vNode.next();
mappingPerformed = false;
if (!nodeMapping.containsKey(toMapvNode)) {
for (Iterator<Node<?>> sNode = SortedNodeNR_i_opt_subs.keySet()
.iterator(); sNode.hasNext();) {
SubstrateNode candidateSnode = (SubstrateNode) sNode.next();
if (!nodeMapping.containsValue(candidateSnode)) {
if (dist >= 0) {
if (NodeLinkAssignation.isMappable(toMapvNode,
candidateSnode)
&& MiscelFunctions.nodeDistance(toMapvNode,
candidateSnode, dist)) {
if (NodeLinkAssignation.vnm(toMapvNode,
candidateSnode)) {
nodeMapping.put(toMapvNode, candidateSnode);
mappingPerformed = true;
} else {
throw new AssertionError(
"But we checked before!");
}
}
} else {
if (NodeLinkAssignation.isMappable(toMapvNode,
candidateSnode)) {
if (NodeLinkAssignation.vnm(toMapvNode,
candidateSnode)) {
nodeMapping.put(toMapvNode, candidateSnode);
mappingPerformed = true;
break;
} else {
throw new AssertionError(
"But we checked before!");
}
}
}
}
}
} else {
mappingPerformed = true;
}
if (!mappingPerformed)
return false;
}
return true;
}
示例6: nodeMapping
import vnreal.algorithms.utils.NodeLinkAssignation; //导入方法依赖的package包/类
@SuppressWarnings("unchecked")
@Override
protected boolean nodeMapping(VirtualNetwork vNet) {
/*
* Node ranking calculation for virtual and substrate network
* see (Algorithm 1 and 2)
*
* X. Cheng, S. Su, Z. Zhang, H. Wang, F. Yang, Y. Luo, J. Wang, Virtual network embedding
* through topology-aware node ranking, SIGCOMM Comput. Commun. Rev. 41 (2011) 38�47.
*
*/
Map<Node<?>, Double> SortedNodeNR_i_opt_subs = MiscelFunctions
.sortByValue(MiscelFunctions.create_NR(sNet, epsilon));
Map<Node<?>, Double> SortedNodeNR_i_opt_virt = MiscelFunctions
.sortByValue(MiscelFunctions.create_NR(vNet, epsilon));
boolean mappingPerformed;
for (Iterator<Node<?>> vNode = SortedNodeNR_i_opt_virt.keySet()
.iterator(); vNode.hasNext();) {
VirtualNode toMapvNode = (VirtualNode) vNode.next();
mappingPerformed = false;
if (!nodeMapping.containsKey(toMapvNode)) {
for (Iterator<Node<?>> sNode = SortedNodeNR_i_opt_subs.keySet()
.iterator(); sNode.hasNext();) {
SubstrateNode candidateSnode = (SubstrateNode) sNode.next();
if (!nodeMapping.containsValue(candidateSnode)) {
if (withDist) {
if (NodeLinkAssignation.isMappable(toMapvNode,
candidateSnode)
&& MiscelFunctions.nodeDistance(toMapvNode,
candidateSnode, dist)) {
if (NodeLinkAssignation.vnm(toMapvNode,
candidateSnode)) {
nodeMapping.put(toMapvNode, candidateSnode);
mappingPerformed = true;
} else {
throw new AssertionError(
"But we checked before!");
}
}
} else {
if (NodeLinkAssignation.isMappable(toMapvNode,
candidateSnode)) {
if (NodeLinkAssignation.vnm(toMapvNode,
candidateSnode)) {
nodeMapping.put(toMapvNode, candidateSnode);
mappingPerformed = true;
break;
} else {
throw new AssertionError(
"But we checked before!");
}
}
}
}
}
} else {
mappingPerformed = true;
}
if (!mappingPerformed)
return false;
}
return true;
}