_AVAE_Check: обязательное условие ложно: [AVAudioEngine.mm:353:AttachNode: (node! = Nil)] при создании AKDelay

У меня есть минимальное приложение для MacOS (один контроллер представления + одна кнопка) со следующим кодом (в основном копипаст из площадка AudioKit):

public class Player {

    static let playRate = 2.0
    static let scale = [0, 2, 4, 5, 7, 9, 11, 12]

    var pluckedString: AKPluckedString! = nil
    var delay: AKDelay! = nil
    var reverb: AKReverb! = nil
    var performance: AKPeriodicFunction! = nil

    public init() {
        pluckedString = AKPluckedString()

        delay = AKDelay(pluckedString) // <- objc_exception_throw here
        delay.time = 1.5 / Player.playRate
        delay.dryWetMix = 0.3
        delay.feedback = 0.2

        reverb = AKReverb(delay)

        performance = AKPeriodicFunction(frequency: Player.playRate) {
            var note = Player.scale.randomElement()
            let octave = [2, 3, 4, 5].randomElement() * 12
            if random(0, 10) < 1.0 { note += 1 }
            if !Player.scale.contains(note % 12) { print("ACCIDENT!") }

            let frequency = (note + octave).midiNoteToFrequency()
            if random(0, 6) > 1.0 {
                self.pluckedString.trigger(frequency: frequency)
            }
        }
    }

}

Проблема в том, что вызов AKDelay(pluckedString) вызывает исключение ObjC:

AKPluckedString.swift:init(frequency:amplitude:lowestFrequency:):94:Parameter Tree Failed
[avae] AVAEInternal.h:70:_AVAE_Check: required condition is false: [AVAudioEngine.mm:353:AttachNode: (node != nil)]
[General] required condition is false: node != nil
[General] (
    0   CoreFoundation                      0x00007fff49d8d00b __exceptionPreprocess + 171
    1   libobjc.A.dylib                     0x00007fff7096bc76 objc_exception_throw + 48
    2   CoreFoundation                      0x00007fff49d92da2 +[NSException raise:format:arguments:] + 98
    3   AVFAudio                            0x00007fff4610b75e _Z19AVAE_RaiseExceptionP8NSStringz + 158
    4   AVFAudio                            0x00007fff460ab1a2 _Z11_AVAE_CheckPKciS0_S0_b + 330
    5   AVFAudio                            0x00007fff4611f2e7 _ZN17AVAudioEngineImpl10AttachNodeEP11AVAudioNodeb + 63
    6   AVFAudio                            0x00007fff4611f267 -[AVAudioEngine attachNode:] + 67
    7   AudioKit                            0x000000010051de01 globalinit_33_0214DCBA62A4B4A95DF14CC0DE6A86C6_func60 + 13249
    8   AudioKit                            0x000000010051f24d globalinit_33_0214DCBA62A4B4A95DF14CC0DE6A86C6_func60 + 18445
    9   AudioKit                            0x0000000100512284 block_copy_helper.12 + 4852
    10  AudioKit                            0x0000000100519119 block_copy_helper.12 + 33161
    11  AudioKit                            0x0000000100639e8f block_copy_helper.12 + 38463
    12  AudioKit                            0x00000001006397ca block_copy_helper.12 + 36730
...

Как я могу это исправить?

Я использую AudioKit 4.0.4 / Swift 4.0.3 / XCode 9.2 (9C40b).


person 0x416e746f6e    schedule 01.02.2018    source источник
comment
Я запустил ваш код без сбоев. Сообщение об ошибке, которое вы получаете, похоже на ошибку из-за того, что не установлен Audiokit.output. Когда вы вызываете AudioKit.start ()? Это должно быть после Audiokit.output = player.reverb (или чего-то еще).   -  person c_booth    schedule 02.02.2018
comment
Вот что делает его очень странным. Тот же код на детской площадке работает нормально. Пока что я мог понять, что каким-то образом вызов AVAudioNode() в AKPluckedString (ну, на самом деле, в его суперклассе AKNode) возвращает нулевой указатель. Однако CoreAudio не предоставил никаких причин или ошибок.   -  person 0x416e746f6e    schedule 02.02.2018


Ответы (1)


Это потому, что песочница вашего приложения включена? Для моего Xcode (9.2) по умолчанию используется песочница приложения на (вкладка «Возможности» проекта). Это приводит к тому, что AudioKit выдает эту ошибку.

person immyrce    schedule 05.02.2018
comment
Да! Это была причина (фейспалм). - person 0x416e746f6e; 07.02.2018