2023-05-14 08:47:02 +02:00
|
|
|
#if !__has_feature(objc_arc)
|
|
|
|
#error This file must be compiled with automatic reference counting enabled (-fobjc-arc)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#import "whisper-encoder.h"
|
|
|
|
#import "whisper-encoder-impl.h"
|
2023-04-15 12:21:27 +02:00
|
|
|
|
|
|
|
#import <CoreML/CoreML.h>
|
|
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
#if __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
struct whisper_coreml_context {
|
|
|
|
const void * data;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct whisper_coreml_context * whisper_coreml_init(const char * path_model) {
|
|
|
|
NSString * path_model_str = [[NSString alloc] initWithUTF8String:path_model];
|
|
|
|
|
|
|
|
NSURL * url_model = [NSURL fileURLWithPath: path_model_str];
|
|
|
|
|
2023-09-15 11:18:18 +02:00
|
|
|
// select which device to run the Core ML model on
|
|
|
|
MLModelConfiguration *config = [[MLModelConfiguration alloc] init];
|
2024-01-04 15:28:30 +01:00
|
|
|
// config.computeUnits = MLComputeUnitsCPUAndGPU;
|
2023-09-15 11:18:18 +02:00
|
|
|
//config.computeUnits = MLComputeUnitsCPUAndNeuralEngine;
|
2024-01-04 15:28:30 +01:00
|
|
|
config.computeUnits = MLComputeUnitsAll;
|
2023-09-15 11:18:18 +02:00
|
|
|
|
|
|
|
const void * data = CFBridgingRetain([[whisper_encoder_impl alloc] initWithContentsOfURL:url_model configuration:config error:nil]);
|
2023-04-15 12:21:27 +02:00
|
|
|
|
|
|
|
if (data == NULL) {
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
whisper_coreml_context * ctx = new whisper_coreml_context;
|
|
|
|
|
|
|
|
ctx->data = data;
|
|
|
|
|
|
|
|
return ctx;
|
|
|
|
}
|
|
|
|
|
|
|
|
void whisper_coreml_free(struct whisper_coreml_context * ctx) {
|
|
|
|
CFRelease(ctx->data);
|
|
|
|
delete ctx;
|
|
|
|
}
|
|
|
|
|
|
|
|
void whisper_coreml_encode(
|
|
|
|
const whisper_coreml_context * ctx,
|
2023-11-08 21:01:41 +01:00
|
|
|
int64_t n_ctx,
|
|
|
|
int64_t n_mel,
|
2023-04-15 12:21:27 +02:00
|
|
|
float * mel,
|
|
|
|
float * out) {
|
|
|
|
MLMultiArray * inMultiArray = [
|
|
|
|
[MLMultiArray alloc] initWithDataPointer: mel
|
2023-11-08 21:01:41 +01:00
|
|
|
shape: @[@1, @(n_mel), @(n_ctx)]
|
2023-04-15 12:21:27 +02:00
|
|
|
dataType: MLMultiArrayDataTypeFloat32
|
2023-11-08 21:01:41 +01:00
|
|
|
strides: @[@(n_ctx*n_mel), @(n_ctx), @1]
|
2023-04-15 12:21:27 +02:00
|
|
|
deallocator: nil
|
|
|
|
error: nil
|
|
|
|
];
|
|
|
|
|
2023-08-29 14:44:38 +02:00
|
|
|
@autoreleasepool {
|
|
|
|
whisper_encoder_implOutput * outCoreML = [(__bridge id) ctx->data predictionFromLogmel_data:inMultiArray error:nil];
|
2023-04-15 12:21:27 +02:00
|
|
|
|
2023-08-29 14:44:38 +02:00
|
|
|
memcpy(out, outCoreML.output.dataPointer, outCoreML.output.count * sizeof(float));
|
|
|
|
}
|
2023-04-15 12:21:27 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#if __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|