**Multi-Agent Accelerator for Data Science (MAADS): AutoML for Conventional ML or Historical Batch Data**
*Revolutionizing Data Science with Artificial Intelligence*
**Overview**
*MAADS combines Artificial Intelligence, Machine Learning and Natural Language Processing (with data engineering task automation) in one easy to use library, that allows clients to connect to the MAADS server located anywhere in the world and perform advanced analytics and embed intelligence in their organization seamlessly and fast!*
This library allows users to harness the power of agent-based computing using hundreds of advanced linear and non-linear algorithms. Users can easily integrate Predictive Analytics and Prescriptive Analytics in any solution by wrapping additional code around the functions below.
To install this library a request should be made to **support@otics.ca** for a username and a MAADSTOKEN. Once you have these credentials then install this Python library.
**Compatibility**
- Python 3.8 or greater
- Minimal Python skills needed
**Copyright**
- Author: Sebastian Maurice, PhD
**Installation**
- At the command prompt write:
**pip install maads**
- This assumes you have [Downloaded Python](https://www.python.org/downloads/) and installed it on your computer.
**Syntax**
- There are literally two lines of code you need to write to train your data and make predictions:
**Main functions:**
- **dotraining**
Executes hundreds of agents, running hundreds of advanced algorithms and completes in minutes. A master agent then chooses the BEST algorithm that best models your data.
- **dopredictions**
After training, make high quality predictions - takes 1-2 seconds.
- **hyperpredictions**
After training, make high quality predictions - takes less than half a second (about ~100 milliseconds). Users can also generate predictions using **non-python code** such as JAVA. Using the **maadshyperpredictions.CLASS** file, java apps can call the MAADS prediction server to return predictions very fast. Other apps, using **any** other language, can also call the MAADS prediction server using standard TCP/IP client/server communication protocols like REST: This gives MAADS users' the maximum flexibility to integrate MAADS predictions in any solution!
You can also use hyperpredictions as an API (Python not needed) and make calls from any application using the following format:
GET http://[maads server website]:[port]/[microserviceid]/?hyperpredict=[optimal algo key],[[input data]],[MAADSTOKEN]
MAADS hyper-prediction can also be used in a MICROSERVICES architecture that utilize API gateways (reverse proxies). This allows organizations to balance loads on the server and manage millions or billions of connections, to hyper-predictions, per day without experiencing latency issues.
**Support functions:**
- **dolistkeys**
- List all of the keys associated with the data you have analysed.
- **dolistkeyswithkey**
- List data associated with a single key.
- **dodeletewithkey**
- Permanently delete all data associated with your key.
- **returndata**
- Returns data from the string buffer.
- **getpicklezip**
- Automatically downloads a ZIP file containing the optimal algorithms. Users can modify the parameter estimates as they wish.
- **sendpicklezip**
- Automatically upload a ZIP file containing the optimal algorithms to MAADS. The optimal algorithms will immediately take effect for predictions.
- **deploytoprod**
- Automatically deploy the optimal algorithms to another MAADS server (i.e. production); MAADS will read the ZIP file, extract the algorithms and make all database updates. This function is useful when your MAADS training server(s) and MAADS prediction server(s) are separate. A powerful way to integrate MAADS in a distributed architecture is to automatically train your data, then deploy the optimal algorithms to some other server for predictions. This is a great way to scale your analytics in a large (global) entreprise setting, seamlessly and fast, with MAADS!
- **algoinfo**
- Get detailed information on the algorithm and other information.
- **genpdf**
- Retrieve the PDF containing all of the detailed information on the algorithm and other information like model explanation and feature selection, etc.
- **featureselectionjson**
- Returns JSON collection of feature selection results for easier programmatic manipulation. Use dotraining feature selection switch to return a CSV file of
feature selections. This function conducts **unsupervised learning** and important part of model building.
**Optimization:**
- **optimize**
- Automatically perform optimization of the optimal algorithms by minimizing or maximixing them to find optimal values for the independent variables:
- MAADS offers a unique and powerful way to find the optimal values of the independent variables
- Users can even minimize or maximize upto THREE optimal algorithms AT THE SAME TIME by building a multi-objective equation with the optimal algorithms
- By finding the optimal values of the independent variables you can "prescribe" the right combination of independent variables' values that will lead to the HIGHEST or LOWEST value for the optimal algorithms
- MAADS is one of the first technologies to offer a seamless integration between PREDICTIVE and PRESCRIPTIVE analytics.
**Natural Language Processing (NLP):**
- **nlp**
- Automatically perform NLP to summarize large amounts of text data. Specifically, there are three data sources one can use:
- **Website URL:** you can pass a URL to the NLP function and it will automatically scrape the site and return a summary of the text.
- **PDF:** Send a PDF to be summarized.
- **Text:** Paste text to be summarized.
- This allows users to integrate NLP in unique and powerful ways with advanced analytics.
- **nlpclassify**
- Automatically apply machine learning to predict outcomes from text data. Specifically, MAADS will:
- Preprocess text data and convert it to numeric vectors using over 50 Billion words to vector mappings plus custom mappings specific to your trained model
- Clean your text data by removing strange characters, punctuations, common words, lemmatize the words, etc..
- Convert the dependent category variable to labels.
- If dependent variable is not categorical, you can tell MAADS not to convert the dependent variable. This means you can regress TEXT data on NUMERIC data!
- This function allows users to integrate NLP in unique and powerful ways with advanced analytics to text based systems like Help Desk or security platforms.
**Data Prepping:**
- **balancebigdata**
- This is a very convenient function to extract a data subset from a very large dataset while maintaining its structure. MAADS will do a very detailed analysis of the data to
determine the distribution of the data by binning each variable in a histogram to determine which variables have a good distribution and which ones do not. Using a special algorithm it can effectively extract a subset of data from a **very large data set** which will make it easier for users to use this dataset for MAADS training. This function can also be very effective in reducing MAADS compute times when training.
**First import the Python library.**
**import maads**
1. **maads.dotraining(MAADSTOKEN,CSV_local_file, feature_analysis, remove_outliers, has_seasonality, dependent_variable, maadsurl,throttle,theserverlocalname,summer,winter,shoulder,trainingpercentage,retrainingdays,retraindeploy,shuffle)**
**Parameters:**
*MAADSTOKEN* : string, required
- A token given to you by MAADS administrator.
*CSV_local_file* : string, required
- A local comma-separated-file (csv) with Date in the first column. Date must be MM/DD/YYYY format.
- All other data must be numbers.
*feature_analysis* : int, required, 1 or 0
- If 1, then a feature analysis will be done on your data along with training. If 0, no analysis is done. If -1, features will be generated, and downloaded to your local computer folder WITHOUT training.
*remove_outliers* : int, required, 1 or 0
- If 1, then outliers will be removed from your data. If 0, no outliers are removed.
*has_seasonality* : int, required, 1 or 0
- If 1, then your data will be modeled for seasonality: Winter, Summer, Shoulder. If 0, then your data will
not be modeled for seasonality. If modeling for seasonality, ensure you have enough data points that
covers the seasons, usually 1 year of data.
*dependent_variable* : string, required
- This is the dependent variable in your file. All other variables will be modeled as independent variables.
*maadsurl* : string, required
- Indicate location of MAADS server. You would have received this URL when you received your username and MAADSTOKEN.
*throttle* : int, optional, Default=-1
- Indicates whether you want to throttle the data in the server. For example, if you are dealing with big data and facing memory limitations in the
server, then you can specify a smaller number of rows to use in the training process by specifying the number of rows in the throttle parameter.
*theserverlocalname* : string, optional
- Indicates location of filename with full path in the server to use for training. If this is specified, then CSV_local_file must be empty.
*summer* : string, optional
- Indicate summer months. The default value is '6,7,8' for North America. If you are analysing other continents you could change this value.
*winter* : string, optional
- Indicate winter months. The default value is '12,1,2,3' for North America. If you are analysing other continents you could change this value.
*shoulder* : string, optional
- Indicate shoulder months. The default value is '4,5,9,10,11' for North America. If you are analysing other continents you could change this value.
*trainingpercentage* : number between 40 and 100, inclusive, optional
- Indicates how much of the complete data set to you as the Training data set. The default value is 75% or 75, the rest is used for test or validation.
*retrainingdays* : number, optional
- Indicates how many days to wait, from initial training, to re-train the model. This is convenient to automate re-training of models to take advantage of new data. Default value is 0, for no re-training.
*retraindeploy* : number, 0 or 1, optional
- Indicates whether to deploy (retraindeploy=1) the optimal algorithm to a server (i.e. production) for immediate use after re-training. This assumes FTP server is listed in the MAADS lookup table. Default value is 0, for no deployment after re-training.
*shuffle* : number, 0 or 1, optional
- Indicates whether to shuffle the training dataset or not, default=0.
**Returns:** string buffer, PDF of Results, CSV of Prediction Data
- The string buffer contains the following sections:
- DATA: : This consists of the feature selection results
- PKEY: : This is the key to the BEST algorithm and must be used when making predictions.
**2. maads.dopredictions(MAADSTOKEN,attr,pkey,inputs,maadsurl)**
**Parameters:**
*MAADSTOKEN* : string, required
- A token given to you by MAADS administrator.
*attr* : int, required
- This value should be 0. It may change to other values in the future.
*pkey* : string, required
- This value must be retrieved from dotraining. Note you can store PKEY after you have trained your file.
Training does not have to run before predictions, as training occurs more infrequently.
*inputs* : string, required
- This is a row of input data that must match the independent variables in your CSV. For example, if your
trained file is: Date, A, B, C, D and A is your dependent variable, then your inputs must be:
Date, B, C, D
*maadsurl* : string, required
- Indicate location of MAADS server. You would have received this URL when you received your username and MAADSTOKEN.
**Returns:** string buffer
- The string buffer contains the following sections:
DATA: : This contains your prediction.
**3. maads.hyperpredictions(MAADSTOKEN,pkey,inputdata,host,port,use_reverse_proxy,microserviceid)**
**Parameters:**
*MAADSTOKEN* : string, required
- A token given to you by MAADS administrator.
*pkey* : string, required
- This is the key to the optimal algorithm.
*inputdata* : string, required
- This is the input data for the optimal algorithm to produce a prediction.
*host* : string, required
- The host is the webserver that connects to the MAADS prediction server. This will be provided by the MAADS administrator.
*port* : int, required
- This is the port that the MAADS prediction server listens on. This will be provided by the MAADS administrator. Note: This will bypass any reverse proxy you are using.
*use_reverse_proxy* : int, optional, Default=0 for no reverse proxy
- For users that are using a reverse proxy to balance server load this can be set to 1. You will need to use the port that your proxy is listening on. Note: Your MAADS administrator will have this information. A reverse proxy (or API Gateway) can be a very effective way to manage high loads on the server and route traffic accordingly.
*microserviceid* : string, optional, Default is empty.
- For users that are using a reverse proxy to balance server load and directing connection traffic to specific microservices listening on internal ports in the server then this should be provided. Note: Your MAADS administrator will have this information as needed. Using microservices with an API gateway is a very effective way to scale MAADS in a (global) enterprise environment.
**Returns:** json, prediction value
- The difference between doprediction and hyperpredictions is that do prediction returns
predictions in a few seconds, hyperpredictions returns predictions in milliseconds. So if you require very fast predictions
use hyperpredictions.
**4. maads.returndata(thepredictions, section_attr)**
**Parameters:**
*thepredictions* : string buffer
- This value is returned from dopredictions.
*section_attr* : string buffer
This value can be any one of the values:
- PKEY: : This returns the key from the dotraining function. Note the semi-colon.
- DATA: : This returns the data from the dotraining or dopredictions functions. Note the semi-colon.
- ALGO0: : This returns the BEST algorithm determined by MAADS - without seasonality.
- ACCURACY0: : This returns the forecast accuracy for the BEST algorithm - without seasonaility.
- SEASON0: : This returns allseason - for no seasonality.
- ALGO1: : This returns the BEST algorithm determined by MAADS for WINTER.
- ACCURACY1: : This returns the forecast accuracy for the BEST algorithm for WINTER.
- SEASON1: : This returns WINTER.
- ALGO2: : This returns the BEST algorithm determined by MAADS for SUMMER.
- ACCURACY2: : This returns the forecast accuracy for the BEST algorithm for SUMMER.
- SEASON2: : This returns SUMMER.
- ALGO3: : This returns the BEST algorithm determined by MAADS for SHOULDER season.
- ACCURACY3: : This returns the forecast accuracy for the BEST algorithm for SHOULDER season.
- SEASON3: : This returns SHOULDER.
**Returns:** string buffer
- The string buffer contains the prediction or the key or the feature analysis.
**5. maads.dodeletewithkey(MAADSTOKEN,pkey,maadsurl)**
**Parameters:**
*MAADSTOKEN* : string, required
- A token given to you by MAADS administrator.
*pkey* : string buffer
- The key you want deleted. This can be attained from dolistkeys function.
*maadsurl* : string, required
- Indicate location of MAADS server. You would have received this URL when you received your username and MAADSTOKEN.
**Returns:** NULL
- Deletes all files and tables associated with the key permanently.
**6. maads.dolistkeys(MAADSTOKEN,maadsurl)**
**Parameters:**
*MAADSTOKEN* : string, required
- A token given to you by MAADS administrator.
*maadsurl* : string, required
- Indicate location of MAADS server. You would have received this URL when you received your username and MAADSTOKEN.
**Returns:** string buffer
- Lists all the keys associated with your MAADSTOKEN.
**7. maads.dolistkeyswithkey(MAADSTOKEN, pkey,maadsurl)**
**Parameters:**
*MAADSTOKEN* : string, required
- A token given to you by MAADS administrator.
*pkey* : string buffer
- The key you want returned.
*maadsurl* : string, required
- Indicate location of MAADS server. You would have received this URL when you received your username and MAADSTOKEN.
**Returns:** string buffer
- Returns the information (with independent variables) associated with your key.
**8. maads.getpicklezip(MAADSTOKEN,pkey,url,localfolder)**
**Parameters:**
*MAADSTOKEN* : string, required
- A token given to you by MAADS administrator.
*pkey* : string buffer
- The key for the trained model.
*url* : string, required
- Indicate location of MAADS server. This is the root location of the MAADS folder in the webserver.
*localfolder* : string, required
- Indicates local folder location where file will be saved (i.e. C:/MAADS). Please use folder slashes.
**Returns:** ZIP File
- This is a binary ZIP file and stored in the location of the localfolder.
**9. maads.sendpicklezip(MAADSTOKEN, pkey,url,localfilename)**
**Parameters:**
*MAADSTOKEN* : string, required
- A token given to you by MAADS administrator.
*pkey* : string buffer
- The key for the trained model.
*url* : string, required
- Indicate location of MAADS PHP file in the webserver.
*localfilename* : string, required
- Indicates local filename to be sent to the server. The file name should have a proper file format: key_DEPLOYTOPROD.zip
**Returns:** Server Response.
- The ZIP file will be stored and read by MAADS and all necessary changes will immediately take effect.
**10. maads.deploytoprod(MAADSTOKEN, pkey,url,localfilename,ftpserver,ftpuser,ftppass)**
**Parameters:**
*MAADSTOKEN* : string, required
- A token given to you by MAADS administrator.
*pkey* : string buffer
- The key for the trained model.
*url* : string, required
- Indicate location of MAADS PHP file in the webserver.
*localfilename* : string, optional
- Indicates local filename to be sent to the server. If indicating localfilename it must have a proper file format: key_DEPLOYTOPROD.zip
*ftpserver* : string, optional
- Indicates ftp server you want to deploy the optimal algorithms to for predictions. If no FTP server is specified a default FTP server
will used as listed on the MAADS server. If none is listed this function will fail.
*ftpuser* : string, optional
- Indicates ftp username to login to ftp server. If no FTP username is specified a default FTP username
will used as listed on the MAADS server.
*ftppass* : string, optional
- Indicates ftp password to login to ftp server. If no FTP password is specified a default FTP password
will used as listed on the MAADS server.
**Returns:** Server Response.
- The ZIP file will be stored and deployed to the MAADS PROD server (with FTP connection) and read by MAADS and all necessary changes will immediately take effect. The functions: dopredictions and hyperpredictions can immediately be used.
**11. maads.nlp(MAADSTOKEN,url,buffer,theserverfolder,wordcount,maxkeywords)**
**Parameters:**
*MAADSTOKEN* : string, required
- A token given to you by MAADS administrator.
*url* : string, required
- Indicate location of MAADS PHP file in the webserver.
*buffer* : string buffer, optional
- The data source to be summarized: URL, PDF, TEXT. If this is not specified, then theserverfolder cannot be empty.
*theserverfolder* : string buffer, optional
- This is a folder in the server that MAADS will read for files. This is convenient when you do not want to transfer files to the server. If this is not specified, then buffer cannot be empty.
*wordcount* : int, required
- Indicates how many words you want returned.
*maxkeywords* : int, optional, Default=10
- Indicates how many keywords you want returned.
**Returns:** Two JSON objects separated by semi-colon.
- The first JSON are the extracted keywords in the text. The second is the text summary.
**12. maads.nlpclassify(MAADSTOKEN,iscategory,maads_rest_url,csvfile,theserverlocalname,throttle,csvonly,
username,trainingpercentage,retrainingdays,retraindeploy)**
**Parameters:**
*MAADSTOKEN* : string, required
- A token given to you by MAADS administrator.
*iscategory* : int, required
- 1=Dependent Variable is a category, 0=Dependent variable is continuous
*maads_rest_url* : buffer, required
- Indicates the url for the MAADS training server with main PHP file.
*csvfile* : string buffer, optional
- The csvfile file to analyse. The file must contain headers in the first row, and TWO columns: first column is the dependent variable (text or numeric), the
second column is text. If this is not specified, then
*theserverlocalname* : string buffer, optional
- The full path of the filename in the server that MAADS will read for training. If this is empty, then csvfile must be specified.
*throttle* : int, optional, Default=-1
- Indicates whether you want to throttle the data in the server. For example, if you are dealing with big data and facing memory limitations in the
server, then you can specify a smaller number of rows to use in the training process by specifying the number of rows in the throttle parameter.
*csvonly* : number, 0 or 1, optional, Default=0
- IF csvonly is set to 1, MAADS will return the converted file only in csv format. This is convenient because nlpclassify can take several minutes for conversion and training, when a user may only want the converted file without the optimal algorithm. Also, the converted file could be used as input into another model for training...especially when combining machine learning models that use only numeric data, and those using text data.
*username* : string, optional, Default=empty
- IF csvonly is set to 1, you must specify your username in the server.
*trainingpercentage* : number between 40 and 100, inclusive, optional
- Indicates how much of the complete data set to use as the Training data set. The default value is 75% or 75, the rest is used for test or validation.
*retrainingdays* : number, optional
- Indicates how many days to wait, from initial training, to re-train the model. This is convenient to automate re-training of models to take advantage of new data. Default value is 0, for no re-training.
*retraindeploy* : number, 0 or 1, optional
- Indicates whether to deploy (retraindeploy=1) the optimal algorithm to a server (i.e. production) for immediate use after re-training. This assumes FTP server is listed in the MAADS lookup table. Default value is 0, for no deployment after re-training.
**Returns:** Server Response.
- Key to the optimal algorithm used for predictions. NOTE: This key must be used in the HYPERPREDICTION function only.
**13. maads.algoinfo(MAADSTOKEN,maads_rest_url,key,finddistribution)**
**Parameters:**
*MAADSTOKEN* : string, required
- A token given to you by MAADS administrator.
*maads_rest_url* : string, required
- Indicates the url for the MAADS training server with main PHP file.
*key* : string, required
- The key to the optimal algorithm returned by dotraining function.
*finddistribution* : int, optional, Default=0
- Finds the distribution of the trained data.
**Returns:** JSON formatted information.
- The information contains all of the key details associated with the algorithm.
**14. maads.genpdf(MAADSTOKEN,maads_rest_url,key,urltomaadsserver,savetofolder)**
**Parameters:**
*MAADSTOKEN* : string, required
- A token given to you by MAADS administrator.
*maads_rest_url* : string, required
- Indicates the url for the MAADS training server with main PHP file.
*key* : string, required
- The key to the optimal algorithm returned by dotraining function.
*urltomaadsserver* : string, required
- The website url to MAADS server.
*savetofolder* : string, required
- Your local folder names where you want the PDF saved.
**Returns:** PDF file.
- The PDF contains all of the key details associated with the algorithm.
**15. maads.featureselectionjson(MAADSTOKEN,maads_rest_url,key)**
**Parameters:**
*MAADSTOKEN* : string, required
- A token given to you by MAADS administrator.
*maads_rest_url* : string, required
- Indicates the url for the MAADS training server with main PHP file.
*key* : string, required
- The key to the optimal algorithm returned by dotraining function.
**Returns:** JSON formatted information.
- The information contains all of the key details associated with feature selection.
**16. maads.optimize(MAADSTOKEN, maads_rest_url, algo1, ismin=1, objeq='1', a1cons=1, boundslimits='',
forceupdate=0, algo2='', algo3='', a2cons=1,a3cons=1, iters=100, step=4, perc='min_0_max_0')**
**Parameters:**
*MAADSTOKEN* : string, required
- A token given to you by MAADS administrator.
*maads_rest_url* : string, required
- Indicates the url for the MAADS training server with main PHP file.
*algo1* : string, required
- The optimal algo key to minimize or maximize - the optimal algorithm returned by dotraining function.
*algo2* : string, optional
- The optimal algo key to minimize or maximize - the optimal algorithm returned by dotraining function.
*algo3* : string, optional
- The optimal algo key to minimize or maximize - the optimal algorithm returned by dotraining function.
*ismin* : int, optional, default=1
- If ismin=1 then optimal algo will be minimized, if ismin=0 then it will be maximized.
*objeq* : string, optional, default='1'
- objeq is when you have a multi-objective optimal algorithms you want to maximize or minimize. For example, if you want to minimize TWO optimal algorithms and you want an objective function= algo1 + algo2, then objeq=1,1. If objective function=-algo1 - algo2 then objeq=-1,-1. If objective function=-algo1 + algo2 + algo3 then objeq=-1,1,1, etc. etc.
*boundslimits* : string, default='none'
- Sets custom limits on the bounds of independent variable. The lower and upper limit bounds can be for each variable or a subset of variable. The format must be the following:
*variablename:[-1,0,1]:[lowervalue,equal,none]:[uppervalue,none]:[i,f]*
- variablename is the name of your independent variable
- [-1,0,1] must be ONE of -1,0,1. -1 means values of variable name must be all negative, 0 means values can be negative or positive, 1 means values must be all positive
- lowervalue is the lower bound on variable name or equal or none. If 'equal' you must specify the value in the 'uppervalue' field.
- uppervalue is the upper bound on variable name or none for no bound. If no bound, MAADS will create a large value using the High value of variable.
- [i,f] means i=integer, f=float, this allows users to specify the types of values for variables.
For example: If you have two variables named HOUR and MINUTE and you want to bound them, then you can specify:
- *"hour:1:0:23,minute:1:0:59"* means hour is all positive, bounded between 0 and 23, AND minute is all positive bounded between 0 and 59. You can also just specify
- *"hour:1:none:none,minute:1:none:none"* means hour is all positive and minute is all positive. Or,
- *"hour:1:none:23,minute:1:0:none" means hour is all positive with no lower limit, and upper limit of 23, minute is all positive with lower limit of 0 and no upper limit.
- *"hour:1:equal:12,minute:1:0:59"* means hour will equal 12 (hour=12), AND minute is all positive bounded between 0 and 59. You can also just specify
- *Boundslimits* will give users maximum amount of flexibity when specifying bounds for constraints.
*NOTE:* Variablename MUST match the variables that the model is trained on. You can retrieve these EXACT names from the function: *maads.dolistkeyswithkey(MAADSTOKEN, pkey,maadsurl)*
*a1cons* : int, optional, default=1, can be 1,2,3,4
- a1cons specifies the bounds on the independent variables in the constraint equations for algo 1. For example:
- if a1cons=1, then MAADS will "USE MIN/MAX Of Variables For Bounds". Specifically, min <= var <= max
- if a1cons=2, then MAADS will "USE MEAN +/- STD Of Variables For Bounds". Specifically, mean-std <= var <= mean+std
- if a1cons=3, then MAADS will "USE MIN/MAX +/- STD Of Variables For Bounds". Specifically, min-std <= var <= max+std
- if a1cons=4, then MAADS will "USE MEDIAN +/- STD Of Variables For Bounds". Specifically, median-std <= var <= median+std
*a2cons* : int, optional, default=1, can be 1,2,3,4. Only used if algo2 is specified.
- a2cons specifies the bounds on the independent variables in the constraint equations for algo 2. For example:
- if a2cons=1, then MAADS will "USE MIN/MAX Of Variables For Bounds". Specifically, min <= var <= max
- if a2cons=2, then MAADS will "USE MEAN +/- STD Of Variables For Bounds". Specifically, mean-std <= var <= mean+std
- if a2cons=3, then MAADS will "USE MIN/MAX +/- STD Of Variables For Bounds". Specifically, min-std <= var <= max+std
- if a2cons=4, then MAADS will "USE MEDIAN +/- STD Of Variables For Bounds". Specifically, median-std <= var <= median+std
*a3cons* : int, optional, default=1, can be 1,2,3,4. Only used if algo3 is specified.
- a3cons specifies the bounds on the independent variables in the constraint equations for algo 3. For example:
- if a3cons=1, then MAADS will "USE MIN/MAX Of Variables For Bounds". Specifically, min <= var <= max
- if a3cons=2, then MAADS will "USE MEAN +/- STD Of Variables For Bounds". Specifically, mean-std <= var <= mean+std
- if a3cons=3, then MAADS will "USE MIN/MAX +/- STD Of Variables For Bounds". Specifically, min-std <= var <= max+std
- if a3cons=4, then MAADS will "USE MEDIAN +/- STD Of Variables For Bounds". Specifically, median-std <= var <= median+std
*forceupdate* : int, optional, default=0, can be 1, or 0
- forceupdate tells MAADS to update the optimal values. If forceupdate=0, MAADS will decide if the NEW optimal values should replace the OLD optimal values. Specifically, if you are maximizing an optimal algo and the new value is LOWER than old value, MAADS will NOT replace old value with new value, because the old value is better. If forceupdate=1, MAADS will force an update regardless if the new value is better or worse than old value.
*iters* : int, optional, default=100, max=500
- Specifies the number of iterations to use in the optimization algorithms.
*step* : int, optional, default=3, can be 1,2,3,4
- Specifies how to generate the values of the independent variables for the constraint equations. For example,
- if step=1, then MAADS will use a uniform distribution bounded by the choices of a1cons, a2cons, a3cons, as applicable.
- if step=2, then MAADS will use a Gaussian distribution bounded by the choices of a1cons, a2cons, a3cons, as applicable.
- if step=3, then MAADS will combine uniform and Gaussian by averaging to create a distribution bounded by the choices of a1cons, a2cons, a3cons, as applicable.
- if step=4, then MAADS will find values around an epsilon distance, using the standard deviation, around the values that have historically led to lowest or highest values depending on your optimization problem.
*perc* : string, optional, default='min_0_max_0' - 0 means 0%, values should be greater and equal to 0.
- Specifies by how much to "stretch" the bounds on the constraints. For example, if "min_50_max_150", means to lower the MIN bound by 50%, and increase the MAX bound by 150%. This allows users to specify any size of bounds.
**Returns:** JSON formatted information.
- The information contains all of the key details associated with optimization including, value of the objective function, constraints, bounds, initial conditions, optimal values of independent variables, etc..
**17. maads.balancebigdata(localcsvfile,numberofbins,maxrows,outputfile,bincutoff,distcutoff,startcolumn=0)**
**Parameters:**
*localcsvfile* : string, required
- Local file, must be CSV formatted.
*numberofbins* : int, required
- The number of bins for the histogram. You can set to any value but 10 is usually fine.
*maxrows* : int, required
- The number of rows to return, which will be a subset of your original data.
*outputfile* : string, required
- Your new data will be writted as CSV to this file.
*bincutoff* : float, required.
- This is the threshold percentage for the bins. Specifically, the data in each variable is allocated to bins, but many
times it will not fall in ALL of the bins. By setting this percentage between 0 and 1, MAADS will choose variables that
exceed this threshold to determine which variables have data that are well distributed across bins. The variables
with the most distributed values in the bins will drive the selection of the rows in your dataset that give the best
distribution - this will be very important for MAADS training. Usually 0.7 is good.
*distcutoff* : float, required.
- This is the threshold percentage for the distribution. Specifically, MAADS uses a Lilliefors statistic to determine whether
the data are well distributed. The lower the number the better. Usually 0.45 is good.
*startcolumn* : int, optional
- This tells MAADS which column to start from. If you have DATE in the first column, you can tell MAADS to start from 1 (columns are zero-based)
RETURNS: Returns a detailed JSON object and new balaced dataset written to outputfile.
**Simple Example**
#############################################################
Author: Sebastian Maurice, PhD
Copyright by Sebastian Maurice 2018
All rights reserved.
Email: Sebastian.maurice@otics.ca
#############################################################
** IMPORT THE MAAADS LIBRARY*
import maads
** IMPORT ADDITIONAL LIBRARY**
import imp
** LOAD ANY DATABASE LIBRARY TO STORE PREDICTIONS**
sqlconn = imp.load_source('sqlconn','C:\\sqlsrvconnpython.py')
** OPEN DATABASE CONNECTION**
connection = sqlconn.doconnect()
cur = connection.cursor()
** TEST DATA **
inputs = '1/12/2018,37.76896'
pkey='demouser_test2log_csv'
MAADSTOKEN=XXXXXXXXXXXXXXXXXXXX
username='demouser'
url='/maads/remotemasstreamremote.php'
** DO TRAINING - SERVER RETURNS A KEY THAT POINTS TO THE BEST ALGORITHM**
thedata=maads.dotraining(MAADSTOKEN,'C:\\test2log.csv',1,0,0,'depvar',url)
** PARSE RETURNED DATA**
pkey=maads.returndata(thedata,'PKEY:')
algo=maads.returndata(thedata,'ALGO0:')
accuracy=maads.returndata(thedata,'ACCURACY0:')
** DO PREDICTIONS WITH THE RETURNED KEY**
thepredictions=maads.dopredictions(MAADSTOKEN,0,pkey,inputs,url)
** PARSE THE DATA**
prediction=maads.returndata(thepredictions,'DATA:')
** INSERT PREDICTIONS TO ANY DATABASE TABLE**
forecastdate=inputs.split(',')[0]
predictionvalue=prediction[2]
accuracy=prediction[3]
SQL="INSERT INTO PREDICTIONS VALUES('%s','%s','%s','%s','%s',%.3f,%.3f)" % (forecastdate,username,pkey,company,inputs,predictionvalue,accuracy)
cur.execute(SQL)
cur.commit()
** CLOSE THE DATABASE CONNECTION**
cur.close()
Raw data
{
"_id": null,
"home_page": "https://github.com/smaurice101/acnsmauricedsmas",
"name": "maads",
"maintainer": "",
"docs_url": null,
"requires_python": "",
"maintainer_email": "",
"keywords": "multi-agent, data science, optimization, prescriptive analytics, machine learning, automl,auto-ml,artificial intelligence,predictive analytics,advanced analytics",
"author": "Sebastian Maurice",
"author_email": "sebastian.maurice@otics.ca",
"download_url": "https://files.pythonhosted.org/packages/91/ec/32b9ff16f5680126abd97eabac754f6754a3b11af2f3778de24506727be6/maads-5.2.3.tar.gz",
"platform": null,
"description": "**Multi-Agent Accelerator for Data Science (MAADS): AutoML for Conventional ML or Historical Batch Data**\r\n\r\n*Revolutionizing Data Science with Artificial Intelligence*\r\n\r\n**Overview**\r\n\r\n*MAADS combines Artificial Intelligence, Machine Learning and Natural Language Processing (with data engineering task automation) in one easy to use library, that allows clients to connect to the MAADS server located anywhere in the world and perform advanced analytics and embed intelligence in their organization seamlessly and fast!*\r\n\r\nThis library allows users to harness the power of agent-based computing using hundreds of advanced linear and non-linear algorithms. Users can easily integrate Predictive Analytics and Prescriptive Analytics in any solution by wrapping additional code around the functions below. \r\n\r\nTo install this library a request should be made to **support@otics.ca** for a username and a MAADSTOKEN. Once you have these credentials then install this Python library.\r\n\r\n**Compatibility**\r\n - Python 3.8 or greater\r\n - Minimal Python skills needed\r\n\r\n**Copyright**\r\n - Author: Sebastian Maurice, PhD\r\n\r\n**Installation**\r\n - At the command prompt write:\r\n **pip install maads**\r\n - This assumes you have [Downloaded Python](https://www.python.org/downloads/) and installed it on your computer. \r\n\r\n**Syntax**\r\n - There are literally two lines of code you need to write to train your data and make predictions:\r\n\r\n**Main functions:**\r\n - **dotraining**\r\n Executes hundreds of agents, running hundreds of advanced algorithms and completes in minutes. A master agent then chooses the BEST algorithm that best models your data.\r\n - **dopredictions**\r\n After training, make high quality predictions - takes 1-2 seconds.\r\n - **hyperpredictions**\r\n After training, make high quality predictions - takes less than half a second (about ~100 milliseconds). Users can also generate predictions using **non-python code** such as JAVA. Using the **maadshyperpredictions.CLASS** file, java apps can call the MAADS prediction server to return predictions very fast. Other apps, using **any** other language, can also call the MAADS prediction server using standard TCP/IP client/server communication protocols like REST: This gives MAADS users' the maximum flexibility to integrate MAADS predictions in any solution! \r\n\t \r\n\t You can also use hyperpredictions as an API (Python not needed) and make calls from any application using the following format:\r\n\t GET http://[maads server website]:[port]/[microserviceid]/?hyperpredict=[optimal algo key],[[input data]],[MAADSTOKEN]\r\n\t \r\n\t MAADS hyper-prediction can also be used in a MICROSERVICES architecture that utilize API gateways (reverse proxies). This allows organizations to balance loads on the server and manage millions or billions of connections, to hyper-predictions, per day without experiencing latency issues.\r\n\t \r\n**Support functions:**\r\n\r\n- **dolistkeys**\r\n - List all of the keys associated with the data you have analysed. \r\n- **dolistkeyswithkey**\r\n - List data associated with a single key.\r\n- **dodeletewithkey**\r\n - Permanently delete all data associated with your key.\r\n- **returndata**\r\n - Returns data from the string buffer.\r\n- **getpicklezip**\r\n - Automatically downloads a ZIP file containing the optimal algorithms. Users can modify the parameter estimates as they wish.\r\n- **sendpicklezip**\r\n - Automatically upload a ZIP file containing the optimal algorithms to MAADS. The optimal algorithms will immediately take effect for predictions.\r\n- **deploytoprod**\r\n - Automatically deploy the optimal algorithms to another MAADS server (i.e. production); MAADS will read the ZIP file, extract the algorithms and make all database updates. This function is useful when your MAADS training server(s) and MAADS prediction server(s) are separate. A powerful way to integrate MAADS in a distributed architecture is to automatically train your data, then deploy the optimal algorithms to some other server for predictions. This is a great way to scale your analytics in a large (global) entreprise setting, seamlessly and fast, with MAADS!\r\n- **algoinfo**\r\n - Get detailed information on the algorithm and other information.\r\n- **genpdf**\r\n - Retrieve the PDF containing all of the detailed information on the algorithm and other information like model explanation and feature selection, etc.\t\r\n- **featureselectionjson**\r\n - Returns JSON collection of feature selection results for easier programmatic manipulation. Use dotraining feature selection switch to return a CSV file of \r\n\t\t feature selections. This function conducts **unsupervised learning** and important part of model building.\r\n\r\n**Optimization:**\r\n\r\n- **optimize**\r\n - Automatically perform optimization of the optimal algorithms by minimizing or maximixing them to find optimal values for the independent variables:\r\n - MAADS offers a unique and powerful way to find the optimal values of the independent variables\r\n - Users can even minimize or maximize upto THREE optimal algorithms AT THE SAME TIME by building a multi-objective equation with the optimal algorithms\r\n\t - By finding the optimal values of the independent variables you can \"prescribe\" the right combination of independent variables' values that will lead to the HIGHEST or LOWEST value for the optimal algorithms\r\n\t - MAADS is one of the first technologies to offer a seamless integration between PREDICTIVE and PRESCRIPTIVE analytics.\r\n\t\t\r\n**Natural Language Processing (NLP):**\r\n\r\n- **nlp**\r\n - Automatically perform NLP to summarize large amounts of text data. Specifically, there are three data sources one can use:\r\n - **Website URL:** you can pass a URL to the NLP function and it will automatically scrape the site and return a summary of the text.\r\n - **PDF:** Send a PDF to be summarized.\r\n - **Text:** Paste text to be summarized.\r\n - This allows users to integrate NLP in unique and powerful ways with advanced analytics.\r\n\t \r\n- **nlpclassify**\r\n - Automatically apply machine learning to predict outcomes from text data. Specifically, MAADS will:\r\n - Preprocess text data and convert it to numeric vectors using over 50 Billion words to vector mappings plus custom mappings specific to your trained model\r\n\t - Clean your text data by removing strange characters, punctuations, common words, lemmatize the words, etc..\r\n\t - Convert the dependent category variable to labels. \r\n\t - If dependent variable is not categorical, you can tell MAADS not to convert the dependent variable. This means you can regress TEXT data on NUMERIC data!\r\n - This function allows users to integrate NLP in unique and powerful ways with advanced analytics to text based systems like Help Desk or security platforms.\r\n\r\n**Data Prepping:**\r\n- **balancebigdata**\r\n - This is a very convenient function to extract a data subset from a very large dataset while maintaining its structure. MAADS will do a very detailed analysis of the data to \r\n determine the distribution of the data by binning each variable in a histogram to determine which variables have a good distribution and which ones do not. Using a special algorithm it can effectively extract a subset of data from a **very large data set** which will make it easier for users to use this dataset for MAADS training. This function can also be very effective in reducing MAADS compute times when training.\t\r\n\r\n**First import the Python library.**\r\n\r\n**import maads**\r\n\r\n1. **maads.dotraining(MAADSTOKEN,CSV_local_file, feature_analysis, remove_outliers, has_seasonality, dependent_variable, maadsurl,throttle,theserverlocalname,summer,winter,shoulder,trainingpercentage,retrainingdays,retraindeploy,shuffle)**\r\n\r\n**Parameters:**\t\r\n\r\n*MAADSTOKEN* : string, required\r\n\r\n- A token given to you by MAADS administrator.\r\n\r\n*CSV_local_file* : string, required\r\n\r\n- A local comma-separated-file (csv) with Date in the first column. Date must be MM/DD/YYYY format. \r\n- All other data must be numbers.\r\n\r\n*feature_analysis* : int, required, 1 or 0\r\n\r\n- If 1, then a feature analysis will be done on your data along with training. If 0, no analysis is done. If -1, features will be generated, and downloaded to your local computer folder WITHOUT training.\r\n \r\n*remove_outliers* : int, required, 1 or 0\r\n\r\n- If 1, then outliers will be removed from your data. If 0, no outliers are removed.\r\n\r\n*has_seasonality* : int, required, 1 or 0\r\n \r\n- If 1, then your data will be modeled for seasonality: Winter, Summer, Shoulder. If 0, then your data will \r\n not be modeled for seasonality. If modeling for seasonality, ensure you have enough data points that \r\n covers the seasons, usually 1 year of data.\r\n\r\n*dependent_variable* : string, required\r\n \r\n- This is the dependent variable in your file. All other variables will be modeled as independent variables.\r\n \r\n*maadsurl* : string, required\r\n \r\n- Indicate location of MAADS server. You would have received this URL when you received your username and MAADSTOKEN. \r\n\r\n*throttle* : int, optional, Default=-1\r\n \r\n- Indicates whether you want to throttle the data in the server. For example, if you are dealing with big data and facing memory limitations in the \r\n server, then you can specify a smaller number of rows to use in the training process by specifying the number of rows in the throttle parameter. \r\n\r\n*theserverlocalname* : string, optional\r\n \r\n- Indicates location of filename with full path in the server to use for training. If this is specified, then CSV_local_file must be empty.\r\n\r\n*summer* : string, optional\r\n\r\n- Indicate summer months. The default value is '6,7,8' for North America. If you are analysing other continents you could change this value. \r\n\r\n*winter* : string, optional\r\n\r\n- Indicate winter months. The default value is '12,1,2,3' for North America. If you are analysing other continents you could change this value. \r\n\r\n*shoulder* : string, optional\r\n\r\n- Indicate shoulder months. The default value is '4,5,9,10,11' for North America. If you are analysing other continents you could change this value. \r\n\r\n*trainingpercentage* : number between 40 and 100, inclusive, optional\r\n\r\n- Indicates how much of the complete data set to you as the Training data set. The default value is 75% or 75, the rest is used for test or validation.\r\n\r\n*retrainingdays* : number, optional\r\n\r\n- Indicates how many days to wait, from initial training, to re-train the model. This is convenient to automate re-training of models to take advantage of new data. Default value is 0, for no re-training.\r\n\r\n*retraindeploy* : number, 0 or 1, optional\r\n\r\n- Indicates whether to deploy (retraindeploy=1) the optimal algorithm to a server (i.e. production) for immediate use after re-training. This assumes FTP server is listed in the MAADS lookup table. Default value is 0, for no deployment after re-training.\r\n\r\n*shuffle* : number, 0 or 1, optional\r\n\r\n- Indicates whether to shuffle the training dataset or not, default=0.\r\n\r\n**Returns:** string buffer, PDF of Results, CSV of Prediction Data\r\n \r\n- The string buffer contains the following sections:\r\n \r\n- DATA: : This consists of the feature selection results\r\n- PKEY: : This is the key to the BEST algorithm and must be used when making predictions.\r\n\r\n\t\t\t\r\n\r\n**2. maads.dopredictions(MAADSTOKEN,attr,pkey,inputs,maadsurl)**\r\n\r\n**Parameters:**\t\r\n\r\n*MAADSTOKEN* : string, required\r\n\r\n- A token given to you by MAADS administrator.\r\n\r\n*attr* : int, required\r\n\r\n- This value should be 0. It may change to other values in the future.\r\n\r\n*pkey* : string, required\r\n\r\n- This value must be retrieved from dotraining. Note you can store PKEY after you have trained your file. \r\n Training does not have to run before predictions, as training occurs more infrequently.\r\n\r\n*inputs* : string, required\r\n \r\n- This is a row of input data that must match the independent variables in your CSV. For example, if your \r\n trained file is: Date, A, B, C, D and A is your dependent variable, then your inputs must be:\r\n Date, B, C, D\r\n \r\n*maadsurl* : string, required\r\n \r\n- Indicate location of MAADS server. You would have received this URL when you received your username and MAADSTOKEN. \r\n\t \r\n**Returns:** string buffer\r\n \r\n- The string buffer contains the following sections:\r\n \r\n DATA: : This contains your prediction.\r\n\r\n**3. maads.hyperpredictions(MAADSTOKEN,pkey,inputdata,host,port,use_reverse_proxy,microserviceid)**\r\n\r\n**Parameters:**\t\r\n\r\n*MAADSTOKEN* : string, required\r\n\r\n- A token given to you by MAADS administrator.\r\n \r\n*pkey* : string, required\r\n \r\n- This is the key to the optimal algorithm.\r\n\r\n*inputdata* : string, required\r\n \r\n- This is the input data for the optimal algorithm to produce a prediction.\r\n\r\n*host* : string, required\r\n\r\n- The host is the webserver that connects to the MAADS prediction server. This will be provided by the MAADS administrator.\r\n\r\n*port* : int, required\r\n\r\n- This is the port that the MAADS prediction server listens on. This will be provided by the MAADS administrator. Note: This will bypass any reverse proxy you are using.\r\n\r\n*use_reverse_proxy* : int, optional, Default=0 for no reverse proxy\r\n \r\n- For users that are using a reverse proxy to balance server load this can be set to 1. You will need to use the port that your proxy is listening on. Note: Your MAADS administrator will have this information. A reverse proxy (or API Gateway) can be a very effective way to manage high loads on the server and route traffic accordingly.\r\n\r\n*microserviceid* : string, optional, Default is empty.\r\n \r\n- For users that are using a reverse proxy to balance server load and directing connection traffic to specific microservices listening on internal ports in the server then this should be provided. Note: Your MAADS administrator will have this information as needed. Using microservices with an API gateway is a very effective way to scale MAADS in a (global) enterprise environment.\r\n\r\n**Returns:** json, prediction value\r\n \r\n- The difference between doprediction and hyperpredictions is that do prediction returns \r\n predictions in a few seconds, hyperpredictions returns predictions in milliseconds. So if you require very fast predictions\r\n\t\tuse hyperpredictions. \r\n \r\n**4. maads.returndata(thepredictions, section_attr)**\r\n\r\n**Parameters:**\t\r\n\r\n*thepredictions* : string buffer\r\n\r\n- This value is returned from dopredictions.\r\n\r\n*section_attr* : string buffer\r\n\r\nThis value can be any one of the values:\r\n \r\n- PKEY: : This returns the key from the dotraining function. Note the semi-colon.\r\n- DATA: : This returns the data from the dotraining or dopredictions functions. Note the semi-colon.\r\n- ALGO0: : This returns the BEST algorithm determined by MAADS - without seasonality.\r\n- ACCURACY0: : This returns the forecast accuracy for the BEST algorithm - without seasonaility.\r\n- SEASON0: : This returns allseason - for no seasonality.\r\n- ALGO1: : This returns the BEST algorithm determined by MAADS for WINTER.\r\n- ACCURACY1: : This returns the forecast accuracy for the BEST algorithm for WINTER.\r\n- SEASON1: : This returns WINTER.\r\n- ALGO2: : This returns the BEST algorithm determined by MAADS for SUMMER.\r\n- ACCURACY2: : This returns the forecast accuracy for the BEST algorithm for SUMMER.\r\n- SEASON2: : This returns SUMMER.\r\n- ALGO3: : This returns the BEST algorithm determined by MAADS for SHOULDER season.\r\n- ACCURACY3: : This returns the forecast accuracy for the BEST algorithm for SHOULDER season.\r\n- SEASON3: : This returns SHOULDER.\r\n \r\n**Returns:** string buffer\r\n \r\n- The string buffer contains the prediction or the key or the feature analysis.\r\n \r\n**5. maads.dodeletewithkey(MAADSTOKEN,pkey,maadsurl)**\r\n\r\n**Parameters:**\t\r\n\r\n*MAADSTOKEN* : string, required\r\n\r\n- A token given to you by MAADS administrator.\r\n\r\n*pkey* : string buffer\r\n\r\n- The key you want deleted. This can be attained from dolistkeys function.\r\n\r\n*maadsurl* : string, required\r\n \r\n- Indicate location of MAADS server. You would have received this URL when you received your username and MAADSTOKEN. \r\n\t \r\n**Returns:** NULL\r\n \r\n- Deletes all files and tables associated with the key permanently.\r\n \r\n**6. maads.dolistkeys(MAADSTOKEN,maadsurl)**\r\n\r\n**Parameters:**\t\r\n\r\n*MAADSTOKEN* : string, required\r\n\r\n- A token given to you by MAADS administrator.\r\n\r\n*maadsurl* : string, required\r\n \r\n- Indicate location of MAADS server. You would have received this URL when you received your username and MAADSTOKEN. \r\n\t \r\n**Returns:** string buffer\r\n \r\n- Lists all the keys associated with your MAADSTOKEN.\r\n \r\n**7. maads.dolistkeyswithkey(MAADSTOKEN, pkey,maadsurl)**\r\n\r\n**Parameters:**\t\r\n\r\n*MAADSTOKEN* : string, required\r\n\r\n- A token given to you by MAADS administrator.\r\n\r\n*pkey* : string buffer\r\n\r\n- The key you want returned.\r\n\r\n*maadsurl* : string, required\r\n \r\n- Indicate location of MAADS server. You would have received this URL when you received your username and MAADSTOKEN. \r\n\t \r\n**Returns:** string buffer\r\n \r\n- Returns the information (with independent variables) associated with your key.\r\n\r\n \r\n**8. maads.getpicklezip(MAADSTOKEN,pkey,url,localfolder)**\r\n\r\n**Parameters:**\t\r\n\r\n*MAADSTOKEN* : string, required\r\n\r\n- A token given to you by MAADS administrator.\r\n\r\n*pkey* : string buffer\r\n\r\n- The key for the trained model.\r\n\r\n*url* : string, required\r\n \r\n- Indicate location of MAADS server. This is the root location of the MAADS folder in the webserver. \r\n\r\n*localfolder* : string, required\r\n \r\n- Indicates local folder location where file will be saved (i.e. C:/MAADS). Please use folder slashes.\r\n\t \r\n**Returns:** ZIP File\r\n \r\n- This is a binary ZIP file and stored in the location of the localfolder.\r\n \r\n**9. maads.sendpicklezip(MAADSTOKEN, pkey,url,localfilename)**\r\n\r\n**Parameters:**\t\r\n\r\n*MAADSTOKEN* : string, required\r\n\r\n- A token given to you by MAADS administrator.\r\n\r\n*pkey* : string buffer\r\n\r\n- The key for the trained model.\r\n\r\n*url* : string, required\r\n \r\n- Indicate location of MAADS PHP file in the webserver. \r\n\r\n*localfilename* : string, required\r\n \r\n- Indicates local filename to be sent to the server. The file name should have a proper file format: key_DEPLOYTOPROD.zip \r\n\t \r\n**Returns:** Server Response.\r\n \r\n- The ZIP file will be stored and read by MAADS and all necessary changes will immediately take effect.\r\n \r\n**10. maads.deploytoprod(MAADSTOKEN, pkey,url,localfilename,ftpserver,ftpuser,ftppass)**\r\n\r\n**Parameters:**\t\r\n\r\n*MAADSTOKEN* : string, required\r\n\r\n- A token given to you by MAADS administrator.\r\n\r\n*pkey* : string buffer\r\n\r\n- The key for the trained model.\r\n\r\n*url* : string, required\r\n \r\n- Indicate location of MAADS PHP file in the webserver. \r\n\r\n*localfilename* : string, optional\r\n \r\n- Indicates local filename to be sent to the server. If indicating localfilename it must have a proper file format: key_DEPLOYTOPROD.zip \r\n\r\n*ftpserver* : string, optional\r\n \r\n- Indicates ftp server you want to deploy the optimal algorithms to for predictions. If no FTP server is specified a default FTP server\r\n will used as listed on the MAADS server. If none is listed this function will fail.\r\n\t \r\n*ftpuser* : string, optional\r\n \r\n- Indicates ftp username to login to ftp server. If no FTP username is specified a default FTP username\r\n will used as listed on the MAADS server.\r\n\r\n*ftppass* : string, optional\r\n \r\n- Indicates ftp password to login to ftp server. If no FTP password is specified a default FTP password\r\n will used as listed on the MAADS server.\r\n\t \r\n**Returns:** Server Response.\r\n \r\n- The ZIP file will be stored and deployed to the MAADS PROD server (with FTP connection) and read by MAADS and all necessary changes will immediately take effect. The functions: dopredictions and hyperpredictions can immediately be used.\r\n\r\n**11. maads.nlp(MAADSTOKEN,url,buffer,theserverfolder,wordcount,maxkeywords)**\r\n\r\n**Parameters:**\t\r\n\r\n*MAADSTOKEN* : string, required\r\n\r\n- A token given to you by MAADS administrator.\r\n\r\n*url* : string, required\r\n \r\n- Indicate location of MAADS PHP file in the webserver. \r\n\r\n*buffer* : string buffer, optional\r\n\r\n- The data source to be summarized: URL, PDF, TEXT. If this is not specified, then theserverfolder cannot be empty.\r\n\r\n*theserverfolder* : string buffer, optional\r\n\r\n- This is a folder in the server that MAADS will read for files. This is convenient when you do not want to transfer files to the server. If this is not specified, then buffer cannot be empty.\r\n\r\n*wordcount* : int, required\r\n \r\n- Indicates how many words you want returned. \r\n\r\n*maxkeywords* : int, optional, Default=10\r\n \r\n- Indicates how many keywords you want returned. \r\n\r\n**Returns:** Two JSON objects separated by semi-colon.\r\n \r\n- The first JSON are the extracted keywords in the text. The second is the text summary.\r\n\r\n**12. maads.nlpclassify(MAADSTOKEN,iscategory,maads_rest_url,csvfile,theserverlocalname,throttle,csvonly,\r\n\tusername,trainingpercentage,retrainingdays,retraindeploy)**\r\n \r\n**Parameters:**\t\r\n\r\n*MAADSTOKEN* : string, required\r\n\r\n- A token given to you by MAADS administrator.\r\n\r\n*iscategory* : int, required\r\n \r\n- 1=Dependent Variable is a category, 0=Dependent variable is continuous\r\n\r\n*maads_rest_url* : buffer, required\r\n \r\n- Indicates the url for the MAADS training server with main PHP file.\r\n\r\n*csvfile* : string buffer, optional\r\n\r\n- The csvfile file to analyse. The file must contain headers in the first row, and TWO columns: first column is the dependent variable (text or numeric), the \r\n second column is text. If this is not specified, then \r\n\r\n*theserverlocalname* : string buffer, optional\r\n\r\n- The full path of the filename in the server that MAADS will read for training. If this is empty, then csvfile must be specified.\r\n\r\n*throttle* : int, optional, Default=-1\r\n \r\n- Indicates whether you want to throttle the data in the server. For example, if you are dealing with big data and facing memory limitations in the \r\n server, then you can specify a smaller number of rows to use in the training process by specifying the number of rows in the throttle parameter. \r\n\r\n*csvonly* : number, 0 or 1, optional, Default=0\r\n\r\n- IF csvonly is set to 1, MAADS will return the converted file only in csv format. This is convenient because nlpclassify can take several minutes for conversion and training, when a user may only want the converted file without the optimal algorithm. Also, the converted file could be used as input into another model for training...especially when combining machine learning models that use only numeric data, and those using text data.\r\n\r\n*username* : string, optional, Default=empty\r\n\r\n- IF csvonly is set to 1, you must specify your username in the server.\r\n\r\n*trainingpercentage* : number between 40 and 100, inclusive, optional\r\n\r\n- Indicates how much of the complete data set to use as the Training data set. The default value is 75% or 75, the rest is used for test or validation.\r\n\r\n*retrainingdays* : number, optional\r\n\r\n- Indicates how many days to wait, from initial training, to re-train the model. This is convenient to automate re-training of models to take advantage of new data. Default value is 0, for no re-training.\r\n\r\n*retraindeploy* : number, 0 or 1, optional\r\n\r\n- Indicates whether to deploy (retraindeploy=1) the optimal algorithm to a server (i.e. production) for immediate use after re-training. This assumes FTP server is listed in the MAADS lookup table. Default value is 0, for no deployment after re-training.\r\n\t \r\n**Returns:** Server Response.\r\n \r\n- Key to the optimal algorithm used for predictions. NOTE: This key must be used in the HYPERPREDICTION function only.\r\n\r\n\r\n**13. maads.algoinfo(MAADSTOKEN,maads_rest_url,key,finddistribution)**\r\n\r\n**Parameters:**\t\r\n\r\n*MAADSTOKEN* : string, required\r\n\r\n- A token given to you by MAADS administrator.\r\n\r\n*maads_rest_url* : string, required\r\n \r\n- Indicates the url for the MAADS training server with main PHP file.\r\n\r\n*key* : string, required\r\n\r\n- The key to the optimal algorithm returned by dotraining function.\r\n\r\n*finddistribution* : int, optional, Default=0\r\n\r\n- Finds the distribution of the trained data.\r\n\r\n**Returns:** JSON formatted information.\r\n \r\n- The information contains all of the key details associated with the algorithm.\r\n\r\n\r\n**14. maads.genpdf(MAADSTOKEN,maads_rest_url,key,urltomaadsserver,savetofolder)**\r\n\r\n**Parameters:**\t\r\n\r\n*MAADSTOKEN* : string, required\r\n\r\n- A token given to you by MAADS administrator.\r\n\r\n*maads_rest_url* : string, required\r\n \r\n- Indicates the url for the MAADS training server with main PHP file.\r\n\r\n*key* : string, required\r\n\r\n- The key to the optimal algorithm returned by dotraining function.\r\n\r\n*urltomaadsserver* : string, required\r\n\r\n- The website url to MAADS server.\r\n\r\n*savetofolder* : string, required\r\n\r\n- Your local folder names where you want the PDF saved.\r\n\r\n**Returns:** PDF file.\r\n \r\n- The PDF contains all of the key details associated with the algorithm.\r\n\r\n\r\n**15. maads.featureselectionjson(MAADSTOKEN,maads_rest_url,key)**\r\n\r\n**Parameters:**\t\r\n\r\n*MAADSTOKEN* : string, required\r\n\r\n- A token given to you by MAADS administrator.\r\n\r\n*maads_rest_url* : string, required\r\n \r\n- Indicates the url for the MAADS training server with main PHP file.\r\n\r\n*key* : string, required\r\n\r\n- The key to the optimal algorithm returned by dotraining function.\r\n\r\n**Returns:** JSON formatted information.\r\n \r\n- The information contains all of the key details associated with feature selection.\r\n\r\n\r\n**16. maads.optimize(MAADSTOKEN, maads_rest_url, algo1, ismin=1, objeq='1', a1cons=1, boundslimits='',\r\n\t\tforceupdate=0, algo2='', algo3='', a2cons=1,a3cons=1, iters=100, step=4, perc='min_0_max_0')**\r\n\r\n**Parameters:**\t\r\n\r\n*MAADSTOKEN* : string, required\r\n\r\n- A token given to you by MAADS administrator.\r\n\r\n*maads_rest_url* : string, required\r\n \r\n- Indicates the url for the MAADS training server with main PHP file.\r\n\r\n*algo1* : string, required\r\n\r\n- The optimal algo key to minimize or maximize - the optimal algorithm returned by dotraining function.\r\n\r\n*algo2* : string, optional\r\n\r\n- The optimal algo key to minimize or maximize - the optimal algorithm returned by dotraining function.\r\n\r\n*algo3* : string, optional\r\n\r\n- The optimal algo key to minimize or maximize - the optimal algorithm returned by dotraining function.\r\n\r\n*ismin* : int, optional, default=1\r\n\r\n- If ismin=1 then optimal algo will be minimized, if ismin=0 then it will be maximized.\r\n\r\n*objeq* : string, optional, default='1'\r\n\r\n- objeq is when you have a multi-objective optimal algorithms you want to maximize or minimize. For example, if you want to minimize TWO optimal algorithms and you want an objective function= algo1 + algo2, then objeq=1,1. If objective function=-algo1 - algo2 then objeq=-1,-1. If objective function=-algo1 + algo2 + algo3 then objeq=-1,1,1, etc. etc. \r\n\r\n*boundslimits* : string, default='none'\r\n- Sets custom limits on the bounds of independent variable. The lower and upper limit bounds can be for each variable or a subset of variable. The format must be the following:\r\n *variablename:[-1,0,1]:[lowervalue,equal,none]:[uppervalue,none]:[i,f]*\r\n \r\n - variablename is the name of your independent variable\r\n \r\n - [-1,0,1] must be ONE of -1,0,1. -1 means values of variable name must be all negative, 0 means values can be negative or positive, 1 means values must be all positive\r\n \r\n - lowervalue is the lower bound on variable name or equal or none. If 'equal' you must specify the value in the 'uppervalue' field.\r\n \r\n - uppervalue is the upper bound on variable name or none for no bound. If no bound, MAADS will create a large value using the High value of variable.\r\n \r\n - [i,f] means i=integer, f=float, this allows users to specify the types of values for variables.\r\n \r\n For example: If you have two variables named HOUR and MINUTE and you want to bound them, then you can specify:\r\n \r\n - *\"hour:1:0:23,minute:1:0:59\"* means hour is all positive, bounded between 0 and 23, AND minute is all positive bounded between 0 and 59. You can also just specify\r\n \r\n - *\"hour:1:none:none,minute:1:none:none\"* means hour is all positive and minute is all positive. Or, \r\n \r\n - *\"hour:1:none:23,minute:1:0:none\" means hour is all positive with no lower limit, and upper limit of 23, minute is all positive with lower limit of 0 and no upper limit. \r\n\r\n - *\"hour:1:equal:12,minute:1:0:59\"* means hour will equal 12 (hour=12), AND minute is all positive bounded between 0 and 59. You can also just specify\r\n \r\n - *Boundslimits* will give users maximum amount of flexibity when specifying bounds for constraints.\r\n \r\n *NOTE:* Variablename MUST match the variables that the model is trained on. You can retrieve these EXACT names from the function: *maads.dolistkeyswithkey(MAADSTOKEN, pkey,maadsurl)*\r\n \r\n\r\n*a1cons* : int, optional, default=1, can be 1,2,3,4\r\n\r\n- a1cons specifies the bounds on the independent variables in the constraint equations for algo 1. For example:\r\n\r\n - if a1cons=1, then MAADS will \"USE MIN/MAX Of Variables For Bounds\". Specifically, min <= var <= max\r\n\r\n - if a1cons=2, then MAADS will \"USE MEAN +/- STD Of Variables For Bounds\". Specifically, mean-std <= var <= mean+std\r\n\r\n - if a1cons=3, then MAADS will \"USE MIN/MAX +/- STD Of Variables For Bounds\". Specifically, min-std <= var <= max+std\r\n\r\n - if a1cons=4, then MAADS will \"USE MEDIAN +/- STD Of Variables For Bounds\". Specifically, median-std <= var <= median+std\r\n\r\n*a2cons* : int, optional, default=1, can be 1,2,3,4. Only used if algo2 is specified.\r\n\r\n- a2cons specifies the bounds on the independent variables in the constraint equations for algo 2. For example:\r\n\r\n - if a2cons=1, then MAADS will \"USE MIN/MAX Of Variables For Bounds\". Specifically, min <= var <= max\r\n \r\n - if a2cons=2, then MAADS will \"USE MEAN +/- STD Of Variables For Bounds\". Specifically, mean-std <= var <= mean+std\r\n\r\n - if a2cons=3, then MAADS will \"USE MIN/MAX +/- STD Of Variables For Bounds\". Specifically, min-std <= var <= max+std\r\n\r\n - if a2cons=4, then MAADS will \"USE MEDIAN +/- STD Of Variables For Bounds\". Specifically, median-std <= var <= median+std\r\n\r\n*a3cons* : int, optional, default=1, can be 1,2,3,4. Only used if algo3 is specified.\r\n\r\n- a3cons specifies the bounds on the independent variables in the constraint equations for algo 3. For example:\r\n\r\n - if a3cons=1, then MAADS will \"USE MIN/MAX Of Variables For Bounds\". Specifically, min <= var <= max\r\n\r\n - if a3cons=2, then MAADS will \"USE MEAN +/- STD Of Variables For Bounds\". Specifically, mean-std <= var <= mean+std\r\n \r\n - if a3cons=3, then MAADS will \"USE MIN/MAX +/- STD Of Variables For Bounds\". Specifically, min-std <= var <= max+std\r\n\r\n - if a3cons=4, then MAADS will \"USE MEDIAN +/- STD Of Variables For Bounds\". Specifically, median-std <= var <= median+std\r\n\r\n*forceupdate* : int, optional, default=0, can be 1, or 0\r\n\r\n- forceupdate tells MAADS to update the optimal values. If forceupdate=0, MAADS will decide if the NEW optimal values should replace the OLD optimal values. Specifically, if you are maximizing an optimal algo and the new value is LOWER than old value, MAADS will NOT replace old value with new value, because the old value is better. If forceupdate=1, MAADS will force an update regardless if the new value is better or worse than old value.\r\n\r\n\r\n*iters* : int, optional, default=100, max=500\r\n- Specifies the number of iterations to use in the optimization algorithms.\r\n\r\n*step* : int, optional, default=3, can be 1,2,3,4\r\n- Specifies how to generate the values of the independent variables for the constraint equations. For example,\r\n\r\n - if step=1, then MAADS will use a uniform distribution bounded by the choices of a1cons, a2cons, a3cons, as applicable.\r\n\r\n - if step=2, then MAADS will use a Gaussian distribution bounded by the choices of a1cons, a2cons, a3cons, as applicable.\r\n\r\n - if step=3, then MAADS will combine uniform and Gaussian by averaging to create a distribution bounded by the choices of a1cons, a2cons, a3cons, as applicable.\r\n\r\n - if step=4, then MAADS will find values around an epsilon distance, using the standard deviation, around the values that have historically led to lowest or highest values depending on your optimization problem.\r\n\r\n*perc* : string, optional, default='min_0_max_0' - 0 means 0%, values should be greater and equal to 0.\r\n- Specifies by how much to \"stretch\" the bounds on the constraints. For example, if \"min_50_max_150\", means to lower the MIN bound by 50%, and increase the MAX bound by 150%. This allows users to specify any size of bounds. \r\n\r\n\r\n**Returns:** JSON formatted information.\r\n \r\n- The information contains all of the key details associated with optimization including, value of the objective function, constraints, bounds, initial conditions, optimal values of independent variables, etc..\r\n \r\n**17. maads.balancebigdata(localcsvfile,numberofbins,maxrows,outputfile,bincutoff,distcutoff,startcolumn=0)**\r\n\r\n**Parameters:**\t\r\n\r\n*localcsvfile* : string, required\r\n\r\n- Local file, must be CSV formatted.\r\n\r\n*numberofbins* : int, required\r\n\r\n- The number of bins for the histogram. You can set to any value but 10 is usually fine.\r\n\r\n*maxrows* : int, required\r\n\r\n- The number of rows to return, which will be a subset of your original data.\r\n\r\n*outputfile* : string, required\r\n\r\n- Your new data will be writted as CSV to this file.\r\n\r\n*bincutoff* : float, required. \r\n\r\n- This is the threshold percentage for the bins. Specifically, the data in each variable is allocated to bins, but many \r\n times it will not fall in ALL of the bins. By setting this percentage between 0 and 1, MAADS will choose variables that\r\n exceed this threshold to determine which variables have data that are well distributed across bins. The variables\r\n with the most distributed values in the bins will drive the selection of the rows in your dataset that give the best\r\n distribution - this will be very important for MAADS training. Usually 0.7 is good.\r\n\r\n*distcutoff* : float, required. \r\n\r\n- This is the threshold percentage for the distribution. Specifically, MAADS uses a Lilliefors statistic to determine whether \r\n the data are well distributed. The lower the number the better. Usually 0.45 is good.\r\n \r\n*startcolumn* : int, optional\r\n\r\n- This tells MAADS which column to start from. If you have DATE in the first column, you can tell MAADS to start from 1 (columns are zero-based)\r\n\r\nRETURNS: Returns a detailed JSON object and new balaced dataset written to outputfile.\r\n\r\n\r\n**Simple Example** \r\n\r\n#############################################################\r\n\r\nAuthor: Sebastian Maurice, PhD\r\n\r\nCopyright by Sebastian Maurice 2018\r\n\r\nAll rights reserved.\r\n\r\nEmail: Sebastian.maurice@otics.ca\r\n\r\n#############################################################\r\n\r\n\r\n** IMPORT THE MAAADS LIBRARY*\r\n import maads\r\n\r\n** IMPORT ADDITIONAL LIBRARY**\r\n import imp\r\n\r\n\r\n** LOAD ANY DATABASE LIBRARY TO STORE PREDICTIONS**\r\n sqlconn = imp.load_source('sqlconn','C:\\\\sqlsrvconnpython.py')\r\n\r\n** OPEN DATABASE CONNECTION**\r\n connection = sqlconn.doconnect()\r\n\r\n cur = connection.cursor()\r\n\r\n** TEST DATA ** \r\n inputs = '1/12/2018,37.76896'\r\n \r\n pkey='demouser_test2log_csv'\r\n MAADSTOKEN=XXXXXXXXXXXXXXXXXXXX\r\n username='demouser'\r\n\r\n url='/maads/remotemasstreamremote.php'\r\n\r\n\r\n** DO TRAINING - SERVER RETURNS A KEY THAT POINTS TO THE BEST ALGORITHM**\r\n thedata=maads.dotraining(MAADSTOKEN,'C:\\\\test2log.csv',1,0,0,'depvar',url)\r\n\r\n** PARSE RETURNED DATA**\r\n pkey=maads.returndata(thedata,'PKEY:')\r\n\r\n algo=maads.returndata(thedata,'ALGO0:')\r\n\r\n accuracy=maads.returndata(thedata,'ACCURACY0:')\r\n \r\n** DO PREDICTIONS WITH THE RETURNED KEY**\r\n thepredictions=maads.dopredictions(MAADSTOKEN,0,pkey,inputs,url)\r\n\r\n** PARSE THE DATA**\r\n prediction=maads.returndata(thepredictions,'DATA:')\r\n\r\n\r\n** INSERT PREDICTIONS TO ANY DATABASE TABLE**\r\n forecastdate=inputs.split(',')[0]\r\n\r\n predictionvalue=prediction[2]\r\n\r\n accuracy=prediction[3]\r\n\r\n SQL=\"INSERT INTO PREDICTIONS VALUES('%s','%s','%s','%s','%s',%.3f,%.3f)\" % (forecastdate,username,pkey,company,inputs,predictionvalue,accuracy)\r\n\r\n cur.execute(SQL)\r\n\r\n cur.commit()\r\n\r\n** CLOSE THE DATABASE CONNECTION**\r\n cur.close()\r\n\r\n \r\n",
"bugtrack_url": null,
"license": "MIT License",
"summary": "Multi-Agent Accelerator for Data Science (MAADS)",
"version": "5.2.3",
"project_urls": {
"Homepage": "https://github.com/smaurice101/acnsmauricedsmas"
},
"split_keywords": [
"multi-agent",
" data science",
" optimization",
" prescriptive analytics",
" machine learning",
" automl",
"auto-ml",
"artificial intelligence",
"predictive analytics",
"advanced analytics"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "6c40853f80807a2d0a392f1ae2cc0e43254f93e300cf612fc37a0be4e32ae67e",
"md5": "5a38eced1b134accd63590d234feef53",
"sha256": "035ef7bd3d2af0b44a791e780d4e5c8006df5e2d835f928668edb37c22d73384"
},
"downloads": -1,
"filename": "maads-5.2.3-py3-none-any.whl",
"has_sig": false,
"md5_digest": "5a38eced1b134accd63590d234feef53",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": null,
"size": 23796,
"upload_time": "2023-08-04T19:18:16",
"upload_time_iso_8601": "2023-08-04T19:18:16.045078Z",
"url": "https://files.pythonhosted.org/packages/6c/40/853f80807a2d0a392f1ae2cc0e43254f93e300cf612fc37a0be4e32ae67e/maads-5.2.3-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "91ec32b9ff16f5680126abd97eabac754f6754a3b11af2f3778de24506727be6",
"md5": "b6eb921804cc0a95fbed58b656969674",
"sha256": "c380918dfa7c1741f2b066286c4a898ecc67ec87696d48d8cbe5733d5182b881"
},
"downloads": -1,
"filename": "maads-5.2.3.tar.gz",
"has_sig": false,
"md5_digest": "b6eb921804cc0a95fbed58b656969674",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 41684,
"upload_time": "2023-08-04T19:18:17",
"upload_time_iso_8601": "2023-08-04T19:18:17.459321Z",
"url": "https://files.pythonhosted.org/packages/91/ec/32b9ff16f5680126abd97eabac754f6754a3b11af2f3778de24506727be6/maads-5.2.3.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2023-08-04 19:18:17",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "smaurice101",
"github_project": "acnsmauricedsmas",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"lcname": "maads"
}