focusedamazonec2
amazonec2 时间:2021-03-26 阅读:(
)
AugmentingComplexProblemSolvingwithHybridComputeUnitsHong-LinhTruong1,HoaKhanhDam2,AdityaGhose2,andSchahramDustdar11DistributedSystemsGroup,ViennaUniversityofTechnology,Austria{truong,dustdar}@dsg.
tuwien.
ac.
at2UniversityofWollongong,Australia{hoa,aditya}@uow.
edu.
auAbstract.
Combiningsoftware-basedandhuman-basedservicesiscrucialforseveralcomplexproblemsthatcannotbesolvedusingsoftware-basedservicesalone.
Inthispaper,wepresentnovelmethodsformodelinganddevelopinghybridcomputeunitsofsoftware-basedandhuman-basedservices.
Wediscusshigh-levelprogrammingelementsfordifferenttypesofsoftware-andhuman-basedserviceunitsandtheirrelationships.
Inparticular,wefocusonnovelprogrammingelementsreectinghybridity,collectivenessandadaptivenessprop-erties,suchaselasticityandsocialconnectiondependencies,andon-demandandpay-per-useeconomicproperties,suchascost,qualityandbenets,forcom-plexproblemsolving.
Basedontheseprogrammingelements,wepresentpro-grammingconstructsandpatternsforbuildingcomplexapplicationsusinghybridservices.
1IntroductionRecently,severalnovelconceptshavebeenintroducedtoexploithumancomputingcapabilitiestogetherwithmachinecomputingcapabilities.
Thiscombinationhasintro-ducedanewformof"computingmodel"thatincludesbothmachine-basedandhuman-based"computers".
Inthisemergingcomputingmodel,machine-basedandhuman-basedcomputingelementsareinterconnectedindifferentways,thusitispossibletosupportdifferentprogrammingmodelsbuiltontopofthem.
Indeed,therearedifferentwaystodevelopapplicationsatopsuchanewcomputingmodel.
Inthecurrentresearchapproaches,human-basedcapabilitiesareusuallyprovi-sionedvia"crowdsourcing"platforms[1]orspecichuman-taskplug-ins[2,3].
Theseapproachesachievehumanandsoftwareintegrationmainlyusing(specic)platformintegration.
Themainprogrammingmodelismostlytheworkowwhichishowevernotexibleenoughforprogrammingdifferenttypesofinteractionsamongmultipletypesofservices.
Intheseapproaches,essentialprogrammingelementsrepresentingsoftware-basedservices(SBS)andhuman-basedservices(HBS)cannotbeprogrammeddirectlyintoapplications.
Furthermore,theseapproachesdonotprovideauniformviewofSBSandHBS,andletthedeveloperperformthecomplextasksofestablishingrelationshipsbetweenSBSandHBS.
Inaddition,althoughSBSandHBScanbeprovisionedusingcloudprovisioningmodels(thustheycanberequestedandinitiatedon-demandunderA.
R.
Lomuscioetal.
(Eds.
):ICSOC2013Workshops,LNCS8377,pp.
95–110,2014.
cSpringerInternationalPublishingSwitzerland201496H.
-L.
Truongetal.
differentquality,costandbenetmodels),thereisalackofmechanismstoprogramexplicitlyquality,cost,andbenetconstraintsforcomplexelasticapplications.
Inthispaper,weviewthe"newcomputingmodel"asacollectionofdiverseandhet-erogeneousSBSandHBSthatcanbeprovisioned(e.
g.
,bycloudcomputingmodels)on-demandunderdifferentcost,benetsandqualitymodels.
Thisviewisverydiffer-entfromhuman-basedworkowsofwhichtasksandowsare(statically)mappedtohumans.
Morespecically,ourmodelconsidershumansasaserviceunit,likesoftwareserviceunits,andtakesintoaccountdiversetypesofrelationshipsamonghuman-basedandsoftware-basedserviceunits,quality,costandbenetproperties.
Ourapproachprovidesconceptsfordevelopingsuchapplicationswherehybridserviceunits,theirre-lationships,andcost,qualityandbenetsarerst-classprogrammingelements.
Hence,ourapproachprovidesahigherlevelofabstractionandaexiblewayforcombininghybridity,collectivenessandadaptivenessofhuman-basedandsoftware-basedservices.
Therestofthispaperisorganizedasfollows:Section2discussesbackground,relatedworkandourapproach.
Section3servestodescribeprogrammingelementscoveringunits,relationshipsandnon-functionalparameters.
InSection4wedescribehigh-levelprogrammingconstructs.
Section5illustratesanexampleofhowourapproachworksinpractice.
WeconcludethepaperandoutlineourfutureworkinSection6.
2BackgroundandRelatedWorkSeveraltypesofSBS,suchasInfrastructure-as-a-Service(IaaS),Platform-as-a-Service(PaaS),Software-as-a-Service(SaaS),andData-as-a-Service(DaaS),havebeenavail-ableandwidelyusedinpractice.
AmongthesetypesofSBS,SaaSandIaaSarewellconceptualizedusingservicemodelsandthedevelopercaneasilyprogramandutilizeSBS,theirdataandcontrolows,usingAPIs,suchas,JClouds1,Boto2andOpen-Stack3.
Ontheotherhand,HBShavebeenemergingandseveralworkhavedevotedforvirtualizingHBSandintegratingthemwithSBS.
MostsystemssupportHBSintermsofprovidingspecicplatformsandplug-ins.
CloudAPIsforinterfacingtohumansandon-demandaccessingHBShavebeenproposed[4].
Although,suchexistingworkhas,tosomeextent,yetmatured,thereisanincreasingdemandforapplicationsthatusebothHBSandSBS.
However,existingprogramminglanguagesandtoolsdonotcon-siderandexploitwelltheuseofHBSandSBStogether,inaexible,on-demand,andpay-per-usemanner.
Inthefollowing,wediscussourmainrelatedwork.
Software-BasedServiceUnitsConstructs:Thereexistseveralframeworksforengi-neeringandexecutingcloudapplicationsusingdifferentIaaS,PaaSandSaaS,suchasAneka[5],BOOM[6].
Theyabstractcloudresourcesandsupportdifferentprogram-mingmodels,suchasMapReduceanddataows.
Buttheydonotconsiderhybridser-vicesconsistingofSBSandHBSanddonotprovidehighlevelprogrammingconstructsformodellingtherelationshipsamongHBSandSBS.
MostofthemrelyontraditionalrelationshipsamongSBS,suchascontrolanddatadependencies,modeledinspecicapplicationstructuredescriptions,workowsanddeclarativeprogramminglanguages.
1http://www.
jclouds.
org/2http://docs.
pythonboto.
org/en/latest/index.
html3http://www.
openstack.
org/AugmentingComplexProblemSolvingwithHybridComputeUnits97HumanComputationProgrammingFrameworks:Therehavebeenanincreasingnumberofprogrammingframeworksforhumancomputationintroducedinrecentyears.
Mostofexistingwork(e.
g.
,Crowdforge[1],TurKit[2])considerhumanworkersasbeinghomogeneousandinterchangeable,whichisusefulindevelopingcrowdsourc-ingsolutionswherescalabilityandavailabilityarethemainissues.
Suchframeworks,however,providelimitednotionofidentity,humanskills,andsocialrelationshipswhichareimportantindevelopinganecosystemofconnected,heterogeneouspeopleandsoft-ware.
TherecentJabberwockyframework[7]hasaddressedthisissuetosomeextentbyprovidingaprogrammingenvironmentforbothhumanandmachinecomputation.
Jab-berwockyalsoallowstheprogrammertospecifytypesofpeoplebasedonpersonalpropertiesandexpertiseandroutetasksbasedonsocialstructure.
However,Jabber-wockydoesnotallowtoexplicitlymodeltherelationshipsbetweenpeopleandma-chines.
General-purposeprogramminglanguagesforhumancomputation,suchasCrowdLang[8],donotrelyonservicemodelsanddonotconsiderquality,cost,bene-tsandelasticityasrst-classentitiesinprogrammingandconstructinghybridcomputeunits.
High-LevelConstructsforHybridComputeUnits:UsingseverallowlevelAPIsforaccessingSBS,likeJClouds,Boto,andOpenStack,thedevelopercandeneSBSob-jectsandestablishdataandcontrolows.
Ourpreviouswork(e.
g.
,[4])hasfocusedonprovidingwell-denedAPIsforprovisioningHBS.
However,thereisalackofsupportforprogrammingdifferenttypesofrelationshipsamongSBSandHBS.
Thedeveloperhastodothisonhis/herown.
Asaresult,he/shewouldnditdifculttocodesuchrelationshipsduetothelackofwell-denedprogrammingelements,inparticularthoserelatedtocost,benet,qualityconstraintsandtomixedcompositionsofSBSandHBS.
Theuseofgeneric"buildingblocks"abstractingpatternsandprovidingthemviaAPIstosimplifythedevelopertaskiswell-knowninSBSinclouds[9].
However,nohigh-levelprogramconstructsandcodegenerationhavebeenproposedforHBSandSBSincloudenvironments.
ComparedwithexistingworkwearefocusingoncombiningHBSandSBSforhybridcomputeunitsusingservicecomputingandcloudcomputingmodels.
Ourap-proachsupportsuniedframeworkforhumanandsoftware,andprovidehigh-levelprogrammingconstructsfordifferenttypesofservices,relationships,andcost,quality,andbenetsmodels.
3FundamentalElementsforHybridComputeUnits3.
1Service-BasedComputeUnitsInourmodel,atthecoreofSBSandHBSthereare"processingunits",realizedviaeithermachineCPUs/coresorhumanbrains.
Toprogramanapplication,thedevelopercanexploitanSBSorHBSviaanabstractserviceunit.
Therefore,anapplicationdevel-opedinourframeworkisabstractlyviewedasconsistingofanumberofservice-basedcomputeunits(seeFigure1)andtheirinteractions.
AUnitcanperformanumberfunc-tions(e.
g.
,detectingapatterninorenrichingthequalityofanimage)withinputandoutputdata.
Aunitalsohasanumberofcost,benet,andqualityproperties(seeSec-tion3.
3formoredetails).
AunitcanbeeitheraSBS(Software-BasedService)orHBS98H.
-L.
Truongetal.
(Human-BasedService).
WefurtherdivideHBSintoICU(IndividualComputeUnit–representingaserviceofferedbyanindividual)andSCU(SocialComputeUnit–representingaserviceofferedbyateam).
BothHBSandSBSunitscanpotentiallysup-portelasticityintermsofcapability(resource),costandquality[10].
Forexample,aSBSfordataanalyticscanincreaseitscostwhenbeingaskedtoprovidehigheranalysisaccuracyoraSCUcanreduceitssizeandthecostwhenbeingaskedtoreducethequal-ityoftheresult.
Tosupportsolvingcomplexproblemswithelasticserviceunits,wemodelelasticitycapability(ElasticityCapability)andassociateitwithUnit.
Fig.
1.
AconceptualmodelforelementsinprogramminghybridcomputeunitsASBSunitcanbeinnumberofknownsoftwareformsofferedincloudcomputingmodels,suchasIaaS(e.
g.
,AmazonEC),DaaS(e.
g.
,MicrosoftAzureDataMarket-place),PaaS(e.
g.
,GoogleAppEngine)orSaaS(e.
g.
,Salesforce.
com).
AlthoughmanyongoingworkisstillbeingdevelopedforSBS,SBSarealreadyextensivelyexploredintermsofservicemanagement,capabilities,andfunctionmodeling.
Therefore,werelyonexistingcommonmodelsforrepresentingSBS.
ForHBS,theircomputingcapabilityisspeciedintermsofhumanskillsandskilllevels.
Therefore,inourmodelaHBSunithasasetofSkills,eachofwhichisasso-ciatedwithaskilllevel.
Thoseskillsandskilllevelscanbedenedconsistentlywithinaparticularserviceprovisioningplatform(usingevaluationtechniques,benchmarking,ormappingskillsfromdifferentsourcesintoacommonviewforthewholeplatform).
Therefore,weassociateeachHBSwithaHumanPowerUnit(HPU)[4],avaluedenedbytheHBSprovisioningplatformtodescribethecomputingpoweroftheHBSbasedonitsskillsandskilllevels,whicharealwaysassociatedwithspecicArchetypesindicatingthedomaininwhichtheskillsareestablished.
AugmentingComplexProblemSolvingwithHybridComputeUnits99BycombiningasetofHBSandSBS,weintroducehybridcomputeunits(HCUs).
AHCUisacollective,hybridservice-basedunitsamongwhichthereexistdifferenttypesofrelationships,coveringhuman-specic,software-specic,aswellashuman-softwarespecicones.
AHCU,asacollectiveunit,canbeelastic:itcanbeexpandedandreducedbasedonspecicconditions.
3.
2RelationshipsbetweenServiceUnitsUsingcloudcomputingprovisioningmodelsinwhichSBSandHBSareabstractlyrepresentedunderthesameserviceunitmodelwithpay-per-useandon-demandser-viceusage,arangeofprogrammingelementsreectingrelationshipsamongdifferenttypesofserviceunitsareimportantandusefulinbuildingcomplexapplications.
Table1describesdifferenttypesofrelationshipsbetweenserviceunitsthatweconsiderasimportantprogrammingelements,eachofwhichappliestoHBS,SBSorHCU.
Table1.
DifferenttypesofrelationshipsbetweenservicesRelationshipTypeHBSSBSHCUDescriptionSimilarityYesYesYesThistraditionaltypeofrelationshipindicateshowsimilaraserviceistoanother.
Inprinciple,similaritycanbemea-suredintermsoffunctions,non-functionalparametersandsocialcontexts.
CompositionYesYesYesThiswell-knowntypeofservicerelationshipsindicatesthataserviceiscomposedofseveralotherservices.
Datadepen-dencyYesYesYesAservicedependsonanotherserviceiftheformerrequiresthelatterforprovidingacertaindataforoneofitsfunc-tions.
Controldepen-dencyYesYesYesAservicedependsonanotherserviceiftheoutcomeoflat-terdetermineswhetherformershouldbeexecutedornot.
LocationdependencyYesYesYesThelocationsoftwoserviceunitsaredependent,e.
g.
,co-locatedinthesamedatacenterorcountryForwardingYesYesYesThisisaformofbrokering/outsourcinginwhichataskisforwardedformoneservicetoanother.
DelegationYesYesYesThisisaformofbrokering/outsourcinginwhichaservicedelegatesatasktoanotherservice.
SocialrelationYesNoYesThisrelationshipdescribesdifferenttypesofsocialrela-tions(e.
g.
familyorLinkedinconnection)betweentwoser-vices.
ElasticityYesYesYesThisrelationshipdescribeshowaserviceunitisformedbyelasticizinganotherserviceunit,e.
g.
viaresizing,replac-ingor(de)composingelementsofthelatertooffersimilarfunctionsbutdifferentcost,benetandqualityatruntime.
Similarity.
Giventhatcertaintaskscanbeconductedbysoftwareorhuman,develop-erswillneedtocompareHBSandSBSinordertoselectsuitableonesforthetasks.
WeextendtraditionalsimilarityamongSBSforHBS(e.
g.
,simulationresultanalysiscanbe100H.
-L.
Truongetal.
providedbytwodifferentresearchteamswhicharesimilarintermsofarchetypeand/orcost)orbetweenHBSandSBS(e.
g.
,specicimagepatternscanbedetectedbyscien-tistsorimageprocessingsoftware).
Fromtheprogrammingperspective,similaritycanbespeciedinapplicationsintermsofcostandquality(forallunittypes),archetype(betweenHBSunits),capability(betweenSBSunits)andfunction(betweenHBSandSBSunits).
Composition.
ComposingHBSandSBSunitsforcomplextasksarepossible.
There-fore,weextendtraditionalcompositionrelationshipstocoveralsocompositesofhybridservices,suchasdescribinghowICUcanbecomposedwithSBStoestablishhuman-basedlter.
Compositioncanbeindifferentformssuchasdataorcontroldecomposi-tion,andcanbestructuredindifferentways(e.
g.
,starvs.
ringstructure).
Dependency.
Wesupporttheclassicalviewofdependencybetweenservicesintermsofdata(aservicerequiresdataprovidedbyanotherservice)andcontrol(aservicerequiresansuccessfulcompletionofanotherservice).
DataandcontroldependenciescanbeprogrammedforanytypesofSBSandHBS.
Inparticular,dataexchangebetweentwounitscanbeconductedviaotherserviceunits(e.
g.
,twoHBScanexchangedataviaDropbox–aSBS).
Furthermore,weconsiderlocationdependencywhichiscrucialincloudsduetonotonlyperformancebutalsocompliancerequirements.
Developerscanusethelocationdependencytocontroltheco-locationofservices.
Brokering.
Weconsiderbrokeringrelationshipsforworkdistributionamongserviceunits.
Twotypesofbrokeringrelationshipsareconsidered:delegation(aservicemanip-ulatesarequest/responseanddelegatestherequest/responseto/fromanotherservices)andforwarding(aservicejustforwardsrequest/resultto/fromanotherservice).
Withhybridservices,suchrelationshipscanalsobeestablishedbetweenaSBSandaHBS,e.
g.
,aSBScandecidewhereaSBSoranHBSwillbeusedforevaluatingthequalityofdatabasedonthetypeofthedata.
SocialRelation.
WhenusingHBSforcertaintasksincomplexapplications,wemayrequirespecicsocialrelationsamongHBSsolvingthetasks,forexample,twoscien-tistswhohaveconductedajointresearchbefore.
Tosupportthis,socialrelationsareconsideredasprogrammingelements.
Elasticity.
Thisemergingrelationshipisduetotheelasticitycapabilityofservicesatruntime[10].
Totheconsumer,elasticitymeansthattheexpectedservicefunctionisunchangedbutthecost,benetsand/orqualitycanbescaledup/downatruntime.
Totheserviceprovider,toenabletheelasticityofcosts,benets,and/orquality,atruntimeserviceunitscanbereplacedbydifferentvariantsorsimilarunitsor(re)composedbyadding/removingappropriateunits,ornewcompositionsareintroduced.
3.
3Quality,Cost,andBenetsSBSandHBShavecommonanddistinguishablequality,costandbenetproperties.
Inordertoallowprogrammerstospecifytheseproperties,wesupportthefollowingprogrammingelements:AugmentingComplexProblemSolvingwithHybridComputeUnits101–Quality:representscommonqualitymetricsandmodelsforprocessingunitsanddata.
QualitycanbefurtherclassiedintoPerformanceforprocessingcapa-bilitiesofserviceunitsandQoD(qualityofdata)forinput/outputofserviceunits.
PerformanceandQoDcanhaveseveralothersubentities,suchasResponse-Time,Availability,Accuracy,andCompleteness.
–Cost:representsmonetarypricingmodels,suchaschargingorrewardingmodels.
–Benets:representsnon-monetarybenets.
Itisclassiedintodifferententities,suchasReturn-on-OpportunityorPromotion.
Weconsiderthesepropertiesasrst-classprogrammingelementssinceserviceunitsareconstrainedbyvarioustypesofcost,benetandqualitymodelsandtheserviceproviderwantstoprogramherSBS/HBS/HCUtobeabletoscalein/outwithexpectedqualityunderdesirablecostandbenetatruntime.
Forexample,inasituationwithsev-eralreal-timeeventssignalinganemergencysituation,anHCUmightbeprogrammedtoreducetheaccuracyofanalyticsinordertomeettheresponsetimetoquicklyreacttothesituation.
Ontheotherhand,innon-criticalsituationsitcouldbeprogrammedtoutilizemore(cheap)HBStominimizethecost,maximizetheaccuracy,butacceptanincreasingresponsetimeasatrade-off.
Therefore,treatingthesepropertiesasrst-classprogram-mingelementswillallowthedevelopertoexplicitlyspecify,control,andenforceelasticconstraints.
4High-LevelConstructsforHybridComputeUnitsFromourproposedfundamentalelements,inordertoassistthedevelopmentofcomplexapplications,wedevelopanumberofhigh-levelconstructsforserviceunitsandtherelationshipsbetweenthemthathelpestablishinteractionsamongunitsinahybridcomputeunit.
ThoseconstructscorrespondtotheconceptualmodelelementspresentedinFigure1.
ConstructsforserviceunitshaveasetofAPIsthatcanbecalledupontheunits.
Constructsforarelationshiphaveasetof(usage)patternsthatcanbeusedtoestablishtherelationship.
Constructsforcost,qualityandbenetsalsohaveasetofAPIsforspecifyingexpectedcosts,qualityandbenets.
Usinghigh-levelprogrammingconstructsthedevelopercanfocusonthelogicofthehybridcomputeunit,insteadofdealingwithimplementation-specicdetailsofserviceunitsandcomplexalgorithmsforestablishingrelationshipsamongunits.
Table2presentsmainprogrammingconstructsforrelationships,eachofwhichisabstractlyrepresentedasafunctionwhichtakesanumberofarguments.
Therearetwotypesoffunctions:onethattakesgroundedvariables(denotedascapitalletters)asar-guments,andonethattakesfreevariable(denotedaslowercaseletters)asarguments.
Thelatterisdenotedwiththesymbol""inthefunctionname.
Inthefollowing,weexplainsomepossiblealgorithmicpatternsforhigh-levelconstructsforrelationships:Similarity.
Theconstructsimilarity(U,V,criteria)representsasimilarityrelation-shipbetweenunitsUandVwithregardtoagivencriteria(namely"Cost","Quality",102H.
-L.
Truongetal.
Table2.
High-levelconstructsforrelationshipsinhybridcomputeunitsConstructDescriptionsimilarity(U,V,criteria)trueifUissimilartoVw.
r.
t.
criteriadatadependency(U,D,[M,]V)UproducingdataDwhichisneededbyV.
TheoptionalmediumisthelocationassociatedwithaDaaS(e.
g.
,aDropboxURL)wherethedatawillbeplacedandshared.
controldependency(U,V)declaresthatVshouldexecuteonlyafterUnishes.
locationdependency(U,V,ctx,path)declaresthatUandVshouldbelinkedinagivenlocationcontext(e.
g.
,countryordatacenter)withapathinthatcontext(e.
g.
,cityorserverrack)composition(structure,type,U1,U2,Un)constructacompositionofU1,U2,.
.
.
,Unforagivenstruc-turemodelandtypeforward(U,t,V)UforwardstaskttoV.
delegate(U,t,V)UdelegatestaskttoV.
socialrelation(U,V,ctx,path)returnsadistancerelationbetweenUandVinagivensocialcontext.
elasticity(U,[Func,]NFPs,x)xisanewformofUorxprovidesfunctionFunctosat-isfygivencost/quality/benetmodelsspeciedinNFPs.
"Archetype",or"Function").
Avariantofthisconstructissimilarity(U,x,criteria)whichreturnsasetofunitssimilartoUwithregardtoagivencriteriaandstoretheminafreevariablex.
Pseudoalgorithmicforthisconstructusagesisshownbelow.
if(criteria=="Cost")returnsimCost(U,V);elseif(criteria=="Quality")returnsimQuality(U,V);elseif(criteria=="Archetype"&&U.
type==HBS&&V.
type==HBS)return(U.
Archetype==V.
Archetype);elseif(criteria=="Function")returnU.
Function==V.
Function;returnfalse;DataDependency.
Theconstructdatadependency(U,D,M,V)statesthatVde-pendsonUfordataDandmediumMwherethedataisstored.
Variantsofthisconstructincludedatadependency(x,D,M,V)(ndunitxwhichprovidesdataDneededbyunitV),datadependency(U,D,M,x)(ndunitxwhichneedsdataD),anddatadependency(U,D,x[c],V)(ndamediumxthatcanbeusedtoshareDbetweenUandVsatisfyingagivenconstraintc).
Pseudoalgorithmiccodefordatadependencyconstructsareshowninthefollowing:datadependency(U,D,M,V){UnitstorageUnit=M;if(M==null)storageUnit=getDedaultMedium()requestUstoresDintostorageUnit//gettheURIindicatingthelocationofthedataURIuri=storageUnit.
getURI(D)requestVaccessDfromuri}AugmentingComplexProblemSolvingwithHybridComputeUnits103LocationDependency.
Theconstructlocationdependency(U,V,ctx,path)estab-lishesalocationdependencybetweenUandVbasedonaspeciccontextctxandaspecicpathincxt.
Herectxcanrepresenthuman-speciclocationcontext,suchasthecloudplatformprovidingHBS(e.
g.
,basedonAmazonMechanicalTurk)orthecountry,orclouddatacenterlocationshostingSBS(e.
g.
,AmazonEC2EUsite).
Thepathcanindicatefurtherdependenciesinctx,suchasthesamecityorthesameserverrackinadatacenter.
Brokering.
Delegationandforwardingrelationsaresimplyrepresentedbydelegate(U,task,V)andforward(U,task,V)wheretaskisagiventaskthatneedstobedelegatedorforwarded.
Avariantofthedelegationconstructisdelegate(U,task,x)whichndsaappropriateunitxthatUcandelegatetasktto.
Pseudocodegeneratedfordelegate(U,task,x)aregivenasfollows:foru:listUnit()forf:u.
listFunction()if((f.
input==task.
in)&&f.
output==task.
out){u.
execute(task);U.
waitUntil(task.
finished==true);U.
addInput(task.
out);return;}SocialRelations.
Theconstructsocialrelation(U,V,ctx,path)returnsadistancebetweenUandV(HBSonly)viasocialrelationsinagivensocialcontext,denotedby(cxt,path).
ItcanalsobeusedtoestablishasocialrelationconstraintbetweenUandV.
Thecontextctxisasocialnetwork(e.
g.
,Linkedin)andpathisaspecicgroupinthatnetwork(e.
g.
,datascientist).
Anegativedistance(e.
g.
,-1)indicatesthatthereisnosocialrelationfoundbetweenUandV,whilstavalueof0indicatesthattheybelongstothesamegivensocialgroup(e.
g.
,indatasciencegrouponLinkedin).
Ontheotherhand,apositivevalueindicatesthattheyarerelatedviasomethirdpartieswhoaredirectlyrelatedwiththem,e.
g.
,AisaLinkedincolleagueofB,Bisacol-leagueofC,thenthedistancebetweenAandCis1.
InordertondaHBSthatissociallyrelatedtoagivenHBSwithinaspecieddistance,onecanusetheconstructsocialrelation(U,x,distance,ctx,path).
Thepseudoalgorithmiccodeforsocialrelation(U,x,distance,ctx,path)constructisasfollows:socialrelation(U,x,distance,ctx,path){forhbs:listHBS()//getthesubgraphofthesocialnetworkwithinacontextGraphsocialNet=getSocialNetwork(ctx);//findthedistanceintd=social.
findDistance(U,hbs,path);ifd0.
9){preProcessedData=preprocessingUnit.
execute("preprocessing",params);}SpecifyingLocationDependency.
LetsolverUnitbethesolverSBSunit.
ThefollowingcodeexcerptshowshowtomakesurethatthepreprocessingUnitandsolvingUnitshouldbecolocatedinthesamedatacenterinordertominimizethedatatransferamongthem://createanewsoftwareunitforsimulationsolversSBSsolverUnit=newSBS("solver");//makesurethesolverunitandthepreprocessingunitareinthesamedatacenterRelationship.
locationDependency(preprocessingUnit,solverUnit,"AmazonEC2:Europe");ArrayListparams1=newArrayList();params1.
add(preProcessedData);//executesolverunitwithinputdatafrompreprocessingunitObjectsolverResult=solverUnit.
execute("solving",params1);ProgrammingElasticityandCollectivenessinSolvingSteps.
Usingdifferentcon-structs,theprogrammercaninvokedifferenttypesofunitstodealwithdifferentsitua-tions.
ThefollowingcodeexcerptshowsexamplesofusingICUtocheckwhythedataisbadortondsolversthatcanhandledirtydataaslongastheymeetcostandqualityrequirements:AugmentingComplexProblemSolvingwithHybridComputeUnits107DoubleqodPreProcessedData=(Double)qodEvalUnit.
execute("qodEvaluate",params1);//getanICUtocheckwhydataisbadif(qodPreProcessedDatascuDropbox=null;DropboxAPI.
DropboxLinklink=scuDropbox.
share("/hbscloud");//askthecloudofHBStoinvoketheICUVieCOMHBSvieCOMHBS=newVieCOMHBSImpl();vieCOMHBS.
startHBS(dataScientist);HBSMessagemsg=newHBSMessage();msg.
setMsg("pls.
useshareddropboxforcommunication"+link.
url);vieCOMHBS.
sendMessageToHBS(dataScientist,msg);}elseif(qodPreProcessedData<0.
7){//inthiscase,wejustneedasoftwaretocleanthedataSBSdataCleansing=newSBS("datacleaner");}elseif(qodPreProcessedData<0.
9){//specifysomestaticpropertiesofthesolverSBSsolverUnit2=newSBS("solver");solverUnit2.
capabilities.
put("DIRTY_DATA",Boolean.
valueOf(true));//specifyexpectedcostandaccuracysupportCostModelcostModel=newCostModel();costModel.
price=100;//maxinEURcostModel.
usageTime=10006060;//1hourQualityquality=newQuality();quality.
name=Quality.
ACCURACY;quality.
value=0.
95;//minimumvalueArrayListnfps=newArrayList();nfps.
add(quality);nfps.
add(costModel);//findsolversmetqualityandcostneedsSBSelasticSolverUnit=(SBS)Relationship.
elasticity(solverUnit2,nfps);ObjectsolverResult2=elasticSolverUnit.
execute("solving",params1);}else{}ForwardingandDelegatingAnalysisRequest.
Afterpost-processing,indataanalysis,ananalystcancaptureanunknownpatternwhichhe/shecanforwardtohis/herresearchconnectors,whohaveasocialrelationtohim/herinLinkedin.
108H.
-L.
Truongetal.
Aprofessormayreceivethispatternandhe/shedelegatestheanalysistaskstohis/herSCU,asetofgraduatestudents.
Thefollowingcodeexcerptshowstheabove-mentionedillustrativetasks:ICUdataScientist=newICU();ICUfUnit=newICU();Relationship.
socialrelation(dataScientist,fUnit,1,"Linkedin:DataScienceGroup/TUWien");Relationship.
forward(data,fUnit);SCUstudentSCU=newSCU();//.
.
Relationship.
delegate(data,studentSCU);5.
3ComparisonofProgrammingModelsforCloudApplicationsWealsoconductacomparisonofourapproachwithotherprominentprogrammingframeworksforcloudapplications.
Thesetoffeaturesthatareconsideredinthiscom-parisonis:–Proactivehumanservice:supportforproactivelyinvokinghuman-basedserviceunitsthroughhuman'scapabilitiesareutilized.
–Elasticity:supportforadaptingservicesagainstchangingnon-functionalparame-ters.
–Teaminteraction/collaborativepatterns:supportforinteractionsand/orcollabora-tionpatternsamongdifferentservicestoestablishteamwork.
–Socialstructure/relations:supporttorequestservicesbasedonsocialstructureand/orrelations.
–Uniedframeworkforhumanandsoftware:allowthedevelopertonaturallypro-gramsoftwareservicesandhuman-basedservicesinsimilarways.
–Cross-platform:workwithanycloudplatformthathooksintotheframeworkandandcansupportexecutionacrossseveralplatformsinthesameprogram.
ProgrammingFeatureCrowdforgeTurKitJabberwockyJCloudsOpenStackVieCOMProactivehumanserviceNNYNNYExplicitcost/benets/qualityNNNNNYElasticityNNNNNYTeaminteraction/collabora-tivepatternsNNNNNYSocialstructure/relationsNNYNNYUniedframeworkforhu-manandsoftwareNNYNNYCross-platformNNYYYYFig.
4.
ComparisonofdifferentprogrammingmodelsforcloudapplicationsAugmentingComplexProblemSolvingwithHybridComputeUnits109Figure4describesourcomparison.
Itisnotastrangeresultthat,conceptually,ourapproach(VieCOM)supportsseveralfeatures,inparticular,coveringbothSBSandHBS.
ThemainreasonisthatcurrentlyexistingframeworksfocuseitheronSBSorHBS.
WhileJabberwockyalsosupportsSBSandHBS,itdoesnotsupportprogrammingelementsfordeningcosts,benetsandqualityaswellaselasticityrelations.
6ConclusionsandFutureWorkEmergingpay-per-usemodels,on-demandserviceacquisition,andadvancedhuman-machineintegrationtechniquesenabletheprovisioningofhumanandmachinecapabil-itiesunderthesameservicemodeltosupportthedevelopmentofcomplexapplications.
Inthispaper,weinvestigatehighlevelprogrammingsupportsforsolvingcomplexprob-lemsusingsoftware-basedandhuman-basedcomputeunits.
Wehavepresentedarangeofpossiblefundamentalprogrammingelementsabstractingsoftwareandpeopleandseveralpossiblehigh-levelconstructs.
Asthepapermainlydiscussesabouthigh-levelmodelsandconstructs,ourvalidationislimitedtoillustratingexamplesandcompar-isons.
Webelievethatprogrammingelementsandhigh-levelprogrammingconstructspresentedinthispapercanbefoundationsforthedevelopmentofdomain-speciclan-guagesandsoftwareengineeringprocessesforhybridcomputeunits.
Ourfutureworkinvolvesfurtherdevelopingourprototypeandtoolingsupportfortheproposedhigh-levelprogrammingconstructs.
Acknowledgment.
TheworkmentionedinthispaperispartiallysupportedbytheEUFP7SmartSociety.
References1.
Kittur,A.
,Smus,B.
,Khamkar,S.
,Kraut,R.
E.
:CrowdForge:crowdsourcingcomplexwork.
In:Proceedingsofthe24thAnnualACMSymposiumonUserInterfaceSoftwareandTech-nology,UIST2011,pp.
43–52.
ACM,NewYork(2011)2.
Little,G.
,Chilton,L.
B.
,Goldman,M.
,Miller,R.
C.
:Turkit:toolsforiterativetasksonme-chanicalturk.
In:ProceedingsoftheACMSIGKDDWorkshoponHumanComputation,HCOMP2009,pp.
29–30.
ACM,NewYork(2009)3.
Marcus,A.
,Wu,E.
,Karger,D.
,Madden,S.
,Miller,R.
:Human-poweredsortsandjoins.
Proc.
VLDBEndow.
5,13–24(2011)4.
Truong,H.
-L.
,Dustdar,S.
,Bhattacharya,K.
:Programminghybridservicesinthecloud.
In:Liu,C.
,Ludwig,H.
,Toumani,F.
,Yu,Q.
(eds.
)ICSOC2012.
LNCS,vol.
7636,pp.
96–110.
Springer,Heidelberg(2012)5.
Calheiros,R.
N.
,Vecchiola,C.
,Karunamoorthy,D.
,Buyya,R.
:TheAnekaplatformandqos-drivenresourceprovisioningforelasticapplicationsonhybridclouds.
FutureGenerationComp.
Syst.
28(6),861–870(2012)6.
Alvaro,P.
,Marczak,W.
R.
,Conway,N.
,Hellerstein,J.
M.
,Maier,D.
,Sears,R.
:DEDALUS:Datalogintimeandspace.
In:deMoor,O.
,Gottlob,G.
,Furche,T.
,Sellers,A.
(eds.
)Datalog2010.
LNCS,vol.
6702,pp.
262–281.
Springer,Heidelberg(2011)7.
Ahmad,S.
,Battle,A.
,Malkani,Z.
,Kamvar,S.
:Thejabberwockyprogrammingenvironmentforstructuredsocialcomputing.
In:Proceedingsofthe24thAnnualACMSymposiumonUserInterfaceSoftwareandTechnology,UIST2011,pp.
53–64.
ACM,NewYork(2011)110H.
-L.
Truongetal.
8.
Minder,P.
,Bernstein,A.
:crowdLang:Aprogramminglanguageforthesystematicexplo-rationofhumancomputationsystems.
In:Aberer,K.
,Flache,A.
,Jager,W.
,Liu,L.
,Tang,J.
,Gueret,C.
(eds.
)SocInfo2012.
LNCS,vol.
7710,pp.
124–137.
Springer,Heidelberg(2012)9.
Fehling,C.
,Leymann,F.
,Ruetschlin,J.
,Schumm,D.
:Pattern-baseddevelopmentandman-agementofcloudapplications.
FutureInternet4(1),110–141(2012)10.
Dustdar,S.
,Guo,Y.
,Satzger,B.
,Truong,H.
L.
:Principlesofelasticprocesses.
IEEEInternetComputing15(5),66–71(2011)11.
Reiter,M.
,Breitenb¨ucher,U.
,Dustdar,S.
,Karastoyanova,D.
,Leymann,F.
,Truong,H.
L.
:Anovelframeworkformonitoringandanalyzingqualityofdatainsimulationworkows.
In:eScience,pp.
105–112.
IEEEComputerSociety(2011)
imidc怎么样?imidc彩虹数据或彩虹网络现在促销旗下日本多IP站群独立服务器,原价159美元的机器现在只需要88美元,而且给13个独立IPv4,30Mbps直连带宽,不限制月流量!IMIDC又名为彩虹数据,rainbow cloud,香港本土运营商,全线产品都是商家自营的,自有IP网络资源等,提供的产品包括VPS主机、独立服务器、站群独立服务器等,数据中心区域包括香港、日本、台湾、美国和南非...
柚子互联官网商家介绍柚子互联(www.19vps.cn)本次给大家带来了盛夏促销活动,本次推出的活动是湖北十堰高防产品,这次老板也人狠话不多丢了一个6.5折优惠券而且还是续费同价,稳撸。喜欢的朋友可以看看下面的活动详情介绍,自从站长这么久以来柚子互联从19年开始算是老商家了。六五折优惠码:6kfUGl07活动截止时间:2021年9月30日客服QQ:207781983本次仅推荐部分套餐,更多套餐可进...
ttcloud怎么样?ttcloud是一家海外服务器厂商,运营服务器已经有10年时间,公司注册地址在香港地区,业务范围包括服务器托管,机柜托管,独立服务器等在内的多种服务。我们后台工单支持英文和中文服务。TTcloud最近推出了新上架的日本独立服务器促销活动,价格 $70/月起,季付送10Mbps带宽。也可以跟进客户的需求进行各种DIY定制。点击进入:ttcloud官方网站地址TTcloud拥有自...
amazonec2为你推荐
蓝色骨头手机宠物的一个蓝色骨头代表多少级,灰色又代表多少级,另外假如有骨头又代表多少级mathplayerjavascript 如何判断document.body.innerHTML是否为空mole.61.com谁知道摩尔庄园的网址啊qq530.com求教:如何下载http://www.qq530.com/ 上的音乐抓站工具仿站必备软件有哪些工具?最好好用的仿站工具是那个几个?杨丽晓博客杨丽晓是如何进入娱乐圈的?www.22zizi.com乐乐电影天堂 http://www.leleooo.com 这个网站怎么样?sodu.tw台湾的可以看小说的网站百度关键字百度推广关键词匹配方式有哪些?邯郸纠风网邯郸市信访局地址
荷兰vps lamp 香港vps99idc 安云加速器 搬瓦工官网 国内加速器 免费网站申请 可外链相册 qq对话框 服务器干什么用的 爱奇艺会员免费试用 360云服务 跟踪路由命令 空间登入 注册阿里云邮箱 万网注册 免费网络空间 杭州电信宽带 umax tracker服务器 更多