Forecasting Future Revenue Data For ROI Calculation

The name of the pictureThe name of the pictureThe name of the pictureClash Royale CLAN TAG#URR8PPP











up vote
2
down vote

favorite
1












I have some daily revenue data and I am trying to calculate the return on investment (ROI) by predicting what the expected revenue 'should be' and comparing it to what the company actually made. I used a moving average time series method on the data, but this assumes a linear trend, which is yielding poor results when calculating ROI because of the volatility in the actual data itself. I can post my results/data in an excel file if you want.



ROI is calculated using this formula: [(Actual Revenue - Forecasted Revenue From Time Series/Forecast Method) - Cost] / Cost Actual Revenue figures are given on a daily basis as is the cost.



I need to use an improved time series (or alternative) method to find an expected value for the several days worth of revenue. I am not sure what method to use as I am only familiar with the moving average time series method.



Can you please suggest a suitable method? Furthermore, if you have an example of how it works in excel, I would be grateful.



I have been told Stochastic Modeling is a good alternative as it is used to model stock prices but I cannot find a model in excel which I can use.



Can someone please help me out?










share|cite|improve this question

























    up vote
    2
    down vote

    favorite
    1












    I have some daily revenue data and I am trying to calculate the return on investment (ROI) by predicting what the expected revenue 'should be' and comparing it to what the company actually made. I used a moving average time series method on the data, but this assumes a linear trend, which is yielding poor results when calculating ROI because of the volatility in the actual data itself. I can post my results/data in an excel file if you want.



    ROI is calculated using this formula: [(Actual Revenue - Forecasted Revenue From Time Series/Forecast Method) - Cost] / Cost Actual Revenue figures are given on a daily basis as is the cost.



    I need to use an improved time series (or alternative) method to find an expected value for the several days worth of revenue. I am not sure what method to use as I am only familiar with the moving average time series method.



    Can you please suggest a suitable method? Furthermore, if you have an example of how it works in excel, I would be grateful.



    I have been told Stochastic Modeling is a good alternative as it is used to model stock prices but I cannot find a model in excel which I can use.



    Can someone please help me out?










    share|cite|improve this question























      up vote
      2
      down vote

      favorite
      1









      up vote
      2
      down vote

      favorite
      1






      1





      I have some daily revenue data and I am trying to calculate the return on investment (ROI) by predicting what the expected revenue 'should be' and comparing it to what the company actually made. I used a moving average time series method on the data, but this assumes a linear trend, which is yielding poor results when calculating ROI because of the volatility in the actual data itself. I can post my results/data in an excel file if you want.



      ROI is calculated using this formula: [(Actual Revenue - Forecasted Revenue From Time Series/Forecast Method) - Cost] / Cost Actual Revenue figures are given on a daily basis as is the cost.



      I need to use an improved time series (or alternative) method to find an expected value for the several days worth of revenue. I am not sure what method to use as I am only familiar with the moving average time series method.



      Can you please suggest a suitable method? Furthermore, if you have an example of how it works in excel, I would be grateful.



      I have been told Stochastic Modeling is a good alternative as it is used to model stock prices but I cannot find a model in excel which I can use.



      Can someone please help me out?










      share|cite|improve this question













      I have some daily revenue data and I am trying to calculate the return on investment (ROI) by predicting what the expected revenue 'should be' and comparing it to what the company actually made. I used a moving average time series method on the data, but this assumes a linear trend, which is yielding poor results when calculating ROI because of the volatility in the actual data itself. I can post my results/data in an excel file if you want.



      ROI is calculated using this formula: [(Actual Revenue - Forecasted Revenue From Time Series/Forecast Method) - Cost] / Cost Actual Revenue figures are given on a daily basis as is the cost.



      I need to use an improved time series (or alternative) method to find an expected value for the several days worth of revenue. I am not sure what method to use as I am only familiar with the moving average time series method.



      Can you please suggest a suitable method? Furthermore, if you have an example of how it works in excel, I would be grateful.



      I have been told Stochastic Modeling is a good alternative as it is used to model stock prices but I cannot find a model in excel which I can use.



      Can someone please help me out?







      time-series






      share|cite|improve this question













      share|cite|improve this question











      share|cite|improve this question




      share|cite|improve this question










      asked Sep 5 '13 at 10:35









      Dino Abraham

      113




      113




















          2 Answers
          2






          active

          oldest

          votes

















          up vote
          0
          down vote













          http://msdn.microsoft.com/en-us/library/ff524510%28v=vs.93%29.aspx



          In the 4th table down (entitled Solver Foundation Ribbon) in the link above,
          if you take a look at 'Method' in the 'Simulation' group it reads 'Sets options to solve stochastic models. Choose between Automatic (the default), Monte Carlo, and Latin Hypercube.'



          I used Monte Carlo simulation to simulate a hypothetical stock price in my dissertation, alhough I didn't use Excel. I used Maple. I don't know what sort of stock you're dealing with. Excel might not need to know that when employing the built in simulation methods it has for stochastic models. You could try the default or built in Monte Carlo. If that doesn't improve your results, you might want to write your own simulation. You may be able to do this in Excel itself. If you do want to try and write your own method, you might want to think about which sort of model would best fit the stock you're dealing with. The example I dealt with was modelling energy prices (gas and electricity). Models used for those (which may or may not also apply to the stock you're dealing with) are Mean Reverting Processes (such as the Vasicek Model or the Cox-Ingersoll-Ross model) and Jump Diffusion Processes (I think the latter are supposed to be more realistic).



          I'd go for a jump diffusion model if you're tryng your own, but since I used mean reversion I'll just show you the method, which isn't too difficult:



          the Vasicek model is $dS = a(b-S)dt + sigma dz$



          where



          S is the spot price (or in your case revenue at a given time t)



          dS is the expected change in price at a given time step



          a is the 'mean reversion rate' (which you choose yourself)



          b is the mean reversion level or long run equilibrium price (which again, you choose)



          $sigma$ is the volatility



          dz is the random shock to price at a given time step



          The idea is to solve this stochastic differential equation numerically (using Euler's method if you want to keep things reasonably simple or another method if you need to improve your results (i.e. Milstein method))



          so the code I used (in Maple) was this:



          (comments are actually done with a hash in Maple, but hash emboldens and enlarges in latex so I've changed hash to //)



          // method stochEulerMRP takes the parameters you've chosen (start, a, b, $sigma$, finalT, h) and uses Euler's method to produce and graph a prediction of how the stock price will change over the time you've specified



          stochEulerMRP:=proc(start, a, b, $sigma$, finalT, h)



          (start = revenue or price at time $0$, a,b, $sigma$ as above, h = time step, finalT = time you want simulation to run until)



          global N, x;



          local t, xLine, eps, i, pEuler, pLine, A B, Z;



          N = floor(finalT/h);

          t:=array(,0..N);

          x:=array(,0..N);

          eps:=array(,0..N);

          xLine:=array(,0..N);



          Z:=Random Variable(Normal(0,1)):

          eps:=Sample(Z,N):



          t[0]:=0;

          x[0]:=start;

          xLine:=0;



          for i from 1 to N do

          t[i:=t[i-1]+h;

          x[i]:=x[i-1]+a*(b-x[i-1])*h+$sigma$*eps[i]*sqrth;

          xLine[i]:=xLine[i-1]+a*h;

          od:



          // plot results

          pEuler:=[seq(t[i],x[i]], i=0..N)];

          pLine:=[seq([t[i],xLine[i]],i=0..N)];

          A:=listplot(pEuler,color=red, style=line, view=[0..1,-2..2]):

          display(A);



          end:



          So that code produces one simulation (or guess) at how the stock price or revenue will change over the given time by using Euler's method to solve the stochastic differential equation you've specified using the Vasicek Model and choosing your own guesses of what the parameters a and b are. Monte Carlo simulation relies on the fact you can produce more than one of these simulations and then take the average of all of them at each point you want to predict and the more simulations you do, the closer this average will be to the true mean (so it's used for solving stochastic differential equations where you don't already know the true mean because you can't find it analytically, as you can for the Vasicek Model). I used the Vasicek model to see how well my simulation process was working, by looking at how close my averages were to the true mean.



          You have to choose b and $sigma$ so that $frac2bsigma^2ge1$ if you want to prevent the revenue going negative (which you only want to do if this is impossible).



          You can find the true mean and variance of the Vasicek Model on the Wikipedia page.



          I must say, I did have some problems with my models: the accuracy wasn't improving as it said it should have done in a book I was referring to on the subject, called something like The Numerical Solution of Stochastic Differential Equations (Kloeden and Platen), (the problem was that accuracy is meant to improve by a certain order each time you halve the time step, but mine wasn't improving by the amount theirs was in the book, even though I was using exactly the same equation and almost everything else exactly the same so there might have been a glitch or 2 in my implementation (possibly in the random number generation), but hopefully this will help to get you started, even if it doesn't immediately produce good enough results.



          An example of values of a, b, and $sigma$, finalT, and step size(h) I used are 0.05, 70, 0.2, 1, and 0.01 respectively, but obviously these depend on what you're modelling.



          One problem with this is time: I was doing $1,000-1,000,000$ runs. $1,000,000$ runs was taking an hour or more, but you may not need to do so many, and you're pc may be faster than the one I was using at the time. $100,000$ runs might not have taken too long, and $10,000$ was fine.






          share|cite|improve this answer






















          • Thanks for the very detailed and informative post. The problem I have is all I've got it daily revenue data, say Jan 1st - Dec 31st. I know the company spends, say, 1 million in June 1st on advertising. So, I need to use Jan 1st - May 31st data to predict what the rev should be without the 1m spend, and then I also know what it actually is because of the 1m spend (the 'actual' revenue). The issue is I cannot make assumptions as I know nothing more than the revenue figures. Whats the best method I can use please?
            – Dino Abraham
            Sep 5 '13 at 12:35











          • In all honesty, despite my dissertation, I'm no expert on the subject: just a beginner, but as I understand it, modelling always involves assumptions. The modelling process works by taking a guess at the way you think things are working and comparing to your results and then trying to improve your model. Of course you can make your model fit one set of data. The real test is to see how it performs on new sets of data.
            – George Tomlinson
            Sep 5 '13 at 12:44










          • I'd start by trying the default Excel stochastic model and see how it performs
            – George Tomlinson
            Sep 5 '13 at 12:45










          • And then if that's not good, maybe try the built in Monte Carlo.
            – George Tomlinson
            Sep 5 '13 at 12:46






          • 1




            What about linear regression?
            – George Tomlinson
            Sep 6 '13 at 18:27

















          up vote
          0
          down vote













          I'd probably use Variable and Fixed cost analysis as an input to a forecast of future sales and costs. I have a full blog about it linked below with an excel template. I'll talk about your specific example as much as I can.



          Variable and Fixed Costs - Small Business Decisions



          Variable costs may change drastically from day to day, but the real point of what you're trying to do is understand the general trend so that you can forecast your expected ROI. You should use a longer period of time to understand what portion of your sales revenue is variable with the cost than a single day. In the end, a month over month value for expected ROI should be sufficient. Daily analysis would be overkill in any of the business programs I've been involved in, most of which were multi-million dollar programs.



          You should use the template provided to determine your variable costs. The template is set up for 12 months if you have the data. Then you should estimate what kind of sales volume you can expect to continue from your latest sales data. The Sales team at your company should be able to help you with that. With an understanding of the variable costs, you can project your expected sales and the expected costs associated with those sales.



          If your company has several other products, I'd also suggest you use the sales revenue specific to your product as the top line instead of the overall company sales. This will help identify which portion of the overall company sales are correlated with your specific product. The two numbers should be relatively similar in percentage, but drastically different in scale. Ex: 12% variable cost for $1 Million in sales at the company level is $120,000. 14% variable cost of $10,000 in sales of your specific product is $1,400. Similar variable cost percentage rates, but vastly different scales. Now, this comparison is important because in the case that another product had sales increases at the same time as your product, it'll be very difficult to ensure that the costs your allocating to your product are actually a result of your product's changes in sales.



          If you work in a company that is so large your product won't make up the difference in a rounding error on their P&L (not an insult, I've been there), then you should look for standard allocations for SAR and add them to your direct costs.






          share|cite|improve this answer






















            Your Answer




            StackExchange.ifUsing("editor", function ()
            return StackExchange.using("mathjaxEditing", function ()
            StackExchange.MarkdownEditor.creationCallbacks.add(function (editor, postfix)
            StackExchange.mathjaxEditing.prepareWmdForMathJax(editor, postfix, [["$", "$"], ["\\(","\\)"]]);
            );
            );
            , "mathjax-editing");

            StackExchange.ready(function()
            var channelOptions =
            tags: "".split(" "),
            id: "69"
            ;
            initTagRenderer("".split(" "), "".split(" "), channelOptions);

            StackExchange.using("externalEditor", function()
            // Have to fire editor after snippets, if snippets enabled
            if (StackExchange.settings.snippets.snippetsEnabled)
            StackExchange.using("snippets", function()
            createEditor();
            );

            else
            createEditor();

            );

            function createEditor()
            StackExchange.prepareEditor(
            heartbeatType: 'answer',
            convertImagesToLinks: true,
            noModals: false,
            showLowRepImageUploadWarning: true,
            reputationToPostImages: 10,
            bindNavPrevention: true,
            postfix: "",
            noCode: true, onDemand: true,
            discardSelector: ".discard-answer"
            ,immediatelyShowMarkdownHelp:true
            );



            );













             

            draft saved


            draft discarded


















            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fmath.stackexchange.com%2fquestions%2f484768%2fforecasting-future-revenue-data-for-roi-calculation%23new-answer', 'question_page');

            );

            Post as a guest






























            2 Answers
            2






            active

            oldest

            votes








            2 Answers
            2






            active

            oldest

            votes









            active

            oldest

            votes






            active

            oldest

            votes








            up vote
            0
            down vote













            http://msdn.microsoft.com/en-us/library/ff524510%28v=vs.93%29.aspx



            In the 4th table down (entitled Solver Foundation Ribbon) in the link above,
            if you take a look at 'Method' in the 'Simulation' group it reads 'Sets options to solve stochastic models. Choose between Automatic (the default), Monte Carlo, and Latin Hypercube.'



            I used Monte Carlo simulation to simulate a hypothetical stock price in my dissertation, alhough I didn't use Excel. I used Maple. I don't know what sort of stock you're dealing with. Excel might not need to know that when employing the built in simulation methods it has for stochastic models. You could try the default or built in Monte Carlo. If that doesn't improve your results, you might want to write your own simulation. You may be able to do this in Excel itself. If you do want to try and write your own method, you might want to think about which sort of model would best fit the stock you're dealing with. The example I dealt with was modelling energy prices (gas and electricity). Models used for those (which may or may not also apply to the stock you're dealing with) are Mean Reverting Processes (such as the Vasicek Model or the Cox-Ingersoll-Ross model) and Jump Diffusion Processes (I think the latter are supposed to be more realistic).



            I'd go for a jump diffusion model if you're tryng your own, but since I used mean reversion I'll just show you the method, which isn't too difficult:



            the Vasicek model is $dS = a(b-S)dt + sigma dz$



            where



            S is the spot price (or in your case revenue at a given time t)



            dS is the expected change in price at a given time step



            a is the 'mean reversion rate' (which you choose yourself)



            b is the mean reversion level or long run equilibrium price (which again, you choose)



            $sigma$ is the volatility



            dz is the random shock to price at a given time step



            The idea is to solve this stochastic differential equation numerically (using Euler's method if you want to keep things reasonably simple or another method if you need to improve your results (i.e. Milstein method))



            so the code I used (in Maple) was this:



            (comments are actually done with a hash in Maple, but hash emboldens and enlarges in latex so I've changed hash to //)



            // method stochEulerMRP takes the parameters you've chosen (start, a, b, $sigma$, finalT, h) and uses Euler's method to produce and graph a prediction of how the stock price will change over the time you've specified



            stochEulerMRP:=proc(start, a, b, $sigma$, finalT, h)



            (start = revenue or price at time $0$, a,b, $sigma$ as above, h = time step, finalT = time you want simulation to run until)



            global N, x;



            local t, xLine, eps, i, pEuler, pLine, A B, Z;



            N = floor(finalT/h);

            t:=array(,0..N);

            x:=array(,0..N);

            eps:=array(,0..N);

            xLine:=array(,0..N);



            Z:=Random Variable(Normal(0,1)):

            eps:=Sample(Z,N):



            t[0]:=0;

            x[0]:=start;

            xLine:=0;



            for i from 1 to N do

            t[i:=t[i-1]+h;

            x[i]:=x[i-1]+a*(b-x[i-1])*h+$sigma$*eps[i]*sqrth;

            xLine[i]:=xLine[i-1]+a*h;

            od:



            // plot results

            pEuler:=[seq(t[i],x[i]], i=0..N)];

            pLine:=[seq([t[i],xLine[i]],i=0..N)];

            A:=listplot(pEuler,color=red, style=line, view=[0..1,-2..2]):

            display(A);



            end:



            So that code produces one simulation (or guess) at how the stock price or revenue will change over the given time by using Euler's method to solve the stochastic differential equation you've specified using the Vasicek Model and choosing your own guesses of what the parameters a and b are. Monte Carlo simulation relies on the fact you can produce more than one of these simulations and then take the average of all of them at each point you want to predict and the more simulations you do, the closer this average will be to the true mean (so it's used for solving stochastic differential equations where you don't already know the true mean because you can't find it analytically, as you can for the Vasicek Model). I used the Vasicek model to see how well my simulation process was working, by looking at how close my averages were to the true mean.



            You have to choose b and $sigma$ so that $frac2bsigma^2ge1$ if you want to prevent the revenue going negative (which you only want to do if this is impossible).



            You can find the true mean and variance of the Vasicek Model on the Wikipedia page.



            I must say, I did have some problems with my models: the accuracy wasn't improving as it said it should have done in a book I was referring to on the subject, called something like The Numerical Solution of Stochastic Differential Equations (Kloeden and Platen), (the problem was that accuracy is meant to improve by a certain order each time you halve the time step, but mine wasn't improving by the amount theirs was in the book, even though I was using exactly the same equation and almost everything else exactly the same so there might have been a glitch or 2 in my implementation (possibly in the random number generation), but hopefully this will help to get you started, even if it doesn't immediately produce good enough results.



            An example of values of a, b, and $sigma$, finalT, and step size(h) I used are 0.05, 70, 0.2, 1, and 0.01 respectively, but obviously these depend on what you're modelling.



            One problem with this is time: I was doing $1,000-1,000,000$ runs. $1,000,000$ runs was taking an hour or more, but you may not need to do so many, and you're pc may be faster than the one I was using at the time. $100,000$ runs might not have taken too long, and $10,000$ was fine.






            share|cite|improve this answer






















            • Thanks for the very detailed and informative post. The problem I have is all I've got it daily revenue data, say Jan 1st - Dec 31st. I know the company spends, say, 1 million in June 1st on advertising. So, I need to use Jan 1st - May 31st data to predict what the rev should be without the 1m spend, and then I also know what it actually is because of the 1m spend (the 'actual' revenue). The issue is I cannot make assumptions as I know nothing more than the revenue figures. Whats the best method I can use please?
              – Dino Abraham
              Sep 5 '13 at 12:35











            • In all honesty, despite my dissertation, I'm no expert on the subject: just a beginner, but as I understand it, modelling always involves assumptions. The modelling process works by taking a guess at the way you think things are working and comparing to your results and then trying to improve your model. Of course you can make your model fit one set of data. The real test is to see how it performs on new sets of data.
              – George Tomlinson
              Sep 5 '13 at 12:44










            • I'd start by trying the default Excel stochastic model and see how it performs
              – George Tomlinson
              Sep 5 '13 at 12:45










            • And then if that's not good, maybe try the built in Monte Carlo.
              – George Tomlinson
              Sep 5 '13 at 12:46






            • 1




              What about linear regression?
              – George Tomlinson
              Sep 6 '13 at 18:27














            up vote
            0
            down vote













            http://msdn.microsoft.com/en-us/library/ff524510%28v=vs.93%29.aspx



            In the 4th table down (entitled Solver Foundation Ribbon) in the link above,
            if you take a look at 'Method' in the 'Simulation' group it reads 'Sets options to solve stochastic models. Choose between Automatic (the default), Monte Carlo, and Latin Hypercube.'



            I used Monte Carlo simulation to simulate a hypothetical stock price in my dissertation, alhough I didn't use Excel. I used Maple. I don't know what sort of stock you're dealing with. Excel might not need to know that when employing the built in simulation methods it has for stochastic models. You could try the default or built in Monte Carlo. If that doesn't improve your results, you might want to write your own simulation. You may be able to do this in Excel itself. If you do want to try and write your own method, you might want to think about which sort of model would best fit the stock you're dealing with. The example I dealt with was modelling energy prices (gas and electricity). Models used for those (which may or may not also apply to the stock you're dealing with) are Mean Reverting Processes (such as the Vasicek Model or the Cox-Ingersoll-Ross model) and Jump Diffusion Processes (I think the latter are supposed to be more realistic).



            I'd go for a jump diffusion model if you're tryng your own, but since I used mean reversion I'll just show you the method, which isn't too difficult:



            the Vasicek model is $dS = a(b-S)dt + sigma dz$



            where



            S is the spot price (or in your case revenue at a given time t)



            dS is the expected change in price at a given time step



            a is the 'mean reversion rate' (which you choose yourself)



            b is the mean reversion level or long run equilibrium price (which again, you choose)



            $sigma$ is the volatility



            dz is the random shock to price at a given time step



            The idea is to solve this stochastic differential equation numerically (using Euler's method if you want to keep things reasonably simple or another method if you need to improve your results (i.e. Milstein method))



            so the code I used (in Maple) was this:



            (comments are actually done with a hash in Maple, but hash emboldens and enlarges in latex so I've changed hash to //)



            // method stochEulerMRP takes the parameters you've chosen (start, a, b, $sigma$, finalT, h) and uses Euler's method to produce and graph a prediction of how the stock price will change over the time you've specified



            stochEulerMRP:=proc(start, a, b, $sigma$, finalT, h)



            (start = revenue or price at time $0$, a,b, $sigma$ as above, h = time step, finalT = time you want simulation to run until)



            global N, x;



            local t, xLine, eps, i, pEuler, pLine, A B, Z;



            N = floor(finalT/h);

            t:=array(,0..N);

            x:=array(,0..N);

            eps:=array(,0..N);

            xLine:=array(,0..N);



            Z:=Random Variable(Normal(0,1)):

            eps:=Sample(Z,N):



            t[0]:=0;

            x[0]:=start;

            xLine:=0;



            for i from 1 to N do

            t[i:=t[i-1]+h;

            x[i]:=x[i-1]+a*(b-x[i-1])*h+$sigma$*eps[i]*sqrth;

            xLine[i]:=xLine[i-1]+a*h;

            od:



            // plot results

            pEuler:=[seq(t[i],x[i]], i=0..N)];

            pLine:=[seq([t[i],xLine[i]],i=0..N)];

            A:=listplot(pEuler,color=red, style=line, view=[0..1,-2..2]):

            display(A);



            end:



            So that code produces one simulation (or guess) at how the stock price or revenue will change over the given time by using Euler's method to solve the stochastic differential equation you've specified using the Vasicek Model and choosing your own guesses of what the parameters a and b are. Monte Carlo simulation relies on the fact you can produce more than one of these simulations and then take the average of all of them at each point you want to predict and the more simulations you do, the closer this average will be to the true mean (so it's used for solving stochastic differential equations where you don't already know the true mean because you can't find it analytically, as you can for the Vasicek Model). I used the Vasicek model to see how well my simulation process was working, by looking at how close my averages were to the true mean.



            You have to choose b and $sigma$ so that $frac2bsigma^2ge1$ if you want to prevent the revenue going negative (which you only want to do if this is impossible).



            You can find the true mean and variance of the Vasicek Model on the Wikipedia page.



            I must say, I did have some problems with my models: the accuracy wasn't improving as it said it should have done in a book I was referring to on the subject, called something like The Numerical Solution of Stochastic Differential Equations (Kloeden and Platen), (the problem was that accuracy is meant to improve by a certain order each time you halve the time step, but mine wasn't improving by the amount theirs was in the book, even though I was using exactly the same equation and almost everything else exactly the same so there might have been a glitch or 2 in my implementation (possibly in the random number generation), but hopefully this will help to get you started, even if it doesn't immediately produce good enough results.



            An example of values of a, b, and $sigma$, finalT, and step size(h) I used are 0.05, 70, 0.2, 1, and 0.01 respectively, but obviously these depend on what you're modelling.



            One problem with this is time: I was doing $1,000-1,000,000$ runs. $1,000,000$ runs was taking an hour or more, but you may not need to do so many, and you're pc may be faster than the one I was using at the time. $100,000$ runs might not have taken too long, and $10,000$ was fine.






            share|cite|improve this answer






















            • Thanks for the very detailed and informative post. The problem I have is all I've got it daily revenue data, say Jan 1st - Dec 31st. I know the company spends, say, 1 million in June 1st on advertising. So, I need to use Jan 1st - May 31st data to predict what the rev should be without the 1m spend, and then I also know what it actually is because of the 1m spend (the 'actual' revenue). The issue is I cannot make assumptions as I know nothing more than the revenue figures. Whats the best method I can use please?
              – Dino Abraham
              Sep 5 '13 at 12:35











            • In all honesty, despite my dissertation, I'm no expert on the subject: just a beginner, but as I understand it, modelling always involves assumptions. The modelling process works by taking a guess at the way you think things are working and comparing to your results and then trying to improve your model. Of course you can make your model fit one set of data. The real test is to see how it performs on new sets of data.
              – George Tomlinson
              Sep 5 '13 at 12:44










            • I'd start by trying the default Excel stochastic model and see how it performs
              – George Tomlinson
              Sep 5 '13 at 12:45










            • And then if that's not good, maybe try the built in Monte Carlo.
              – George Tomlinson
              Sep 5 '13 at 12:46






            • 1




              What about linear regression?
              – George Tomlinson
              Sep 6 '13 at 18:27












            up vote
            0
            down vote










            up vote
            0
            down vote









            http://msdn.microsoft.com/en-us/library/ff524510%28v=vs.93%29.aspx



            In the 4th table down (entitled Solver Foundation Ribbon) in the link above,
            if you take a look at 'Method' in the 'Simulation' group it reads 'Sets options to solve stochastic models. Choose between Automatic (the default), Monte Carlo, and Latin Hypercube.'



            I used Monte Carlo simulation to simulate a hypothetical stock price in my dissertation, alhough I didn't use Excel. I used Maple. I don't know what sort of stock you're dealing with. Excel might not need to know that when employing the built in simulation methods it has for stochastic models. You could try the default or built in Monte Carlo. If that doesn't improve your results, you might want to write your own simulation. You may be able to do this in Excel itself. If you do want to try and write your own method, you might want to think about which sort of model would best fit the stock you're dealing with. The example I dealt with was modelling energy prices (gas and electricity). Models used for those (which may or may not also apply to the stock you're dealing with) are Mean Reverting Processes (such as the Vasicek Model or the Cox-Ingersoll-Ross model) and Jump Diffusion Processes (I think the latter are supposed to be more realistic).



            I'd go for a jump diffusion model if you're tryng your own, but since I used mean reversion I'll just show you the method, which isn't too difficult:



            the Vasicek model is $dS = a(b-S)dt + sigma dz$



            where



            S is the spot price (or in your case revenue at a given time t)



            dS is the expected change in price at a given time step



            a is the 'mean reversion rate' (which you choose yourself)



            b is the mean reversion level or long run equilibrium price (which again, you choose)



            $sigma$ is the volatility



            dz is the random shock to price at a given time step



            The idea is to solve this stochastic differential equation numerically (using Euler's method if you want to keep things reasonably simple or another method if you need to improve your results (i.e. Milstein method))



            so the code I used (in Maple) was this:



            (comments are actually done with a hash in Maple, but hash emboldens and enlarges in latex so I've changed hash to //)



            // method stochEulerMRP takes the parameters you've chosen (start, a, b, $sigma$, finalT, h) and uses Euler's method to produce and graph a prediction of how the stock price will change over the time you've specified



            stochEulerMRP:=proc(start, a, b, $sigma$, finalT, h)



            (start = revenue or price at time $0$, a,b, $sigma$ as above, h = time step, finalT = time you want simulation to run until)



            global N, x;



            local t, xLine, eps, i, pEuler, pLine, A B, Z;



            N = floor(finalT/h);

            t:=array(,0..N);

            x:=array(,0..N);

            eps:=array(,0..N);

            xLine:=array(,0..N);



            Z:=Random Variable(Normal(0,1)):

            eps:=Sample(Z,N):



            t[0]:=0;

            x[0]:=start;

            xLine:=0;



            for i from 1 to N do

            t[i:=t[i-1]+h;

            x[i]:=x[i-1]+a*(b-x[i-1])*h+$sigma$*eps[i]*sqrth;

            xLine[i]:=xLine[i-1]+a*h;

            od:



            // plot results

            pEuler:=[seq(t[i],x[i]], i=0..N)];

            pLine:=[seq([t[i],xLine[i]],i=0..N)];

            A:=listplot(pEuler,color=red, style=line, view=[0..1,-2..2]):

            display(A);



            end:



            So that code produces one simulation (or guess) at how the stock price or revenue will change over the given time by using Euler's method to solve the stochastic differential equation you've specified using the Vasicek Model and choosing your own guesses of what the parameters a and b are. Monte Carlo simulation relies on the fact you can produce more than one of these simulations and then take the average of all of them at each point you want to predict and the more simulations you do, the closer this average will be to the true mean (so it's used for solving stochastic differential equations where you don't already know the true mean because you can't find it analytically, as you can for the Vasicek Model). I used the Vasicek model to see how well my simulation process was working, by looking at how close my averages were to the true mean.



            You have to choose b and $sigma$ so that $frac2bsigma^2ge1$ if you want to prevent the revenue going negative (which you only want to do if this is impossible).



            You can find the true mean and variance of the Vasicek Model on the Wikipedia page.



            I must say, I did have some problems with my models: the accuracy wasn't improving as it said it should have done in a book I was referring to on the subject, called something like The Numerical Solution of Stochastic Differential Equations (Kloeden and Platen), (the problem was that accuracy is meant to improve by a certain order each time you halve the time step, but mine wasn't improving by the amount theirs was in the book, even though I was using exactly the same equation and almost everything else exactly the same so there might have been a glitch or 2 in my implementation (possibly in the random number generation), but hopefully this will help to get you started, even if it doesn't immediately produce good enough results.



            An example of values of a, b, and $sigma$, finalT, and step size(h) I used are 0.05, 70, 0.2, 1, and 0.01 respectively, but obviously these depend on what you're modelling.



            One problem with this is time: I was doing $1,000-1,000,000$ runs. $1,000,000$ runs was taking an hour or more, but you may not need to do so many, and you're pc may be faster than the one I was using at the time. $100,000$ runs might not have taken too long, and $10,000$ was fine.






            share|cite|improve this answer














            http://msdn.microsoft.com/en-us/library/ff524510%28v=vs.93%29.aspx



            In the 4th table down (entitled Solver Foundation Ribbon) in the link above,
            if you take a look at 'Method' in the 'Simulation' group it reads 'Sets options to solve stochastic models. Choose between Automatic (the default), Monte Carlo, and Latin Hypercube.'



            I used Monte Carlo simulation to simulate a hypothetical stock price in my dissertation, alhough I didn't use Excel. I used Maple. I don't know what sort of stock you're dealing with. Excel might not need to know that when employing the built in simulation methods it has for stochastic models. You could try the default or built in Monte Carlo. If that doesn't improve your results, you might want to write your own simulation. You may be able to do this in Excel itself. If you do want to try and write your own method, you might want to think about which sort of model would best fit the stock you're dealing with. The example I dealt with was modelling energy prices (gas and electricity). Models used for those (which may or may not also apply to the stock you're dealing with) are Mean Reverting Processes (such as the Vasicek Model or the Cox-Ingersoll-Ross model) and Jump Diffusion Processes (I think the latter are supposed to be more realistic).



            I'd go for a jump diffusion model if you're tryng your own, but since I used mean reversion I'll just show you the method, which isn't too difficult:



            the Vasicek model is $dS = a(b-S)dt + sigma dz$



            where



            S is the spot price (or in your case revenue at a given time t)



            dS is the expected change in price at a given time step



            a is the 'mean reversion rate' (which you choose yourself)



            b is the mean reversion level or long run equilibrium price (which again, you choose)



            $sigma$ is the volatility



            dz is the random shock to price at a given time step



            The idea is to solve this stochastic differential equation numerically (using Euler's method if you want to keep things reasonably simple or another method if you need to improve your results (i.e. Milstein method))



            so the code I used (in Maple) was this:



            (comments are actually done with a hash in Maple, but hash emboldens and enlarges in latex so I've changed hash to //)



            // method stochEulerMRP takes the parameters you've chosen (start, a, b, $sigma$, finalT, h) and uses Euler's method to produce and graph a prediction of how the stock price will change over the time you've specified



            stochEulerMRP:=proc(start, a, b, $sigma$, finalT, h)



            (start = revenue or price at time $0$, a,b, $sigma$ as above, h = time step, finalT = time you want simulation to run until)



            global N, x;



            local t, xLine, eps, i, pEuler, pLine, A B, Z;



            N = floor(finalT/h);

            t:=array(,0..N);

            x:=array(,0..N);

            eps:=array(,0..N);

            xLine:=array(,0..N);



            Z:=Random Variable(Normal(0,1)):

            eps:=Sample(Z,N):



            t[0]:=0;

            x[0]:=start;

            xLine:=0;



            for i from 1 to N do

            t[i:=t[i-1]+h;

            x[i]:=x[i-1]+a*(b-x[i-1])*h+$sigma$*eps[i]*sqrth;

            xLine[i]:=xLine[i-1]+a*h;

            od:



            // plot results

            pEuler:=[seq(t[i],x[i]], i=0..N)];

            pLine:=[seq([t[i],xLine[i]],i=0..N)];

            A:=listplot(pEuler,color=red, style=line, view=[0..1,-2..2]):

            display(A);



            end:



            So that code produces one simulation (or guess) at how the stock price or revenue will change over the given time by using Euler's method to solve the stochastic differential equation you've specified using the Vasicek Model and choosing your own guesses of what the parameters a and b are. Monte Carlo simulation relies on the fact you can produce more than one of these simulations and then take the average of all of them at each point you want to predict and the more simulations you do, the closer this average will be to the true mean (so it's used for solving stochastic differential equations where you don't already know the true mean because you can't find it analytically, as you can for the Vasicek Model). I used the Vasicek model to see how well my simulation process was working, by looking at how close my averages were to the true mean.



            You have to choose b and $sigma$ so that $frac2bsigma^2ge1$ if you want to prevent the revenue going negative (which you only want to do if this is impossible).



            You can find the true mean and variance of the Vasicek Model on the Wikipedia page.



            I must say, I did have some problems with my models: the accuracy wasn't improving as it said it should have done in a book I was referring to on the subject, called something like The Numerical Solution of Stochastic Differential Equations (Kloeden and Platen), (the problem was that accuracy is meant to improve by a certain order each time you halve the time step, but mine wasn't improving by the amount theirs was in the book, even though I was using exactly the same equation and almost everything else exactly the same so there might have been a glitch or 2 in my implementation (possibly in the random number generation), but hopefully this will help to get you started, even if it doesn't immediately produce good enough results.



            An example of values of a, b, and $sigma$, finalT, and step size(h) I used are 0.05, 70, 0.2, 1, and 0.01 respectively, but obviously these depend on what you're modelling.



            One problem with this is time: I was doing $1,000-1,000,000$ runs. $1,000,000$ runs was taking an hour or more, but you may not need to do so many, and you're pc may be faster than the one I was using at the time. $100,000$ runs might not have taken too long, and $10,000$ was fine.







            share|cite|improve this answer














            share|cite|improve this answer



            share|cite|improve this answer








            edited Sep 5 '13 at 12:36

























            answered Sep 5 '13 at 11:12









            George Tomlinson

            1,236611




            1,236611











            • Thanks for the very detailed and informative post. The problem I have is all I've got it daily revenue data, say Jan 1st - Dec 31st. I know the company spends, say, 1 million in June 1st on advertising. So, I need to use Jan 1st - May 31st data to predict what the rev should be without the 1m spend, and then I also know what it actually is because of the 1m spend (the 'actual' revenue). The issue is I cannot make assumptions as I know nothing more than the revenue figures. Whats the best method I can use please?
              – Dino Abraham
              Sep 5 '13 at 12:35











            • In all honesty, despite my dissertation, I'm no expert on the subject: just a beginner, but as I understand it, modelling always involves assumptions. The modelling process works by taking a guess at the way you think things are working and comparing to your results and then trying to improve your model. Of course you can make your model fit one set of data. The real test is to see how it performs on new sets of data.
              – George Tomlinson
              Sep 5 '13 at 12:44










            • I'd start by trying the default Excel stochastic model and see how it performs
              – George Tomlinson
              Sep 5 '13 at 12:45










            • And then if that's not good, maybe try the built in Monte Carlo.
              – George Tomlinson
              Sep 5 '13 at 12:46






            • 1




              What about linear regression?
              – George Tomlinson
              Sep 6 '13 at 18:27
















            • Thanks for the very detailed and informative post. The problem I have is all I've got it daily revenue data, say Jan 1st - Dec 31st. I know the company spends, say, 1 million in June 1st on advertising. So, I need to use Jan 1st - May 31st data to predict what the rev should be without the 1m spend, and then I also know what it actually is because of the 1m spend (the 'actual' revenue). The issue is I cannot make assumptions as I know nothing more than the revenue figures. Whats the best method I can use please?
              – Dino Abraham
              Sep 5 '13 at 12:35











            • In all honesty, despite my dissertation, I'm no expert on the subject: just a beginner, but as I understand it, modelling always involves assumptions. The modelling process works by taking a guess at the way you think things are working and comparing to your results and then trying to improve your model. Of course you can make your model fit one set of data. The real test is to see how it performs on new sets of data.
              – George Tomlinson
              Sep 5 '13 at 12:44










            • I'd start by trying the default Excel stochastic model and see how it performs
              – George Tomlinson
              Sep 5 '13 at 12:45










            • And then if that's not good, maybe try the built in Monte Carlo.
              – George Tomlinson
              Sep 5 '13 at 12:46






            • 1




              What about linear regression?
              – George Tomlinson
              Sep 6 '13 at 18:27















            Thanks for the very detailed and informative post. The problem I have is all I've got it daily revenue data, say Jan 1st - Dec 31st. I know the company spends, say, 1 million in June 1st on advertising. So, I need to use Jan 1st - May 31st data to predict what the rev should be without the 1m spend, and then I also know what it actually is because of the 1m spend (the 'actual' revenue). The issue is I cannot make assumptions as I know nothing more than the revenue figures. Whats the best method I can use please?
            – Dino Abraham
            Sep 5 '13 at 12:35





            Thanks for the very detailed and informative post. The problem I have is all I've got it daily revenue data, say Jan 1st - Dec 31st. I know the company spends, say, 1 million in June 1st on advertising. So, I need to use Jan 1st - May 31st data to predict what the rev should be without the 1m spend, and then I also know what it actually is because of the 1m spend (the 'actual' revenue). The issue is I cannot make assumptions as I know nothing more than the revenue figures. Whats the best method I can use please?
            – Dino Abraham
            Sep 5 '13 at 12:35













            In all honesty, despite my dissertation, I'm no expert on the subject: just a beginner, but as I understand it, modelling always involves assumptions. The modelling process works by taking a guess at the way you think things are working and comparing to your results and then trying to improve your model. Of course you can make your model fit one set of data. The real test is to see how it performs on new sets of data.
            – George Tomlinson
            Sep 5 '13 at 12:44




            In all honesty, despite my dissertation, I'm no expert on the subject: just a beginner, but as I understand it, modelling always involves assumptions. The modelling process works by taking a guess at the way you think things are working and comparing to your results and then trying to improve your model. Of course you can make your model fit one set of data. The real test is to see how it performs on new sets of data.
            – George Tomlinson
            Sep 5 '13 at 12:44












            I'd start by trying the default Excel stochastic model and see how it performs
            – George Tomlinson
            Sep 5 '13 at 12:45




            I'd start by trying the default Excel stochastic model and see how it performs
            – George Tomlinson
            Sep 5 '13 at 12:45












            And then if that's not good, maybe try the built in Monte Carlo.
            – George Tomlinson
            Sep 5 '13 at 12:46




            And then if that's not good, maybe try the built in Monte Carlo.
            – George Tomlinson
            Sep 5 '13 at 12:46




            1




            1




            What about linear regression?
            – George Tomlinson
            Sep 6 '13 at 18:27




            What about linear regression?
            – George Tomlinson
            Sep 6 '13 at 18:27










            up vote
            0
            down vote













            I'd probably use Variable and Fixed cost analysis as an input to a forecast of future sales and costs. I have a full blog about it linked below with an excel template. I'll talk about your specific example as much as I can.



            Variable and Fixed Costs - Small Business Decisions



            Variable costs may change drastically from day to day, but the real point of what you're trying to do is understand the general trend so that you can forecast your expected ROI. You should use a longer period of time to understand what portion of your sales revenue is variable with the cost than a single day. In the end, a month over month value for expected ROI should be sufficient. Daily analysis would be overkill in any of the business programs I've been involved in, most of which were multi-million dollar programs.



            You should use the template provided to determine your variable costs. The template is set up for 12 months if you have the data. Then you should estimate what kind of sales volume you can expect to continue from your latest sales data. The Sales team at your company should be able to help you with that. With an understanding of the variable costs, you can project your expected sales and the expected costs associated with those sales.



            If your company has several other products, I'd also suggest you use the sales revenue specific to your product as the top line instead of the overall company sales. This will help identify which portion of the overall company sales are correlated with your specific product. The two numbers should be relatively similar in percentage, but drastically different in scale. Ex: 12% variable cost for $1 Million in sales at the company level is $120,000. 14% variable cost of $10,000 in sales of your specific product is $1,400. Similar variable cost percentage rates, but vastly different scales. Now, this comparison is important because in the case that another product had sales increases at the same time as your product, it'll be very difficult to ensure that the costs your allocating to your product are actually a result of your product's changes in sales.



            If you work in a company that is so large your product won't make up the difference in a rounding error on their P&L (not an insult, I've been there), then you should look for standard allocations for SAR and add them to your direct costs.






            share|cite|improve this answer


























              up vote
              0
              down vote













              I'd probably use Variable and Fixed cost analysis as an input to a forecast of future sales and costs. I have a full blog about it linked below with an excel template. I'll talk about your specific example as much as I can.



              Variable and Fixed Costs - Small Business Decisions



              Variable costs may change drastically from day to day, but the real point of what you're trying to do is understand the general trend so that you can forecast your expected ROI. You should use a longer period of time to understand what portion of your sales revenue is variable with the cost than a single day. In the end, a month over month value for expected ROI should be sufficient. Daily analysis would be overkill in any of the business programs I've been involved in, most of which were multi-million dollar programs.



              You should use the template provided to determine your variable costs. The template is set up for 12 months if you have the data. Then you should estimate what kind of sales volume you can expect to continue from your latest sales data. The Sales team at your company should be able to help you with that. With an understanding of the variable costs, you can project your expected sales and the expected costs associated with those sales.



              If your company has several other products, I'd also suggest you use the sales revenue specific to your product as the top line instead of the overall company sales. This will help identify which portion of the overall company sales are correlated with your specific product. The two numbers should be relatively similar in percentage, but drastically different in scale. Ex: 12% variable cost for $1 Million in sales at the company level is $120,000. 14% variable cost of $10,000 in sales of your specific product is $1,400. Similar variable cost percentage rates, but vastly different scales. Now, this comparison is important because in the case that another product had sales increases at the same time as your product, it'll be very difficult to ensure that the costs your allocating to your product are actually a result of your product's changes in sales.



              If you work in a company that is so large your product won't make up the difference in a rounding error on their P&L (not an insult, I've been there), then you should look for standard allocations for SAR and add them to your direct costs.






              share|cite|improve this answer
























                up vote
                0
                down vote










                up vote
                0
                down vote









                I'd probably use Variable and Fixed cost analysis as an input to a forecast of future sales and costs. I have a full blog about it linked below with an excel template. I'll talk about your specific example as much as I can.



                Variable and Fixed Costs - Small Business Decisions



                Variable costs may change drastically from day to day, but the real point of what you're trying to do is understand the general trend so that you can forecast your expected ROI. You should use a longer period of time to understand what portion of your sales revenue is variable with the cost than a single day. In the end, a month over month value for expected ROI should be sufficient. Daily analysis would be overkill in any of the business programs I've been involved in, most of which were multi-million dollar programs.



                You should use the template provided to determine your variable costs. The template is set up for 12 months if you have the data. Then you should estimate what kind of sales volume you can expect to continue from your latest sales data. The Sales team at your company should be able to help you with that. With an understanding of the variable costs, you can project your expected sales and the expected costs associated with those sales.



                If your company has several other products, I'd also suggest you use the sales revenue specific to your product as the top line instead of the overall company sales. This will help identify which portion of the overall company sales are correlated with your specific product. The two numbers should be relatively similar in percentage, but drastically different in scale. Ex: 12% variable cost for $1 Million in sales at the company level is $120,000. 14% variable cost of $10,000 in sales of your specific product is $1,400. Similar variable cost percentage rates, but vastly different scales. Now, this comparison is important because in the case that another product had sales increases at the same time as your product, it'll be very difficult to ensure that the costs your allocating to your product are actually a result of your product's changes in sales.



                If you work in a company that is so large your product won't make up the difference in a rounding error on their P&L (not an insult, I've been there), then you should look for standard allocations for SAR and add them to your direct costs.






                share|cite|improve this answer














                I'd probably use Variable and Fixed cost analysis as an input to a forecast of future sales and costs. I have a full blog about it linked below with an excel template. I'll talk about your specific example as much as I can.



                Variable and Fixed Costs - Small Business Decisions



                Variable costs may change drastically from day to day, but the real point of what you're trying to do is understand the general trend so that you can forecast your expected ROI. You should use a longer period of time to understand what portion of your sales revenue is variable with the cost than a single day. In the end, a month over month value for expected ROI should be sufficient. Daily analysis would be overkill in any of the business programs I've been involved in, most of which were multi-million dollar programs.



                You should use the template provided to determine your variable costs. The template is set up for 12 months if you have the data. Then you should estimate what kind of sales volume you can expect to continue from your latest sales data. The Sales team at your company should be able to help you with that. With an understanding of the variable costs, you can project your expected sales and the expected costs associated with those sales.



                If your company has several other products, I'd also suggest you use the sales revenue specific to your product as the top line instead of the overall company sales. This will help identify which portion of the overall company sales are correlated with your specific product. The two numbers should be relatively similar in percentage, but drastically different in scale. Ex: 12% variable cost for $1 Million in sales at the company level is $120,000. 14% variable cost of $10,000 in sales of your specific product is $1,400. Similar variable cost percentage rates, but vastly different scales. Now, this comparison is important because in the case that another product had sales increases at the same time as your product, it'll be very difficult to ensure that the costs your allocating to your product are actually a result of your product's changes in sales.



                If you work in a company that is so large your product won't make up the difference in a rounding error on their P&L (not an insult, I've been there), then you should look for standard allocations for SAR and add them to your direct costs.







                share|cite|improve this answer














                share|cite|improve this answer



                share|cite|improve this answer








                edited Aug 29 '16 at 5:31

























                answered Aug 29 '16 at 5:22









                turbonate

                13




                13



























                     

                    draft saved


                    draft discarded















































                     


                    draft saved


                    draft discarded














                    StackExchange.ready(
                    function ()
                    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fmath.stackexchange.com%2fquestions%2f484768%2fforecasting-future-revenue-data-for-roi-calculation%23new-answer', 'question_page');

                    );

                    Post as a guest













































































                    這個網誌中的熱門文章

                    How to combine Bézier curves to a surface?

                    Mutual Information Always Non-negative

                    Why am i infinitely getting the same tweet with the Twitter Search API?