Name |
Description |
---|---|
List | List of experiments including their configuration details. |
Get details | Get the configuration details of an experiment. |
List versions | List all versions for an experiment. |
Get version details | Get a specific version for an experiment. |
List variants | List all variants for an experiment. |
Get variant details | Get a specific variant for an experiment. |
Get variant inclusions | Get all inclusions (users) for a variant. |
Create variant | Create a new variant for an experiment. |
Edit variant | Edit a variant for an experiment. |
Remove variant | Remove a variant from an experiment. |
Add users to variant | Add users to experiment's variant. |
Remove users from variant | Remove users from experiment's variant. |
Remove all users from variant | Remove all users from experiment's variant. |
Bulk remove users from variant | Bulk remove users from experiment's variant. |
List deployments | List all deployments for an experiment. |
Add deployment | Add a deployment to an experiment. |
Remove deployment | Remove a deployment from an experiment. |
Edit | Edit experiment. |
Create | Create a new experiment. |
1GET https://experiment.amplitude.com/api/1/experiments
Fetch a list of experiments including their configuration details. Results are ordered with the most recently created items first.
Name | Description |
---|---|
limit |
The max number of experiments to be returned. Capped at 1000. |
cursor |
The offset to start the "page" of results from. |
includeArchived |
Optional. Boolean. By default it is false. When false, only return active experiments. When true, return active and archived experiments. |
A successful request returns a 200 OK
response and a list of experiments encoded as JSON in the response body. createdAt
and lastModifiedAt
are in UTC in ISO 8601 format.
1curl --request GET \2--url 'https://experiment.amplitude.com/api/1/experiments?limit=1000' \3--header 'Accept: application/json' \4--header 'Authorization: Bearer <management-api-key>'
1{ 2 "experiments": [ 3 { 4 "id": <id>, 5 "projectId": <projectId>, 6 "deployments": [<deploymentId>], 7 "key": "experiment-key", 8 "name": "experiment-name", 9 "decision": null,10 "decisionReason": null,11 "description": "description",12 "enabled": true,13 "evaluationMode": "remote",14 "bucketingKey": "amplitude_id",15 "bucketingSalt": <bucketingSalt>,16 "bucketingUnit": "User",17 "variants": [18 {19 "key": "control"20 },21 {22 "key": "treatment"23 }24 ],25 "rolledOutVariant": null,26 "rolloutPercentage": 10,27 "rolloutWeights": {28 "control": 1,29 "treatment": 130 },31 "targetSegments": [32 {33 "name": "Segment 1",34 "conditions": [35 {36 "prop": "device_id",37 "op": "is",38 "type": "property",39 "values": [40 "(none)"41 ]42 }43 ],44 "percentage": 50,45 "bucketingKey": "amplitude_id",46 "rolloutWeights": {47 "control": 1,48 "treatment": 149 }50 }51 ],52 "stickyBucketing": false,53 "state": "planning",54 "startDate": null,55 "endDate": null,56 "experimentType": "a-b-test",57 "createdBy": "abc@amplitude.com",58 "lastModifiedBy": "abc@amplitude.com",59 "createdAt":"2022-09-09T15:29:47.940Z",60 "lastModifiedAt":"2023-01-25T11:43:41.073Z"61 },62 "nextCursor": <cursorId>63 ]64}
1GET https://experiment.amplitude.com/api/1/experiments/<id>
Fetch the configuration details of an experiment.
Name | Description |
---|---|
id |
Required. String. Experiment's ID. |
A successful request returns a 200 OK
response and a JSON object with the experiment's details.
1curl --request GET \2 --url 'https://experiment.amplitude.com/api/1/experiments/<id>' \3 --header 'Accept: application/json' \4 --header 'Authorization: Bearer <management-api-key>'
1{ 2 "id": <id>, 3 "projectId": <projectId>, 4 "deployments": [<deploymentId>], 5 "key": "experiment-key", 6 "name": "experiment-key", 7 "decision": null, 8 "decisionReason": null, 9 "description": "save button color",10 "enabled": true,11 "evaluationMode": "remote",12 "bucketingKey": "amplitude_id",13 "bucketingSalt": <bucketingSalt>,14 "bucketingUnit": "User",15 "variants": [16 {17 "key": "control"18 },19 {20 "key": "treatment"21 }22 ],23 "rolledOutVariant": null,24 "rolloutPercentage": 0,25 "rolloutWeights": {26 "control": 1,27 "treatment": 128 },29 "targetSegments": [30 {31 "name": "Segment 1",32 "conditions": [33 {34 "prop": "city",35 "op": "is",36 "type": "property",37 "values": [38 "San Francisco"39 ]40 }41 ],42 "percentage": 0,43 "bucketingKey": "amplitude_id",44 "rolloutWeights": {45 "control": 1,46 "treatment": 147 }48 }49 ],50 "stickyBucketing": false,51 "state": "running",52 "startDate": "2023-07-29",53 "endDate": null,54 "experimentType": "a-b-test",55 "deleted": false,56 "tags": [],57 "createdBy: "x@amplitude.com"58}
1GET https://experiment.amplitude.com/api/1/experiments/{id}/versions
Fetch a list of all versions for an experiment.
Name | Requirement | Type | Description |
---|---|---|---|
id |
Required | string | Experiment's ID. |
A successful request returns a 200 OK
response and a list of experiment's versions encoded as an array of JSON objects in the response body. Versions are sorted in a descending order.
1curl --request GET \2 --url 'https://experiment.amplitude.com/api/1/experiments/<id>/versions' \3 --header 'Accept: application/json' \4 --header 'Authorization: Bearer <management-api-key>'
1[ 2 { 3 "createdAt": "2023-07-29T03:30:18.427Z", 4 "createdBy": <userId>, 5 "version": 3, 6 "flagConfig": { 7 "id": <id>, 8 "projectId": <projectId>, 9 "deployments": [<deploymentId>], 10 "key": "experiment-key", 11 "name": "experiment-key", 12 "description": "save button color", 13 "enabled": true, 14 "bucketingKey": "amplitude_id", 15 "variants": [ 16 { 17 "key": "control" 18 }, 19 { 20 "key": "treatment" 21 } 22 ], 23 "rolloutWeights": { 24 "control": 1, 25 "treatment": 1 26 }, 27 "targetSegments": [ 28 { 29 "name": "Segment 1", 30 "conditions": [ 31 { 32 "prop": "city", 33 "op": "is", 34 "type": "property", 35 "values": [ 36 "San Francisco" 37 ] 38 } 39 ], 40 "percentage": 0, 41 "bucketingKey": "amplitude_id", 42 "rolloutWeights": { 43 "control": 1, 44 "treatment": 1 45 } 46 } 47 ], 48 "stickyBucketing": false, 49 "state": "decision-made", 50 "startDate": "2023-07-29", 51 "endDate": "2023-07-29", 52 "experimentType": "a-b-test" 53 } 54 }, 55 { 56 "createdAt": "2023-07-29T03:26:23.603Z", 57 "createdBy": <userId>, 58 "version": 2, 59 "flagConfig": { 60 "id": <id>, 61 "projectId": <projectId>, 62 "deployments": [], 63 "key": "experiment-key", 64 "name": "experiment-key", 65 "description": "save button color", 66 "enabled": false, 67 "bucketingKey": "amplitude_id", 68 "variants": [ 69 { 70 "key": "control" 71 }, 72 { 73 "key": "treatment" 74 } 75 ], 76 "rolloutWeights": { 77 "control": 1, 78 "treatment": 1 79 }, 80 "targetSegments": [], 81 "stickyBucketing": false, 82 "state": "planning", 83 "startDate": null, 84 "endDate": null, 85 "experimentType": "a-b-test" 86 } 87 }, 88 { 89 "createdAt": "2023-07-29T03:25:42.236Z", 90 "createdBy": <userId>, 91 "version": 1, 92 "flagConfig": { 93 "id": <id>, 94 "projectId": <projectId>, 95 "deployments": [], 96 "key": "experiment-key", 97 "name": "experiment-key", 98 "description": "", 99 "enabled": false,100 "bucketingKey": "amplitude_id",101 "variants": [102 {103 "key": "control"104 },105 {106 "key": "treatment"107 }108 ],109 "rolloutWeights": {110 "control": 1,111 "treatment": 1112 },113 "targetSegments": [],114 "stickyBucketing": false,115 "state": "planning",116 "startDate": null,117 "endDate": null,118 "experimentType": "a-b-test"119 }120 }121]
1GET https://experiment.amplitude.com/api/1/experiments/{id}/versions/{versionId}
Fetch details of a specific version of an experiment.
Name | Requirement | Type | Description |
---|---|---|---|
id |
Required | string | Experiment's ID. |
versionId |
Required | string | The version's ID. |
A successful request returns a 200 OK
response and a JSON object with details of the version.
1curl --request GET \2 --url 'https://experiment.amplitude.com/api/1/experiments/<id>/versions/<versionId>' \3 --header 'Accept: application/json' \4 --header 'Authorization: Bearer <management-api-key>'
1{ 2 "createdAt": "2023-07-29T03:30:18.427Z", 3 "createdBy": <userId>, 4 "version": 3, 5 "flagConfig": { 6 "id": <id>, 7 "projectId": <projectId>, 8 "deployments": [<deploymentId>], 9 "key": "experiment-key",10 "name": "experiment-key",11 "description": "save button color",12 "enabled": true,13 "bucketingKey": "amplitude_id",14 "variants": [15 {16 "key": "control"17 },18 {19 "key": "treatment"20 }21 ],22 "rolloutWeights": {23 "control": 1,24 "treatment": 125 },26 "targetSegments": [27 {28 "name": "Segment 1",29 "conditions": [30 {31 "prop": "city",32 "op": "is",33 "type": "property",34 "values": [35 "San Francisco"36 ]37 }38 ],39 "percentage": 0,40 "bucketingKey": "amplitude_id",41 "rolloutWeights": {42 "control": 1,43 "treatment": 144 }45 }46 ],47 "stickyBucketing": false,48 "state": "decision-made",49 "startDate": "2023-07-29",50 "endDate": "2023-07-29",51 "experimentType": "a-b-test"52 }53}
1GET https://experiment.amplitude.com/api/1/experiments/{id}/variants
Fetch a list of all variants for an experiment.
Name | Requirement | Type | Description |
---|---|---|---|
id |
Required | string | Experiment's ID. |
A successful request returns a 200 OK
response and a list of variants encoded as an array of JSON objects in the response body.
1curl --request GET \2 --url 'https://experiment.amplitude.com/api/1/experiments/<id>/variants' \3 --header 'Accept: application/json' \4 --header 'Authorization: Bearer <management-api-key>'
1[ 2 { 3 "key": "control", 4 "name": "", 5 "payload": {}, 6 "description": "", 7 "rolloutWeight": 1 8 }, 9 {10 "key": "treatment",11 "name": "",12 "payload": {},13 "description": "",14 "rolloutWeight": 115 }16]
1GET https://experiment.amplitude.com/api/1/experiments/{id}/variants/{variantKey}
Fetch details of a specific variant of an experiment.
Name | Requirement | Type | Description |
---|---|---|---|
id |
Required | string | Experiment's ID. |
variantKey |
Required | string | The variant's key. |
A successful request returns a 200 OK
response and a JSON object with details of experiment variant.
1curl --request GET \2 --url 'https://experiment.amplitude.com/api/1/experiments/<id>/variants/<variantKey>' \3 --header 'Accept: application/json' \4 --header 'Authorization: Bearer <management-api-key>'
1{2 "key": "control",3 "name": "",4 "payload": {},5 "description": "",6 "rolloutWeight": 17}
1GET https://experiment.amplitude.com/api/1/experiments/{id}/variants/{variantKey}/users
Fetch a list of inclusions for a specific variant of an experiment.
Name | Requirement | Type | Description |
---|---|---|---|
id |
Required | string | Experiment's ID. |
variantKey |
Required | string | The variant's key. |
A successful request returns a 200 OK
response and a list of inclusions of experiment's variant as an array of JSON objects.
1curl --request GET \2 --url 'https://experiment.amplitude.com/api/1/experiments/<id>/variants/<variantKey>/users' \3 --header 'Accept: application/json' \4 --header 'Authorization: Bearer <management-api-key>'
1[2 <user>@<your-company-email>,3 <userId>4]
1POST https://experiment.amplitude.com/api/1/experiments/{id}/variants
Create a new variant for an experiment.
Name | Description |
---|---|
id |
Required. String. Experiment's ID. |
Name |
Requirement | Type | Description |
---|---|---|---|
key |
Required | string | The variant key. |
description |
Optional | string | Description for the variant. |
name |
Optional | string | Name for the variant. |
payload |
Optional | JSON | Optional payload. Value must be a valid JSON element. |
rolloutWeight |
Optional | number | Rollout weight for non-targeted users. |
1{2 "key": "new-variant-key",3 "description": "optional description for variant",4 "name": "optional name for variant",5 "payload": {"variant-payload": "example payload"},6 "rolloutWeight": 07}
A successful request returns a 200 OK
response and OK
text.
1curl --request POST \2 --url 'https://experiment.amplitude.com/api/1/experiments/<id>/variants' \3 --header 'Content-Type: application/json' \4 --header 'Accept: application/json' \5 --header 'Authorization: Bearer <management-api-key>' \6 --data '{"key":"<key>","name":"<name>","description":"<description>","payload":"<payload>","rolloutWeight":<rolloutWeight>}'
1PATCH https://experiment.amplitude.com/api/1/experiments/<id>/variants/<variantKey>
Edit a variant for an experiment.
Name | Requirement | Type | Description |
---|---|---|---|
id |
Required | string | Experiment's ID. |
variantKey |
Required | string | The variant's key. |
Name |
Requirement | Type | Description |
---|---|---|---|
key |
Optional | string | The variant key. |
description |
Optional | string | Description for the variant. |
name |
Optional | string | Name for the variant. |
payload |
Optional | JSON | Optional payload. Value must be a valid JSON element. This value replaces the existing value for the variant payload. |
rolloutWeight |
Optional | number | Rollout weight for non-targeted users. |
1{2 "key": "updated-variant-key",3 "description": "updated-optional description for variant",4 "name": "optional name for variant",5 "payload": {"variant-payload": "example payload"},6 "rolloutWeight": 107}
A successful request returns a 200 OK
response and OK
text.
1curl --request PATCH \2 --url 'https://experiment.amplitude.com/api/1/experiments/<id>/variants/<variantKey>' \3 --header 'Content-Type: application/json' \4 --header 'Accept: application/json' \5 --header 'Authorization: Bearer <management-api-key>' \6 --data '{"key":"<key>","name":"<name>","description":"<description>","payload":"<payload>","rolloutWeight":<rolloutWeight>}'
1DELETE https://experiment.amplitude.com/api/1/experiments/{id}/variants/{variantKey}
Remove a variant from an experiment.
Name | Requirement | Type | Description |
---|---|---|---|
id |
Required | string | Experiment's ID. |
variantKey |
Required | string | The variant's key. |
A successful request returns a 200 OK
response and OK
text.
1curl --request DELETE \2 --url 'https://experiment.amplitude.com/api/1/experiments/<id>/variants/<variantKey>' \3 --header 'Accept: application/json' \4 --header 'Authorization: Bearer <management-api-key>'
1POST https://experiment.amplitude.com/api/1/experiments/{id}/variants/{variantKey}/users
Add inclusions (users or devices) to experiment's variant.
Name | Requirement | Type | Description |
---|---|---|---|
id |
Required | string | Experiment's ID. |
variantKey |
Required | string | The variant's key. |
1{2 "inclusions": [<user1>@<your-company-email>, <user2>@<your-company-email>, <userId>]3}
Name |
Requirement | Type | Description |
---|---|---|---|
inclusions |
Required | object | Contains an string array of user or device ids. |
A successful request returns a 200 OK
response and OK
text.
1curl --request POST \2 --url 'https://experiment.amplitude.com/api/1/experiments/<id>/variants/<variantKey>/users' \3 --header 'Content-Type: application/json' \4 --header 'Accept: application/json' \5 --header 'Authorization: Bearer <management-api-key>' \6 --data '{"inclusions":<["id1", "id2", "id3"]>}'
1DELETE https://experiment.amplitude.com/api/1/experiments/{id}/variants/{variantKey}/users/{userIndex}
Remove inclusions (users or devices) from experiment's variant.
Name | Requirement | Type | Description |
---|---|---|---|
id |
Required | string | Experiment's ID. |
variantKey |
Required | string | The variant's key. |
userIndex |
Required | string | The user's index. Zero-indexed. Get an index-based array of users from Get variant inclusions |
A successful request returns a 200 OK
response and OK
text.
1curl --request DELETE \2 --url 'https://experiment.amplitude.com/api/1/experiments/<id>/variants/<variantKey>/users/<userIndex>' \3 --header 'Accept: application/json' \4 --header 'Authorization: Bearer <management-api-key>'
1DELETE https://experiment.amplitude.com/api/1/experiments/{id}/variants/{variantKey}/users
Remove all inclusions (users or devices) from experiment's variant.
Name | Requirement | Type | Description |
---|---|---|---|
id |
Required | string | Experiment's ID. |
variantKey |
Required | string | The variant's key. |
A successful request returns a 200 OK
response and OK
text.
1curl --request DELETE \2 --url 'https://experiment.amplitude.com/api/1/experiments/<id>/variants/<variantKey>/users' \3 --header 'Accept: application/json' \4 --header 'Authorization: Bearer <management-api-key>'
1DELETE https://experiment.amplitude.com/api/1/experiments/{id}/variants/{variantKey}/bulk-delete-users
Bulk remove users or devices from experiment's variant. Limited to 100 per request.
Name | Requirement | Type | Description |
---|---|---|---|
id |
Required | string | Experiment's ID. |
variantKey |
Required | string | The variant's key. |
Name |
Requirement | Type | Description |
---|---|---|---|
users |
Required | object | Contains an string array of user or device ids. |
A successful request returns a 200 OK
response and OK
text.
1curl --request DELETE \2 --url 'https://experiment.amplitude.com/api/1/experiments/<id>/variants/<variantKey>/bulk-delete-users' \3 --header 'Accept: application/json' \4 --header 'Authorization: Bearer <management-api-key>' \5 --data '{"users":<["id1", "id2", "id3"]>}'
1GET https://experiment.amplitude.com/api/1/experiments/{id}/deployments
List all deployments for an experiment.
Name | Requirement | Type | Description |
---|---|---|---|
id |
Required | string | Experiment's ID. |
A successful request returns a 200 OK
response and an array of JSON objects with experiment's deployment details.
1curl --request GET \2 --url 'https://experiment.amplitude.com/api/1/experiments/<id>/deployments' \3 --header 'Accept: application/json' \4 --header 'Authorization: Bearer <management-api-key>'
1[2 {3 "id": <id>,4 "projectId": <projectId>,5 "label": "rest-api",6 "key": <key>,7 "deleted": false8 }9]
1POST https://experiment.amplitude.com/api/1/experiments/{id}/deployments
Add a deployment to an experiment.
Name | Description |
---|---|
id |
Required. String. Experiment's ID. |
Name |
Requirement | Type | Description |
---|---|---|---|
deployments |
Required | object | Contains an string array of deployment ids. |
1{2 "deployments": ["<deploymentId>"]3}
A successful request returns a 200 OK
response and OK
text.
1curl --request POST \2 --url 'https://experiment.amplitude.com/api/1/experiments/<id>/deployments' \3 --header 'Accept: application/json' \4 --header 'Authorization: Bearer <management-api-key>'5 --data '{"deployments":[<deploymentId>]}'
1DELETE https://experiment.amplitude.com/api/1/experiments/{id}/deployments/{deploymentId}
Remove a deployment from an experiment.
Name | Requirement | Type | Description |
---|---|---|---|
id |
Required | string | Experiment's ID. |
deploymentId |
Required | string | The deployment's ID. |
A successful request returns a 200 OK
response and OK
text.
1curl --request DELETE \2 --url 'https://experiment.amplitude.com/api/1/experiments/<id>/deployments/<deploymentId>' \3 --header 'Accept: application/json' \4 --header 'Authorization: Bearer <management-api-key>'
Web Experimentation doesn't support the editing of experiments. Attempts to edit a web experiment return a 405
error.
1PATCH https://experiment.amplitude.com/api/1/experiments/{id}
Edit an experiment.
Name | Requirement | Type | Description |
---|---|---|---|
id |
Required | string | Experiment's ID. |
Name |
Requirement | Type | Description |
---|---|---|---|
name |
Optional | string | Name. |
description |
Optional | string | Description. |
bucketingKey |
Optional | string | The user property to bucket the user by. |
bucketingSalt |
Optional | string | Bucketing salt. |
bucketingUnit |
Optional | string | Bucketing unit represented by a group type from the accounts add-on. Used for group level bucketing and analysis. |
evaluationMode |
Optional | string | Evaluation mode for the experiment, either local or remote . |
rolloutPercentage |
Optional | number | Rollout percentage for non-targeted users. Range 0 - 100. |
targetSegments |
Optional | object | See the targetSegments table for more information. When targetSegments object is provided, it will replace existing target segments. Note: cohorts are not supported at the moment. |
enabled |
Optional | boolean | Property to activate or deactivate experiment. |
archive |
Optional | boolean | Property to archive or unarchive experiment. |
experimentType |
Optional | string | Experiment type, options include a-b-test or multi-arm-bandit . |
stickyBucketing |
Optional | boolean | If true, the experiment uses sticky bucketing. |
startDate |
Optional | string | Start date of the experiment in ISO 8601 format. |
endDate |
Optional | string | End date of the experiment in ISO 8601 format. End date can be null. |
exposureEvent |
Optional | object | See the exposureEvent table for more information. If set to null, the Amplitude Exposure Event will be used. |
tags |
Optional | string array | A list of tags for the experiment. Tags are added and deleted by the same operation. If you would like to add new tags to the existing ones, you should fetch a list of all experiment tags first. |
Name |
Requirement | Type | Description |
---|---|---|---|
event_type |
Required | string | Event type. |
filters |
Required | object array | A list of property filters. See the filters table for more information. |
Name |
Requirement | Type | Description |
---|---|---|---|
group_type |
Optional | string | Group type of the filter; can be null. Can be User value or one of the group values, eg org _id , org name |
subprop_key |
Required | string | Filter's key; can be null. |
subprop_op |
Required | string | The operation to use in this filter. |
subprop_type |
Required | string | Either event , user or group indicating that the property is either an event, user or group property, respectively. |
subprop_value |
Required | string array | A list of values to filter the event property by. |
is
is not
contains
does not contain
less
less or equal
greater
greater or equal
glob match
glob does not match
1{ 2 "name": "updated name", 3 "description": "updated description", 4 "bucketingKey": "amplitude_id", 5 "bucketingSalt": "<bucketingSalt>", 6 "evaluationMode": "remote", 7 "rolloutPercentage": 0, 8 "enabled": true, 9 "experimentType": "a-b-test",10 "stickyBucketing": false,11 "startDate": "2023-07-31T10:26:00.996Z",12 "endDate": "2023-09-23T10:26:00.996Z",13 "tags": ["prod", "staging"],14 "exposureEvent": {15 "event_type": "_active",16 "filters": [17 {18 "group_type": "User",19 "subprop_key": "amplitude_day_of_week",20 "subprop_op": "is",21 "subprop_type": "day_time_prop",22 "subprop_value": [23 "Tuesday"24 ]25 }26 ]27 }28}
A successful request returns a 200 OK
response.
1curl --request PATCH \2 --url 'https://experiment.amplitude.com/api/1/experiments/<id>' \3 --header 'Content-Type: application/json' \4 --header 'Accept: application/json' \5 --header 'Authorization: Bearer <management-api-key>' \6 --data '{"enabled":<enabled>,"rolloutPercentage":<rolloutPercentage>}'
1POST https://experiment.amplitude.com/api/1/experiments
Create a new feature experiment.
Name |
Requirement | Type | Description |
---|---|---|---|
projectId |
Required | string | The project's ID. |
key |
Required | string | The flag key. |
name |
Optional | string | The experiment name. |
description |
Optional | string | Description for the experiment. |
variants |
Optional | object array | Array of variants . |
bucketingKey |
Optional | string | The user property to bucket the user by. |
rolloutWeights |
Optional | object | Rollout weights for non-targeted users. The object should be a mapping from variant key to rollout weight as an integer. For example: { "control": 1, "treatment": 1 } . |
targetSegments |
Optional | object | See the targetSegments table for more information. |
deployments |
Optional | string array | Array of deployments that the experiment should be assigned to. |
evaluationMode |
Optional | string | Experiment evaluation mode; options include remote or local . |
experimentType |
Optional | string | Experiment type; options include a-b-test or multi-arm-bandit . |
The variants
field contains these objects.
Name |
Requirement | Type | Description |
---|---|---|---|
key |
Required | string | The key (a.k.a value) of the variant. |
payload |
Optional | JSON | Optional payload. Value must be a valid JSON element. |
name |
Optional | string | The variant name. |
description |
Optional | string | The variant description. |
The targetSegments
field contains these objects.
Name |
Requirement | Type | Description |
---|---|---|---|
name |
Required | string | The segment name. |
conditions |
Required | object array | Array of conditions . |
percentage |
Required | number | The allocation percentage for users who match a condition. |
rolloutWeights |
Required | object | A map from variant key to rollout weight. For example: { "control": 1, "treatment": 1 } . |
The conditions
field contains these objects.
Name |
Requirement | Type | Description |
---|---|---|---|
type |
Required | string | Must have value: property |
prop |
Required | string | The property to use in the condition. Prefix custom and free-form properties with gp: |
op |
Required | string | The operation to use in this condition. |
values |
Required | string array | The values to use in the operation. |
A string value representing operations on a property value. Possible values are:
is
is not
contains
does not contain
less
less or equal
greater
greater or equal
set is
set is not
set contains
set does not contain
glob match
glob does not match
1{ 2 "projectId":"<projectId>", 3 "name": "Analyze button clicks experiment", 4 "key": "analyze-button-clicks-experiment", 5 "description": "analyze button clicks on the main page", 6 "variants": [ 7 { 8 "key": "control" 9 },10 {11 "key": "treatment"12 }13 ],14 "rolloutWeights": {"control": 1, "treatment": 1},15 "targetSegments": [16 {17 "name": "Segment 1",18 "conditions": [19 {20 "prop": "country",21 "op": "is",22 "type": "property",23 "values": [24 "United States"25 ]26 }27 ],28 "percentage": 0,29 "bucketingKey": "amplitude_id",30 "rolloutWeights": {31 "control": 1,32 "treatment": 133 }34 }35 ],36 "deployments": ["<deploymentId>"],37 "evaluationMode": "remote",38 "experimentType": "a-b-test"39}
A successful request returns a 200 OK
response and a JSON object with the experiment's id and url.
1curl --request POST \2 --url 'https://experiment.amplitude.com/api/1/experiments' \3 --header 'Content-Type: application/json' \4 --header 'Accept: application/json' \5 --header 'Authorization: Bearer <management-api-key>' \6 --data '{"projectId":"<projectId>","key":"<key>"}'
1{2 "id": "<id>",3 "url": "http://experiment.amplitude.com/amplitude/<projectId>/config/<id>"4}
Thanks for your feedback!
December 18th, 2024
Need help? Contact Support
Visit Amplitude.com
Have a look at the Amplitude Blog
Learn more at Amplitude Academy
© 2025 Amplitude, Inc. All rights reserved. Amplitude is a registered trademark of Amplitude, Inc.