Skip to content

Commit

Permalink
Lots of cleanup and improvements to make the code more Swifty. A prim…
Browse files Browse the repository at this point in the history
…ary example is changing all snake_case variables to camelCase.
  • Loading branch information
btfranklin committed Apr 22, 2023
1 parent 7396266 commit 4fd959b
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 29 deletions.
32 changes: 20 additions & 12 deletions Sources/CleverBird/chat/OpenAIChatThread.swift
Original file line number Diff line number Diff line change
Expand Up @@ -2,17 +2,24 @@ import Foundation

public class OpenAIChatThread {

private struct ChatCompletionResponse: Codable {
struct Choice: Codable {
let message: ChatMessage
}
let choices: [Choice]
}

private static let DEFAULT_LOGGER: Logger = { message in
print(message)
}

private let connection: OpenAIAPIConnection
private let model: Model
private let temperature: Percentage
private let top_p: Percentage?
private let topP: Percentage?
private let stop: [String]?
private let presence_penalty: Penalty?
private let frequency_penalty: Penalty?
private let presencePenalty: Penalty?
private let frequencyPenalty: Penalty?
private let user: String?
private let logger: Logger

Expand All @@ -21,20 +28,20 @@ public class OpenAIChatThread {
public init(connection: OpenAIAPIConnection,
model: Model = .gpt4,
temperature: Percentage = 0.7,
top_p: Percentage? = nil,
topP: Percentage? = nil,
numberOfCompletionsToCreate: Int? = nil,
stop: [String]? = nil,
presence_penalty: Penalty? = nil,
frequency_penalty: Penalty? = nil,
presencePenalty: Penalty? = nil,
frequencyPenalty: Penalty? = nil,
user: String? = nil,
logger: Logger? = nil) {
self.connection = connection
self.model = model
self.temperature = temperature
self.top_p = top_p
self.topP = topP
self.stop = stop
self.presence_penalty = presence_penalty
self.frequency_penalty = frequency_penalty
self.presencePenalty = presencePenalty
self.frequencyPenalty = frequencyPenalty
self.user = user
self.logger = logger ?? Self.DEFAULT_LOGGER
}
Expand Down Expand Up @@ -77,16 +84,17 @@ extension OpenAIChatThread {
let requestBody = ChatCompletionRequest(
model: self.model,
temperature: self.temperature,
top_p: self.top_p,
topP: self.topP,
stop: self.stop,
presence_penalty: self.presence_penalty,
frequency_penalty: self.frequency_penalty,
presencePenalty: self.presencePenalty,
frequencyPenalty: self.frequencyPenalty,
user: self.user,
messages: self.messages
)

do {
let encoder = JSONEncoder()
encoder.keyEncodingStrategy = .convertToSnakeCase
let httpBodyJson = try encoder.encode(requestBody)
request.httpBody = httpBodyJson
} catch {
Expand Down
26 changes: 9 additions & 17 deletions Sources/CleverBird/chat/datatypes.swift
Original file line number Diff line number Diff line change
@@ -1,30 +1,22 @@
// Created by B.T. Franklin on 4/15/23

struct ChatCompletionResponse: Codable {
struct Choice: Codable {
let message: ChatMessage
}
let choices: [Choice]
}

public struct ChatCompletionRequest: Codable {
public let model: Model
public let temperature: Percentage
public let top_p: Percentage?
public let topP: Percentage?
public let stop: [String]?
public let presence_penalty: Penalty?
public let frequency_penalty: Penalty?
public let presencePenalty: Penalty?
public let frequencyPenalty: Penalty?
public let user: String?
public let messages: [ChatMessage]
}

public struct ChatMessage: Codable {
public let role: ChatRole
public enum Role: String, Codable {
case system
case user
case assistant
}
public let role: Role
public let content: String
}

public enum ChatRole: String, Codable {
case system
case user
case assistant
}

0 comments on commit 4fd959b

Please sign in to comment.