Table of Contents

Class PerplexityRequest

public class PerplexityRequest : IJsonRequest
Inheritance
object
PerplexityRequest

Properties

DisableSearch

Optional. When set to true, disables web search completely and the model will only use its training data to respond. This is useful when you want deterministic responses without external information.

public bool? DisableSearch { get; set; }

Property Value

bool?

EnableSearchClassifier

Optional. Enables a classifier that decides if web search is needed based on your query.

public bool? EnableSearchClassifier { get; set; }

Property Value

bool?

FrequencyPenalty

Optional. Decreases likelihood of repetition based on prior frequency. Applies a penalty to tokens based on how frequently they've appeared in the text so far. Values typically range from 0 (no penalty) to 2.0 (strong penalty). Higher values (e.g., 1.5) reduce repetition of the same words and phrases. Useful for preventing the model from getting stuck in loops.

public float? FrequencyPenalty { get; set; }

Property Value

float?

LastUpdatedAfterFilter

Optional. Filters search results to only include content last updated after this date. Format should be %m/%d/%Y (e.g. 3/1/2025)

public UnixTime? LastUpdatedAfterFilter { get; set; }

Property Value

UnixTime?

LastUpdatedBeforeFilter

Optional. Filters search results to only include content last updated before this date. Format should be %m/%d/%Y (e.g. 3/1/2025)

public UnixTime? LastUpdatedBeforeFilter { get; set; }

Property Value

UnixTime?

MaxTokens

Optional. The maximum number of completion tokens returned by the API. Controls the length of the model's response. If the response would exceed this limit, it will be truncated. Higher values allow for longer responses but may increase processing time and costs.

public int? MaxTokens { get; set; }

Property Value

int?

Messages

Required. A list of messages comprising the conversation so far.

public List<PerplexityMessage> Messages { get; set; }

Property Value

List<PerplexityMessage>

Model

Required. The name of the model that will complete your prompt. Choose from our available Sonar models: sonar (lightweight search), sonar-pro (advanced search), sonar-deep-research (exhaustive research), sonar-reasoning (fast reasoning), or sonar-reasoning-pro (premier reasoning).

public string Model { get; set; }

Property Value

string

PresencePenalty

Optional. Positive values increase the likelihood of discussing new topics. Applies a penalty to tokens that have already appeared in the text, encouraging the model to talk about new concepts. Values typically range from 0 (no penalty) to 2.0 (strong penalty). Higher values reduce repetition but may lead to more off-topic text.

public float? PresencePenalty { get; set; }

Property Value

float?

ReasoningEffort

WARNING: This parameter is ONLY applicable for sonar-deep-research.

Optional. Controls how much computational effort the AI dedicates to each query for deep research models. 'low' provides faster, simpler answers with reduced token usage, 'medium' offers a balanced approach, and 'high' delivers deeper, more thorough responses with increased token usage. WARNING: This parameter is ONLY applicable for sonar-deep-research. Defaults to 'medium' when used with sonar-deep-research.

public ReasoningEffort? ReasoningEffort { get; set; }

Property Value

ReasoningEffort?

ResponseFormat

Optional. Enables structured JSON output formatting.

public JsonSchema ResponseFormat { get; set; }

Property Value

JsonSchema

ReturnImages

Optional. Determines whether search results should include images.

public bool? ReturnImages { get; set; }

Property Value

bool?

ReturnRelatedQuestions

Optional. Determines whether related questions should be returned.

public bool? ReturnRelatedQuestions { get; set; }

Property Value

bool?

SearchAfterDateFilter

Optional. Filters search results to only include content published after this date. Format should be %m/%d/%Y (e.g. 3/1/2025)

public UnixTime? SearchAfterDateFilter { get; set; }

Property Value

UnixTime?

SearchBeforeDateFilter

Optional. Filters search results to only include content published before this date. Format should be %m/%d/%Y (e.g. 3/1/2025)

public UnixTime? SearchBeforeDateFilter { get; set; }

Property Value

UnixTime?

SearchDomainFilter

Optional. A list of domains to limit search results to. Currently limited to 10 domains for Allowlisting and Denylisting. For Denylisting, add a - at the beginning of the domain string.

public DomainFilter SearchDomainFilter { get; set; }

Property Value

DomainFilter

SearchMode

Optional. Controls the search mode used for the request. When set to 'academic', results will prioritize scholarly sources like peer-reviewed papers and academic journals.

public PerplexityTypes.WebSearchMode? SearchMode { get; set; }

Property Value

PerplexityTypes.WebSearchMode?

SearchRecencyFilter

Optional. Filters search results based on time (e.g., 'week', 'day').

public string SearchRecencyFilter { get; set; }

Property Value

string

Stream

Optional. Determines whether to stream the response incrementally.

public bool? Stream { get; set; }

Property Value

bool?

Temperature

Optional. The amount of randomness in the response, valued between 0 and 2. Lower values (e.g., 0.1) make the output more focused, deterministic, and less creative. Higher values (e.g., 1.5) make the output more random and creative. Use lower values for factual/information retrieval tasks and higher values for creative applications.

public float? Temperature { get; set; }

Property Value

float?

TopK

Optional. The number of tokens to keep for top-k filtering. Limits the model to consider only the k most likely next tokens at each step. Lower values (e.g., 10) make the output more focused and deterministic, while higher values allow for more diverse outputs. A value of 0 disables this filter. Often used in conjunction with top_p to control output randomness.

public int? TopK { get; set; }

Property Value

int?

TopP

Optional. The nucleus sampling threshold, valued between 0 and 1. Controls the diversity of generated text by considering only the tokens whose cumulative probability exceeds the top_p value. Lower values (e.g., 0.5) make the output more focused and deterministic, while higher values (e.g., 0.95) allow for more diverse outputs. Often used as an alternative to temperature.

public float? TopP { get; set; }

Property Value

float?

WebSearchOptions

Optional. Configuration for using web search in model responses.

public PerplexityWebSearchOptions WebSearchOptions { get; set; }

Property Value

PerplexityWebSearchOptions