Integration of Qlikview with R
Transcription
Integration of Qlikview with R
This Whitepaper describes how to integrate the Qlikview with R analytics software on the web Integrate Qlikview with R on the web Swapneel Golapkar Qlikview Developer R&D associate [email protected] Contents Introduction............................................................................................................................. 2 The Connector ......................................................................................................................... 3 Installation of R ....................................................................................................................... 4 Setting the environment for web integration ................................................................................ 13 Building the Qlikview document for integration .......................................................................... 14 Basics of Integration / Qlikview ....................................................................................... 14 The Approach .................................................................................................................. 14 Tweaking the code in Qvd: .............................................................................................. 15 Using the Integration Live. .................................................................................................. 21 References .......................................................................................................................... 25 [email protected] Page 1 Introduction Vision: Developing an Analytical Dashboard in Qlikview, which will initially present the raw data, and allow the user to make desired selection and choose a statistical model. The selections will be passed to R, where the statistical computations be performed and the results generated by R (graphs / tables) shall be retrieved back to Qlikview in either image/tabular format or in form of some Qlikview chart. In other terms to integrate the strengths of the two applications: 1. QlikView’s visualization & in-memory analytics power. 2. R’s analytical power. Leveraging visualization power of QlikView, with the analytical power of R. [email protected] Page 2 Qlikview & R Connector Qlikview Qlikview 11.2 has been used for this integration R Connector StatconnDCOM is the middleware component you can use to integrate R into your application on Microsoft Windows. StatconnDCOM provides a DCOM component for R. The out of process (EXE) server has been designed with both performance and stability in mind. Very low latency makes it well suited for integrating R into an interactive application. It comes in two versions, a licensed version which is paid, and other being Home & Student license which is Non-commercial and comes free, but with a copyright & watermark from the owner. The connector can be downloaded by clicking here [email protected] Page 3 Installation of R Step 1: Install the R 3.1.1 windows edition. Kindly select the following as Yes (customized startup) [email protected] Page 4 Then Select SDI (separate windows) Select Internet2 if your using a proxy network (usually at work locations) [email protected] Page 5 Step 3: Install the StatConnDCOM connector (Kindly download the latest version of statconn) [email protected] Page 6 [email protected] Page 7 Select the checkboxes as shown below [email protected] Page 8 ‘Finish’ the setup. [email protected] Page 9 Step 4: Let’s test the connection between R & StatConn to check if the connector is working fine. Go to Start -> Type in ‘Basic Test’ the search box, and open the Basic Test application (See below image for details.) [email protected] Page 10 Click on the R32 button Statconn image will appear as it’s a non-commercial version. This can be removed by purchasing a paid version of statconn. Plz refer statconn site for the pricing of the same. [email protected] Page 11 Once the test is successful the following will be displayed. It means that the connector is working fine! We can proceed to Qlikview now. [email protected] Page 12 Setting the environment for web integration Step 1: Enabling macro execution on Qlikview Server. Login to the Qlikview Server & open Qlik Management Console.(QMC) Navigate: QMC -> System -> Setup -> Qlikview Servers -> (Select Qvs) -> In the right pane select Security tab. In the Security tab, make the selections under Miscellaneous tabs activating Allow macro execution on server & Allow unsafe macro execution on server. This will allow the macros to be executed on the server via the access point document. [email protected] Page 13 Building the Qlikview document for integration Now the technical environment for the Qlikview & R integration is all set! The integration works the same way as it works on the local environment, but the code requires some small tweaking. Basics of Integration / Qlikview It’s imperative to understand how an application works, so that we can handle it the right way. Below are some basics of Qlikview that will help us identify the hindrances as well as the strengths of Qlikview, which can be used to facilitate the integration process. Qlikview strengths: It has powerful visualization capability. In-memory analytics. Allows macro execution. There exists a connector to R. Qlikview weaknesses: Cannot easily execute statistical algorithms like R. Doesn’t allow reload on the access point. Doesn’t have dedicated a statistical engine. Accounting the strengths and weaknesses of Qlikview we have devised the following approach of integrating Qlikview with R. The Approach 1. The Qlikview document is to be set up on access point (Qlikview Server (Qvs)). 2. There needs a directory on the server which should not be altered by any other user / application. 3. The macro needs to be written considering the Qvs as the local machine and the appropriate paths to be associated with the above mentioned directory, so that all the images / tables are stored / picked to / from the above the directory. [email protected] Page 14 4. Whenever the macro is executed to store the image or execute R script or load image / table, it should address that specific mentioned directory and pull data from same directory. 5. This makes macro calls to be executed on the Qvs, considering it as local machine. 6. The newly generated data now needs to be reloaded, the Qlikview built in functionality of reload doesn’t work directly on the access point, and for this we need another macro. 7. The reloading task is done by calling a macro which executes a batch file to reload the same Qlikview document open in the access point. The batch performs a reload of Qvd through command line. 8. Once the reload is complete the new data is visible in the document open on the browser. Tweaking the code in Qvd: Qlikview Application Welcome screen. [email protected] Page 15 Main sheet In this example we have coded the Import Variables button to trigger export the selected table name & pass it as a parameter to R script & then the R script that will fetch the values & display results in Qlikview [email protected] Page 16 Macro code to export the selection. **The above image has ServerSideExportEX underlined; this is explicitly required when we need to perform export via the web browser. Making a call to the R application & executing the R script. [email protected] Page 17 Reload & Partial Reload Macro Batch files definition: Kindly ensure the location of batch files being stored, should be same as mentioned in macro. Partial Reload.bat Reload.bat [email protected] Page 18 Document Properties to be set in qvd. These settings will allow the update, when the document gets reloaded. [email protected] Page 19 Setting Variables properties: In order to set the layout on the access point according to the variables, we need to include all the variables used in the application into Bookmarks, kindly do this for all the variables. That’s it; we are done with all the settings! We can now go ahead and test & use the application over the browser. [email protected] Page 20 Using the Integration Live. 1. Open access point on the browser & open the Qvd 2. Navigate to the Main Sheet of the Application [email protected] Page 21 3. After Clicking Import Variable, the table name is exported & R script is executed, which sends back the List of dependent & independent variables. 4. Selecting variables & running Linear Regression, R script by passing selected variables to it. The part highlighted in yellow is output generated by R [email protected] Page 22 5. Plot generated by R for Independent variables. 6. Other images plotted by R by same Linear regression algorithm [email protected] Page 23 In this way the Qlikview application can be integrated with R, one can also feed the tabular data generated by R to Qlikview as an input & generate Qlikview visuals. [email protected] Page 24 References 1. QlikView and R Integration for Predictive Analytics Example – Brian Bauer http://community.qlik.com/docs/DOC-3981 2. R application (http://www.r-project.org) [email protected] Page 25