We are Java application developers and we have a question regarding camera access via WebRTC on iPadOS. Specifically, on iPadOS 17.1, we are encountering an issue when trying to access the camera via the WKWebView API in the Chrome browser, where an error occurs and the camera capture fails. Our investigation suggests that device access through the navigator.mediaDevices property via the WKWebView API may not work in Chrome. However, it works as expected in the Safari browser, leading us to wonder if this is a Chrome-specific limitation, or if it's due to an iPadOS setting or specification.
At this point, we are unsure if this issue is related to the WKWebView and WebRTC specifications on iPadOS 17.1, or if there are specific limitations in Chrome. We would appreciate any insights or solutions regarding camera access in iPadOS 17.1 with WKWebView and WebRTC, especially in relation to Chrome.
                    
                  
                Dive into the world of programming languages used for app development.
  
    
    Selecting any option will automatically load the page
  
  
  
  
    
  
  
          Post
Replies
Boosts
Views
Activity
                    
                      Given the below code with Swift 6 language mode, Xcode 16.2
If running with iOS 18+: the app crashes due to _dispatch_assert_queue_fail
If running with iOS 17 and below: there is a warning: warning: data race detected: @MainActor function at Swift6Playground/PublishedValuesView.swift:12 was not called on the main thread
Could anyone please help explain what's wrong here?
import SwiftUI
import Combine
@MainActor
class PublishedValuesViewModel: ObservableObject {
    @Published var count = 0
    @Published var content: String = "NA"
    private var cancellables: Set<AnyCancellable> = []
    
    func start() async {
        let publisher = $count
            .map { String(describing: $0) }
            .removeDuplicates()
        
        for await value in publisher.values {
            content = value
        }
    }
}
struct PublishedValuesView: View {
    @ObservedObject var viewModel: PublishedValuesViewModel
    
    var body: some View {
        Text("Published Values: \(viewModel.content)")
            .task {
                await viewModel.start()
            }
    }
}
                    
                  
                
                    
                      Hello,
I have a problem with Xcode, in C++ language. When I create a new project, I put my program in a file and click Build. It works correctly and without any problems, but when I enter a second file in the same project and click build, it says build failed. In the log it says, duplicate symbols appear.
                    
                  
                
                    
                      Hello everyone.
macOS, IOBluetooth framework.
My goal is to create a temporary SDP service. According to the documentation, by default a temporary service is created (aka Persistent = NO), which is deleted after the application is closed.
The documentation also mentions the IOBluetoothRemoveServiceWithRecordHandle function for forced removal of the service. This function is deprecated and is currently unavailable. I guesse that it has been replaced by the IOBluetoothSDPServiceRecord.removeServiceRecord method.
The essence of the problem is that the server is not deleted either using removeServiceRecord or even after app closing.
That is, if you create several services and try to delete them, they will remain alive. Only turning Bluetooth off and on in the OS helps.
I tested all versions of macOS starting with Monteray. The same behavior.
  for (int i = 0; i < 10; i++) {
        service = [IOBluetoothSDPServiceRecord publishedServiceRecordWithDictionary:dictionary];
        if (!service) {
            NSLog(@"Failed to create service");
        }
        else
        {
            [service getRFCOMMChannelID:&channelID];
            [service getServiceRecordHandle:&serverHandle];
            NSLog(@"A new service has been created handle=%u, channelID=%hhu", serverHandle, channelID);
            if (service.removeServiceRecord != kIOReturnSuccess) {
                NSLog(@"Failed to delete service");
            }
            //service.release;
            service = nil;
        }
    }
Can someone confirm this behavior? And is there a solution?
A minimal test example is available at the link
                    
                  
                
                    
                      Hi There,
I have a iOS App which has been published and purely managing data by SwiftData. I use following simple codes everywhere in Views:
...
@Query var items: [Item]
....
if let firstItem = items.first( where: {...}) {
...
Then I encountered crash at Query that _items.wrapperdValue has some errors.
Then I tried to split first(where...) into ordinary way:
let filteredItems = items.filter(...)
if let firstItem = filteredItems.first {
...
It runs OK.
Is it a bug in SwiftData in 18.2 or I missed some steps to facilitate SwiftData macros?
                    
                  
                
                    
                      I have been recently getting the following error seemingly randomly, when an event handler of a SwiftUI view accesses a relationship of a SwiftData model the view holds a reference to. I haven't yet found a reliable way of reproducing it:
SwiftData/BackingData.swift:866: Fatal error: This model instance was invalidated 
because its backing data could no longer be found the store. 
PersistentIdentifier(id: SwiftData.PersistentIdentifier.ID(url: COREDATA_ID_URL),
implementation: SwiftData.PersistentIdentifierImplementation)
What could cause this error? Could you suggest me a workaround?
                    
                  
                
                    
                      We want to do below addition to iOS Mobile App.
Airpod announces Push notification = which is workking
now we want to use voice command that "Reply to this" and sending Reply to that notification but it is saying it is not supported in your app.
So basically we need to use feature - Listen and respond to messages with AirPods
Do we need to add any integration inside app for this or it will directly worked with Siri settings ?
Is it possible to do in non messaging App?
Is it possible to do without syncing contacts ?
                    
                  
                
                    
                      I recently encountered an issue with Xcode 16.2 while attempting to integrate Settings.bundle into a new app. I added Settings.bundle as a new file (using the provided template), but when I ran the app (the standard simple "Hello World" project), the expected three default controls (Name, Enabled, Slider) did not appear in the app's settings.
To troubleshoot, I downgraded my system to macOS Sonoma 14.7.2 and Xcode 15.4 (on a 2023 Mac Mini, M2). After this downgrade, everything worked as expected. With a new project, adding Settings.bundle, and running the app, the settings entry for the app appeared, including the three default fields.
This behavior suggests a potential issue or incompatibility with Xcode 16.2.
                    
                  
                
                    
                      I use AppIntent to trigger a widget refresh, Appint is used on Button or Toggle,as follows
var isAudibleArming = false
struct SoundAlarmIntent: AppIntent {
static var title: LocalizedStringResource = "SoundAlarmIntent"
func perform() async throws -> some IntentResult {
isAudibleArming = true
return .result()
}
}
func timeline( for configuration: DynamicIntentWidgetPersonIntent, in context: Context ) async -> Timeline {
var entries: [Entry] = []
let currentDate = Date()
let entry = Entry(person: person(for: configuration))
entries.append(entry)
        if isAudibleArming {
            let entry2 = Entry(person: Person(name: "Friend4", dateOfBirth: currentDate.adding(.second, value: 6)))
            entries.append(entry2)
        }
        
        return .init(entries: entries, policy: .never)
    }
The timeline function fires, with entry corresponding to view1 and entry2 corresponding to view2. I expect to show view1 immediately and view2 6 seconds later. You get the correct response on iOS17. But the 6 second delay function on the discovery code in iOS18.2 takes effect immediately, view1 flashes, view2 appears immediately instead of waiting 6 seconds to appear.
                    
                  
                
                    
                      Does SwiftUI now support the ability for a chart to have two different Y Axes?  ChaptGPT seems to think it does, but I keep getting compiler errors in XCode.
                    
                  
                
                    
                      I’m experiencing a crash at runtime when trying to extract audio from a video. This issue occurs on both iOS 18 and earlier versions. The crash is caused by the following error:
*** Terminating app due to uncaught exception 'NSInternalInconsistencyException', reason: '*** -[AVAssetExportSession exportAsynchronouslyWithCompletionHandler:] Cannot call exportAsynchronouslyWithCompletionHandler: more than once.
(0x1851435ec 0x1826dd244 0x1970c09c0 0x214d8f358 0x214d95899 0x190a1c8b9 0x214d8efd9 0x30204cef5 0x302053ab9 0x190a5ae39)
libc++abi: terminating due to uncaught exception of type NSException
My previous code worked fine, but it's crashing with Swift 6.
Does anyone know a solution for this?
Previous code:
func extractAudioFromVideo(from videoURL: URL, exportHandler: ((AVAssetExportSession, CurrentValueSubject<Float, Never>?) -> Void)? = nil, completion: @escaping (Swift.Result<URL, Error>) -> Void) {
    let asset = AVAsset(url: videoURL)
    
    // Create an AVAssetExportSession to export the audio track
    guard let exportSession = AVAssetExportSession(asset: asset, presetName: AVAssetExportPresetAppleM4A) else {
        completion(.failure(NSError(domain: "com.example.app", code: -1, userInfo: [NSLocalizedDescriptionKey: "Failed to create AVAssetExportSession"])))
        return
    }
    
    // Set the output file type and path
    guard let filename = videoURL.lastPathComponent.components(separatedBy: ["."]).first else { return  }
    let outputURL = VideoUtils.getTempAudioExportUrl(filename)
    VideoUtils.deleteFileIfExists(outputURL.path)
    exportSession.outputFileType = .m4a
    exportSession.outputURL = outputURL
    
    let audioExportProgressPublisher = CurrentValueSubject<Float, Never>(0.0)
    if let exportHandler = exportHandler {
        exportHandler(exportSession, audioExportProgressPublisher)
    }
    
    // Periodically check the progress of the export session
    let timer = Timer.scheduledTimer(withTimeInterval: 0.1, repeats: true) { _ in
        audioExportProgressPublisher.send(exportSession.progress)
    }
    
    // Export the audio track asynchronously
    exportSession.exportAsynchronously {
        switch exportSession.status {
        case .completed:
            completion(.success(outputURL))
        case .failed:
            completion(.failure(exportSession.error ?? NSError(domain: "com.example.app", code: -1, userInfo: [NSLocalizedDescriptionKey: "Unknown error occurred while exporting audio"])))
        case .cancelled:
            completion(.failure(NSError(domain: "com.example.app", code: -1, userInfo: [NSLocalizedDescriptionKey: "Export session was cancelled"])))
        default:
            completion(.failure(NSError(domain: "com.example.app", code: -1, userInfo: [NSLocalizedDescriptionKey: "Unknown export session status"])))
        }
        
        // Invalidate the timer when the export session completes or is cancelled
        timer.invalidate()
    }
}
## New Code: 
func extractAudioFromVideo(from videoURL: URL, exportHandler: ((AVAssetExportSession, CurrentValueSubject<Float, Never>?) -> Void)? = nil, completion: @escaping (Swift.Result<URL, Error>) -> Void) 
{
	let asset = AVAsset(url: videoURL)
	
	// Create an AVAssetExportSession to export the audio track
	guard let exportSession = AVAssetExportSession(asset: asset, presetName: AVAssetExportPresetAppleM4A) else {
		completion(.failure(NSError(domain: "com.example.app", code: -1, userInfo: [NSLocalizedDescriptionKey: "Failed to create AVAssetExportSession"])))
		return
	}
	
	// Set the output file type and path
	guard let filename = videoURL.lastPathComponent.components(separatedBy: ["."]).first else { return  }
	let outputURL = VideoUtils.getTempAudioExportUrl(filename)
	VideoUtils.deleteFileIfExists(outputURL.path)
	exportSession.outputFileType = .m4a
	exportSession.outputURL = outputURL
	
	let audioExportProgressPublisher = CurrentValueSubject<Float, Never>(0.0)
	if let exportHandler {
		exportHandler(exportSession, audioExportProgressPublisher)
	}
	
	let task = Task {
		if #available(iOS 18.0, *) {
			// Handle export for iOS 18 and later
			let states = exportSession.states(updateInterval: 0.1)
			for await state in states {
				switch state {
				case .pending, .waiting:
					break
				case .exporting(progress: let progress):
					print("Exporting: \(progress.fractionCompleted)")
					if progress.isFinished {
						completion(.success(outputURL))
					} else if progress.isCancelled {
						completion(.failure(NSError(domain: "com.example.app", code: -1, userInfo: [NSLocalizedDescriptionKey: "Export session was cancelled"])))
					} else {
						audioExportProgressPublisher.send(Float(progress.fractionCompleted))
					}
				}
			}
			
			try await exportSession.export(to: outputURL, as: .m4a)  // Only call export once
			
		} else {
			// Handle export for iOS versions below 18
			let publishTimer = Timer.publish(every: 0.1, on: .main, in: .common)
				.autoconnect()
				.sink { [weak exportSession] _ in
					guard let exportSession = exportSession else { return }
					audioExportProgressPublisher.send(exportSession.progress)
				}
			
			// Only call export once
			await exportSession.export()
			
			// Handle the export session's status
			switch exportSession.status {
			case .completed:
				completion(.success(outputURL))
			case .failed:
				completion(.failure(exportSession.error ?? NSError(domain: "com.example.app", code: -1, userInfo: [NSLocalizedDescriptionKey: "Unknown error occurred while exporting audio"])))
			case .cancelled:
				completion(.failure(NSError(domain: "com.example.app", code: -1, userInfo: [NSLocalizedDescriptionKey: "Export session was cancelled"])))
			default:
				completion(.failure(NSError(domain: "com.example.app", code: -1, userInfo: [NSLocalizedDescriptionKey: "Unknown export session status"])))
			}
			
			// Invalidate the timer when the export session completes or is cancelled
			publishTimer.cancel()
		}
	}
	task.cancel()
}
                    
                  
                
              
                
              
              
                
                Topic:
                  
	
		Programming Languages
  	
                
                
                SubTopic:
                  
                    
	
		Swift
		
  	
                  
                
              
              
              
  
  
    
    
  
  
              
                
                
              
            
          
                    
                      System provides AnyShape type erasure that animates correctly. But system doesn't provide AnyInsettableShape. Here is my implementation of AnyInsettableShape (and AnyAnimatableData that is needed to support animation).
Let me know if there is simpler solution.
struct AnyInsettableShape: InsettableShape {
	private let _path: (CGRect) -> Path
	private let _inset: (CGFloat) -> AnyInsettableShape
	private let _getAnimatableData: () -> AnyAnimatableData
	private let _setAnimatableData: (_ data: AnyAnimatableData) -> AnyInsettableShape
	init<S>(_ shape: S) where S : InsettableShape {
		_path = { shape.path(in: $0) }
		_inset = { AnyInsettableShape(shape.inset(by: $0)) }
		_getAnimatableData = { AnyAnimatableData(shape.animatableData) }
		_setAnimatableData = { data in
			guard let otherData = data.rawValue as? S.AnimatableData else { assertionFailure(); return AnyInsettableShape(shape) }
			var shape = shape
			shape.animatableData = otherData
			return AnyInsettableShape(shape)
		}
	}
	var animatableData: AnyAnimatableData {
		get { _getAnimatableData() }
		set { self = _setAnimatableData(newValue) }
	}
	func path(in rect: CGRect) -> Path {
		_path(rect)
	}
	func inset(by amount: CGFloat) -> some InsettableShape {
		_inset(amount)
	}
}
struct AnyAnimatableData : VectorArithmetic {
	init<T : VectorArithmetic>(_ value: T) {
		self.init(optional: value)
	}
	
	private init<T : VectorArithmetic>(optional value: T?) {
		rawValue = value
		
		_scaleBy = { factor in
			(value != nil) ? AnyAnimatableData(value!.scaled(by: factor)) : .zero
		}
		_add = { other in
			AnyAnimatableData(value! + (other.rawValue as! T))
		}
		_subtract = { other in
			AnyAnimatableData(value! - (other.rawValue as! T))
		}
		_equal = { other in
			value! == (other.rawValue as! T)
		}
		_magnitudeSquared = {
			(value != nil) ? value!.magnitudeSquared : .zero
		}
		_zero = {
			AnyAnimatableData(T.zero)
		}
	}
	
	fileprivate let rawValue: (any VectorArithmetic)?
	private let _scaleBy: (_: Double) -> AnyAnimatableData
	private let _add: (_ other: AnyAnimatableData) -> AnyAnimatableData
	private let _subtract: (_ other: AnyAnimatableData) -> AnyAnimatableData
	private let _equal: (_ other: AnyAnimatableData) -> Bool
	private let _magnitudeSquared: () -> Double
	private let _zero: () -> AnyAnimatableData
	
	
	mutating func scale(by rhs: Double) {
		self = _scaleBy(rhs)
	}
	
	var magnitudeSquared: Double {
		_magnitudeSquared()
	}
	
	static let zero = AnyAnimatableData(optional: nil as Double?)
	
	@inline(__always)
	private var isZero: Bool { rawValue == nil }
	
	static func + (lhs: AnyAnimatableData, rhs: AnyAnimatableData) -> AnyAnimatableData {
		guard let (lhs, rhs) = fillZeroTypes(lhs, rhs) else { return .zero }
		return lhs._add(rhs)
	}
	
	static func - (lhs: AnyAnimatableData, rhs: AnyAnimatableData) -> AnyAnimatableData {
		guard let (lhs, rhs) = fillZeroTypes(lhs, rhs) else { return .zero }
		return lhs._subtract(rhs)
	}
	
	static func == (lhs: AnyAnimatableData, rhs: AnyAnimatableData) -> Bool {
		guard let (lhs, rhs) = fillZeroTypes(lhs, rhs) else { return true }
		return lhs._equal(rhs)
	}
	
	@inline(__always)
	private static func fillZeroTypes(_ lhs: AnyAnimatableData, _ rhs: AnyAnimatableData) -> (AnyAnimatableData, AnyAnimatableData)? {
		switch (!lhs.isZero, !rhs.isZero) {
		case (true, true): (lhs, rhs)
		case (true, false): (lhs, lhs._zero())
		case (false, true): (rhs._zero(), rhs)
		case (false, false): nil
		}
	}
}
                    
                  
                
                    
                      These helper methods allow to use modifier methods in standard for SwiftUI short way.
extension View {
	@inline(__always)
	func modify(_ block: (_ view: Self) -> some View) -> some View {
		block(self)
	}
	
	@inline(__always)
	func modify<V : View, T>(_ block: (_ view: Self, _ data: T) -> V, with data: T) -> V {
		block(self, data)
	}
}
_
DISCUSSION
Suppose you have modifier methods:
func addBorder(view: some View) -> some View {
		view.padding().border(Color.red, width: borderWidth)
}
	
	func highlight(view: some View, color: Color) -> some View {
		view.border(Color.red, width: borderWidth).overlay { color.opacity(0.3) }
}
_
Ordinar Decision
Your code may be like this:
var body: some View {
		let image = Image(systemName: "globe")
		let borderedImage = addBorder(view: image)
		let highlightedImage = highlight(view: borderedImage, color: .red)
		
		let text = Text("Some Text")
		let borderedText = addBorder(view: text)
		let highlightedText = highlight(view: borderedText, color: .yellow)
		
		VStack {
			highlightedImage
			highlightedText
		}
}
This code doesn't look like standard SwiftUI code.
_
Better Decision
Described above helper methods modify(:)  and modify(:,with:) allow to write code in typical for SwiftUI short way:
var body: some View {
		VStack {
			Image(systemName: "globe")
				.modify(addBorder)
				.modify(highlight, with: .red)
			
			Text("Some Text")
				.modify(addBorder)
				.modify(highlight, with: .yellow)
		}
}
                    
                  
                
                    
                      Consider this Swift struct:
public struct Example
{
    public func foo(callback: ()->Void)
    {
        ....
    }
    public func blah(i: Int)
    {
        ....
    }
    ....
}
Using Swift/C++ interop, I can create Example objects and call methods like blah. But I can't call foo because Swift/C++ interop doesn't currently support passing closures (right?).
On the other hand, Swift/objC does support passing objC blocks to Swift functions. But I can't use that here because Example is a Swift struct, not a class. So I could change it to a class, and update everything to work with reference rather than value semantics; but then I also have to change the objC++ code to create the object and call its methods using objC syntax. I'd like to avoid that.
Is there some hack that I can use to make this possible? I'm hoping that I can wrap a C++ std::function in some sort of opaque wrapper and pass that to swift, or something.
Thanks for any suggestions!
                    
                  
                
                    
                      I'm dealing with a strange bug where I am requesting read access for 'appleExerciseTime' and 'activitySummaryType', and despite enabling both in the permission sheet, they are being set to 'sharingDenied'.
I'm writing a Swift Test for making sure permissions are being granted.
@Test
func PermissionsGranted() {
    try await self.manager.getPermissions()
    for type in await manager.allHealthTypes {
        let status = await manager.healthStore.authorizationStatus(for: type)
        #expect(status == .sharingAuthorized, "\(type) authorization status is \(status)")
    }
}
let healthTypesToShare: Set<HKSampleType> = [
    HKQuantityType(.bodyMass),
    HKQuantityType(.bodyFatPercentage),
    HKQuantityType(.leanBodyMass),
    HKQuantityType(.activeEnergyBurned),
    HKQuantityType(.basalEnergyBurned),
    HKObjectType.workoutType()
]
let allHealthTypes: Set<HKObjectType> = [
    HKQuantityType(.bodyMass),
    HKQuantityType(.bodyFatPercentage),
    HKQuantityType(.leanBodyMass),
    HKQuantityType(.activeEnergyBurned),
    HKQuantityType(.basalEnergyBurned),
    HKQuantityType(.appleExerciseTime),
    HKObjectType.activitySummaryType()
]
let healthStore = HKHealthStore()
func getPermissions() async throws {
    try await healthStore.requestAuthorization(toShare: self.healthTypesToShare, read: self.allHealthTypes)
}
After 'getPermissions' runs, the permission sheet shows up on the Simulator, and I accept all. I've double checked that the failing permissions show up on the sheet and are enabled. Then the test fails with:
Expectation failed: (status → HKAuthorizationStatus(rawValue: 1)) == (.sharingAuthorized → HKAuthorizationStatus(rawValue: 2)) HKActivitySummaryTypeIdentifier authorization status is HKAuthorizationStatus(rawValue: 1)
Expectation failed: (status → HKAuthorizationStatus(rawValue: 1)) == (.sharingAuthorized → HKAuthorizationStatus(rawValue: 2)) HKActivitySummaryTypeIdentifier authorization status is HKAuthorizationStatus(rawValue: 1)
With the rawValue of '1' being 'sharingDenied'. All other permissions are granted. Is there a workaround here, or something I'm potentially doing wrong?
                    
                  
                
                    
                      Hello dear community,
I have the sample code from Apple “CapturingDepthUsingLiDAR” to access the LiDAR on my iPhone 12 Pro. My goal is to use the “photo output” function to generate a point cloud from a single image and then save it as a ply file. So far I have tested different approaches to create a .ply file from the depthmap, the intrinsic camera data and the rgba values. Unfortunately, I have had no success so far and the result has always been an incorrect point cloud.
My question now is whether there are already approaches to this and whether anyone has any experience with it.
Thank you very much in advance!!!
                    
                  
                
                    
                      Hi guys,
I've been struggling for a few days with this really weird behaviour.
We made an app for our e-commerce website and found out that a part of the product page is missing.
For any reason, the header and first blocks of the page and footer are displayed, but then a massive part of the content is missing. This content is not loaded through ajax; that's why I don't understand why it's not displayed.
You can see here 2 screenshots of what the page should look like and what the page looks like with WKWebView.
I've been inspecting this with Safari; there isn't any blocking error in the console, and html elements are just empty. There is the div with class row and nothing in it.
The same website is working perfectly with native Android Webview.
If anyone has any clue to find out what's going wrong
                    
                  
                
              
                
              
              
                
                Topic:
                  
	
		Programming Languages
  	
                
                
                SubTopic:
                  
                    
	
		Swift
		
  	
                  
                
              
              
              
  
  
    
    
  
  
              
                
                
              
            
          
                    
                      Crash Log
We have a issue with our watch app.  When we do a release build with xcode 16 the watch app will not launch and crashes on watchOS 10 and below devices.
It does not do this on debug builds...and it does not do this on xcode 15 release/debug builds.
Anybody running into watch crashes on xcode 16?
Thanks
                    
                  
                
                    
                      Hello Im having an error in swiftUI project of mine. I use fullscreencover to navigate through views. Normally it s been working but one point it doesn't.  I go through MainMenu -> SomeOtherView -> GameView -> AfterGameView -> SomeOtherView -> MainMenu. When it comes to mainmenu at last, it s showing main menu for a glimpse of a look and then goes back to GameView. In console an error took my notice.
> A new orientation transaction token is being requested while a valid one already exists. reason=Fullscreen transition (dismissing): fromVC=<_TtGC7SwiftUI29PresentationHostingControllerVS_7AnyView_: 0x10795ca00>; toVC=<_TtGC7SwiftUI29PresentationHostingControllerVS_7AnyView_: 0x1071c3400>;; windowOrientation=portrait; sceneOrientation=portrait; existingTransaction=<_UIForcedOrientationTransactionToken: 0x600001804a40; state: active; originalOrientation: portrait (1)>
Cant really finding the solution. Need help asap I will release a bug update to Appstore.
                    
                  
                
              
                
              
              
                
                Topic:
                  
	
		Programming Languages
  	
                
                
                SubTopic:
                  
                    
	
		Swift
		
  	
                  
                
              
              
              
  
  
    
    
  
  
              
                
                
              
            
          
                    
                      I am currently studying the Accelerate library by referring to Apple documentation.
Here is the link to the referenced document:
https://developer.apple.com/documentation/accelerate/veclib/vforce
When I executed the sample code provided at the bottom of the document, I found a case where the results were different.
let n = 10_000
let x = (0..<n).map { _ in
    Float.random(in: 1 ... 10_000)
}
let y = x.map {
    return sqrt($0)
}
and
let y = [Float](unsafeUninitializedCapacity: n) { buffer, initializedCount in
    vForce.sqrt(x,
                result: &buffer)
    
    initializedCount = n
}
The code below is provided to observe the issue described above.
import Accelerate
Task {
    let n = 1//10_000
    let x = (0..<n).map { _ in
        Float(6737.015)//Float.random(in: 1 ... 10_000)
    }
    let y = x.map {
        return sqrt($0)
    }
    try? await Task.sleep(nanoseconds: 1_000_000_000)
    let z = [Float](unsafeUninitializedCapacity: n) { buffer, initializedCount in
        vForce.sqrt(x, result: &buffer)
        initializedCount = n
    }
}
For a value of 6737.015 when calculating the square root:
Using the sqrt(_:) function gives the result 82.07932,
While using the vForce.sqrt(_:result:) function gives the result 82.07933.
Using a calculator, the value comes out as 82.07932139, which shows that the result from vForce is incorrect.
Could you explain the reason behind this difference?