Commit 1dbbe212 authored by Douglas's avatar Douglas

Fixes typos and export inventory as csv snippet

parent 7e9f1202
...@@ -6,22 +6,22 @@ ...@@ -6,22 +6,22 @@
"source": [ "source": [
"# Introduction\n", "# Introduction\n",
"\n", "\n",
"This tutorial will guide your through predicting orders in ERP5 using an ARIMA model. The orders will be exported by ERP5 in CSV format (comma-sepparated values), and accessed and processed localy in a Jupyter Notebok.\n", "This tutorial will guide your through predicting orders in ERP5 using an ARIMA model. The orders will be exported by ERP5 in CSV format (comma-sepparated values), and accessed and processed localy in a Jupyter Notebook.\n",
"\n", "\n",
"Please note that pandas and numpy can also be used inside ERP5 Wendelin software release, but Jupyter notebook adds more convenient. Soon ERP5 integration with Jupyter will be released and merged into Wendelin software release, which will make everything much easier." "Please note that **Pandas** and **NumPy** can also be used inside ERP5 Wendelin software release, but Jupyter notebook adds more convenient. Soon ERP5 integration with Jupyter will be released and merged into Wendelin software release, which will make everything much easier."
] ]
}, },
{ {
"cell_type": "markdown", "cell_type": "markdown",
"metadata": {}, "metadata": {},
"source": [ "source": [
"# A simple sales order\n", "# A simple sale order\n",
"\n", "\n",
"The first step in our experimentation is to create a sample data which will be used to generate the batch of data on which the statistic method will be applied. \n", "The first step in our experimentation is to create a sample data which will be used to generate the batch of data on which the statistic method will be applied. \n",
"\n", "\n",
"So first go to Product Module and create one product named 'Test Product'. Then go to the Organisation Module and create two different organisations: Test Company and Demo Clothes. Now go to Sales Order Module and fill an order as it is shown in the example below. Keep the order very simple and use the product and organisations you just created.\n", "So first go to Product Module and create one product named 'Test Product'. Then go to the Organisation Module and create two different organisations: Test Company and Demo Clothes. Now go to Sales Order Module and fill an order as it is shown in the example below. Keep the order very simple and use the product and organisations you just created.\n",
"\n", "\n",
"Once the order has been created, you must change the workflow status to planned. \n", "Once the order has been created, you must change the workflow status to 'planned'. \n",
"\n", "\n",
"![Sample Order](http://img.erp5.cn/osoe-simple.sales.order-screenshot?format=png)\n" "![Sample Order](http://img.erp5.cn/osoe-simple.sales.order-screenshot?format=png)\n"
] ]
...@@ -32,7 +32,7 @@ ...@@ -32,7 +32,7 @@
"source": [ "source": [
"# Create script to clone data\n", "# Create script to clone data\n",
"\n", "\n",
"Once the sample order has been created we can now create the script to duplicate it and modify the quantity according to the cosinus function we will use. \n", "Once the sample order has been created we can now create the script to duplicate it and modify the quantity according to the cosinus function. \n",
"\n", "\n",
"The custom script must be created in the 'custom' folder within the 'portal_skins' folder. In order to do so you must go to `https://<your_instance_url/portal_skins/custom/manage`. \n", "The custom script must be created in the 'custom' folder within the 'portal_skins' folder. In order to do so you must go to `https://<your_instance_url/portal_skins/custom/manage`. \n",
"\n", "\n",
...@@ -64,7 +64,7 @@ ...@@ -64,7 +64,7 @@
"source": [ "source": [
"# Check the sample data\n", "# Check the sample data\n",
"\n", "\n",
"Now you can go to the Sales Order module and take a look at the generated sale orders. If you don't see any Sale Order there add a filter to see orders with the 'planned' status by writting in the first row of the table in the 'Status' column: '%planned%'. You should have something like the picture below.\n", "Now you can go to the Sales Order Module and take a look at the generated sale orders. If you don't see any Sale Order there add a filter to see orders with the 'planned' status by writting in the first row of the table in the 'Status' column: '%planned%'. You should have something like the picture below.\n",
"\n", "\n",
"![Sample data](http://img.erp5.cn/osoe-watch.sample.data-screenshot?format=png)\n", "![Sample data](http://img.erp5.cn/osoe-watch.sample.data-screenshot?format=png)\n",
"\n", "\n",
...@@ -77,7 +77,7 @@ ...@@ -77,7 +77,7 @@
"source": [ "source": [
"# Extract order data from database\n", "# Extract order data from database\n",
"\n", "\n",
"In order to create a time series of orders we must create the report of the past orders to be used by the method. SO we need to create a new Z SQL Method. You must go to the 'custom' folder in 'portal_skins' (`https://<your_instance_url>/portal_skins/custom/manage`), click in 'Add' and then in 'Z SQL Method'. User 'SaleOrderModule_zGetStock' as SQL Method ID.\n", "In order to create a time series of orders we must create the report of the past orders to be used by the method. So we need to create a new Z SQL Method. You must go to the 'custom' folder in 'portal_skins' (`https://<your_instance_url>/portal_skins/custom/manage`), click in 'Add' and then in 'Z SQL Method'. Use 'SaleOrderModule_zGetStock' as SQL Method ID.\n",
"\n", "\n",
"Then you will type the following query:\n", "Then you will type the following query:\n",
"\n", "\n",
...@@ -108,7 +108,8 @@ ...@@ -108,7 +108,8 @@
" \n", " \n",
" product = self.portal_catalog(title='Test Product', portal_type=\"Product\")[0]\n", " product = self.portal_catalog(title='Test Product', portal_type=\"Product\")[0]\n",
" nexedi = self.portal_catalog(title='Demo Clothes', portal_type='Organisation')[0]\n", " nexedi = self.portal_catalog(title='Demo Clothes', portal_type='Organisation')[0]\n",
" result = self.portal_simulation.getInventoryList() \n", " columns = ['date', 'quantity']\n",
" quantity_list = ([item['date'], item['total_quantity']] for item in self.portal_simulation.getInventoryList()) \n",
" \n", " \n",
" csv_file = StringIO.StringIO()\n", " csv_file = StringIO.StringIO()\n",
" writer = csv.writer(csv_file, delimiter=';')\n", " writer = csv.writer(csv_file, delimiter=';')\n",
...@@ -126,7 +127,7 @@ ...@@ -126,7 +127,7 @@
"source": [ "source": [
"# Exporting the sample data as CSV (external method)\n", "# Exporting the sample data as CSV (external method)\n",
"\n", "\n",
"Then you will need to create an external method to call your extension and run the export code. Navigate again to the 'custom folder' inside 'portal_skins', click 'Add' and choose 'External Method'. Now choose 'getInventoryCsv' as ID, 'InventoryCsv' as 'Module Name' and 'inventory_gsv' as 'Function Name'. Click 'Save changes'." "Then you will need to create an external method to call your extension and run the export code. Navigate again to the 'custom folder' inside 'portal_skins', click 'Add' and choose 'External Method'. Now choose 'getInventoryCsv' as ID, 'InventoryCsv' as 'Module Name' and 'inventory_csv' as 'Function Name'. Click 'Save changes'."
] ]
}, },
{ {
...@@ -190,7 +191,7 @@ ...@@ -190,7 +191,7 @@
}, },
{ {
"cell_type": "code", "cell_type": "code",
"execution_count": 14, "execution_count": 24,
"metadata": { "metadata": {
"collapsed": false, "collapsed": false,
"scrolled": true "scrolled": true
...@@ -199,10 +200,10 @@ ...@@ -199,10 +200,10 @@
{ {
"data": { "data": {
"text/plain": [ "text/plain": [
"<matplotlib.axes._subplots.AxesSubplot at 0x7fda251625d0>" "<matplotlib.axes._subplots.AxesSubplot at 0x7fda2396b150>"
] ]
}, },
"execution_count": 14, "execution_count": 24,
"metadata": {}, "metadata": {},
"output_type": "execute_result" "output_type": "execute_result"
}, },
...@@ -210,7 +211,7 @@ ...@@ -210,7 +211,7 @@
"data": { "data": {
"image/png": "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\nU/8PaSACu+MwelEAAAAASUVORK5CYII=\n", "image/png": "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\nU/8PaSACu+MwelEAAAAASUVORK5CYII=\n",
"text/plain": [ "text/plain": [
"<matplotlib.figure.Figure at 0x7fda32cf9a90>" "<matplotlib.figure.Figure at 0x7fda2397ee10>"
] ]
}, },
"metadata": {}, "metadata": {},
...@@ -219,8 +220,8 @@ ...@@ -219,8 +220,8 @@
], ],
"source": [ "source": [
"# need ssh tunnel to use this url\n", "# need ssh tunnel to use this url\n",
"url = 'http://localhost:2200/erp5/portal_skins/erp5_r_order_prediction_tutorial/SaleOrderModule_getArimaPredictionList'\n", "url = 'https://<your_instance_url>/portal_skins/custom/getInventoryCsv'\n",
"response = requests.get(url, auth=('zope', 'insecure'))\n", "response = requests.get(url, auth=('<your_instance_user>', '<your_instance_user_password'))\n",
"csv_file = StringIO()\n", "csv_file = StringIO()\n",
"csv_file.write(response.text)\n", "csv_file.write(response.text)\n",
"csv_file.seek(0)\n", "csv_file.seek(0)\n",
...@@ -239,14 +240,14 @@ ...@@ -239,14 +240,14 @@
"source": [ "source": [
"# Check if series is stationary\n", "# Check if series is stationary\n",
"\n", "\n",
"ARIMA models requires that the time series is stationary to give good predictions. A data series is stationary when its statiscal properties, like mean, variance, autocorrelation, and etc are all constant over time. You can check it just be looking at the plotted data, but you can also use the Augmented Dicker-Fuller test to have a more precise analysis. \n", "ARIMA models requires that the time series is stationary to give good predictions. A data series is stationary when its statiscal properties, like mean, variance, autocorrelation, and etc are all constant over time. You can check it just be looking at the plotted data, but you can also use the **Augmented Dicker-Fuller** test to have a more precise analysis. \n",
"\n", "\n",
"Using the Augmented Dicker-Fuller test we can check if out data is stationary. For this, we need to get an **adf statistic** value __smaller__ (more negative) than the critical value at 5% for regression **c** (constant), **ct** (constant and trend), **ctt** (constant and quadratic trend)." "Using the Augmented Dicker-Fuller you need to get an **adf statistic** value __smaller__ (more negative) than the critical value at 5% for regression **c** (constant), **ct** (constant and trend), **ctt** (constant and quadratic trend)."
] ]
}, },
{ {
"cell_type": "code", "cell_type": "code",
"execution_count": 15, "execution_count": 25,
"metadata": { "metadata": {
"collapsed": false "collapsed": false
}, },
...@@ -260,11 +261,7 @@ ...@@ -260,11 +261,7 @@
"Time series is stationary with regression constant and trend! :D\n", "Time series is stationary with regression constant and trend! :D\n",
"\n", "\n",
"Time series is stationary with regression constant, linear and quadratic trend! :D\n", "Time series is stationary with regression constant, linear and quadratic trend! :D\n",
"\n", "\n"
"Time series is not stationary with no constant, no trend. See data below:\n",
" - adf statistics: 0.770156930328\n",
" - p-value: 0.879767773183\n",
" - critical values: {'5%': -1.9444409856898011, '1%': -2.5916151807851238, '10%': -1.6141150636269721}\n"
] ]
} }
], ],
...@@ -287,7 +284,7 @@ ...@@ -287,7 +284,7 @@
" print 'Time series is stationary with regression %s! :D\\n' % regressions[regression]\n", " print 'Time series is stationary with regression %s! :D\\n' % regressions[regression]\n",
" return True\n", " return True\n",
"\n", "\n",
"stationarity_tests = [check_stationarity(ts, regression) for regression in ['c', 'ct', 'ctt', 'nc']]\n", "stationarity_tests = [check_stationarity(ts, regression) for regression in ['c', 'ct', 'ctt']]\n",
" " " "
] ]
}, },
...@@ -297,14 +294,15 @@ ...@@ -297,14 +294,15 @@
"source": [ "source": [
"# Statistical analysis (auto correlation and partial auto correlation)\n", "# Statistical analysis (auto correlation and partial auto correlation)\n",
"\n", "\n",
"Now you need to idenfity which ARIMA model order fits better your data. So you will need to plot both the auto correlation and partial correlation graphs and make an analysis on them. 'statsmodels' provide easy to use method to plat both these graphs. Use the snippet below to plot them." "Now you need to idenfity which ARIMA model order fits better your data. So you will need to plot both the auto correlation and partial correlation graphs and make an analysis on them. 'statsmodels' provide easy to use method to plot both these graphs. Use the snippet below to do it."
] ]
}, },
{ {
"cell_type": "code", "cell_type": "code",
"execution_count": 2, "execution_count": 2,
"metadata": { "metadata": {
"collapsed": false "collapsed": false,
"scrolled": false
}, },
"outputs": [ "outputs": [
{ {
...@@ -350,7 +348,7 @@ ...@@ -350,7 +348,7 @@
"source": [ "source": [
"# Minimum order sugestion for ARMA modelling\n", "# Minimum order sugestion for ARMA modelling\n",
"\n", "\n",
"'statsmodels' also have methods to give mathmetical suggestions for ARMA models order. This method can use different information criteria to make its decision. You will use the Akaike Information Criteria (aic) for this tutorial." "'statsmodels' also has useful methods to give mathmetical suggestions for ARMA models order. This method can use different information criteria to make its decision. You will use the Akaike Information Criteria (aic) for this tutorial."
] ]
}, },
{ {
...@@ -491,7 +489,7 @@ ...@@ -491,7 +489,7 @@
"cell_type": "markdown", "cell_type": "markdown",
"metadata": {}, "metadata": {},
"source": [ "source": [
"# ARIMA forecast for orders\n", "# ARIMA prediction for orders\n",
"\n", "\n",
"Finally, you can plot the prediction for your model. And inspect the prediction series values if you like." "Finally, you can plot the prediction for your model. And inspect the prediction series values if you like."
] ]
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment