当前位置: 编程技术>移动开发
本页文章导读:
▪跳转到app评述页面 跳转到app评论页面
在APP里经常会引导用户给自己的应用评分,实现代码如下:
NSString *appID = @"584215425"; // 用developer账户登陆itunes connect创建应用时会产生一个app id
NSString *appURL = [NSS.........
▪ 用OpenGL兑现无限循环的coverflow 用OpenGL实现无限循环的coverflow
网上找了很久,都是用Gallery实现的,效果不是很满意,结果发现这个用OpenGL实现的,稍微修改了一下源码,实现了无限循环功能源码地址:https://github.com/jack.........
▪ R语言经典范例 R语言经典实例
《R语言经典实例》
基本信息
原书名:R Cookbook
作者: Paul Teetor
译者: 李洪成 朱文佳 沈毅诚
丛书名: O'Reilly精品图书系列
出版社:机械工业出版社
ISBN:9787111420217
上架时.........
[1]跳转到app评述页面
来源: 互联网 发布时间: 2014-02-18
跳转到app评论页面
在APP里经常会引导用户给自己的应用评分,实现代码如下:
NSString *appID = @"584215425"; // 用developer账户登陆itunes connect创建应用时会产生一个app id NSString *appURL = [NSString stringWithFormat:@"https://itunes.apple.com/cn/app/id%@?mt=8",appID]; [[UIApplication sharedApplication] openURL:[NSURL URLWithString:appURL]];
[2] 用OpenGL兑现无限循环的coverflow
来源: 互联网 发布时间: 2014-02-18
用OpenGL实现无限循环的coverflow
网上找了很久,都是用Gallery实现的,效果不是很满意,结果发现这个用OpenGL实现的,稍微修改了一下源码,实现了无限循环功能
源码地址:https://github.com/jackfengji/glcoverflow
使用时
网上找了很久,都是用Gallery实现的,效果不是很满意,结果发现这个用OpenGL实现的,稍微修改了一下源码,实现了无限循环功能
源码地址:https://github.com/jackfengji/glcoverflow
public class CoverFlowOpenGL extends GLSurfaceView implements GLSurfaceView.Renderer { private static final int TOUCH_MINIMUM_MOVE = 5; private static final int IMAGE_SIZE = 128; private static final int MAX_TILES = 48; // the visble tiles left and right private static final int VISIBLE_TILES = 1; private static final float SCALE = 0.7f; private static final float SPREAD_IMAGE = 0.14f; private static final float FLANK_SPREAD = 0.4f; private static final float FRICTION = 10.0f; private static final float MAX_SPEED = 6.0f; private static final float[] GVertices = new float[] { -1.0f, -1.0f, 0.0f, 1.0f, -1.0f, 0.0f, -1.0f, 1.0f, 0.0f, 1.0f, 1.0f, 0.0f, }; private static final float[] GTextures = new float[] { 0.0f, 1.0f, 1.0f, 1.0f, 0.0f, 0.0f, 1.0f, 0.0f, }; private GL10 mGLContext; private FloatBuffer mVerticesBuffer; private FloatBuffer mTexturesBuffer; private float[] mMatrix; private int mBgTexture; private FloatBuffer mBgVerticesBuffer; private FloatBuffer mBgTexturesBuffer; private int mBgBitmapId; private boolean mInitBackground; private float mOffset; private int mLastOffset; private RectF mTouchRect; private int mWidth; private boolean mTouchMoved; private float mTouchStartPos; private float mTouchStartX; private float mTouchStartY; private float mStartOffset; private long mStartTime; private float mStartSpeed; private float mDuration; private Runnable mAnimationRunnable; private VelocityTracker mVelocity; private CoverFlowListener mListener; private DataCache<Integer, CoverFlowRecord> mCache; public CoverFlowOpenGL(Context context) { super(context); setEGLConfigChooser(8, 8, 8, 8, 16, 0); setRenderer(this); setRenderMode(RENDERMODE_WHEN_DIRTY); getHolder().setFormat(PixelFormat.TRANSLUCENT); mCache = new DataCache<Integer, CoverFlowRecord>(MAX_TILES); mLastOffset = 0; mOffset = 0; mInitBackground = false; mBgBitmapId = 0; } public void setCoverFlowListener(CoverFlowListener listener) { mListener = listener; } public void setSelection(int position) { endAnimation(); mOffset = position; requestRender(); } private int getActuallyPosition(int position) { int max = mListener.getCount(this); while (position < 0 || position >= max) { if (position < 0) position += max; else if (position >= max) position -= max; } return position; } @Override public boolean onTouchEvent(MotionEvent event) { int action = event.getAction(); switch (action) { case MotionEvent.ACTION_DOWN: touchBegan(event); return true; case MotionEvent.ACTION_MOVE: touchMoved(event); return true; case MotionEvent.ACTION_UP: touchEnded(event); return true; } return false; } private void touchBegan(MotionEvent event) { endAnimation(); float x = event.getX(); mTouchStartX = x; mTouchStartY = event.getY(); mStartTime = System.currentTimeMillis(); mStartOffset = mOffset; mTouchMoved = false; mTouchStartPos = (x / mWidth) * 10 - 5; mTouchStartPos /= 2; mVelocity = VelocityTracker.obtain(); mVelocity.addMovement(event); } private void touchMoved(MotionEvent event) { float pos = (event.getX() / mWidth) * 10 - 5; pos /= 2; if (!mTouchMoved) { float dx = Math.abs(event.getX() - mTouchStartX); float dy = Math.abs(event.getY() - mTouchStartY); if (dx < TOUCH_MINIMUM_MOVE && dy < TOUCH_MINIMUM_MOVE) return; mTouchMoved = true; } mOffset = mStartOffset + mTouchStartPos - pos; requestRender(); mVelocity.addMovement(event); } private void touchEnded(MotionEvent event) { float pos = (event.getX() / mWidth) * 10 - 5; pos /= 2; if (mTouchMoved) { mStartOffset += mTouchStartPos - pos; mOffset = mStartOffset; mVelocity.addMovement(event); mVelocity.computeCurrentVelocity(1000); double speed = mVelocity.getXVelocity(); speed = (speed / mWidth) * 10; if (speed > MAX_SPEED) speed = MAX_SPEED; else if (speed < -MAX_SPEED) speed = -MAX_SPEED; startAnimation(-speed); } else { if (mTouchRect.contains(event.getX(), event.getY())) { mListener.topTileClicked(this, getActuallyPosition((int) (mOffset + 0.01))); } } } private void startAnimation(double speed) { if (mAnimationRunnable != null) return; double delta = speed * speed / (FRICTION * 2); if (speed < 0) delta = -delta; double nearest = mStartOffset + delta; nearest = Math.floor(nearest + 0.5); mStartSpeed = (float) Math.sqrt(Math.abs(nearest - mStartOffset) * FRICTION * 2); if (nearest < mStartOffset) mStartSpeed = -mStartSpeed; mDuration = Math.abs(mStartSpeed / FRICTION); mStartTime = AnimationUtils.currentAnimationTimeMillis(); mAnimationRunnable = new Runnable() { @Override public void run() { driveAnimation(); } }; post(mAnimationRunnable); } private void driveAnimation() { float elapsed = (AnimationUtils.currentAnimationTimeMillis() - mStartTime) / 1000.0f; if (elapsed >= mDuration) endAnimation(); else { updateAnimationAtElapsed(elapsed); post(mAnimationRunnable); } } private void endAnimation() { if (mAnimationRunnable != null) { mOffset = (float) Math.floor(mOffset + 0.5); requestRender(); removeCallbacks(mAnimationRunnable); mAnimationRunnable = null; } } private void updateAnimationAtElapsed(float elapsed) { if (elapsed > mDuration) elapsed = mDuration; float delta = Math.abs(mStartSpeed) * elapsed - FRICTION * elapsed * elapsed / 2; if (mStartSpeed < 0) delta = -delta; mOffset = mStartOffset + delta; requestRender(); } @Override public void onSurfaceCreated(GL10 gl, EGLConfig config) { mCache.clear(); mGLContext = gl; mVerticesBuffer = makeFloatBuffer(GVertices); mTexturesBuffer = makeFloatBuffer(GTextures); } @Override public void onSurfaceChanged(GL10 gl, int w, int h) { mWidth = w; float imagew = w * 0.45f / SCALE / 2.0f; float imageh = h * 0.45f / SCALE / 2.0f; mTouchRect = new RectF(w / 2 - imagew, h / 2 - imageh, w / 2 + imagew, h / 2 + imageh); gl.glViewport(0, 0, w, h); float ratio = ((float) w) / h; gl.glMatrixMode(GL10.GL_PROJECTION); gl.glLoadIdentity(); gl.glOrthof(-ratio * SCALE, ratio * SCALE, -1 * SCALE, 1 * SCALE, 1, 3); float[] vertices = new float[] { -ratio * SCALE, -SCALE, 0, ratio * SCALE, -SCALE, 0, -ratio * SCALE, SCALE, 0, ratio * SCALE, SCALE, 0 }; mBgVerticesBuffer = makeFloatBuffer(vertices); } public void setBackgroundTexture(int res) { mBgBitmapId = res; mInitBackground = true; } public void clearTileCache() { mCache.clear(); } private void initBg() { mInitBackground = false; if (mBgBitmapId != 0) { Bitmap bitmap = BitmapFactory.decodeResource(getResources(), mBgBitmapId); mBgBitmapId = 0; int tmp = 1; int w = bitmap.getWidth(); int h = bitmap.getHeight(); while (w > tmp || h > tmp) { tmp <<= 1; } int width = tmp; int height = tmp; Bitmap bm = Bitmap.createBitmap(width, height, Bitmap.Config.RGB_565); Canvas cv = new Canvas(bm); int left = (width - w) / 2; int top = (height - h) / 2; cv.drawBitmap(bitmap, left, top, new Paint()); GL10 gl = mGLContext; int[] tex = new int[1]; gl.glGenTextures(1, tex, 0); mBgTexture = tex[0]; gl.glBindTexture(GL10.GL_TEXTURE_2D, mBgTexture); GLUtils.texImage2D(GL10.GL_TEXTURE_2D, 0, bm, 0); bitmap.recycle(); bm.recycle(); gl.glTexParameterf(GL10.GL_TEXTURE_2D, GL10.GL_TEXTURE_MIN_FILTER, GL10.GL_NEAREST); gl.glTexParameterf(GL10.GL_TEXTURE_2D, GL10.GL_TEXTURE_MAG_FILTER, GL10.GL_LINEAR); gl.glTexParameterf(GL10.GL_TEXTURE_2D, GL10.GL_TEXTURE_WRAP_S, GL10.GL_CLAMP_TO_EDGE); gl.glTexParameterf(GL10.GL_TEXTURE_2D, GL10.GL_TEXTURE_WRAP_T, GL10.GL_CLAMP_TO_EDGE); gl.glTexEnvf(GL10.GL_TEXTURE_ENV, GL10.GL_TEXTURE_ENV_MODE, GL10.GL_REPLACE); float[] textcoor = new float[] { (tmp - w) / 2.0f / tmp, (tmp - h) / 2.0f / tmp, (tmp + w) / 2.0f / tmp, (tmp - h) / 2.0f / tmp, (tmp - w) / 2.0f / tmp, (tmp + h) / 2.0f / tmp, (tmp + w) / 2.0f / tmp, (tmp + h) / 2.0f / tmp }; mBgTexturesBuffer = makeFloatBuffer(textcoor); } } @Override public void onDrawFrame(GL10 gl) { gl.glMatrixMode(GL10.GL_MODELVIEW); gl.glLoadIdentity(); GLU.gluLookAt(gl, 0, 0, 2, 0f, 0f, 0f, 0f, 1.0f, 0.0f); gl.glDisable(GL10.GL_DEPTH_TEST); gl.glClearColor(0, 0, 0, 0); gl.glClear(GL10.GL_COLOR_BUFFER_BIT | GL10.GL_DEPTH_BUFFER_BIT); gl.glEnableClientState(GL10.GL_VERTEX_ARRAY); gl.glEnableClientState(GL10.GL_TEXTURE_COORD_ARRAY); drawBg(gl); draw(gl); } public void drawBg(GL10 gl) { if (mInitBackground) initBg(); if (mBgTexture != 0) { gl.glPushMatrix(); gl.glVertexPointer(3, GL10.GL_FLOAT, 0, mBgVerticesBuffer); gl.glTexCoordPointer(2, GL10.GL_FLOAT, 0, mBgTexturesBuffer); gl.glEnable(GL10.GL_TEXTURE_2D); gl.glBindTexture(GL10.GL_TEXTURE_2D, mBgTexture); gl.glDrawArrays(GL10.GL_TRIANGLE_STRIP, 0, 4); gl.glPopMatrix(); } } private void draw(GL10 gl) { gl.glPushMatrix(); gl.glVertexPointer(3, GL10.GL_FLOAT, 0, mVerticesBuffer); gl.glTexCoordPointer(2, GL10.GL_FLOAT, 0, mTexturesBuffer); gl.glEnable(GL10.GL_TEXTURE_2D); gl.glEnable(GL10.GL_BLEND); gl.glBlendFunc(GL10.GL_SRC_ALPHA, GL10.GL_ONE_MINUS_SRC_ALPHA); final float offset = mOffset; int i = 0; int mid = (int) Math.floor(offset + 0.5); // draw the left tiles int iStartPos = mid - VISIBLE_TILES; for (i = iStartPos; i < mid; ++i) { drawTile(i, i - offset, gl); } // draw the right tiles int iEndPos = mid + VISIBLE_TILES; for (i = iEndPos; i >= mid; --i) { drawTile(i, i - offset, gl); } if (mLastOffset != (int) offset) { mListener.tileOnTop(this, getActuallyPosition((int) offset)); mLastOffset = (int) offset; } gl.glPopMatrix(); } private void drawTile(int position, float off, GL10 gl) { final CoverFlowRecord fcr = getTileAtIndex(position, gl); if (fcr != null && fcr.mTexture != 0) { if (mMatrix == null) { mMatrix = new float[16]; mMatrix[15] = 1; mMatrix[10] = 1; mMatrix[5] = 1; mMatrix[0] = 1; } float trans = off * SPREAD_IMAGE; float f = off * FLANK_SPREAD; if (f > FLANK_SPREAD) f = FLANK_SPREAD; else if (f < -FLANK_SPREAD) f = -FLANK_SPREAD; mMatrix[3] = -f; mMatrix[0] = 1 - Math.abs(f); float sc = 0.38f * mMatrix[0]; trans += f * 1; gl.glPushMatrix(); gl.glBindTexture(GL10.GL_TEXTURE_2D, fcr.mTexture); // draw bitmap gl.glTranslatef(trans, 0, 0); gl.glScalef(sc, sc, 1.0f); gl.glMultMatrixf(mMatrix, 0); gl.glDrawArrays(GL10.GL_TRIANGLE_STRIP, 0, 4); // draw the reflection gl.glTranslatef(0, -2, 0); gl.glScalef(1, -1, 1); gl.glColor4f(1f, 1f, 1f, 0.5f); gl.glDrawArrays(GL10.GL_TRIANGLE_STRIP, 0, 4); gl.glColor4f(1, 1, 1, 1); gl.glPopMatrix(); } } private CoverFlowRecord getTileAtIndex(int position, GL10 gl) { synchronized (this) { position = getActuallyPosition(position); CoverFlowRecord fcr = mCache.objectForKey(position); if (fcr == null) { Bitmap bm = mListener.getImage(this, position); if (bm == null) return null; int texture = imageToTexture(bm, gl); fcr = new CoverFlowRecord(texture, gl); mCache.putObjectForKey(position, fcr); } return fcr; } } private static Bitmap createTextureBitmap(Bitmap bitmap) { int width = bitmap.getWidth(); int height = bitmap.getHeight(); final Bitmap bm = Bitmap.createBitmap(IMAGE_SIZE, IMAGE_SIZE, Bitmap.Config.ARGB_8888); Canvas cv = new Canvas(bm); if (width > IMAGE_SIZE || height > IMAGE_SIZE) { // scale the bitmap, make the width or height to the IMAGE_SIZE Rect src = new Rect(0, 0, width, height); float scale = 1.0f; if (width > height) scale = ((float) IMAGE_SIZE) / width; else scale = ((float) IMAGE_SIZE) / height; width = (int) (width * scale); height = (int) (height * scale); float left = (IMAGE_SIZE - width) / 2.0f; float top = (IMAGE_SIZE - height) / 2.0f; RectF dst = new RectF(left, top, left + width, top + height); cv.drawBitmap(bitmap, src, dst, new Paint()); } else { float left = (IMAGE_SIZE - width) / 2.0f; float top = (IMAGE_SIZE - height) / 2.0f; cv.drawBitmap(bitmap, left, top, new Paint()); } return bm; } private int imageToTexture(Bitmap bitmap, GL10 gl) { // generate texture int[] texture = new int[1]; gl.glGenTextures(1, texture, 0); gl.glBindTexture(GL10.GL_TEXTURE_2D, texture[0]); final Bitmap bm = createTextureBitmap(bitmap); bitmap.recycle(); GLUtils.texImage2D(GL10.GL_TEXTURE_2D, 0, bm, 0); // draw the bitmap in // the texture bm.recycle(); // some texture settings gl.glTexParameterf(GL10.GL_TEXTURE_2D, GL10.GL_TEXTURE_MIN_FILTER, GL10.GL_NEAREST); gl.glTexParameterf(GL10.GL_TEXTURE_2D, GL10.GL_TEXTURE_MAG_FILTER, GL10.GL_LINEAR); gl.glTexParameterf(GL10.GL_TEXTURE_2D, GL10.GL_TEXTURE_WRAP_S, GL10.GL_CLAMP_TO_EDGE); gl.glTexParameterf(GL10.GL_TEXTURE_2D, GL10.GL_TEXTURE_WRAP_T, GL10.GL_CLAMP_TO_EDGE); gl.glTexEnvf(GL10.GL_TEXTURE_ENV, GL10.GL_TEXTURE_ENV_MODE, GL10.GL_MODULATE); return texture[0]; } private static FloatBuffer makeFloatBuffer(final float[] arr) { ByteBuffer bb = ByteBuffer.allocateDirect(arr.length * 4); bb.order(ByteOrder.nativeOrder()); FloatBuffer fb = bb.asFloatBuffer(); fb.put(arr); fb.position(0); return fb; } public static class CoverFlowRecord { private int mTexture; private GL10 gl; public CoverFlowRecord(int texture, GL10 gl) { mTexture = texture; this.gl = gl; } @Override protected void finalize() throws Throwable { if (mTexture != 0) { gl.glDeleteTextures(1, new int[] { mTexture }, 0); } super.finalize(); } } public static interface CoverFlowListener { public int getCount(CoverFlowOpenGL view); public Bitmap getImage(CoverFlowOpenGL anotherCoverFlow, int position); public void tileOnTop(CoverFlowOpenGL view, int position); public void topTileClicked(CoverFlowOpenGL view, int position); } }
public class DataCache<K, E> { private int mCapacity; private LinkedHashMap<K, E> mCache; private final ReadWriteLock mReadWriteLock = new ReentrantReadWriteLock(); public DataCache(int capacity) { mCapacity = capacity; mCache = new LinkedHashMap<K, E>(mCapacity) { private static final long serialVersionUID = -9165777183357349715L; @Override protected boolean removeEldestEntry(Entry<K, E> eldest) { if (size() > mCapacity) { mReadWriteLock.writeLock().lock(); remove(eldest.getKey()); mReadWriteLock.writeLock().unlock(); } return false; } }; } public E objectForKey(K key) { mReadWriteLock.readLock().lock(); final E result = mCache.get(key); mReadWriteLock.readLock().unlock(); return result; } public void putObjectForKey(final K key, final E value) { if (key != null && value != null) { mReadWriteLock.writeLock().lock(); mCache.put(key, value); mReadWriteLock.writeLock().unlock(); } } public boolean containsKey(final K key) { mReadWriteLock.readLock().lock(); final boolean result = mCache.containsKey(key); mReadWriteLock.readLock().unlock(); return result; } public void clear() { mReadWriteLock.writeLock().lock(); mCache.clear(); mReadWriteLock.writeLock().unlock(); } public void setCapacity(int capacity) { mCapacity = capacity; } }
使用时
private static int[] SAMPLE_IMAGES = new int[] { R.drawable.gallery_photo_1, R.drawable.gallery_photo_2, R.drawable.gallery_photo_3, R.drawable.gallery_photo_4, R.drawable.gallery_photo_5, R.drawable.gallery_photo_6, R.drawable.gallery_photo_7, R.drawable.gallery_photo_8 }; mCoverFlow = new CoverFlowOpenGL(this); mCoverFlow.setCoverFlowListener(new CoverFlowOpenGL.CoverFlowListener() { @Override public int getCount(CoverFlowOpenGL view) { return SAMPLE_IMAGES_2.length; } @Override public View getView(CoverFlowOpenGL anotherCoverFlow, int position) { return BitmapFactory.decodeResource(getResources(), SAMPLE_IMAGES_2[position]); } @Override public void tileOnTop(CoverFlowOpenGL view, int position) { // you can control what will happen when one image is in // middle } @Override public void topTileClicked(CoverFlowOpenGL view, int position) { // you can control what will happen when the image in // middle is clicked } });
[3] R语言经典范例
来源: 互联网 发布时间: 2014-02-18
R语言经典实例
《R语言经典实例》
基本信息
原书名:R Cookbook
作者: Paul Teetor
译者: 李洪成 朱文佳 沈毅诚
丛书名: O'Reilly精品图书系列
出版社:机械工业出版社
ISBN:9787111420217
上架时间:2013-4-13
出版日期:2013 年5月
开本:16开
页码:1
版次:1-1
所属分类:计算机
更多关于 》》》《R语言经典实例》
内容简介
计算机书籍
《r语言经典实例》内容简介:o’reilly media通过图书、杂志、在线服务、调查研究和会议等方式传播创新知识。自1978年开始,o’reilly一直都是前沿发展的见证者和推动者。超级极客们正在开创着未来,而我们关注真正重要的技术趋势——通过放大那些“细微的信号”来刺激社会对新科技的应用。作为技术社区中活跃的参与者,o’reilly的发展充满了对创新的倡导、创造和发扬光大。
o’reilly为软件开发人员带来革命性的“动物书”;创建第一个商业网站(gnn);组织了影响深远的开放源代码峰会,以至于开源软件运动以此命名;创立了make杂志,从而成为diy革命的主要先锋;公司一如既往地通过多种形式缔结信息与人的纽带。o’reilly的会议和峰会集聚了众多超级极客和高瞻远瞩的商业领袖,共同描绘出开创新产业的革命性思想。作为技术人士获取信息的选择,o’reilly现在还将先锋专家的知识传递给普通的计算机用户。无论是通过书籍出版,在线服务或者面授课程,每一项o’reilly的产品都反映了公司不可动摇的理念——信息是激发创新的力量。
目录
《r语言经典实例》
前言1
第1章 r入门和获得帮助7
1.1 下载和安装r软件8
1.2 开始运行r软件10
1.3 输入r命令13
1.4 退出r15
1.5 中断r正在运行的程序16
1.6 查看帮助文档17
1.7 获取函数的帮助文档18
1.8 搜索帮助文档20
1.9 查看r软件包帮助信息21
1.10 通过网络获取帮助23
1.11 寻找相关函数与数据包26
1.12 查询邮件列表 27
1.13 向邮件列表提交问题27
第2章 基础知识30
2.1 显示内容30
2.2 设定变量32
2.3 列出所有变量34
.2.4 删除变量35
2.5 生成向量36
2.6 计算基本统计量37
2.7 生成数列40
2.8 向量比较42
2.9 选取向量中的元素43
2.10 向量的计算46
2.11 运算符优先级问题48
2.12 定义函数50
2.13 减少输入,得到更多命令52
2.14 常见错误54
第3章 r软件导览 58
3.1 获取和设定工作目录58
3.2 保存工作空间59
3.3 查看历史命令记录60
3.4 保存先前命令产生的结果60
3.5 显示搜索路径61
3.6 使用r包中的函数62
3.7 使用r的内置数据集64
3.8 查看已安装的r包列表65
3.9 从cran网站安装r包67
3.10 设定默认cran网站镜像69
3.11 隐藏启动信息70
3.12 运行脚本70
3.13 批量运行r代码71
3.14 获取和设定环境变量74
3.15 找到r的主目录75
3.16 r的客户化76
第4章 输入与输出80
4.1 使用键盘输入数据81
4.2 显示更少的位数(或更多的位数)82
4.3 将输出结果重定向到某一文件84
4.4 显示文件列表85
4.5 解决无法在windows中打开文件的问题86
4.6 阅读固定宽度数据记录87
4.7 读取表格数据文件88
4.8 读取csv文件90
4.9 写入csv文件92
4.10 从网络中读取表格或csv格式数据93
4.11 读取html表格数据94
4.12 读取复杂格式数据文件96
4.13 读取mysql数据库中的数据100
4.14 保存和传送目标102
第5章 数据结构104
5.1 对向量添加数据111
5.2 在向量中插入数据112
5.3 理解循环规则113
5.4 构建因子(即分类变量)115
5.5 将多个向量合并成单个向量以及平行因子117
5.6 创建列表118
5.7 根据位置选定列表元素119
5.8 根据名称选定列表元素121
5.9 构建一个名称/值关联表122
5.10 从列表中移除元素124
5.11 将列表转换为向量125
5.12 从列表中移除取值为空值(即null)的元素126
5.13 使用条件来移除列表元素127
5.14 矩阵初始化129
5.15 执行矩阵运算130
5.16 将描述性名称赋给矩阵的行和列131
5.17 从矩阵中选定一行或一列132
5.18 用列数据初始化数据框133
5.19 由行数据初始化数据框134
5.20 添加行至数据框136
5.21 预分配数据框137
5.22 根据位置选择数据框的列138
5.23 根据列名选定数据框的列142
5.24 更便捷地选定行和列143
5.25 修改数据框的列名145
5.26 编辑数据框146
5.27 从数据框中移除na值148
5.28 根据名称排除列149
5.29 合并两个数据框150
5.30 根据共有列合并数据框151
5.31 更便捷地访问数据框内容152
5.32 基本数据类型之间的转换154
5.33 不同结构化数据类型间的转换156
第6章 数据转换159
6.1 向量分组160
6.2 将函数应用于每个列表元素161
6.3 将函数应用于每行163
6.4 将函数应用于每列164
6.5 将函数应用于组数据166
6.6 将函数应用于行组168
6.7 将函数应用于平行向量或列表170
第7章 字符串和日期172
7.1 获取字符串长度174
7.2 连接字符串 175
7.3 提取子串176
7.4 根据分隔符分割字符串176
7.5 替代子串178
7.6 查看字符串中的特殊字符179
7.7 生成字符串的所有成对组合179
7.8 得到当前日期181
7.9 转换字符串为日期181
7.10 转换日期为字符串182
7.11 转化年、月、日为日期183
7.12 得到儒略日期185
7.13 提取日期的一部分185
7.14 创建日期序列187
第8章 概率189
8.1 计算组合数191
8.2 生成组合192
8.3 生成随机数193
8.4 生成可再生的随机数194
8.5 生成随机样本196
8.6 生成随机序列197
8.7 随机排列向量198
8.8 计算离散分布的概率198
8.9 计算连续分布的概率200
8.10 转换概率为分位数201
8.11 绘制密度函数203
第9章 统计概论206
9.1 汇总数据208
9.2 计算相对频数210
9.3 因子制表和列联表创建211
9.4 检验分类变量独立性212
9.5 计算数据集的分位数(和四分位数)212
9.6 求分位数的逆213
9.7 数据转换为z分数214
9.8 检验样本均值(t检验)215
9.9 均值的置信区间216
9.10 中位数的置信区间217
9.11 检验样本比例218
9.12 比例的置信区间219
9.13 检验正态性220
9.14 游程检验222
9.15 比较两个样本的均值223
9.16 比较两个非参数样本的位置225
9.17 检验相关系数的显著性226
9.18 检验组的等比例228
9.19 组均值间成对比较229
9.20 检验两样本的相同分布230
第10章 图形232
10.1 创建散点图234
10.2 添加标题和标签236
10.3 添加网格237
10.4 创建多组散点图238
10.5 添加图例240
10.6 绘制散点图的回归线242
10.7 多变量散点图的绘制243
10.8 创建每个因子水平的散点图244
10.9 创建条形图246
10.10 对条形图添加置信区间248
10.11 给条形图上色249
10.12 绘制过点x和y的线251
10.13 改变线的类型、宽度或者颜色253
10.14 绘制多个数据集254
10.15 添加垂直线和水平线256
10.16 创建箱线图257
10.17 对每个因子水平创建箱线图258
10.18 创建直方图259
10.19 对直方图添加密度估计261
10.20 创建离散直方图262
10.21 创建正态q-q图264
10.22 创建其他q-q图265
10.23 用多种颜色绘制变量266
10.24 绘制函数269
10.25 图形间暂停270
10.26 在一页中显示多个图形271
10.27 打开另一个图形窗口273
10.28 在文档中绘制图形274
10.29 改变图形参数275
第11章 线性回归和方差分析277
11.1 简单线性回归279
11.2 多元线性回归281
11.3 得到回归统计量282
11.4 理解回归的汇总结果286
11.5 运行无截距的线性回归289
11.6 运行有交户项的线性回归290
11.7 选择最合适的回归变量292
11.8 对数据子集回归295
11.9 在回归公式中使用表达式296
11.10 多项式回归298
11.11 转换数据的回归299
11.12 寻找最佳幂变换301
11.13 回归系数的置信区间304
11.14 绘制回归残差304
11.15 诊断线性回归306
11.16 识别有影响的观察值309
11.17 残差自相关检验310
11.18 预测新值311
11.19 建立预测区间312
11.20 运行单因素方差分析313
11.21 创建交互关系图315
11.22 找到组间均值的不同316
11.23 执行稳健方差分析318
11.24 运用方差分析比较模型320
第12章 有用的方法323
12.1 查看你的数据323
12.2 拓宽你的输出324
12.3 输出赋值结果325
12.4 对行和列求和325
12.5 按列输出数据326
12.6 对数据分级328
12.7 找到特定值的位置329
12.8 每隔n个选定一个向量元素330
12.9 找到成对的最小值或者最大值331
12.10 生成多个因子的组合332
12.11 转换一个数据框333
12.12 对数据框排序334
12.13 对两列排序335
12.14 移除变量属性336
12.15 显示对象的结构337
12.16 代码运行时间340
12.17 抑制警告和错误消息341
12.18 从列表中提取函数参数342
12.19 定义你自己的二元运算符344
第13章 高级数值分析和统计方法347
13.1 最小化或者最大化一个单参数函数347
13.2 最小化或者最大化多参数函数348
13.3 计算特征值和特征向量350
13.4 主成分分析351
13.5 简单正交回归352
13.6 数据的聚类354
13.7 预测二元变量(逻辑回归)357
13.8 统计量的自助法359
13.9 因子分析361
第14章 时间序列分析366
14.1 表示时间序列367
14.2 绘制时序图 370
14.3 提取最老的观测值或者最新的观测值373
14.4 选取时间序列的子集374
14.5 合并多个时间序列376
14.6 缺失时间序列的填充378
14.7 时间序列的滞后380
14.8 计算逐次差分381
14.9 时间序列相关的计算382
14.10 计算移动平均383
14.11 在日历时间范围内应用函数384
14.12 应用滚动函数386
14.13 绘制自相关函数图388
14.14 检验时间序列的自相关389
14.15 绘制偏自相关函数390
14.16 两个时间序列间的滞后相关性391
14.17 剔除时间序列的趋势393
14.18 拟合arima模型394
14.19 剔除arima模型中不显著的系数397
14.20 对arima模型进行诊断399
14.21 用arima模型进行预测400
14.22 均值回归的检验402
14.23 时间序列的平滑404
本图书信息来源:中国互动出版网
最新技术文章: