inst/ct_shiny/Simulations/mergersSims.R

mergersSims <- function(supply, demand, indata, mktElast, type = c("Horizontal", "Vertical")){
  # a function to execute code from antitrust package based on ui inputs

  type <- match.arg(type)

  if (type == "Horizontal") {

    prices <- indata[,"Prices \n($/unit)"]
    margins <- indata$Margins

    missPrices <- any(is.na(prices))

    shares_quantity <- shares_revenue <- indata$Output/sum(indata$Output, na.rm=TRUE)
    insideSize <- sum(indata[,"Output"], na.rm=TRUE)


    if(!missPrices){

      if(any(grepl("ces|aids",demand,perl=TRUE,ignore.case=TRUE))) insideSize <- sum(prices * indata[,"Output"], na.rm =TRUE)

      shares_revenue <- prices * shares_revenue / sum(prices * shares_revenue)
      if(supply == "2nd Score Auction") margins <- margins * prices # convert to level margins
    }

    firstMargin <- which(!is.na(margins))[1]
    firstPrice <- which(!is.na(prices))[1]


    ownerPre = model.matrix(~-1+indata$'Pre-merger\n Owner')
    ownerPre = tcrossprod(ownerPre)
    if(nlevels(indata$'Post-merger\n Owner') > 1){
      ownerPost = model.matrix(~-1+indata$'Post-merger\n Owner')
      ownerPost = tcrossprod(ownerPost)
    }
    else{ownerPost <- matrix(1, ncol=length(indata$Output), nrow = length(indata$Output))}

    ## Cournot
    # Quantities
    indata <<- indata
    # quantities <- matrix(NA, nrow = length(unique(indata[[2]])), ncol = length(prices))
    # for (row in 1:nrow(indata)){
    #   quantities[as.integer(gsub("\\D", "", as.character(indata[row, 2]))), as.integer(gsub("\\D", "", as.character(indata[row, 1])))] <- indata[row, 'Output']
    # }
    #
    # # Margins
    # marginsCournot <- matrix(NA, nrow = length(unique(indata[[2]])), ncol = length(prices))
    # for (row in 1:nrow(indata)){
    #   marginsCournot[as.integer(gsub("\\D", "", as.character(indata[row, 2]))), as.integer(gsub("\\D", "", as.character(indata[row, 1])))] <- indata[row, 'Margins']
    # }


    switch(supply,
           Bertrand =
             switch(demand,
                    `logit (unknown elasticity)` = logit.alm(prices= prices,
                                                             shares= shares_quantity,
                                                             margins= margins,
                                                             ownerPre= ownerPre,
                                                             ownerPost= ownerPost,
                                                             insideSize = insideSize ,
                                                             mcDelta = indata$mcDelta, labels=indata$Name),
                    `aids (unknown elasticity)` = aids(prices= prices,
                                                       shares= shares_revenue,
                                                       margins= margins,
                                                       ownerPre= ownerPre,
                                                       ownerPost= ownerPost,
                                                       insideSize = insideSize ,
                                                       mcDelta = indata$mcDelta, labels=indata$Name),
                    `ces (unknown elasticity)`= ces.alm(prices= prices,
                                                        shares= shares_revenue,
                                                        margins= margins,
                                                        ownerPre= ownerPre,
                                                        ownerPost= ownerPost,
                                                        insideSize = insideSize ,
                                                        mcDelta = indata$mcDelta, labels=indata$Name),
                    linear = linear(prices= prices,
                                  quantities= indata[,"Output"],
                                  margins= margins,
                                  ownerPre= ownerPre,
                                  ownerPost= ownerPost,
                                  mcDelta = indata$mcDelta, labels=indata$Name),
                    aids = aids(prices= prices,
                              shares= shares_revenue,
                              margins= margins,
                              ownerPre= ownerPre,
                              ownerPost= ownerPost,
                              insideSize = insideSize ,
                              mcDelta = indata$mcDelta, labels=indata$Name, mktElast = mktElast),
                    logit = logit.alm(prices= prices,
                                     shares= shares_quantity,
                                     margins= margins,
                                     ownerPre= ownerPre,
                                     ownerPost= ownerPost,
                                     insideSize = insideSize ,
                                     mcDelta = indata$mcDelta, labels=indata$Name, mktElast = mktElast),
                    ces = ces.alm(prices= prices,
                                  shares= shares_revenue,
                                  margins= margins,
                                  ownerPre= ownerPre,
                                  ownerPost= ownerPost,
                                  insideSize = insideSize ,
                                  mcDelta = indata$mcDelta, labels=indata$Name, mktElast = mktElast),
                    pcaids = pcaids(prices= prices,
                                    shares= shares_revenue,
                                    knownElast = -1/margins[firstMargin],
                                    knownElastIndex = firstMargin,
                                    mktElast = mktElast,
                                    insideSize = insideSize,
                                    ownerPre= ownerPre,
                                    ownerPost= ownerPost,
                                    mcDelta = indata$mcDelta,
                                    labels=indata$Name)
             ),

           Cournot = switch(demand,
                            linear = cournot(prices = na.omit(prices)[1],
                                             #demand = rep("linear", length(prices)),
                                             demand = "linear",
                                             #cost= rep("linear", nrow(indata)),
                                             quantities = as.matrix(indata$Output),
                                             margins= as.matrix(margins),
                                             ownerPre= ownerPre,
                                             ownerPost= ownerPost,
                                             mktElast = mktElast,
                                             mcDelta = indata$mcDelta,
                                             labels=list(indata$Name, indata$Name[1])),
                            loglinear = cournot(prices = na.omit(prices)[1],
                                                demand = "log",
                                                #cost= rep("linear", nrow(indata)),
                                                quantities = as.matrix(indata$Output),
                                                margins= as.matrix(margins),
                                                ownerPre= ownerPre,
                                                ownerPost= ownerPost,
                                                mktElast = mktElast,
                                                mcDelta = indata$mcDelta,
                                                labels=list(indata$Name, indata$Name[1])),
                            `linear (unknown elasticity)` = cournot(prices = na.omit(prices)[1],
                                                                    demand = "linear",
                                                                    #cost= rep("linear", nrow(indata)),
                                                                    quantities = as.matrix(indata$Output),
                                                                    margins= as.matrix(margins),
                                                                    ownerPre= ownerPre,
                                                                    ownerPost= ownerPost,
                                                                    mktElast = NA_real_,
                                                                    mcDelta = indata$mcDelta,
                                                                    labels = list(indata$Name, indata$Name[1])),
                            `loglinear (unknown elasticity)` = cournot(prices = na.omit(prices)[1],
                                                                       demand = "log",
                                                                       #cost= rep("linear", nrow(indata)),
                                                                       quantities = as.matrix(indata$Output),
                                                                       margins= as.matrix(margins),
                                                                       ownerPre= ownerPre,
                                                                       ownerPost= ownerPost,
                                                                       mktElast = NA_real_,
                                                                       mcDelta = indata$mcDelta,
                                                                       labels = list(indata$Name, indata$Name[1]))
           ),

           `2nd Score Auction`= switch(demand,
                                       `logit (unknown elasticity)` = auction2nd.logit.alm(prices= prices,
                                                                                           shares= shares_quantity,
                                                                                           margins= margins,
                                                                                           ownerPre= ownerPre,
                                                                                           ownerPost= ownerPost,
                                                                                           insideSize = insideSize,
                                                                                           mcDelta = indata$mcDelta,
                                                                                           labels=indata$Name),
                                       logit = auction2nd.logit.alm(prices= prices,
                                                                    shares= shares_quantity,
                                                                    margins= margins,
                                                                    ownerPre= ownerPre,
                                                                    ownerPost= ownerPost,
                                                                    insideSize = insideSize,
                                                                    mcDelta = indata$mcDelta,
                                                                    labels=indata$Name,
                                                                    mktElast = mktElast)

           )
    )

  } else if (type == "Vertical") {

    marginUp <- indata[grepl("marginsUp", colnames(indata))][[1]]
    marginDown <- indata[grepl("marginsDown", colnames(indata))][[1]]

    indata <<- indata

    switch(supply,
           Bertrand = vertical.barg(supplyDown = "bertrand",
                                    sharesDown = indata$sharesDown,
                                    pricesDown = indata$pricesDown,
                                    marginsDown = marginDown,
                                    ownerPreDown = indata$ownerPreDown,
                                    ownerPostDown = indata$ownerPostDown,
                                    pricesUp = indata$pricesUp,
                                    marginsUp = marginUp,
                                    ownerPreUp = indata$ownerPreUp,
                                    ownerPostUp = indata$ownerPostUp,
                                    priceOutside = 0,
                                    labels = indata$Name),
           `2nd Score Auction` = vertical.barg(supplyDown = "2nd",
                                               sharesDown = indata$sharesDown,
                                               pricesDown = indata$pricesDown,
                                               marginsDown = marginDown,
                                               ownerPreDown = indata$ownerPreDown,
                                               ownerPostDown = indata$ownerPostDown,
                                               pricesUp = indata$pricesUp,
                                               marginsUp = marginUp,
                                               ownerPreUp = indata$ownerPreUp,
                                               ownerPostUp = indata$ownerPostUp,
                                               priceOutside = 0,
                                               labels = indata$Name)
           )

  }

}

Try the competitiontoolbox package in your browser

Any scripts or data that you put into this service are public.

competitiontoolbox documentation built on Aug. 25, 2022, 9:08 a.m.