c - Floating point precision nuances -


मुझे यह कोड NVIDIA के CUDA SDK नमूनों में मिला।

  अयोग्य गणना गॉल्ड (फ्लोट * संदर्भ, फ्लोट * idata, कॉन्स्ट अहस्ताक्षरित अंतर लेन) {संदर्भ [0] = 0; डबल total_sum = 0; अहस्ताक्षरित int i; के लिए (i = 1; i & lt; len; ++ i) {total_sum + = idata [i-1]; संदर्भ [i] = idata [i-1] + संदर्भ [i-1]; } // यह उपयोग करने के लिए ठीक होना चाहिए! = क्योंकि हमारे पास पूर्णांक मूल्य हैं / / जहां एक श्रेणी में फ्लोट का प्रतिनिधित्व किया जा सकता है यदि (total_sum! = संदर्भ [i-1]) printf ("चेतावनी: एकल-सटीक सटीकता से अधिक स्कैन अयोग्य हो जाएगा। \ N "); } // (सी) एनवीडिया कॉर्प  

क्या कोई मुझे एक ऐसा मामला बता सकता है जहां चेतावनी छपी जाएगी, और सबसे महत्वपूर्ण बात, क्यों।

फ़ंक्शन को कुछ निश्चित इनपुट डेटा के साथ दिमाग में लिखा जाता है। यदि उस इनपुट डेटा की अपेक्षा पूरी नहीं हुई है, तो चेतावनी प्रिंट होगी:

  #include & lt; stdio.h & gt; #DEFINE COUNT_OF (x) (sizeof (x) / sizeof (0 [(x)]) शून्य computeGold (फ्लोट * संदर्भ, फ्लोट * idata, const अहस्ताक्षरित int लेन) {डबल total_sum = 0; अहस्ताक्षरित int i; संदर्भ [0] = 0; के लिए (i = 1; i & lt; len; ++ i) {total_sum + = idata [i-1]; संदर्भ [i] = idata [i-1] + संदर्भ [i-1]; } // यह उपयोग करने के लिए ठीक होना चाहिए! = क्योंकि हमारे पास पूर्णांक मूल्य हैं / / जहां एक श्रेणी में फ्लोट का प्रतिनिधित्व किया जा सकता है यदि (total_sum! = संदर्भ [i-1]) printf ("चेतावनी: एकल-सटीक सटीकता से अधिक स्कैन अयोग्य हो जाएगा। \ N "); } // (सी) एनवीडिया कॉर्प फ्लोट डेटा [] = {1.0, 2.0, 3.0, 4.0, 5.0}; फ्लोट डेटा 2 [] = {123456.0, 99 9999.0, 99 99 99.0, 99 9999.0, 99 99 99.0, 99 99 99.0, 99 99 99.0, 99 9999.0, 99 99 99.0, 99 9999.0, 99 99 99.0, 99 9999.0, 99 9999.0, 99 9999.0, 99 9999.0, 99 9999.0, 99 9999.0, 99 9999.0, 123456.0}; फ्लोट रिफ [COUNT_OF (data2)] = {0.0}; Int main () {computeGold (रेफरी, डेटा, COUNT_OF (डेटा)); ComputeGold (रेफरी, डेटा 2, COUNT_OF (डेटा 2)); वापसी 0; }  

Comments

Popular posts from this blog

python - rename keys in a dictionary -

windows - Heroku throws SQLITE3 Read only exception -

lex - Building a lexical Analyzer in Java -