HomeGuidesRecipesAPI ReferenceChangelog
Log In
Guides

Step 4 - Model Storage-in-Switch Solar Production

It’s time to model a solar system!

Creating a Solar profile

As we covered in the last step, an Account object can have several profiles, and historical bill usage data can be loaded into a Profile with a service type of ELECTRICITY. Profiles are versatile and can hold lots of different types of energy data in them, including solar production numbers. For solar, you use a service type of SOLAR_PV.

We have a lot of flexibility and options around how you can model your proposed solar systems production. The Arcadia API offers the following methods to provide this data:

  1. You can use the integrated NREL PVWatts tool by passing in system size and other properties. This is the most commonly used option with our residential customers.
  2. If you have your own solar model, you can use our API to pass in your own estimated hourly production for a typical year.
  3. Alternatively, you can use our File Uploader to pass in a CSV, a PVSyst file, or a PVSIM file and we'll automatically parse and load it.
  4. You can use our Typical Solar Production data, which is a first-pass easy approximation and suitable for market assessments and marketing.

For this tutorial, we will use #1, our integration of NREL PVWatts API. More specifically, we will model a 3 kW PV system facing south with a 20-degree tilt. Here's how you request it.

PUT /rest/v1/profiles
{  
  "providerAccountId" : "api-eg-01",  
  "providerProfileId" : "PVWATTS_RESIDENTIAL_CA_V8_TESTING",  
  "groupBy" : "YEAR",  
  "serviceTypes" : "SOLAR_PV",  
  "source": {  
    "sourceId":"PVWatts",  
    "sourceVersion":"8"  
  },  
  "properties" : {  
    "systemSize" : {  
      "keyName" : "systemSize",  
      "dataValue" : "2.65"  
    },  
    "azimuth" : {  
      "keyName" : "azimuth",  
      "dataValue" : "170"  
    },  
    "losses" : {  
      "keyName" : "losses",  
      "dataValue" : "15"  
    },  
    "inverterEfficiency" : {  
      "keyName" : "inverterEfficiency",  
      "dataValue" : "96"  
    },  
    "tilt" : {  
      "keyName" : "tilt",  
      "dataValue" : "17"  
    },  
    "bifaciality" : {  
        "keyName" : "bifaciality",  
        "dataValue" : "0.5"  
    },  
    "albedo" : {  
        "keyName" : "albedo",  
        "dataValue" : "0.5"  
    },  
    "useWeatherFileAlbedo" : {  
        "keyName" : "useWeatherFileAlbedo",  
        "dataValue" : "0"  
    },  
    "soiling" : {  
        "keyName" : "soiling",  
        "dataValue" : "12.0, 4.0, 45.0, 23.0, 9.0, 99.0, 67.0, 12.54, 54.0, 9.0, 0.0, 7.6"  
    }  
  }  
}  

As you can see above, this is the same API route that you used to load billing usage data. But we passed in a number of different parameters. The first ones to notice is serviceType of SOLAR_PV which lets us know it is solar and not electricity. The sourceId of PVWatts is what tells us to call PVWatts. When creating a profile sourced from the PVWatts API, there are a number of different parameters that you can specify to model various characteristics of your system. The most important ones are the ones shown above: systemSize, azimuth, and tilt. Other parameters can be used to denote loss, etc., and these parameters have reasonable defaults that should work in many cases, but you can adjust them any way you like. Read the Profile API Reference documentation for details of these.

Once you've made your request, the response should look like this:

{  
    "status": "success",  
    "count": 1,  
    "type": "UsageProfile",  
    "results": \[  
        {  
            "profileId": "b86e450a-f82d-4de1-b90a-d091ecaf2a33",  
            "providerProfileId": "PVWATTS_RESIDENTIAL_CA_V8_TESTING",  
            "profileName": "2.7 kW | PVWatts",  
            "accountId": "d900ee72-2f12-4854-bc34-5ca5f6a22bd4",  
            "serviceTypes": "SOLAR_PV",  
            "source": {  
                "sourceId": "PVWatts",  
                "name": "PVWatts",  
                "type": "Reading",  
                "sourceVersion": "8"  
            },  
            "dataStatus": 2,  
            "properties": {  
                "systemSize": {  
                    "keyName": "systemSize",  
                    "dataValue": "2.65",  
                    "accuracy": 100  
                },  
                "inverterEfficiency": {  
                    "keyName": "inverterEfficiency",  
                    "dataValue": "96",  
                    "accuracy": 100  
                },  
                "useWeatherFileAlbedo": {  
                    "keyName": "useWeatherFileAlbedo",  
                    "dataValue": "0",  
                    "accuracy": 100  
                },  
                "moduleType": {  
                    "keyName": "moduleType",  
                    "dataType": "INTEGER",  
                    "dataValue": "0",  
                    "accuracy": 50  
                },  
                "derate": {  
                    "keyName": "derate",  
                    "dataType": "DECIMAL",  
                    "dataValue": "0.816"  
                },  
                "azimuth": {  
                    "keyName": "azimuth",  
                    "dataValue": "170",  
                    "accuracy": 100  
                },  
                "tilt": {  
                    "keyName": "tilt",  
                    "dataValue": "17",  
                    "accuracy": 100  
                },  
                "losses": {  
                    "keyName": "losses",  
                    "dataValue": "15",  
                    "accuracy": 100  
                },  
                "climateDataFileName": {  
                    "keyName": "climateDataFileName",  
                    "dataType": "STRING",  
                    "dataValue": "84361.csv"  
                },  
                "soiling": {  
                    "keyName": "soiling",  
                    "dataValue": "12.0, 4.0, 45.0, 23.0, 9.0, 99.0, 67.0, 12.54, 54.0, 9.0, 0.0, 7.6",  
                    "accuracy": 100  
                },  
                "trackMode": {  
                    "keyName": "trackMode",  
                    "dataType": "INTEGER",  
                    "dataValue": "0",  
                    "accuracy": 50  
                },  
                "systemYield": {  
                    "keyName": "systemYield",  
                    "dataType": "DECIMAL",  
                    "dataValue": "1123.74"  
                },  
                "bifaciality": {  
                    "keyName": "bifaciality",  
                    "dataValue": "0.5",  
                    "accuracy": 100  
                },  
                "albedo": {  
                    "keyName": "albedo",  
                    "dataValue": "0.5",  
                    "accuracy": 100  
                }  
            },  
            "baselineMeasures": [  
                {  
                    "i": 1,  
                    "v": 2977.898016000000  
                }  
            ]  
        }  
    ]  
}  

Modeling multiple arrays

You can add as many solar profiles to your Account as you need. For example, if you plan on having both a south and a west-facing array in your system, you can create two solar profiles, each with individual shading and orientation parameters. Give each a different providerProfileId to keep track of them.

Summary

You now have a model of the hourly solar production for your proposed system in our database. Previously you created an account, confirmed your customer's utility and rate plan, and created a profile denoting historical electricity usage.

Next, let's analyze your customer's savings.